:root{--c-primary:#4f46e5;--c-primary-dark:#3730a3;--c-primary-light:#e0e7ff;--c-primary-mid:#818cf8;--c-success:#22c55e;--c-success-light:#dcfce7;--c-warning:#f59e0b;--c-warning-light:#fef9c3;--c-danger:#ef4444;--c-danger-light:#fee2e2;--c-orange:#f97316;--c-bg:#f1f5f9;--c-surface:#fff;--c-surface-2:#f8fafc;--c-border:#e2e8f0;--c-border-light:#f1f5f9;--c-text:#1e293b;--c-text-2:#475569;--c-text-muted:#94a3b8;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 8px #00000012, 0 1px 2px #0000000a;--shadow-lg:0 8px 24px #0000001a, 0 2px 6px #0000000f;--font-sans:-apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic UI", "Meiryo", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--c-bg);-webkit-font-smoothing:antialiased;color:var(--c-text)}button,input,select{font-family:inherit}.header{background:var(--c-surface)}.header-bar{background:linear-gradient(135deg,#3730a3 0%,#4f46e5 55%,#6366f1 100%);justify-content:center;align-items:center;padding:10px 14px;display:flex;position:relative}.header-logo{align-items:center;gap:8px;display:flex}.header-logo svg{filter:drop-shadow(0 1px 2px #0003)}.header-logo-text{color:#fff;letter-spacing:.3px;font-size:18px;font-weight:900}.header-gear{cursor:pointer;background:#ffffff26;border:none;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.header-gear:hover{background:#ffffff47}.header-gear.active{background:#fff6}.route-row{padding:9px 14px}.time-stepper{flex-direction:column;align-items:flex-end;gap:3px;display:flex}.stepper-label{color:var(--c-text-muted);align-items:center;gap:3px;font-size:10px;font-weight:500;display:flex}.stepper-ctrl{background:var(--c-primary-light);border-radius:var(--radius-sm);align-items:center;gap:2px;padding:3px 6px;display:flex}.stepper-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:background .15s;display:flex}.stepper-btn:hover:not(:disabled){background:#4f46e51f}.stepper-btn:disabled{opacity:.3;cursor:default}.stepper-val{color:var(--c-primary);text-align:center;letter-spacing:-.3px;min-width:36px;font-size:15px;font-weight:800}.logo-picker{border-bottom:1px solid var(--c-border);align-items:center;gap:6px;margin-bottom:8px;padding:6px 0 8px;display:flex}.logo-picker-label{color:var(--c-text-muted);white-space:nowrap;font-size:10px;font-weight:600}.logo-pick-btn{background:var(--c-surface-2);cursor:pointer;border:2px solid #0000;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:4px;transition:border-color .15s;display:flex}.logo-pick-btn:hover{border-color:var(--c-primary-mid)}.logo-pick-active{border-color:var(--c-primary)!important;background:var(--c-primary-light)!important}.logo-pick-preview{background:linear-gradient(145deg,#3730a3,#6366f1);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.logo-pick-id{color:var(--c-text-muted);font-size:9px;font-weight:700}.route-info-row{align-items:center;gap:6px;margin-top:5px;padding:0 14px 8px;display:flex}.route-gear-btn{background:var(--c-surface-2);border:1.5px solid var(--c-border);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;padding:5px;transition:background .15s,border-color .15s;display:flex}.route-gear-btn:hover{background:var(--c-primary-light);border-color:var(--c-primary)}.route-info-bar{background:var(--c-primary-light);border-radius:var(--radius-sm);border-left:3px solid var(--c-primary);cursor:pointer;flex:1;align-items:center;gap:6px;padding:5px 9px;text-decoration:none;transition:background .15s;display:flex}.route-info-bar:hover{background:#c7d2fe}.route-info-via{color:var(--c-primary);white-space:nowrap;flex:1;font-size:11px;font-weight:700}.route-info-dist{color:var(--c-text-2);white-space:nowrap;font-size:10px}.route-info-toll{background:var(--c-warning);color:#fff;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:800}.route-info-wp{color:var(--c-text-2);background:var(--c-border);white-space:nowrap;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.route-info-maps-hint{color:var(--c-primary);white-space:nowrap;opacity:.75;margin-left:auto;font-size:10px;font-weight:600}.route-row{align-items:flex-end;gap:4px;display:flex}.route-arrow-sep{opacity:.5;flex-shrink:0;padding-bottom:7px}.route-arrow-btn{background:var(--c-surface-2);border:1.5px solid var(--c-border);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-bottom:3px;padding:0;transition:background .15s,border-color .15s;display:flex;position:relative}.route-arrow-btn:hover{background:var(--c-primary-light);border-color:var(--c-primary)}.route-arrow-open{background:var(--c-primary-light)!important;border-color:var(--c-primary)!important}.route-arrow-dot{background:var(--c-primary);border-radius:50%;width:5px;height:5px;position:absolute;top:2px;right:0}.route-selector-wrap{flex:1;min-width:0;position:relative}.route-micro-label{color:var(--c-text-muted);align-items:center;gap:3px;margin-bottom:2px;font-size:9px;font-weight:500;display:flex}.route-chip{background:var(--c-surface-2);border:1.5px solid var(--c-border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;align-items:center;gap:5px;width:100%;padding:5px 8px;transition:border-color .15s,background .15s;display:flex}.route-chip:hover{border-color:var(--c-primary-mid)}.chip-open{border-color:var(--c-primary)!important;background:var(--c-primary-light)!important}.chip-badge{color:#fff;white-space:nowrap;letter-spacing:.2px;border-radius:4px;flex-shrink:0;padding:2px 5px;font-size:7.5px;font-weight:800;line-height:1.3}.chip-name{color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;font-weight:700;overflow:hidden}.dropdown{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);min-width:230px;box-shadow:var(--shadow-lg);z-index:200;position:absolute;top:calc(100% + 5px);left:0;overflow:hidden}.dropdown-right{left:auto;right:0}.dropdown-item{border:none;border-bottom:1px solid var(--c-border-light);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:9px;width:100%;padding:11px 14px;transition:background .12s;display:flex}.dropdown-item:last-child{border-bottom:none}.dd-selected{background:var(--c-primary-light)}.dropdown-item:hover:not(.dd-selected){background:var(--c-surface-2)}.dd-badge{color:#fff;white-space:pre;text-align:center;border-radius:4px;flex-shrink:0;padding:3px 6px;font-size:8px;font-weight:800;line-height:1.3}.dd-text{flex:1;min-width:0}.dd-name{color:var(--c-text);font-size:13px;font-weight:700}.dd-sub{color:var(--c-text-muted);margin-top:1px;font-size:10px}.dd-admin-btn{border:none;border-top:1px solid var(--c-border);cursor:pointer;width:100%;color:var(--c-text-muted);background:0 0;align-items:center;gap:7px;padding:9px 14px;font-size:11px;font-weight:600;transition:background .12s;display:flex}.dd-admin-btn:hover{background:var(--c-surface-2);color:var(--c-text-2)}.tab-bar{background:var(--c-surface);border-top:1px solid var(--c-border);gap:0;padding:0 4px;display:flex}.tab-item{color:var(--c-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2.5px solid #0000;flex-direction:column;flex:1;align-items:center;gap:4px;min-width:0;padding:9px 2px 8px;font-size:13px;font-weight:700;transition:color .15s,border-color .15s;display:flex}.tab-item.active{color:var(--c-primary);border-bottom-color:var(--c-primary)}.tab-item:hover:not(.active){color:var(--c-text-2)}.tab-label{line-height:1}.tab-girne{color:#f97316;position:relative}.tab-girne.active{color:#ea580c;border-bottom-color:#ea580c}.tab-girne:hover:not(.active){color:#f97316}.tab-girne-badge{color:#fff;letter-spacing:.2px;background:#f97316;border-radius:4px;padding:1px 5px;font-size:8px;font-weight:800;line-height:1.4;position:absolute;top:2px;right:6px}.dc-wrap{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:32px 16px;display:flex}.dc-icon{font-size:40px;animation:2s infinite dc-pulse}@keyframes dc-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.dc-title{color:var(--c-text);font-size:16px;font-weight:800}.dc-desc{color:var(--c-text-muted);white-space:pre-line;font-size:12px;line-height:1.7}.dc-progress-wrap{flex-direction:column;gap:6px;width:100%;max-width:240px;margin-top:8px;display:flex}.dc-progress-bar{background:var(--c-border);border-radius:4px;width:100%;height:8px;overflow:hidden}.dc-progress-fill{background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;min-width:4px;height:100%;transition:width .5s}.dc-progress-label{color:var(--c-text-muted);text-align:center;font-size:11px;font-weight:600}.now-card{background:linear-gradient(135deg,#4f46e5 0%,#6366f1 55%,#818cf8 100%);border-radius:18px;margin:10px 12px;position:relative;overflow:hidden;box-shadow:0 6px 22px #4f46e559}.now-card-glow{pointer-events:none;background:radial-gradient(circle,#ffffff59 0%,#fff0 70%);width:180px;height:180px;position:absolute;top:-40%;right:-10%}.now-card-inner{padding:14px 16px 16px;position:relative}.now-card-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;display:flex}.now-card-via{color:#ffffffd9;margin-bottom:12px;font-size:11px;font-weight:600}.now-card-title-wrap{align-items:center;gap:6px;display:flex}.now-card-title{color:#fff;letter-spacing:.2px;font-size:14px;font-weight:800}.now-card-route{color:#ffffffbf;white-space:nowrap;text-overflow:ellipsis;max-width:45%;font-size:10px;font-weight:600;overflow:hidden}.now-card-btn{color:#4f46e5;cursor:pointer;background:#fff;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-size:14px;font-weight:800;transition:transform .12s,box-shadow .12s;display:flex;box-shadow:0 2px 8px #0000001f}.now-card-btn:active{transform:scale(.98)}.now-card-btn:hover{box-shadow:0 4px 14px #0000002e}.now-card-loading{color:#fff;justify-content:center;align-items:center;gap:10px;padding:13px;font-size:13px;font-weight:600;display:flex}.now-spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite now-spin}@keyframes now-spin{to{transform:rotate(360deg)}}.now-card-result{background:#fffffff2;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;animation:.35s cubic-bezier(.34,1.56,.64,1) now-pop;display:flex}@keyframes now-pop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.now-result-main{align-items:center;gap:14px;display:flex}.now-result-minutes{letter-spacing:-2px;font-size:42px;font-weight:900;line-height:1}.now-result-unit{margin-left:1px;font-size:18px;font-weight:800}.now-result-meta{flex-direction:column;gap:3px;display:flex}.now-result-level{font-size:13px;font-weight:800}.now-result-arrival{color:#6b7280;font-size:11px;font-weight:600}.now-card-refresh{color:#6366f1;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:6px;font-size:11px;font-weight:700}.now-card-refresh:hover{background:#6366f11a}.now-card-error{color:#ef4444;background:#fffffff2;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;font-size:13px;font-weight:600;display:flex}.now-card-retry{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:700}.now-card-maps{text-align:center;color:#fff;background:#ffffff2e;border-radius:10px;margin-top:10px;padding:9px;font-size:12.5px;font-weight:700;text-decoration:none;transition:background .15s;display:block}.now-card-maps:hover{background:#ffffff4d}.weekly-tab{padding-top:4px}.forecast-period{color:var(--c-text-muted);margin-left:auto;font-size:11px;font-weight:500}.forecast-scroll-wrap{-webkit-overflow-scrolling:touch;margin:0 -4px;padding:0 4px 6px;overflow-x:auto}.forecast-grid{gap:6px;width:max-content;min-width:100%;margin-bottom:4px;display:flex}.forecast-day{background:var(--c-surface-2);border-radius:var(--radius-sm);flex-direction:column;flex-shrink:0;align-items:center;gap:5px;width:calc(20vw - 16px);min-width:62px;max-width:80px;padding:10px 4px;display:flex}.forecast-date-label{color:var(--c-text-muted);text-align:center;font-size:10px;font-weight:700;line-height:1.4}.forecast-minutes{letter-spacing:-.5px;font-size:20px;font-weight:900;line-height:1}.min-unit{font-size:11px;font-weight:700}.forecast-level{text-align:center;font-size:9px;font-weight:700}.forecast-day-weekend{opacity:.85;background:#fef2f2}.forecast-day-today{background:var(--c-primary-light);border:1.5px solid var(--c-primary)}.forecast-day-clickable{cursor:pointer;transition:transform .1s}.forecast-day-clickable:active{transform:scale(.96)}.calc-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:flex-end;animation:.2s calc-fade;display:flex;position:fixed;inset:0}@keyframes calc-fade{0%{opacity:0}to{opacity:1}}.calc-sheet{background:var(--c-surface);border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:10px 20px 24px;animation:.25s cubic-bezier(.32,.72,0,1) calc-slide}@keyframes calc-slide{0%{transform:translateY(100%)}to{transform:translateY(0)}}.calc-handle{background:var(--c-border);border-radius:2px;width:38px;height:4px;margin:0 auto 14px}.calc-title{color:var(--c-text);text-align:center;font-size:17px;font-weight:800}.calc-sub{color:var(--c-text-muted);text-align:center;margin-top:2px;margin-bottom:16px;font-size:12px}.calc-rows{flex-direction:column;gap:2px;display:flex}.calc-row{border-bottom:1px solid var(--c-border-light);align-items:center;gap:8px;padding:9px 4px;display:flex}.calc-key{color:var(--c-text);flex-shrink:0;width:96px;font-size:13px;font-weight:700}.calc-val{color:var(--c-primary);width:56px;font-size:14px;font-weight:800}.calc-note{color:var(--c-text-muted);text-align:right;flex:1;font-size:11px}.calc-formula{text-align:center;color:var(--c-text-2);letter-spacing:.3px;margin-top:16px;font-size:14px;font-weight:700}.calc-result{text-align:center;font-size:38px;font-weight:900;line-height:1.2}.calc-arrival{text-align:center;color:var(--c-primary);margin-bottom:14px;font-size:13px;font-weight:700}.calc-disclaimer{color:var(--c-text-muted);background:var(--c-surface-2);border-radius:10px;margin-bottom:16px;padding:10px 12px;font-size:11px;line-height:1.6}.calc-close{color:#fff;background:var(--c-primary);cursor:pointer;border:none;border-radius:12px;width:100%;padding:13px;font-size:15px;font-weight:800}.forecast-today-badge{color:#fff;background:var(--c-primary);border-radius:6px;margin-bottom:2px;padding:1px 6px;font-size:9px;font-weight:800}.forecast-arrival{color:var(--c-primary);white-space:nowrap;font-size:10px;font-weight:700}.forecast-no-data{color:var(--c-text-muted);margin-top:2px;font-size:9px}.forecast-weather-text{color:var(--c-text-2);text-align:center;min-height:20px;font-size:8.5px;font-weight:600;line-height:1.2}.forecast-pop{font-size:9px;font-weight:700}.forecast-temp{gap:3px;font-size:9px;font-weight:700;display:flex}.temp-max{color:#ef4444}.temp-min{color:#3b82f6}.forecast-collecting-banner{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;align-items:center;gap:6px;margin-bottom:10px;padding:8px 12px;font-size:12px;display:flex}.forecast-source{color:var(--c-text-muted);text-align:right;margin-bottom:4px;padding-top:6px;font-size:9.5px}.legend{border-top:1px solid var(--c-border-light);padding-top:10px}.legend-items{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.legend-chip{color:var(--c-text-2);align-items:center;gap:3px;font-size:10px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.weekly-tip{border-radius:var(--radius-sm);background:#fffbeb;border:1px solid #fde68a;align-items:flex-start;gap:8px;margin-top:10px;padding:10px 12px;display:flex}.tip-icon-wrap{flex-shrink:0;margin-top:1px}.tip-text{color:var(--c-text-2);font-size:12px;line-height:1.6}.best-row{border-bottom:1px solid var(--c-border-light);align-items:center;gap:10px;padding:9px 0;display:flex}.best-medal{text-align:center;color:#fff;border-radius:5px;flex-shrink:0;width:34px;padding:3px 0;font-size:10px;font-weight:800}.best-time{color:var(--c-text);flex:1;font-size:13px;font-weight:600}.best-limit{color:var(--c-success);font-size:14px;font-weight:800}.best-arrival{color:var(--c-primary);white-space:nowrap;font-size:12px;font-weight:700}.best-note{color:var(--c-text-muted);text-align:center;margin-top:10px;font-size:11px}.peak-badge{text-align:center;color:#92400e;border-radius:var(--radius-sm);background:#fef3c7;width:100%;margin-top:4px;padding:5px 10px;font-size:11px;display:inline-block}.dep-time-bar{background:var(--c-surface);border-bottom:1px solid var(--c-border);justify-content:center;align-items:center;gap:14px;padding:7px 12px;display:flex}.dep-time-label{color:var(--c-text-muted);align-items:center;gap:5px;font-size:11px;font-weight:700;display:flex}.dep-time-ctrl{align-items:center;gap:8px;display:flex}.dep-time-btn{background:var(--c-primary-light);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s;display:flex}.dep-time-btn:hover:not(:disabled){background:#c7d2fe}.dep-time-btn:disabled{opacity:.3;cursor:default}.dep-time-val{color:var(--c-primary);text-align:center;letter-spacing:-.5px;min-width:58px;font-size:19px;font-weight:900}.actual-tab{padding-top:4px}.gmap-source{color:#888;align-items:center;gap:6px;margin:8px 12px 4px;font-size:11px;display:flex}.section-tabs{scrollbar-width:none;gap:6px;padding:0 12px 4px;display:flex;overflow-x:auto}.section-tabs::-webkit-scrollbar{display:none}.section-tab-btn{color:#555;cursor:pointer;background:#f5f5f5;border:1.5px solid #e5e5e5;border-radius:16px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:500}.section-tab-btn.active{color:#fff;background:#22c55e;border-color:#22c55e;font-weight:700}.date-input{box-sizing:border-box;appearance:none;background:#fafafa;border:1px solid #e5e5e5;border-radius:10px;outline:none;width:100%;min-width:0;max-width:100%;margin-bottom:12px;padding:9px 12px;font-size:14px;display:block}.date-input:focus{border-color:#22c55e}.record-detail{background:#f9fafb;border-radius:12px;padding:12px}.record-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.record-weather{font-size:28px}.record-date-label{color:#1a1a1a;font-size:13px;font-weight:700}.record-dep-label{color:#888;margin-top:2px;font-size:10px}.record-badge{color:#fff;border-radius:20px;margin-left:auto;padding:3px 10px;font-size:11px;font-weight:700}.record-comparison{align-items:center;gap:6px;margin-bottom:12px;display:flex}.comparison-item{text-align:center;background:#fff;border-radius:10px;flex:1;padding:8px 4px}.comparison-label{color:#888;margin-bottom:3px;font-size:10px}.comparison-val{font-size:20px;font-weight:800}.comparison-avg{color:#3b82f6}.comparison-divider{color:#ccc;flex-shrink:0;font-size:11px}.all-slots-title{color:#888;margin-bottom:8px;font-size:11px;font-weight:600}.all-slots-grid{grid-template-columns:repeat(6,1fr);gap:4px;display:grid}.slot-cell{text-align:center;background:#fff;border:1.5px solid #0000;border-radius:6px;padding:5px 2px}.slot-cell.highlighted{background:#f0fdf4;border-color:#22c55e}.slot-time{color:#888;font-size:9px}.slot-val{font-size:11px;font-weight:700}.no-record-day{text-align:center;color:#aaa;flex-direction:column;align-items:center;gap:8px;padding:20px 0;font-size:28px;display:flex}.no-record-day>div:last-child{font-size:13px}.chart-note-row{color:#888;align-items:center;gap:6px;margin-top:6px;font-size:11px;display:flex}.chart-note-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.dow-actual-row{border-bottom:1px solid #f5f5f5;align-items:center;gap:8px;padding:6px 0;display:flex}.dow-actual-label{color:#333;width:44px;font-size:12px}.dow-actual-val{text-align:right;width:36px;font-size:13px;font-weight:700}.weather-actual-grid{gap:8px;display:flex}.weather-actual-item{text-align:center;background:#f9fafb;border-radius:10px;flex:1;padding:12px 8px}.weather-actual-icon{margin-bottom:4px;font-size:28px}.weather-actual-label{color:#666;font-size:11px}.weather-actual-val{color:#1a1a1a;margin:4px 0 2px;font-size:20px;font-weight:800}.weather-actual-count{color:#aaa;font-size:10px}.stats-grid4{gap:6px;margin-bottom:12px;display:flex}.stat4-item{text-align:center;background:#f5f5f5;border-radius:10px;flex:1;padding:10px 4px}.stat4-item.green{background:#f0fdf4}.stat4-item.red{background:#fff7ed}.stat4-val{color:#1a1a1a;font-size:18px;font-weight:800}.stat4-label{color:#888;margin-top:2px;font-size:10px}.extreme-cards{gap:8px;display:flex}.extreme-card{border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px;font-size:12px;display:flex}.green-card{color:#166534;background:#f0fdf4}.red-card{color:#9a3412;background:#fff7ed}.extreme-card-date{color:#888;font-size:11px}.extreme-card-val{font-size:22px;font-weight:800}.dist-row{gap:8px;display:flex}.dist-item{text-align:center;border-radius:10px;flex:1;padding:12px 4px}.green-bg{background:#dcfce7}.yellow-bg{background:#fef9c3}.red-bg{background:#fee2e2}.dist-val{color:#1a1a1a;font-size:22px;font-weight:800}.dist-label{color:#555;margin-top:4px;font-size:10px;line-height:1.4}.monthly-report-btn{color:#16a34a;cursor:pointer;background:#f0fdf4;border:1px solid #22c55e;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:600}.log-list{font-size:12px}.log-header{color:#aaa;border-bottom:2px solid #f0f0f0;grid-template-columns:80px 28px 1fr 1fr 1fr;gap:4px;padding:6px 0;font-size:10px;font-weight:600;display:grid}.log-row{border-bottom:1px solid #f5f5f5;grid-template-columns:80px 28px 1fr 1fr 1fr;align-items:center;gap:4px;padding:7px 0;display:grid}.log-date{color:#555;font-size:11px}.log-actual{font-weight:700}.log-avg{color:#3b82f6}.log-diff{font-weight:600}.hourly-tab{padding-top:4px}.tip-list{flex-direction:column;gap:10px;display:flex}.tip-item{color:#555;align-items:flex-start;gap:8px;font-size:12px;line-height:1.5;display:flex}.tip-badge{color:#fff;border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:700}.tip-badge.green{background:#22c55e}.tip-badge.red{background:#ef4444}.tip-badge.orange{background:#f97316}.dow-tab{padding-top:4px}.dow-bar{border-radius:4px;height:100%}.dow-note{color:#888;text-align:center;margin-top:10px;font-size:11px}.heatmap-scroll{-webkit-overflow-scrolling:touch;width:100%;padding-bottom:4px;overflow-x:auto}.heatmap{min-width:100%;display:inline-block}.heatmap-th{text-align:center;color:#888;flex-shrink:0;width:48px;font-size:10px}.heatmap-day{color:#555;text-align:center;flex-shrink:0;width:22px;font-size:12px}.heatmap-cell{text-align:center;color:#333;border-radius:5px;flex-shrink:0;width:48px;padding:7px 0;font-size:11px;font-weight:700}.seasonal-tab{padding-top:4px}.month-status-grid{grid-template-columns:repeat(6,1fr);gap:6px;margin-top:8px;display:grid}.month-status-item{flex-direction:column;align-items:center;gap:3px;display:flex}.month-status-name{color:var(--c-text-muted);font-size:9px;font-weight:700}.month-status-bar{background:#f0f0f0;border-radius:4px;align-items:flex-end;width:20px;height:32px;display:flex;overflow:hidden}.month-status-fill{background:linear-gradient(#a5b4fc,#6366f1);border-radius:4px;width:100%;transition:height .5s}.month-status-item.ready .month-status-fill{background:linear-gradient(#86efac,#22c55e)}.month-status-item.current .month-status-name{color:var(--c-primary);font-weight:800}.month-status-badge{color:var(--c-text-muted);font-size:8px;font-weight:700}.month-status-item.ready .month-status-badge{color:#22c55e}.month-status-item.current .month-status-badge{color:var(--c-primary)}.season-comparison-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px;display:grid}.season-compare-item{border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:12px 4px;display:flex}.season-compare-icon{font-size:24px}.season-compare-label{font-size:12px;font-weight:800}.season-compare-val{font-size:10px;font-weight:700}.season-compare-collecting{color:#aaa;font-size:9px}.season-not-ready{opacity:.5}.coeff-table{flex-direction:column;gap:6px;display:flex}.coeff-row{align-items:center;gap:8px;font-size:11px;display:flex}.coeff-row>span:first-child{width:60px;color:var(--c-text);flex-shrink:0;font-weight:700}.coeff-row>span:last-child{color:var(--c-text-muted);flex:1}.coeff-status{border-radius:8px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:700}.coeff-status.mock{color:#92400e;background:#fef3c7}.coeff-status.real{color:#065f46;background:#d1fae5}.season-grid{gap:6px;margin-bottom:10px;display:flex}.season-item{background:#f9fafb;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 4px;display:flex}.season-label{color:#333;font-size:11px;font-weight:700}.season-range{color:#888;font-size:9px}.season-icon{font-size:24px}.season-minutes{font-size:22px;font-weight:800}.season-desc{color:#666;text-align:center;white-space:pre-line;font-size:9px;line-height:1.4}.season-note{color:#888;text-align:center;border-top:1px solid #f0f0f0;margin-top:8px;padding-top:8px;font-size:11px}.monthly-ranking{gap:16px;display:flex}.ranking-col{flex:1}.ranking-col-title{border-bottom:1px solid #f0f0f0;margin-bottom:8px;padding-bottom:4px;font-size:12px;font-weight:700}.ranking-col-title.light{color:#22c55e}.ranking-col-title.heavy{color:#ef4444}.ranking-row{border-bottom:1px solid #f9f9f9;align-items:center;gap:6px;padding:6px 0;display:flex}.rank-num{color:#888;width:28px;font-size:12px}.rank-month{color:#333;flex:1;font-size:13px}.rank-min{font-size:14px;font-weight:700}.light-min{color:#22c55e}.heavy-min{color:#ef4444}.weather-row{justify-content:center;align-items:center;gap:8px;padding:12px 0;display:flex}.weather-item{flex-direction:column;align-items:center;gap:4px;display:flex}.weather-icon{font-size:36px}.weather-label{color:#666;font-size:12px}.weather-min{color:#333;font-size:16px;font-weight:700}.weather-arrow{color:#ccc;font-size:20px}.weather-diff{flex-direction:column;align-items:center;gap:2px;display:flex}.diff-min{color:#ef4444;font-size:22px;font-weight:800}.diff-pct{color:#ef4444;font-size:16px;font-weight:700}.diff-label{color:#888;font-size:10px}.dow-row{border-bottom:1px solid #f5f5f5;align-items:center;gap:8px;padding:6px 0;display:flex}.dow-rank{color:#888;width:24px;font-size:11px}.dow-day{color:#333;width:44px;font-size:12px}.dow-bar-wrap{background:#f0f0f0;border-radius:4px;flex:1;height:12px;overflow:hidden}.dow-bar{border-radius:4px;height:100%;transition:width .3s}.dow-min{color:#333;text-align:right;width:32px;font-size:13px;font-weight:700}.annual-calendar{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.cal-month{flex-direction:column;gap:3px;display:flex}.cal-month-btn{cursor:pointer;text-align:left;background:#f9fafb;border:1.5px solid #0000;border-radius:6px;padding:5px;transition:border-color .15s,background .15s}.cal-month-btn:hover{border-color:var(--c-primary);background:var(--c-primary-light)}.cal-month-label{color:#666;margin-bottom:2px;font-size:10px;font-weight:700}.cal-days{flex-wrap:wrap;gap:1.5px;display:flex}.cal-day{border-radius:1px;width:6px;height:6px}.month-modal-sheet{padding-bottom:28px}.month-modal-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.month-modal-title{color:var(--c-text);font-size:17px;font-weight:800}.month-nav-btn{color:var(--c-primary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 10px;font-size:24px;font-weight:700;line-height:1}.month-nav-btn:hover{background:var(--c-primary-light)}.month-dow-row{grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px;display:grid}.month-dow-label{text-align:center;color:var(--c-text-muted);font-size:11px;font-weight:700}.month-grid{grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:8px;display:grid}.month-cell{aspect-ratio:1;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:1px;display:flex}.month-cell-empty{background:0 0}.month-cell-day{color:#000000a6;font-size:11px;font-weight:700;line-height:1}.month-cell-min{color:#00000080;font-size:8px;font-weight:600;line-height:1}.month-stats{background:var(--c-surface-2);border-radius:var(--radius-md);justify-content:space-around;margin-top:14px;padding:10px;display:flex}.month-stat{text-align:center}.month-stat-val{color:var(--c-text);font-size:18px;font-weight:800}.month-stat-label{color:var(--c-text-muted);margin-top:2px;font-size:10px}.heatmap-legend-row{color:#888;align-items:center;gap:8px;margin-top:10px;font-size:11px;display:flex}.analysis-tab{padding-top:4px}.analysis-subtabs{background:var(--c-surface-2);border-radius:12px;gap:6px;margin-bottom:10px;padding:4px;display:flex}.analysis-subtab{color:var(--c-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;flex:1;padding:9px 4px;font-size:13px;font-weight:700;transition:background .15s,color .15s}.analysis-subtab.active{background:var(--c-surface);color:var(--c-primary);box-shadow:0 1px 4px #00000014}.reverse-tab{padding-top:4px}.girne-hero{background:linear-gradient(135deg,#1e1b4b 0%,#312e81 60%,#4f46e5 100%);border-radius:18px;margin:8px 12px;padding:18px 18px 20px;box-shadow:0 6px 24px #4f46e559}.girne-hero-top{align-items:center;gap:6px;margin-bottom:12px;display:flex}.girne-hero-title{color:#fff;letter-spacing:.5px;flex:1;font-size:13px;font-weight:800}.girne-hero-date{color:#fffc;align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.girne-weather-label{color:#ffffffb3;font-size:11px}.girne-hero-label{color:#ffffffa6;margin-bottom:8px;font-size:11px;line-height:1.6}.girne-big-time{color:#fff;letter-spacing:-2px;margin-bottom:10px;font-size:58px;font-weight:900;line-height:1}.girne-hero-sub{color:#ffffffbf;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.girne-sep{opacity:.4}.girne-holiday-msg{color:#fff;text-align:center;padding:16px 0;font-size:18px;font-weight:700}.girne-collecting-msg{text-align:center;color:#fff;padding:16px 0 8px}.picker-label{color:var(--c-text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.date-chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:6px;padding-bottom:4px;display:flex;overflow-x:auto}.date-chip{border:1.5px solid var(--c-border);background:var(--c-surface-2);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;gap:2px;min-width:46px;padding:7px 10px;transition:all .15s;display:flex}.date-chip.active{background:var(--c-primary);border-color:var(--c-primary);color:#fff;box-shadow:0 3px 8px #4f46e54d}.date-chip.weekend{color:#ef4444}.date-chip.weekend.active{color:#fff;background:#ef4444;border-color:#ef4444}.date-chip-md{font-size:13px;font-weight:700}.date-chip-dow{opacity:.8;font-size:10px;font-weight:600}.arrival-slots{flex-wrap:wrap;gap:6px;display:flex}.arrival-btn{border:1.5px solid var(--c-border);background:var(--c-surface-2);color:var(--c-text-2);cursor:pointer;border-radius:20px;padding:6px 11px;font-size:12px;font-weight:500;transition:all .15s}.arrival-btn.active{background:var(--c-primary);border-color:var(--c-primary);color:#fff;font-weight:700}.route-info-row{color:var(--c-text-2);background:var(--c-surface-2);border-radius:8px;align-items:center;gap:6px;padding:7px 10px;font-size:11px;display:flex}.route-arrow{color:#ccc}.option-row{border-bottom:1px solid var(--c-border-light);align-items:center;gap:6px;padding:10px 0;display:flex}.option-row:last-of-type{border-bottom:none}.option-recommended{background:#f0fdf4;border-radius:10px;margin:2px -4px;padding:10px 8px}.option-dep,.option-travel,.option-arr{flex-direction:column;flex:1;align-items:center;display:flex}.option-dep-time,.option-arr-time{color:var(--c-text);font-size:16px;font-weight:700}.option-dep-label,.option-arr-label,.option-travel-label{color:#aaa;font-size:10px}.option-travel-val{color:var(--c-text-2);font-size:14px;font-weight:600}.option-pct-wrap{text-align:center;flex:1}.option-pct{font-size:17px;font-weight:800}.option-pct-label{font-size:10px;font-weight:600}.buffer-guide{flex-direction:column;gap:8px;display:flex}.buffer-row{color:var(--c-text-2);align-items:flex-start;gap:8px;font-size:12px;line-height:1.5;display:flex}.buffer-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:3px}.settings-tab{padding-top:4px}.settings-field{align-items:center;gap:10px;margin-bottom:10px;display:flex}.settings-field-label{color:var(--c-text-2);flex-shrink:0;align-items:center;gap:5px;width:92px;font-size:12px;font-weight:700;display:flex}.settings-select{min-width:0;color:var(--c-text);background:var(--c-surface-2);border:1.5px solid var(--c-border);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:9px;flex:1;padding:9px 28px 9px 10px;font-size:14px;font-weight:600}.settings-select:focus{border-color:var(--c-primary);outline:none}.settings-hint{color:var(--c-text-muted);margin-top:6px;font-size:10.5px}.settings-save-btn{color:#fff;background:var(--c-primary);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;margin-top:4px;padding:11px;font-size:14px;font-weight:800;transition:background .2s;display:flex}.settings-save-btn:disabled{opacity:.4;cursor:default}.settings-save-btn.saved{opacity:1;background:#22c55e}.settings-map-wrap{border:1.5px solid var(--c-border);border-radius:12px;width:100%;margin-bottom:8px;overflow:hidden}.settings-map{border:none;width:100%;height:220px;display:block}.settings-map-link{color:var(--c-primary);font-size:12px;font-weight:700;text-decoration:none;display:inline-block}.settings-map-link:hover{text-decoration:underline}.settings-route-summary{flex-direction:column;gap:6px;display:flex}.settings-route-via{color:var(--c-text);font-size:14px;font-weight:700}.settings-route-meta{color:var(--c-text-muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:11px;display:flex}.settings-route-toll{background:var(--c-warning);color:#fff;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:800}.settings-route-locked{color:var(--c-text-2);font-weight:600}.settings-toggle-btn{color:var(--c-primary);background:var(--c-primary-light);cursor:pointer;border:none;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;text-decoration:none;display:inline-block}.settings-map-wp{color:var(--c-text-muted);margin-bottom:6px;font-size:10.5px}.settings-route-head{color:var(--c-text);margin-bottom:8px;font-size:13px;font-weight:700}.settings-route-summary{margin-top:10px}.settings-add-tabs{background:var(--c-surface-2);border-radius:10px;gap:6px;margin:10px 0;padding:4px;display:flex}.settings-add-tab{color:var(--c-text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-size:13px;font-weight:700}.settings-add-tab.active{background:var(--c-surface);color:var(--c-primary);box-shadow:0 1px 4px #00000014}.settings-add-form{flex-direction:column;gap:8px;display:flex}.settings-input{border:1.5px solid var(--c-border);background:var(--c-surface);box-sizing:border-box;border-radius:9px;width:100%;padding:10px 12px;font-size:14px}.settings-input:focus{border-color:var(--c-primary);outline:none}.settings-color-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.settings-color-label{color:var(--c-text-muted);margin-right:2px;font-size:12px;font-weight:700}.settings-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:24px;height:24px}.settings-color-dot.selected{border-color:var(--c-text);transform:scale(1.1)}.settings-add-btn{color:#fff;background:var(--c-primary);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:11px;font-size:14px;font-weight:800;display:flex}.settings-add-btn:disabled{opacity:.4;cursor:default}.settings-custom-list{flex-direction:column;gap:6px;margin-top:4px;display:flex}.settings-custom-item{background:var(--c-surface-2);border-radius:9px;align-items:center;gap:9px;padding:8px 10px;display:flex}.settings-custom-text{flex:1;min-width:0}.settings-custom-name{color:var(--c-text);font-size:13px;font-weight:700}.settings-custom-sub{color:var(--c-text-muted);font-size:10px}.settings-del-btn{cursor:pointer;background:0 0;border:none;padding:4px}.settings-color-swatch{border-radius:50%;flex-shrink:0;width:16px;height:16px}.settings-route-info{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.settings-route-row{align-items:center;gap:8px;display:flex}.settings-route-label{color:var(--c-text-muted);flex-shrink:0;width:32px;font-size:11px;font-weight:700}.settings-route-val{color:var(--c-text);font-size:14px;font-weight:700}.settings-btn-row{gap:8px;display:flex}.settings-btn{color:var(--c-text-2);background:var(--c-surface-2);border:1.5px solid var(--c-border);cursor:pointer;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:5px;padding:10px 8px;font-size:12px;font-weight:700;transition:border-color .15s,background .15s;display:flex}.settings-btn:hover{border-color:var(--c-primary);background:var(--c-primary-light)}.settings-count-big{align-items:baseline;gap:6px;margin-top:4px;display:flex}.settings-count-num{color:var(--c-primary);letter-spacing:-1px;font-size:40px;font-weight:900;line-height:1}.settings-count-unit{color:var(--c-text-2);font-size:14px;font-weight:700}.settings-count-sub{color:var(--c-text-muted);margin-top:6px;margin-bottom:14px;font-size:11px}.milestone-list{flex-direction:column;gap:2px;display:flex}.milestone-row{border-bottom:1px solid var(--c-border-light);align-items:center;gap:10px;padding:9px 4px;display:flex}.milestone-row:last-child{border-bottom:none}.milestone-check{text-align:center;width:18px;color:var(--c-text-muted);font-weight:800}.milestone-row.reached .milestone-check{color:#22c55e}.milestone-label{color:var(--c-text);flex:1;font-size:13px;font-weight:600}.milestone-row.reached .milestone-label{color:var(--c-text-muted)}.milestone-target{color:var(--c-text-muted);font-size:12px;font-weight:700}.settings-next-hint{color:var(--c-text-2);background:#fffbeb;border:1px solid #fde68a;border-radius:10px;align-items:center;gap:6px;margin-top:12px;padding:9px 12px;font-size:12px;line-height:1.5;display:flex}.settings-info{color:var(--c-text-2);font-size:12px;line-height:1.7}.settings-info p{margin-bottom:10px}.info-source-list{flex-direction:column;gap:6px;display:flex}.info-source-row{align-items:center;gap:10px;display:flex}.info-source-key{color:var(--c-text);flex-shrink:0;width:64px;font-size:11px;font-weight:700}.info-source-val{color:var(--c-text-muted);font-size:11px}.info-source-link{color:var(--c-primary);text-decoration:none}.info-source-link:hover{text-decoration:underline}.access-stat-row{gap:10px;margin-bottom:12px;display:flex}.access-stat{text-align:center;background:var(--c-surface-2);border-radius:12px;flex:1;padding:12px}.access-stat-num{color:var(--c-primary);font-size:28px;font-weight:900;line-height:1}.access-stat-label{color:var(--c-text-muted);margin-top:4px;font-size:11px;font-weight:600}.access-daily-title{color:var(--c-text-muted);margin-bottom:6px;font-size:11px;font-weight:700}.access-daily-row{align-items:center;gap:8px;padding:3px 0;display:flex}.access-daily-date{color:var(--c-text-2);flex-shrink:0;width:40px;font-size:11px}.access-daily-bar-wrap{background:var(--c-surface-2);border-radius:4px;flex:1;height:10px;overflow:hidden}.access-daily-bar{background:linear-gradient(90deg,#6366f1,#818cf8);border-radius:4px;min-width:2px;height:100%}.access-daily-count{color:var(--c-text);text-align:right;width:28px;font-size:12px;font-weight:700}.settings-credit{border-top:1px solid var(--c-border-light);flex-direction:column;gap:5px;margin-top:12px;padding-top:12px;display:flex}.settings-credit-row{gap:10px;display:flex}.settings-credit-key{color:var(--c-text);flex-shrink:0;width:64px;font-size:11px;font-weight:700}.settings-credit-val{color:var(--c-text-muted);font-size:11px}.modal-overlay{z-index:300;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--c-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:430px;max-height:85vh;padding:12px 16px 32px;overflow-y:auto}.modal-sheet-tall{max-height:92vh}.modal-handle{background:var(--c-border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.modal-title{color:var(--c-text);margin-bottom:4px;font-size:17px;font-weight:800}.modal-route-info{color:var(--c-text-muted);margin-bottom:16px;font-size:11px}.modal-section-label{color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:10px;font-weight:700}.modal-option{background:var(--c-surface-2);border-radius:var(--radius-md);cursor:pointer;text-align:left;border:2px solid #0000;align-items:center;gap:10px;width:100%;margin-bottom:6px;padding:12px;transition:border-color .15s;display:flex}.modal-option.selected{border-color:var(--c-primary);background:var(--c-primary-light)}.modal-option:hover:not(.selected){background:#f1f5f9}.modal-badge{color:#fff;white-space:pre;text-align:center;border-radius:4px;flex-shrink:0;padding:4px 6px;font-size:9px;font-weight:800;line-height:1.3}.modal-train{font-size:20px}.modal-option-text{flex:1;min-width:0}.modal-option-name{color:var(--c-text);font-size:13px;font-weight:700}.modal-option-sub{color:var(--c-text-muted);margin-top:1px;font-size:10px}.modal-check{color:var(--c-primary);font-size:16px;font-weight:700}.modal-close-btn{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);width:100%;color:var(--c-text-2);cursor:pointer;margin-top:8px;padding:13px;font-size:14px;font-weight:600;transition:background .15s}.modal-close-btn:hover{background:var(--c-border)}.month-nav{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.month-nav-btn{cursor:pointer;color:#555;background:#f5f5f5;border:none;border-radius:8px;width:36px;height:36px;font-size:20px}.month-nav-label{color:#1a1a1a;font-size:16px;font-weight:700}.monthly-stats{gap:8px;margin-bottom:16px;display:flex}.stat-item{text-align:center;background:#f5f5f5;border-radius:10px;flex:1;padding:10px 6px}.stat-item-avg{background:#f0fdf4}.stat-item-best{background:#eff6ff}.stat-item-worst{background:#fff7ed}.stat-value{color:#1a1a1a;font-size:18px;font-weight:800}.stat-label{color:#888;margin-top:2px;font-size:10px}.no-records{text-align:center;color:#aaa;padding:20px;font-size:13px}.monthly-calendar{margin-bottom:10px}.cal-dow-header{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.cal-dow{text-align:center;color:#888;padding:4px 0;font-size:11px;font-weight:600}.cal-dow.sun{color:#ef4444}.cal-dow.sat{color:#3b82f6}.cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.cal-cell{aspect-ratio:1;background:#f9f9f9;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:2px;display:flex;position:relative}.cal-cell.empty{background:0 0}.cal-cell.sun .cal-day-num{color:#ef4444}.cal-cell.sat .cal-day-num{color:#3b82f6}.cal-day-num{color:#555;font-size:11px;font-weight:600;line-height:1}.cal-actual{color:#333;margin-top:1px;font-size:9px;font-weight:700}.cal-weather-small{font-size:8px;line-height:1}.monthly-legend{color:#888;align-items:center;gap:8px;margin-bottom:16px;font-size:11px;display:flex}.legend-gradient{background:linear-gradient(90deg,#bbf7d0,#86efac,#fde68a,#fb923c,#ef4444);border-radius:4px;flex:1;height:8px}.route-edit-sheet{padding-bottom:24px}.re-locked-banner{background:var(--c-surface-2);color:var(--c-text-2);border-radius:10px;align-items:center;gap:6px;margin-bottom:14px;padding:10px 12px;font-size:12px;font-weight:600;display:flex}.re-new-banner{background:var(--c-primary-light);color:var(--c-primary);border-radius:10px;align-items:center;gap:6px;margin-bottom:14px;padding:10px 12px;font-size:12px;font-weight:600;display:flex}.re-view-list{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.re-view-row{gap:12px;display:flex}.re-view-key{color:var(--c-text-muted);flex-shrink:0;width:64px;font-size:12px;font-weight:700}.re-view-val{color:var(--c-text);font-size:13px;font-weight:600}.re-header{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.re-route-label{width:100%;color:var(--c-text-muted);margin-top:-6px;font-size:11px}.re-section-label{color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;font-size:11px;font-weight:700}.re-input{box-sizing:border-box;border:1.5px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface-2);width:100%;color:var(--c-text);outline:none;margin-bottom:6px;padding:10px 12px;font-size:14px;transition:border-color .15s}.re-input:focus{border-color:var(--c-primary)}.re-input-sm,.re-input-flex{flex:1;margin-bottom:0}.re-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.re-toll{color:var(--c-text-2);white-space:nowrap;cursor:pointer;align-items:center;gap:4px;font-size:12px;display:flex}.re-wp-add{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);flex-direction:column;gap:7px;padding:10px;display:flex}.re-wp-add-title{color:var(--c-text-2);align-items:center;gap:5px;font-size:12px;font-weight:700;display:flex}.re-maps-row{align-items:center;gap:6px;display:flex}.re-maps-btn{background:var(--c-primary-light);color:var(--c-primary);border:1px solid var(--c-primary-mid);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;padding:9px 12px;font-size:12px;font-weight:700;transition:background .12s}.re-maps-btn:hover{background:#c7d2fe}.re-maps-error{color:var(--c-danger);font-size:11px}.re-maps-search-link{color:var(--c-primary);font-size:11px;font-weight:600;text-decoration:none}.re-maps-search-link:hover{text-decoration:underline}.re-add-btn{background:var(--c-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:5px;padding:10px;font-size:13px;font-weight:700;transition:background .15s;display:flex}.re-add-btn:hover:not(:disabled){background:var(--c-primary-dark)}.re-add-btn:disabled{opacity:.45;cursor:not-allowed}.re-wp-item{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);align-items:center;gap:8px;margin-bottom:5px;padding:8px 10px;display:flex}.re-wp-text{flex:1;min-width:0}.re-wp-name{color:var(--c-text);font-size:13px;font-weight:600}.re-wp-addr{color:var(--c-text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:10px;overflow:hidden}.re-footer{gap:8px;margin-top:16px;display:flex}.re-save-btn{background:var(--c-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;padding:13px;font-size:14px;font-weight:700}.re-save-btn:hover{background:var(--c-primary-dark)}.re-reset-btn{border:1px solid var(--c-border);border-radius:var(--radius-md);color:var(--c-text-muted);cursor:pointer;background:0 0;padding:13px 14px;font-size:13px}.re-reset-btn:hover{background:var(--c-surface-2);color:var(--c-text-2)}body{justify-content:center;min-height:100vh;display:flex;overflow:hidden}#root{background:var(--c-bg);flex-direction:column;width:100%;max-width:430px;height:100dvh;display:flex;overflow:hidden;box-shadow:0 0 40px #00000026}.app{flex-direction:column;height:100%;display:flex;overflow:hidden}.sticky-top{background:var(--c-surface);z-index:100;box-shadow:0 1px 0 var(--c-border);flex-shrink:0}.main-content{-webkit-overflow-scrolling:touch;flex:1;padding-bottom:12px;overflow-y:auto}.section-card{background:var(--c-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:10px 12px;padding:16px}.section-title{color:var(--c-text);flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;font-size:13px;font-weight:700;display:flex}.section-subtitle{color:var(--c-text-muted);font-size:11px;font-weight:400}.heatmap{font-size:11px}.heatmap-header{margin-bottom:3px;display:flex}.heatmap-corner{flex-shrink:0;width:26px}.heatmap-th{text-align:center;color:var(--c-text-muted);flex:1;font-size:9px;font-weight:600}.heatmap-row{align-items:center;gap:2px;margin-bottom:2px;display:flex}.heatmap-day{width:22px;color:var(--c-text-2);text-align:center;flex-shrink:0;font-size:11px;font-weight:600}.heatmap-cell{text-align:center;color:#1e293b;border-radius:5px;flex:1;padding:5px 1px;font-size:10px;font-weight:700}.heatmap-legend{color:var(--c-text-muted);align-items:center;gap:8px;margin-top:10px;font-size:10px;display:flex}.heatmap-gradient{background:linear-gradient(90deg,#bbf7d0,#86efac,#fde68a,#fb923c,#ef4444);border-radius:4px;flex:1;height:7px}
