body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}.dashboard{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:60px}.header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 6px #0000001a;padding:1.5rem 2rem;margin-bottom:2rem}.header-content{max-width:1400px;margin:0 auto}.header-left{display:flex;align-items:center;gap:1rem}.logo-icon{color:#667eea}.header h1{font-size:1.8rem;color:#1f2937;font-weight:700}.subtitle{color:#6b7280;font-size:.95rem}.stats-grid{max-width:1400px;margin:0 auto 2rem;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.stat-icon{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:#f3f4f6;color:#667eea}.stat-card.green .stat-icon{background:#dcfce7}.stat-card.yellow .stat-icon{background:#fef9c3}.stat-card.red .stat-icon{background:#fee2e2}.stat-label{color:#6b7280;font-size:.9rem;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:#1f2937}.search-section{max-width:1400px;margin:0 auto 2rem;padding:0 2rem}.search-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.search-card h2{font-size:1.5rem;color:#1f2937;margin-bottom:.5rem}.search-description{color:#6b7280;margin-bottom:1.5rem}.search-form{display:flex;gap:1rem;margin-bottom:1.5rem}.search-input-group{flex:1;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af}.search-input{width:100%;padding:.75rem 1rem .75rem 3rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:#667eea}.search-button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.search-button:hover{background:#5568d3}.search-result{background:#f9fafb;padding:1.5rem;border-radius:8px;border-left:4px solid #667eea}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.result-header h3{font-size:1.3rem;color:#1f2937}.result-ampel{font-size:1.5rem;font-weight:600}.result-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.result-item{display:flex;flex-direction:column;gap:.25rem}.result-label{color:#6b7280;font-size:.9rem}.result-value{font-size:1.1rem;font-weight:600;color:#1f2937}.result-value.positive{color:#22c55e}.result-value.negative{color:#ef4444}.chart-section{max-width:1400px;margin:0 auto 2rem;padding:0 2rem}.chart-section h2{color:#fff;font-size:1.5rem;margin-bottom:1rem}.chart-container{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.rankings-grid{max-width:1400px;margin:0 auto 2rem;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.ranking-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.ranking-card h2{font-size:1.3rem;color:#1f2937;margin-bottom:1.5rem}.ranking-list{display:flex;flex-direction:column;gap:1rem}.ranking-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:8px;transition:background .2s}.ranking-item:hover{background:#f3f4f6}.ranking-left{display:flex;align-items:center;gap:1rem}.ranking-number{font-size:1.2rem;font-weight:700;color:#667eea;min-width:40px}.ranking-city{font-weight:600;color:#1f2937;margin-bottom:.2rem}.ranking-plz{font-size:.85rem;color:#6b7280}.ranking-right{display:flex;align-items:center;gap:.75rem}.ranking-ampel{font-size:1.5rem}.ranking-price{font-size:1.1rem;font-weight:600;color:#1f2937}.no-data{color:#9ca3af;text-align:center;padding:2rem}.footer{max-width:1400px;margin:3rem auto 0;padding:2rem;text-align:center;color:#fffc;font-size:.9rem}@media(max-width:768px){.header{padding:1rem}.stats-grid{grid-template-columns:1fr;padding:0 1rem}.search-section,.chart-section,.rankings-grid{padding:0 1rem}.search-form{flex-direction:column}.rankings-grid,.result-details{grid-template-columns:1fr}}.alle-tarife{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:60px}.tarife-header{max-width:1400px;margin:0 auto 2rem;padding:0 2rem;color:#fff}.tarife-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.tarife-subtitle{font-size:1.1rem;opacity:.9}.city-selector-container{max-width:1400px;margin:0 auto 2rem;padding:0 2rem}.city-selector-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.selector-label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#1f2937;margin-bottom:.75rem;font-size:1rem}.city-select{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;cursor:pointer;transition:border-color .2s}.city-select:focus{outline:none;border-color:#667eea}.stadt-info{max-width:1400px;margin:0 auto 1.5rem;padding:0 2rem}.stadt-info-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.stadt-info h2{font-size:1.8rem;color:#1f2937;margin-bottom:.75rem}.info-badges{display:flex;gap:.75rem;flex-wrap:wrap}.info-badge{background:#f3f4f6;color:#4b5563;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.sort-controls{max-width:1400px;margin:0 auto 1.5rem;padding:0 2rem}.sort-controls-card{background:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.sort-label{font-weight:600;color:#4b5563}.sort-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.sort-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:2px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;color:#4b5563;transition:all .2s}.sort-btn:hover{border-color:#667eea;color:#667eea}.sort-btn.active{background:#667eea;color:#fff;border-color:#667eea}.tarife-table-container{max-width:1400px;margin:0 auto 2rem;padding:0 2rem}.tarife-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow-x:auto}.tarife-table{width:100%;border-collapse:collapse;min-width:1200px}.tarife-table thead{background:#f9fafb}.tarife-table th{padding:1rem;text-align:left;font-weight:600;color:#4b5563;font-size:.9rem;border-bottom:2px solid #e5e7eb;white-space:nowrap}.tarife-table td{padding:1rem .75rem;border-bottom:1px solid #f3f4f6;color:#1f2937}.tarif-row:hover{background:#f9fafb}.tarif-row.highlighted{background:#eff6ff;border-left:4px solid #667eea}.tarif-row.highlighted:hover{background:#dbeafe}.rank-cell{font-weight:700;color:#667eea;font-size:1.1rem;min-width:60px;text-align:center}.ampel-cell{text-align:center;min-width:70px;padding:.5rem!important}.ampel-badge{font-size:1.5rem;display:inline-block}.anbieter-cell{display:flex;flex-direction:column;gap:.25rem;min-width:150px;max-width:200px}.anbieter-cell strong{font-weight:600}.own-badge{display:inline-block;background:#667eea;color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:600;width:fit-content}.tarif-name{color:#6b7280;font-size:.9rem;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.price-cell{font-size:1rem;min-width:140px}.price-cell strong{font-weight:600;font-size:1.05rem}.price-sub{color:#9ca3af;font-size:.8rem;font-weight:400;margin-left:.25rem}.bonus-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;white-space:nowrap}.bonus-badge.yes{background:#dcfce7;color:#166534}.bonus-badge.no{background:#f3f4f6;color:#6b7280}.gv-badge{color:#667eea;font-size:1.2rem;font-weight:700}.empty-state{max-width:600px;margin:4rem auto;text-align:center;color:#fff}.empty-icon{opacity:.5;margin-bottom:1.5rem}.empty-state h3{font-size:1.8rem;margin-bottom:.5rem}.empty-state p{font-size:1.1rem;opacity:.8}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;gap:1rem}.loading-icon{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:1200px){.tarife-table{font-size:.85rem}.tarife-table th,.tarife-table td{padding:.75rem .5rem}}@media(max-width:768px){.tarife-header,.city-selector-container,.stadt-info,.sort-controls,.tarife-table-container{padding:0 1rem}.sort-controls-card{flex-direction:column;align-items:flex-start}.tarife-table-wrapper{overflow-x:auto}}.export-controls{max-width:1400px;margin:0 auto 1.5rem;padding:0 2rem}.export-controls-card{background:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.export-label{font-weight:600;color:#4b5563}.export-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.export-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:2px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;color:#4b5563;transition:all .2s}.export-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.export-btn.csv:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.export-btn.excel:hover{border-color:#16a34a;color:#16a34a;background:#f0fdf4}@media(max-width:768px){.export-controls{padding:0 1rem}.export-controls-card{flex-direction:column;align-items:flex-start}}.alerts-loading-card{max-width:1400px;margin:2rem auto 0;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;text-align:center;color:#1f2937}.loading-spinner{animation:alerts-spin 1s linear infinite;margin-bottom:.75rem}@keyframes alerts-spin{to{transform:rotate(360deg)}}.alerts-card{max-width:1400px;margin:0 auto 2rem;padding:0 2rem}.alerts-card>*{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.alerts-card-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:1rem}.alerts-card-header h2{font-size:1.3rem;color:#1f2937;margin-bottom:.25rem}.alerts-card-subtitle{font-size:.9rem;color:#6b7280}.refresh-button{border:none;border-radius:999px;padding:.5rem .75rem;background:#667eea;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .1s,opacity .15s}.refresh-button:hover:not(.loading){background:#5568d3;transform:translateY(-1px)}.refresh-button.loading{opacity:.6;cursor:default}.alerts-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.filter-btn{border-radius:999px;border:1px solid #e5e7eb;padding:.4rem .9rem;background:#f9fafb;font-size:.85rem;cursor:pointer;color:#374151;transition:background .2s,color .2s,border-color .2s}.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.filter-btn.improvements.active{background:#22c55e;border-color:#22c55e}.filter-btn.regressions.active{background:#ef4444;border-color:#ef4444}.alerts-list{display:flex;flex-direction:column;gap:1.25rem}.alerts-section{border-top:1px solid #e5e7eb;padding-top:.75rem}.section-title{display:flex;align-items:center;gap:.4rem;font-size:.95rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.alerts-items{display:flex;flex-direction:column;gap:.6rem}.alert-item{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.alert-item.improvements{border-left:4px solid #22c55e}.alert-item.regressions{border-left:4px solid #ef4444}.alert-left{display:flex;align-items:flex-start;gap:.75rem}.alert-icon{width:34px;height:34px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:#e5f9f0;color:#16a34a;flex-shrink:0}.alert-item.regressions .alert-icon{background:#fee2e2;color:#b91c1c}.alert-content{display:flex;flex-direction:column;gap:.15rem}.alert-city{font-weight:600;color:#1f2937;font-size:.95rem}.alert-plz{color:#6b7280;font-weight:400}.alert-change{font-size:.85rem;color:#374151}.alert-price{font-size:.8rem;color:#6b7280}.alert-right{display:flex;align-items:center}.alert-badge{border-radius:999px;padding:.25rem .7rem;font-size:.8rem}.alert-badge.improvements{background:#dcfce7;color:#166534}.alert-badge.regressions{background:#fee2e2;color:#b91c1c}.alerts-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;padding-top:.75rem;border-top:1px solid #e5e7eb;font-size:.8rem;color:#6b7280}.auto-refresh{display:flex;align-items:center;gap:.4rem}.no-alerts{text-align:center;padding:1.75rem .75rem;color:#6b7280}.no-alerts svg{margin-bottom:.5rem}.no-alerts-subtitle{font-size:.85rem;color:#9ca3af}@media(max-width:768px){.alerts-card{padding:0 1rem}.alerts-card>*{padding:1.5rem}.alert-item{flex-direction:column;align-items:flex-start}.alert-right{align-self:flex-end}}.app{min-height:100vh}.app-nav{background:#fff;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.nav-container{max-width:1400px;margin:0 auto;display:flex;gap:.5rem;padding:1rem 2rem}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;background:transparent;color:#6b7280;font-size:1rem;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.nav-tab:hover{background:#f3f4f6;color:#1f2937}.nav-tab.active{background:#667eea;color:#fff}.nav-tab.active:hover{background:#5568d3}
