*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #10b981;--primary-dark: #059669;--primary-light: #d1fae5;--secondary: #3b82f6;--accent: #f59e0b;--danger: #ef4444;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--transition: all .2s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--gray-50);color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.main-content{min-height:calc(100vh - 64px);padding-bottom:2rem}.page{max-width:1200px;margin:0 auto;padding:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-full{width:100%;justify-content:center;padding:.75rem}.btn:disabled{opacity:.6;cursor:not-allowed}.navbar{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow)}.navbar-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:64px}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.25rem}.navbar-logo{font-size:1.5rem}.navbar-title{background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-links{display:flex;gap:.25rem}.navbar-link{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--gray-600);transition:var(--transition)}.navbar-link:hover{background:var(--gray-100);color:var(--gray-800)}.navbar-link.active{background:var(--primary-light);color:var(--primary-dark)}.navbar-actions,.navbar-user{display:flex;align-items:center;gap:.75rem}.navbar-points{background:var(--accent);color:#fff;padding:.25rem .5rem;border-radius:20px;font-size:.75rem;font-weight:600}.navbar-name{font-weight:500;font-size:.875rem}.navbar-mobile-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--gray-600)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:998;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.drawer-overlay.open{opacity:1;visibility:visible}.drawer{position:fixed;top:0;right:0;width:280px;max-width:85vw;height:100vh;background:var(--card-bg, #fff);z-index:999;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000026;overflow-y:auto}.drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--gray-200)}.drawer-brand{font-weight:700;font-size:1.1rem;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.drawer-close{background:none;border:none;cursor:pointer;color:var(--gray-600);padding:4px;border-radius:8px;transition:var(--transition)}.drawer-close:hover{background:var(--gray-100)}.drawer-user-info{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--gray-200);background:var(--gray-50, #f9fafb)}.drawer-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.drawer-user-name{font-weight:600;font-size:.95rem}.drawer-user-coins{font-size:.8rem;color:var(--gray-500);margin-top:2px}.drawer-links{flex:1;padding:.5rem 0}.drawer-link{display:flex;align-items:center;gap:.85rem;padding:.85rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--gray-600);text-decoration:none;transition:var(--transition);border:none;background:none;width:100%;cursor:pointer}.drawer-link:hover{background:var(--gray-100);color:var(--gray-800)}.drawer-link.active{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.drawer-link.drawer-logout{color:#ef4444}.drawer-link.drawer-logout:hover{background:#ef444414}.drawer-footer{border-top:1px solid var(--gray-200);padding:.5rem 0}.navbar-mobile-menu{display:none!important}.navbar-mobile-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);font-weight:500;color:var(--gray-600)}.navbar-mobile-link.active{background:var(--primary-light);color:var(--primary-dark)}@media (max-width: 768px){.navbar-links,.navbar-user{display:none}.navbar-mobile-toggle{display:block}.navbar-actions .btn-ghost,.navbar-actions .btn-primary.btn-sm{display:none}}@media (min-width: 769px){.drawer,.drawer-overlay{display:none!important}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 64px);padding:2rem;background:linear-gradient(135deg,var(--gray-50) 0%,var(--primary-light) 100%)}.auth-card{width:100%;max-width:420px;background:#fff;border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{font-size:3rem;display:block;margin-bottom:.5rem}.auth-header h1{font-size:1.5rem;margin-bottom:.25rem}.auth-header p{color:var(--gray-500);font-size:.875rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{display:block;font-size:.8125rem;font-weight:600;margin-bottom:.375rem;color:var(--gray-700)}.form-group input{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.9375rem;transition:var(--transition)}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b98126}.password-input{position:relative}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--gray-400)}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--gray-500)}.auth-footer a{color:var(--primary);font-weight:600}.demo-hint{margin-top:.75rem;padding:.5rem;background:var(--gray-100);border-radius:var(--radius-sm)}.dashboard-hero{margin-bottom:2rem}.hero-text h1{font-size:1.75rem;margin-bottom:.25rem}.hero-subtitle{color:var(--gray-500)}.fill-advice-card{display:flex;align-items:flex-start;gap:1rem;margin-top:1rem;padding:1.25rem;border-radius:var(--radius);border-left:4px solid}.fill-advice-card.fill-now{background:#fef2f2;border-color:var(--danger)}.fill-advice-card.fill-wait{background:var(--primary-light);border-color:var(--primary)}.fill-advice-card h3{font-size:1rem;margin-bottom:.25rem}.fill-advice-card p{font-size:.875rem;color:var(--gray-600)}.savings-highlight{font-weight:700;color:var(--primary-dark)!important;margin-top:.25rem}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1rem;background:#fff;padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow)}.stat-card svg{color:var(--primary)}.stat-value{font-size:1.375rem;font-weight:700}.stat-label{font-size:.8125rem;color:var(--gray-500)}.dashboard-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.25rem}.section-link{color:var(--primary);font-weight:600;font-size:.875rem}.location-badge{display:inline-flex;align-items:center;gap:.3rem;background:#e8f5e9;color:#2e7d32;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;margin-left:.5rem;white-space:nowrap}.station-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem}.login-prompt-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;padding:2.5rem 2rem;background:linear-gradient(135deg,#22c55e0d,#3b82f60d);border:2px dashed var(--gray-200);border-radius:16px}.login-prompt-card h3{font-size:1.25rem;margin:0}.login-prompt-card p{color:var(--gray-500);max-width:420px;line-height:1.6}.login-prompt-card .btn{gap:.5rem}.login-prompt-card.wide{flex-direction:row;text-align:left;justify-content:space-between}.login-prompt-card.wide>div:first-child{flex:1}.cta-buttons{display:flex;gap:.75rem;flex-shrink:0}.guest-cta{margin-top:1rem}@media (max-width: 640px){.login-prompt-card.wide{flex-direction:column;text-align:center}.cta-buttons{flex-direction:column;width:100%}}.station-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);transition:var(--transition);border:1px solid transparent;overflow:hidden;min-width:0}.station-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-light);transform:translateY(-2px)}.station-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;min-width:0;gap:.5rem}.station-card-header>div:first-child{min-width:0;flex:1}.station-card-name{font-size:1rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.station-card-brand{font-size:.8125rem;color:var(--gray-500)}.station-card-address{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--gray-500);margin-bottom:.75rem;min-width:0}.station-card-address>span:first-of-type{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.station-card-distance{margin-left:auto;background:var(--gray-100);padding:.125rem .5rem;border-radius:20px;font-weight:600;color:var(--gray-700);white-space:nowrap;flex-shrink:0;font-size:.8125rem}.station-card-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.5rem;min-width:0}.station-card-prices{display:flex;gap:.5rem;flex-wrap:wrap;min-width:0;flex:1}.station-card-price{display:inline-flex;align-items:center;gap:.25rem;font-size:.85rem;font-weight:700;padding:.2rem .5rem;border-radius:8px;background:var(--gray-50);white-space:nowrap}.station-card-price.petrol{color:var(--primary-dark);background:#22c55e14}.station-card-price.diesel{color:#1d4ed8;background:#3b82f614}.station-card-price .price-label{font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.02em;opacity:.7;margin-right:.125rem}.station-card-price .price-value{font-size:.95rem}.station-card-price small{font-size:.7rem;font-weight:400;color:var(--gray-500)}.est-badge{display:inline-block;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:.05rem .3rem;border-radius:4px;background:#fef3c7;color:#92400e;margin-left:.2rem;vertical-align:middle;line-height:1.3}.est-label{font-size:.7rem;font-style:italic;color:#92400e}.station-card-rating{display:flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:600;flex-shrink:0;white-space:nowrap}.station-card-amenities{display:flex;gap:.375rem;flex-wrap:wrap}.amenity-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:var(--gray-100);border-radius:20px;font-size:.6875rem;font-weight:500;color:var(--gray-600)}.amenity-tag.ev{background:#dbeafe;color:#2563eb}.cashback-badge{display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,var(--primary),#059669);color:#fff;padding:.375rem .625rem;border-radius:var(--radius-sm);line-height:1.2}.cashback-badge-value{font-size:1rem;font-weight:800}.cashback-badge-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.5px}.prediction-card{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);border-left:4px solid var(--gray-300)}.prediction-card.prediction-urgent{border-color:var(--danger);background:#fef2f2}.prediction-card.prediction-medium{border-color:var(--accent);background:#fffbeb}.prediction-card.prediction-calm{border-color:var(--primary);background:var(--primary-light)}.prediction-card.prediction-empty{display:flex;align-items:center;gap:1rem;color:var(--gray-500)}.prediction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.prediction-header h3{display:flex;align-items:center;gap:.5rem;font-size:1rem}.prediction-confidence{font-size:.8125rem;color:var(--gray-500);background:var(--gray-100);padding:.25rem .625rem;border-radius:20px}.prediction-body{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.prediction-prices{display:flex;align-items:center;gap:1.5rem}.prediction-current,.prediction-future{text-align:center}.prediction-current small,.prediction-future small{display:block;font-size:.75rem;color:var(--gray-500)}.prediction-current span,.prediction-future span{font-size:1.5rem;font-weight:700}.prediction-arrow{display:flex;align-items:center}.text-red{color:var(--danger)}.text-green{color:var(--primary)}.text-gray{color:var(--gray-400)}.change-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-weight:700;font-size:.875rem}.change-badge.up{background:#fef2f2;color:var(--danger)}.change-badge.down{background:var(--primary-light);color:var(--primary-dark)}.change-badge.stable{background:var(--gray-100);color:var(--gray-600)}.prediction-recommendation{padding:.75rem;background:#fff9;border-radius:var(--radius-sm)}.prediction-recommendation p{font-size:.9375rem;font-weight:500}.prediction-factors{margin-top:.75rem;padding:.75rem;background:#00000008;border-radius:var(--radius-sm)}.prediction-factors h4{font-size:.8rem;font-weight:600;color:var(--gray-500);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.factors-list{display:flex;flex-direction:column;gap:.35rem}.factor-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.factor-icon{color:var(--gray-400);flex-shrink:0}.factor-name{font-weight:500}.factor-impact{font-size:.78rem;margin-left:auto}.market-detail{font-size:.78rem;color:var(--gray-500);margin-top:.5rem;font-style:italic}.prediction-source{font-size:.72rem;color:var(--gray-400);margin-top:.5rem;text-align:right}.chart-container{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);height:300px}.chart-small{height:250px}.chart-empty{padding:2rem;text-align:center;color:var(--gray-400);background:#fff;border-radius:var(--radius)}.map-controls{display:flex;gap:.75rem;margin-bottom:1rem}.search-form{flex:1;display:flex;align-items:center;gap:.5rem;background:#fff;padding:.5rem 1rem;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.search-form input{flex:1;border:none;outline:none;font-size:.9375rem}.filter-toggle{white-space:nowrap}.filter-bar{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem;padding:1rem;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.filter-bar select{padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.875rem}.filter-checkbox{display:flex;align-items:center;gap:.375rem;font-size:.875rem;cursor:pointer}.map-layout{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.map-layout{grid-template-columns:1.5fr 1fr}}.map-wrapper{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative}.map-station-list{max-height:500px;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.map-station-list h3{font-size:1rem;color:var(--gray-500);margin-bottom:.5rem}.map-station-item{display:block;background:#fff;border-radius:10px;padding:.75rem 1rem;box-shadow:0 1px 3px #0000000f;border:1px solid var(--gray-100);transition:var(--transition);text-decoration:none;color:inherit}.map-station-item:hover{border-color:var(--primary-light);box-shadow:0 2px 8px #0000001a}.map-item-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.25rem}.map-item-name{min-width:0;flex:1}.map-item-name strong{display:block;font-size:.875rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-item-brand{font-size:.7rem;color:var(--gray-500)}.map-item-distance{flex-shrink:0;background:var(--gray-100);padding:.1rem .4rem;border-radius:20px;font-size:.7rem;font-weight:600;color:var(--gray-600);white-space:nowrap}.map-item-address{display:flex;align-items:center;gap:.25rem;font-size:.7rem;color:var(--gray-500);margin-bottom:.4rem}.map-item-address span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-item-bottom{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.map-item-prices{display:flex;gap:.5rem}.map-price{display:inline-flex;align-items:center;gap:.2rem;font-size:.8rem;font-weight:700;padding:.15rem .4rem;border-radius:6px}.map-price.petrol{color:var(--primary-dark);background:#22c55e14}.map-price.diesel{color:#1d4ed8;background:#3b82f614}.map-item-rating{display:flex;align-items:center;gap:.15rem;font-size:.75rem;font-weight:600;flex-shrink:0;color:var(--gray-700)}.map-popup h4{font-size:.9375rem;margin-bottom:.25rem}.popup-brand{font-size:.75rem;color:var(--gray-500)}.popup-address{font-size:.75rem;color:var(--gray-500);margin-bottom:.25rem}.popup-price{font-size:.8125rem;font-weight:600;margin:.125rem 0;line-height:1.4}.popup-price.petrol{color:var(--primary-dark)}.popup-price.diesel{color:#1d4ed8}.popup-prices{display:flex;flex-direction:column;gap:.125rem;margin:.35rem 0}.popup-link{color:var(--primary);font-weight:600;font-size:.8125rem}.station-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.station-detail-header h1{font-size:1.75rem}.station-detail-brand{color:var(--gray-500);margin-bottom:.5rem}.station-detail-address{display:flex;align-items:center;gap:.375rem;color:var(--gray-500);font-size:.875rem;margin-bottom:.375rem}.station-detail-rating{display:flex;align-items:center;gap:.375rem;font-weight:600}.station-detail-cashback{text-align:center}.station-detail-cashback p{font-size:.8125rem;color:var(--gray-500);margin-top:.375rem}.detail-section{margin-bottom:2rem}.detail-section h2{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;margin-bottom:1rem}.fuel-price-grid{display:flex;gap:1rem;flex-wrap:wrap}.fuel-price-tile{display:flex;flex-direction:column;align-items:center;background:#fff;padding:1rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);min-width:120px}.fuel-type-label{font-size:.75rem;text-transform:uppercase;color:var(--gray-500);font-weight:600;letter-spacing:.5px}.fuel-price-value{font-size:1.5rem;font-weight:800;color:var(--primary-dark);margin:.25rem 0}.amenities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.amenity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem}.amenity-item.available{background:var(--primary-light);color:var(--primary-dark)}.amenity-item.unavailable{background:var(--gray-100);color:var(--gray-400);text-decoration:line-through}.rewards-page h1{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.rewards-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.reward-summary-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.reward-summary-card.cashback{background:linear-gradient(135deg,var(--primary-light),#a7f3d0);color:var(--primary-dark)}.reward-summary-card.points{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.reward-value{font-size:1.75rem;font-weight:800}.reward-label{font-size:.8125rem;opacity:.8}.tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;background:var(--gray-100);padding:.25rem;border-radius:var(--radius-sm);width:fit-content}.tab{padding:.5rem 1rem;border:none;background:transparent;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;color:var(--gray-600);transition:var(--transition)}.tab.active{background:#fff;color:var(--gray-800);box-shadow:var(--shadow)}.rewards-list{display:flex;flex-direction:column;gap:.75rem}.reward-item{display:flex;align-items:center;gap:1rem;background:#fff;padding:1rem;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.reward-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-light);color:var(--primary-dark);flex-shrink:0}.reward-details{flex:1}.reward-desc{font-size:.9375rem;font-weight:500}.reward-details small{color:var(--gray-500);font-size:.75rem}.reward-amount{text-align:right}.reward-amount span{font-weight:700;font-size:1rem;display:block}.reward-status{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;text-transform:uppercase;font-weight:600}.reward-status.credited{color:var(--primary)}.reward-status.pending{color:var(--accent)}.transactions-list{display:flex;flex-direction:column;gap:.5rem}.transaction-row{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:.875rem 1rem;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.transaction-row strong{font-size:.9375rem}.transaction-row small{display:block;color:var(--gray-500);font-size:.75rem}.transaction-amount{text-align:right}.transaction-amount span{font-weight:700}.transaction-amount small{color:var(--gray-500)}.tx-cashback{color:var(--primary)!important;font-weight:600}.analytics-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.analytics-header h1{display:flex;align-items:center;gap:.5rem}.period-selector{display:flex;gap:.25rem;background:var(--gray-100);padding:.25rem;border-radius:var(--radius-sm)}.period-btn{padding:.375rem .75rem;border:none;background:transparent;border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:var(--transition)}.period-btn.active{background:#fff;box-shadow:var(--shadow)}.analytics-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.insight-card{background:linear-gradient(135deg,#fffbeb,#fef3c7);padding:1rem 1.25rem;border-radius:var(--radius);border-left:4px solid var(--accent);margin-bottom:2rem}.insight-card p{font-size:.9375rem;font-weight:500}.projections{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.projection-card{background:#fff;padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}.projection-value{font-size:1.5rem;font-weight:800;color:var(--gray-800)}.projection-label{font-size:.8125rem;color:var(--gray-500)}.analytics-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-section h3{margin-bottom:.75rem;font-size:1rem}.consumption-section{margin-bottom:2rem}.consumption-section h2{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.consumption-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.top-stations-section h2{margin-bottom:1rem}.top-stations-list{display:flex;flex-direction:column;gap:.5rem}.top-station-row{display:flex;align-items:center;gap:1rem;background:#fff;padding:1rem;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.top-station-rank{font-size:1.25rem;font-weight:800;color:var(--accent);width:40px}.top-station-row strong{font-size:.9375rem}.top-station-row small{display:block;color:var(--gray-500);font-size:.75rem}.top-station-amount{margin-left:auto;text-align:right}.top-station-amount span{font-weight:700}.top-station-amount small{color:var(--gray-500)}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:var(--gray-400)}.spinner-icon{animation:spin 1s linear infinite;color:var(--primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;text-align:center;color:var(--gray-400)}.empty-state h3{color:var(--gray-600)}.stat-card.live-price{border-left:4px solid #22c55e;background:linear-gradient(135deg,#f0fdf4,#fff)}.price-source-note{margin-top:.5rem;font-size:.75rem;color:var(--gray-500);text-align:right}.fuel-type-toggle{display:flex;gap:.5rem;flex-wrap:wrap}.toggle-btn{padding:.35rem .9rem;border:1px solid var(--gray-300);border-radius:999px;background:transparent;font-size:.8rem;cursor:pointer;transition:all .15s ease;color:var(--gray-700)}.toggle-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.toggle-btn:hover:not(.active){background:var(--gray-100)}.county-selector-section{display:flex;flex-direction:column;gap:1rem}.county-dropdown-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.county-dropdown-row label{font-weight:600;font-size:.9rem;color:var(--gray-700);white-space:nowrap}.county-select{flex:1;min-width:200px;max-width:360px;padding:.6rem 2.5rem .6rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.9rem;background:#fff;color:var(--gray-800);cursor:pointer;transition:var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m4 6 4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px}.county-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b98126}.county-detail-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid var(--gray-200)}.county-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-bottom:1px solid var(--gray-200);gap:1rem;flex-wrap:wrap}.county-detail-header h3{font-size:1.125rem;font-weight:700;margin-bottom:.15rem}.county-detail-brand{font-size:.8rem;color:var(--gray-500)}.county-detail-price{text-align:right}.county-price-lg{display:block;font-size:1.75rem;font-weight:800;color:#16a34a;line-height:1.1}.county-detail-price small{font-size:.75rem;color:var(--gray-500)}.county-detail-body{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;gap:1rem;flex-wrap:wrap}.county-detail-info{display:flex;flex-direction:column;gap:.35rem}.county-detail-info p{display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--gray-600)}.price-badge{display:inline-block;margin-left:.4rem;padding:.1rem .4rem;border-radius:999px;font-size:.65rem;font-weight:600;vertical-align:middle}.price-badge.avg{background:#fef3c7;color:#92400e}.directions-link{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:var(--radius-sm);background:var(--primary);color:#fff;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .15s ease;white-space:nowrap}.directions-link:hover{background:var(--primary-dark)}.directions-link.directions-lg{padding:.65rem 1.25rem;font-size:.9rem}.empty-note{padding:2rem;text-align:center;color:var(--gray-400);font-size:.9rem}@media (max-width: 768px){.page{padding:1rem}.hero-text h1{font-size:1.35rem}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem;gap:.75rem}.stat-value{font-size:1.125rem}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.station-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.map-layout{grid-template-columns:1fr}.map-view-container{height:450px!important}.map-station-list{display:none}.map-controls{flex-direction:row;align-items:center;gap:.5rem}.map-page .filter-bar{flex-direction:row;flex-wrap:wrap;gap:.5rem;padding:.75rem}.fill-advice-card{flex-direction:column;gap:.5rem}.login-prompt-card.wide{flex-direction:column;text-align:center}.cta-buttons{flex-direction:column;width:100%}.county-detail-header{flex-direction:column;padding:1rem}.county-detail-price{text-align:left}.county-detail-body{flex-direction:column;align-items:flex-start;padding:1rem}.directions-link.directions-lg{width:100%;justify-content:center}}@media (max-width: 480px){.page{padding:.75rem}.hero-text h1{font-size:1.15rem}.hero-subtitle{font-size:.85rem}.dashboard-stats{grid-template-columns:1fr 1fr;gap:.5rem}.stat-card{padding:.75rem;gap:.5rem}.stat-value{font-size:1rem}.stat-label{font-size:.7rem}.station-grid{grid-template-columns:1fr}.station-card{padding:1rem}.station-card-prices{gap:.35rem}.search-form{padding:.35rem .75rem}.search-form input{font-size:.85rem}.filter-bar{flex-direction:column;gap:.5rem;padding:.75rem}.map-controls{flex-direction:row;gap:.5rem;align-items:center}.map-controls .search-form{min-width:0}.map-controls .filter-toggle{flex-shrink:0;padding:.4rem .6rem;font-size:.8rem}.map-view-container{height:calc(100vh - 200px)!important}.map-station-list{display:none}.analytics-charts,.projections{grid-template-columns:1fr}.prediction-prices{flex-direction:column;gap:.75rem}.prediction-body{flex-direction:column;gap:1rem}.county-select{max-width:100%;width:100%}.county-dropdown-row{flex-direction:column;align-items:stretch}.fuel-type-toggle{justify-content:flex-start}.navbar-container{padding:0 .75rem}}.coin-progress-bar{position:relative;height:28px;background:var(--gray-200);border-radius:14px;overflow:hidden;margin-top:.5rem}.coin-progress-bar.large{height:36px;border-radius:18px}.coin-progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#f97316);border-radius:14px;transition:width .5s ease;min-width:4px}.coin-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--gray-800);pointer-events:none}.coin-progress-section{background:#fff;padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem}.coin-progress-section h3{margin-bottom:.5rem;font-size:1rem}.coin-progress-hint{margin-top:.5rem;font-size:.85rem;color:var(--gray-500)}.coin-balance-hero{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-md);margin-bottom:1.5rem}.coin-hero-left{display:flex;align-items:center;gap:1rem}.coin-icon-lg{color:#f59e0b}.coin-balance-value{font-size:2.2rem;font-weight:800;color:var(--gray-900)}.coin-balance-label{font-size:.9rem;color:var(--gray-600)}.coin-hero-right p{font-size:.9rem;color:var(--gray-700)}.coin-card{background:linear-gradient(135deg,#fef3c7,#fde68a)!important}.price-submit-section{border:2px dashed var(--primary);border-radius:var(--radius);padding:1.5rem;background:var(--primary-light)}.price-submit-form{display:flex;flex-direction:column;gap:1rem}.price-submit-form .form-row{display:flex;gap:1rem}.price-submit-form .form-group{flex:1;display:flex;flex-direction:column;gap:.35rem}.price-submit-form label{font-weight:600;font-size:.85rem;color:var(--gray-700)}.price-submit-form select,.price-submit-form input{padding:.6rem .8rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:1rem;background:#fff}.price-submit-form input:focus,.price-submit-form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b98126}.submit-result{margin-top:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem}.submit-result.success{background:#d1fae5;color:#065f46}.submit-result.error{background:#fee2e2;color:#991b1b}.submit-result small{display:block;margin-top:.25rem}.submit-locked-card,.login-prompt-card{text-align:center;padding:1.5rem;color:var(--gray-600)}.submit-locked-card p,.login-prompt-card p{margin-top:.5rem}.coin-info{font-size:.85rem;color:var(--gray-500)}.submit-price-cta{margin-top:.5rem;padding:.75rem;background:#fef3c7;border-radius:var(--radius-sm);text-align:center;font-size:.9rem}.submit-price-cta a{color:var(--primary-dark);font-weight:600;text-decoration:underline}.vouchers-section{margin-bottom:1.5rem}.vouchers-section h3{margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.vouchers-list{display:flex;flex-direction:column;gap:.75rem}.voucher-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:var(--radius);border:1px solid #a7f3d0}.voucher-icon{color:var(--primary)}.voucher-info{flex:1}.voucher-value{font-size:1.25rem;font-weight:700;color:var(--primary-dark)}.voucher-desc{font-size:.85rem;color:var(--gray-600)}.voucher-card small{font-size:.75rem;color:var(--gray-400)}.coins-earned{background:linear-gradient(135deg,#fef3c7,#fde68a)!important}@media (max-width: 640px){.coin-balance-hero{flex-direction:column;text-align:center;gap:1rem}.coin-hero-left,.price-submit-form .form-row{flex-direction:column}}.ev-route-page{max-width:900px;margin:0 auto}.ev-route-header h1{display:flex;align-items:center;gap:.5rem}.ev-route-header .page-subtitle{color:var(--gray-600);margin-bottom:1.5rem}.ev-route-form{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;overflow:visible}.ev-locations-row{display:flex;gap:1rem;align-items:flex-end;position:relative;z-index:10}.ev-locations-row>.ev-place-input-wrapper{flex:1;min-width:0}.ev-route-arrow-divider{display:flex;align-items:center;justify-content:center;padding-bottom:.5rem;color:var(--gray-600);flex-shrink:0}.ev-settings-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;position:relative;z-index:1}.ev-settings-row .form-group label{display:flex;align-items:center;gap:4px;font-size:.85rem;font-weight:600;margin-bottom:.35rem;color:var(--gray-700)}.ev-settings-row .form-group input,.ev-settings-row .form-group select{width:100%;padding:.6rem .75rem;border:1px solid var(--gray-300);border-radius:8px;background:#fff;color:var(--gray-800);font-size:.95rem}.ev-place-input-wrapper{position:relative}.ev-place-label{display:flex;align-items:center;gap:4px;font-size:.85rem;font-weight:600;margin-bottom:.35rem;color:var(--gray-700)}.ev-place-input-container{position:relative;display:flex;align-items:center}.ev-place-search-icon{position:absolute;left:10px;color:var(--gray-500);pointer-events:none}.ev-place-input{width:100%;padding:.65rem 2.2rem;border:1px solid var(--gray-300);border-radius:10px;background:#fff;color:var(--gray-800);font-size:.95rem;transition:border-color .2s}.ev-place-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b98126}.ev-place-input.selected{border-color:var(--primary);background:#10b9810d}.ev-place-clear{position:absolute;right:8px;background:none;border:none;color:var(--gray-400);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center}.ev-place-clear:hover{background:var(--border);color:var(--text)}.ev-place-loading{position:absolute;right:32px;color:var(--gray-400);font-size:.8rem}.ev-place-suggestions{position:absolute;top:100%;left:0;right:0;z-index:100;background:#fff;border:1px solid var(--gray-200);border-radius:10px;margin-top:4px;box-shadow:0 8px 32px #0003,0 2px 8px #0000001a;list-style:none;padding:.25rem 0;max-height:220px;overflow-y:auto}.ev-place-suggestions li{display:flex;align-items:flex-start;gap:.6rem;padding:.6rem .85rem;cursor:pointer;transition:background .15s}.ev-place-suggestions li:hover{background:#10b9811a}.ev-suggestion-icon{flex-shrink:0;margin-top:2px;color:var(--primary)}.ev-suggestion-main{display:block;font-weight:600;font-size:.9rem;color:var(--gray-800)}.ev-suggestion-secondary{display:block;font-size:.78rem;color:var(--gray-500)}.ev-selected-locations{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.ev-location-tag{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;padding:.3rem .7rem;border-radius:20px;background:#10b9811a;color:var(--primary);border:1px solid rgba(16,185,129,.2);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ev-location-tag.destination{background:#6366f11a;color:#818cf8;border-color:#6366f133}.ev-tag-arrow{color:var(--gray-400);flex-shrink:0}.ev-plan-btn{align-self:center;min-width:220px;position:relative;z-index:1}.ev-plan-btn:disabled{opacity:.5;cursor:not-allowed}.ev-error{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#f87171;margin-top:1rem}.ev-route-result{margin-top:1.5rem}.ev-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.ev-summary-item{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:1rem;text-align:center}.ev-summary-value{display:block;font-size:1.5rem;font-weight:700;color:var(--primary)}.ev-summary-label{font-size:.8rem;color:var(--gray-400)}.ev-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:10px;background:#10b98114;border:1px solid rgba(16,185,129,.2);color:var(--primary);margin-bottom:1.5rem}.ev-message.success{background:#10b98126}.ev-stops-list h3{margin-bottom:1rem}.ev-stop-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-left:3px solid var(--border);margin-left:16px;position:relative}.ev-stop-item.origin,.ev-stop-item.destination{border-left-color:var(--primary)}.ev-stop-arrow{position:absolute;left:-20px;top:1.2rem;color:var(--gray-400)}.ev-stop-marker{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.ev-stop-info{flex:1;min-width:0}.ev-stop-name{font-weight:600;font-size:.95rem}.ev-stop-operator,.ev-stop-address{font-size:.82rem;color:var(--gray-400)}.ev-stop-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.4rem}.ev-speed-badge{padding:2px 8px;border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;text-transform:capitalize}.ev-ports,.ev-cost{font-size:.78rem;color:var(--gray-400)}.ev-connectors{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.35rem}.ev-connector-tag{font-size:.72rem;padding:2px 6px;border-radius:6px;background:var(--border);color:var(--gray-300)}.ev-stop-distance{text-align:right;flex-shrink:0}.ev-stop-distance span{display:block;font-weight:600;font-size:.9rem}.ev-stop-distance small{color:var(--gray-400);font-size:.72rem}@media (max-width: 768px){.ev-locations-row{flex-direction:column}.ev-route-arrow-divider{transform:rotate(90deg);padding:0}.ev-settings-row,.ev-summary{grid-template-columns:1fr}.ev-stop-distance{display:none}.ev-selected-locations{flex-direction:column;align-items:flex-start}.ev-tag-arrow{transform:rotate(90deg)}}@media (min-width: 769px) and (max-width: 1024px){.ev-settings-row{grid-template-columns:1fr 1fr}}.brand-marker-icon{background:none!important;border:none!important}.brand-marker{width:38px;height:38px;border-radius:50%;background:#fff;border:2px solid var(--primary, #10b981);box-shadow:0 2px 8px #00000040;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.brand-marker:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--primary, #10b981)}.brand-marker img{width:26px;height:26px;object-fit:contain;border-radius:50%}.locate-me-btn{position:absolute;bottom:24px;right:12px;z-index:1000;width:42px;height:42px;border-radius:10px;background:#fff;border:none;box-shadow:0 2px 8px #0003,0 0 0 1px #0000000d;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-700);transition:all .2s ease}.locate-me-btn:hover{background:var(--primary);color:#fff;box-shadow:0 4px 12px #10b98159;transform:scale(1.05)}.locate-me-btn:active{transform:scale(.95)}.fuel-price-tile{position:relative}.fuel-price-tile.estimated{opacity:.75;border-style:dashed}.price-est-badge{display:inline-block;font-size:.65rem;padding:1px 6px;border-radius:8px;background:#fbbf2433;color:#f59e0b;font-weight:600;margin-top:.25rem}.price-updated-badge{display:block;font-size:.65rem;color:var(--gray-400);margin-top:.25rem}.site-footer{background:var(--gray-900);color:var(--gray-300);margin-top:3rem;border-top:3px solid var(--primary)}.footer-container{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 2rem;display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:2.5rem}@media (max-width: 900px){.footer-container{grid-template-columns:1fr 1fr;gap:2rem}.footer-brand{grid-column:1 / -1}}@media (max-width: 560px){.footer-container{grid-template-columns:1fr}.footer-brand{grid-column:auto}}.footer-brand-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.footer-logo-icon{font-size:1.6rem}.footer-title{font-size:1.25rem;font-weight:700;color:#fff}.footer-tagline{font-size:.88rem;line-height:1.6;color:var(--gray-400);margin-bottom:1rem}.footer-badges{display:flex;gap:.5rem;flex-wrap:wrap}.footer-badge{background:var(--gray-800);border:1px solid var(--gray-700);border-radius:20px;padding:.2rem .75rem;font-size:.75rem;color:var(--gray-300)}.footer-col-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);margin-bottom:1rem}.footer-links{list-style:none;display:flex;flex-direction:column;gap:.55rem}.footer-links a,.footer-links span{font-size:.875rem;color:var(--gray-400);transition:color .2s;text-decoration:none}.footer-links a:hover{color:var(--primary)}.footer-contact li{display:flex;align-items:flex-start;gap:.5rem}.footer-contact svg{flex-shrink:0;margin-top:3px;color:var(--primary)}.footer-bottom{border-top:1px solid var(--gray-800);max-width:1200px;margin:0 auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.4rem}.footer-copyright{font-size:.82rem;color:var(--gray-500)}.footer-disclaimer,.footer-data-note{font-size:.78rem;color:var(--gray-600);line-height:1.5}.footer-disclaimer a{color:var(--primary);text-decoration:underline}.footer-disclaimer a:hover{color:var(--primary-dark)}.terms-page{max-width:900px;padding-top:2rem;padding-bottom:4rem}.terms-hero{background:linear-gradient(135deg,var(--gray-900) 0%,var(--gray-800) 100%);border-radius:var(--radius);padding:2.5rem;margin-bottom:2rem;border:1px solid var(--gray-700)}.terms-hero h1{font-size:1.9rem;color:#fff;margin-bottom:.5rem}.terms-meta{font-size:.85rem;color:var(--gray-400);margin-bottom:1rem}.terms-intro{color:var(--gray-300);font-size:.95rem;line-height:1.7;margin-bottom:1.5rem}.terms-nav{display:flex;flex-wrap:wrap;gap:.5rem}.terms-nav a{background:var(--gray-800);border:1px solid var(--gray-700);border-radius:20px;padding:.3rem .85rem;font-size:.78rem;color:var(--primary);text-decoration:none;transition:all .2s}.terms-nav a:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.terms-section{background:#fff;border-radius:var(--radius);padding:2rem 2.5rem;margin-bottom:1.5rem;border:1px solid var(--gray-200);scroll-margin-top:80px}.terms-section-title{font-size:1.3rem;font-weight:700;color:var(--gray-900);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--primary-light);display:flex;align-items:center;gap:.5rem}.terms-emoji{font-size:1.4rem}.terms-section h3{font-size:1rem;font-weight:700;color:var(--gray-800);margin:1.25rem 0 .5rem}.terms-section p,.terms-section li{font-size:.925rem;color:var(--gray-700);line-height:1.75}.terms-section ul{padding-left:1.5rem;margin:.5rem 0}.terms-section ul li{margin-bottom:.35rem}.terms-section a{color:var(--primary);text-decoration:underline}.terms-section a:hover{color:var(--primary-dark)}.terms-section code{background:var(--gray-100);padding:.1rem .4rem;border-radius:4px;font-family:monospace;font-size:.85em}.terms-table-wrap{overflow-x:auto;margin:1rem 0;border-radius:var(--radius-sm);border:1px solid var(--gray-200)}.terms-table{width:100%;border-collapse:collapse;font-size:.875rem}.terms-table th{background:var(--gray-100);padding:.65rem .9rem;text-align:left;font-weight:600;color:var(--gray-700);border-bottom:1px solid var(--gray-200)}.terms-table td{padding:.6rem .9rem;border-bottom:1px solid var(--gray-100);color:var(--gray-700);vertical-align:top}.terms-table tr:last-child td{border-bottom:none}.gdpr-rights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin:1rem 0}.gdpr-right-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:1rem 1.1rem}.gdpr-right-card h4{font-size:.9rem;font-weight:700;color:var(--gray-800);margin-bottom:.4rem}.gdpr-right-card p{font-size:.85rem;color:var(--gray-600);line-height:1.6}.contact-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:.5rem}.contact-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.contact-card h4{font-size:.95rem;font-weight:700;color:var(--gray-800)}.contact-card p{font-size:.85rem;color:var(--gray-600);line-height:1.5}.contact-note{font-size:.8rem!important;color:var(--gray-500)!important}.terms-back-top{text-align:center;padding:1.5rem 0 .5rem;font-size:.88rem;color:var(--gray-500)}.terms-back-top a{color:var(--primary);text-decoration:underline}.voucher-retailer-select{margin-top:.75rem}.retailer-prompt{font-size:.82rem;font-weight:600;color:var(--gray-700);margin-bottom:.5rem}.retailer-btns{display:flex;flex-wrap:wrap;gap:.4rem}.retailer-btn{background:var(--gray-100);border:1px solid var(--gray-300);border-radius:8px;padding:.35rem .75rem;font-size:.8rem;cursor:pointer;transition:all .2s;color:var(--gray-700)}.retailer-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.retailer-btn.cancel{background:transparent;border-color:var(--gray-300);color:var(--gray-500)}.retailer-btn.cancel:hover{background:var(--gray-200);color:var(--gray-700)}.voucher-retailer-badge{display:inline-block;background:var(--primary-light);color:var(--primary-dark);font-size:.72rem;font-weight:700;border-radius:12px;padding:.1rem .6rem;margin-left:.5rem;vertical-align:middle}.scroll-to-top-btn{position:fixed;bottom:1.75rem;right:1.75rem;z-index:9999;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;box-shadow:0 4px 14px #10b98173;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .25s ease,transform .25s ease,visibility .25s ease,background .2s ease}.scroll-to-top-btn--visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top-btn:hover{background:var(--primary-dark);box-shadow:0 6px 18px #10b9818c}.scroll-to-top-btn:active{transform:translateY(2px)}@keyframes skeleton-shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton-block{display:block;background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:600px 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite;border-radius:8px}.skeleton-card{display:flex;align-items:center;gap:14px;padding:1rem 1.25rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.skeleton-section{display:flex;flex-direction:column;gap:10px;padding:1rem 0}.station-card-skeleton{flex-direction:column;align-items:flex-start;gap:0;padding:1.25rem;min-height:160px}.fill-advice-card.fill-skeleton{min-height:80px;padding:1.25rem}
