:root{--bg-base: #1b2232;--bg-raised: #232f45;--bg-card: #1e2b40;--bg-inset: #161f30;--bg-green: #1a2e22;--border: rgba(255,255,255,.08);--border-dim: rgba(255,255,255,.05);--teal: #4ecda4;--teal-dim: rgba(78,205,164,.25);--text-1: #f1f5f9;--text-2: #94a3b8;--text-3: #64748b}.landing-page{min-height:100vh;background:var(--bg-base);color:var(--text-1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.landing-ticker{display:flex;align-items:center;background:var(--bg-inset);border-bottom:1px solid var(--teal-dim);height:36px;overflow:hidden;position:relative}.landing-ticker-label{flex-shrink:0;font-size:.65rem;font-weight:800;letter-spacing:.12em;color:var(--teal);padding:0 1rem;border-right:1px solid var(--teal-dim);height:100%;display:flex;align-items:center;background:#1a2e22;z-index:1}.landing-ticker-track{flex:1;overflow:hidden}.landing-ticker-inner{display:flex;white-space:nowrap;animation:ticker-scroll 60s linear infinite}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.landing-ticker-item{display:inline-flex;align-items:center;gap:.5rem;padding:0 1.5rem;font-size:.72rem;font-family:Courier New,monospace}.t-hc{color:#e2e8f0;font-weight:700}.t-unit{color:var(--teal);font-weight:700}.t-name{color:var(--text-3)}.t-route{color:var(--text-2)}.t-status{color:var(--text-3)}.t-live{color:var(--teal)}.t-railtour{color:#f59e0b}.t-late{color:#f87171}.landing-ticker-loading{color:var(--text-3);font-size:.78rem;padding:0 1rem;align-self:center}.t-sep{color:#ffffff1f;padding:0 .5rem}.landing-hero{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1200px;margin:0 auto;padding:4rem 3rem 3rem;min-height:auto;position:relative;background-image:radial-gradient(rgba(78,205,164,.1) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 40%,transparent 100%);mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 40%,transparent 100%)}.landing-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 50% 55% at 22% 50%,rgba(45,138,110,.18) 0%,transparent 70%),radial-gradient(ellipse 45% 50% at 78% 45%,rgba(30,60,130,.25) 0%,transparent 70%);pointer-events:none;z-index:0}.landing-hero-left,.landing-hero-right{position:relative;z-index:1}.landing-badge{display:inline-flex;align-items:center;gap:.4rem;background:#2d8a6e26;border:1px solid rgba(78,205,164,.35);color:var(--teal);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .85rem;border-radius:50px;margin-bottom:1.5rem}.landing-badge-dot{width:5px;height:5px;background:var(--teal);border-radius:50%;animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.landing-title{font-size:clamp(4rem,10vw,7rem);font-weight:900;letter-spacing:-.04em;line-height:1;margin-bottom:1.25rem;background:linear-gradient(135deg,#fff,#c7f8ea);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-tagline{font-size:1.05rem;color:var(--text-2);line-height:1.7;margin-bottom:2rem}.landing-buttons{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:2rem}.landing-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.75rem;background:#2d8a6e;color:#fff;text-decoration:none;border-radius:8px;font-size:.95rem;font-weight:600;transition:background .2s,transform .2s,box-shadow .2s}.landing-cta:hover{background:#34a07e;transform:translateY(-2px);box-shadow:0 8px 24px #2d8a6e66}.landing-cta:hover svg{transform:translate(3px)}.landing-cta svg{transition:transform .2s}.landing-cta-large{padding:.9rem 2.25rem;font-size:1rem}.landing-login-btn{display:inline-flex;align-items:center;padding:.8rem 1.75rem;background:transparent;color:var(--text-3);border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s}.landing-login-btn:hover{color:var(--text-1);border-color:#ffffff40}.landing-hero-pills{display:flex;flex-wrap:wrap;gap:.5rem}.landing-pill{font-size:.72rem;color:var(--text-3);background:#ffffff0f;border:1px solid var(--border);border-radius:6px;padding:.25rem .65rem;letter-spacing:.02em}.landing-hero-right{display:flex;flex-direction:column;gap:1rem}.landing-board{background:var(--bg-inset);border:1px solid var(--border);border-radius:14px;overflow:hidden;font-family:Courier New,monospace;box-shadow:0 16px 48px #00000040}.landing-board-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem .75rem;border-bottom:1px solid var(--border-dim);background:#ffffff05}.landing-board-station{font-size:.85rem;font-weight:700;color:var(--text-1);letter-spacing:.04em;font-family:-apple-system,sans-serif}.landing-board-live{display:flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;color:var(--teal);font-family:-apple-system,sans-serif}.lf-live-dot{width:5px;height:5px;background:var(--teal);border-radius:50%;animation:blink 1.5s ease-in-out infinite}.landing-board-cols{display:grid;grid-template-columns:50px 56px 72px 1fr;gap:.5rem;padding:.4rem 1rem;font-size:.62rem;color:#fff3;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border-dim);font-family:-apple-system,sans-serif}.landing-board-row{display:grid;grid-template-columns:50px 56px 72px 1fr;gap:.5rem;padding:.65rem 1rem;border-bottom:1px solid var(--border-dim);align-items:start}.landing-board-row:last-child{border-bottom:none}.landing-board-row-now{background:#2d8a6e1a}.lb-dep{font-size:.8rem;color:var(--text-2)}.lb-hc{font-size:.8rem;color:#e2e8f0;font-weight:700}.lb-unit{font-size:.8rem;font-weight:700}.lb-green{color:var(--teal)}.lb-amber{color:#f59e0b}.lb-dim{color:#fff3}.lb-dest{display:flex;flex-direction:column;gap:.15rem}.lb-to{font-size:.78rem;color:var(--text-2);font-family:-apple-system,sans-serif}.lb-note{font-size:.65rem;color:var(--text-3);font-family:-apple-system,sans-serif}.landing-board-visible{opacity:1;transform:translateY(0);transition:opacity .35s ease,transform .35s ease}.landing-board-hidden{opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s ease}.landing-board-footer{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1rem .5rem;border-top:1px solid var(--border-dim);background:#ffffff05}.landing-board-dot{width:6px;height:6px;border-radius:50%;background:#ffffff26;border:none;cursor:pointer;padding:0;transition:background .2s,transform .2s}.landing-board-dot:hover{background:#ffffff59}.landing-board-dot-active{background:var(--teal)!important;transform:scale(1.3)}.landing-scroll-hint{display:flex;justify-content:center;padding:1rem 0 .5rem;color:#4ecda466;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.landing-who{background:var(--bg-raised);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:5rem 3rem}.landing-who-inner{max-width:1100px;margin:0 auto}.landing-section-eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:2.5rem;text-align:center}.landing-who-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}.landing-who-card{background:var(--bg-card);border:1px solid var(--border);border-top:2px solid rgba(78,205,164,.2);border-radius:14px;padding:2rem 1.75rem;transition:border-top-color .25s,transform .25s,box-shadow .25s;box-shadow:0 4px 16px #0003}.landing-who-card:hover{border-top-color:var(--teal);transform:translateY(-4px);box-shadow:0 12px 32px #0000004d}.landing-who-card-mid{background:#1e2e24;border-top-color:var(--teal)}.landing-who-num{font-size:.65rem;font-weight:800;letter-spacing:.15em;color:#4ecda459;margin-bottom:.75rem;font-family:Courier New,monospace}.landing-who-card h3{font-size:1.1rem;font-weight:700;color:var(--text-1);margin-bottom:.75rem}.landing-who-card p{font-size:.88rem;color:var(--text-2);line-height:1.65;margin-bottom:1.25rem}.landing-who-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem}.landing-who-list li{font-size:.82rem;color:var(--text-2);padding-left:1.1rem;position:relative}.landing-who-list li:before{content:"✓";position:absolute;left:0;color:var(--teal);font-size:.72rem}.landing-coming-soon{font-size:.65rem;background:#4ecda41a;border:1px solid rgba(78,205,164,.2);color:var(--teal);padding:.08rem .4rem;border-radius:4px;margin-left:.3rem;vertical-align:middle}.landing-stats-strip{background:var(--bg-green);padding:1.75rem 3rem;border-top:1px solid rgba(78,205,164,.2);border-bottom:1px solid rgba(78,205,164,.2)}.landing-stats-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:center;flex-wrap:wrap}.landing-stat{display:flex;flex-direction:column;align-items:center;padding:.5rem 2.5rem;text-align:center}.ls-num{font-size:1.1rem;font-weight:800;color:var(--teal);letter-spacing:-.02em}.ls-label{font-size:.68rem;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;margin-top:.15rem}.landing-stat-div{width:1px;height:28px;background:#ffffff1a}.landing-features{padding:5rem 3rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:6rem}.landing-feature-row{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}.landing-feature-row-reverse{direction:rtl}.landing-feature-row-reverse>*{direction:ltr}.landing-feature-tag{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:.75rem}.landing-feature-text h2{font-size:clamp(1.35rem,2.5vw,1.8rem);font-weight:700;color:var(--text-1);line-height:1.25;margin-bottom:1rem}.landing-feature-text p{font-size:.92rem;color:var(--text-2);line-height:1.75;margin-bottom:.6rem}.landing-feature-sub{color:var(--text-3)!important;font-size:.85rem!important}.landing-feature-visual{border-radius:14px;background:var(--bg-inset);border:1px solid var(--border);box-shadow:0 8px 32px #0003;overflow:hidden;min-height:280px;display:flex;flex-direction:column;padding:1.25rem;gap:.5rem;position:relative}.landing-feature-live{font-family:Courier New,monospace}.lf-label{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#4ecda466;margin-bottom:.25rem;font-family:-apple-system,sans-serif}.lf-board{width:100%}.lf-board-row{display:grid;grid-template-columns:46px 52px 66px 1fr;gap:.4rem;padding:.45rem .5rem;border-radius:5px;align-items:center;font-size:.78rem}.lf-board-header{color:#fff3;font-size:.6rem;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.2rem;border-bottom:1px solid var(--border-dim);padding-bottom:.35rem;font-family:-apple-system,sans-serif}.lf-board-now{background:#2d8a6e1a;border:1px solid rgba(45,138,110,.15)}.lf-board-dim{opacity:.3}.lf-dep{color:var(--text-2)}.lf-hc{color:#e2e8f0;font-weight:700}.lf-unit{font-weight:700}.lf-unit-green{color:var(--teal)}.lf-unit-amber{color:#f59e0b}.lf-unit-dim{color:#fff3}.lf-dest{color:var(--text-3);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lf-live-pill{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.3rem;background:#2d8a6e26;border:1px solid rgba(78,205,164,.3);color:var(--teal);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .55rem;border-radius:50px;font-family:-apple-system,sans-serif}.landing-feature-db{gap:.65rem}.lf-class-row{display:flex;flex-direction:column;gap:.3rem}.lf-class-head{display:flex;align-items:baseline;gap:.55rem}.lf-cls{font-size:.95rem;font-weight:800;color:var(--teal);min-width:32px;font-family:Courier New,monospace}.lf-cname{font-size:.82rem;color:var(--text-2);flex:1}.lf-count{font-size:.72rem;font-weight:700;color:var(--teal);font-family:Courier New,monospace}.lf-total{color:var(--text-3);font-weight:400}.lf-bar{height:3px;background:#ffffff14;border-radius:2px;overflow:hidden}.lf-bar-fill{height:100%;background:linear-gradient(90deg,#2d8a6e,var(--teal));border-radius:2px}.landing-feature-log{gap:.6rem}.lf-entry{background:#ffffff0a;border:1px solid var(--border);border-radius:9px;padding:.75rem .9rem}.lf-entry-dim{opacity:.4}.lf-entry-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.25rem}.lf-entry-num{font-size:1rem;font-weight:800;color:var(--text-1);font-family:Courier New,monospace}.lf-entry-new{font-size:.58rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#f59e0b;background:#f59e0b1f;border:1px solid rgba(245,158,11,.25);padding:.1rem .4rem;border-radius:4px}.lf-entry-meta{display:flex;align-items:center;gap:.3rem;margin-bottom:.2rem;flex-wrap:wrap}.lf-entry-cls{font-size:.68rem;color:var(--teal);font-weight:600}.lf-entry-loc,.lf-entry-when{font-size:.68rem;color:var(--text-3)}.lf-entry-sep{color:#ffffff26;font-size:.65rem}.lf-entry-note{font-size:.75rem;color:var(--text-3)}.lf-batch-hint{display:flex;align-items:center;gap:.5rem;font-size:.72rem;color:var(--teal);font-weight:600;background:#2d8a6e1a;border:1px solid rgba(78,205,164,.2);border-radius:8px;padding:.5rem .85rem}.landing-bottom-cta{text-align:center;padding:6rem 2rem;background:var(--bg-raised);border-top:1px solid var(--border)}.landing-bottom-cta h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;color:var(--text-1);margin-bottom:.75rem;line-height:1.25}.landing-bottom-cta p{color:var(--text-2);font-size:1rem;line-height:1.65;margin-bottom:2rem;max-width:480px;margin-left:auto;margin-right:auto}.landing-cta-small{display:block;margin-top:1rem!important;font-size:.78rem!important;color:var(--text-3)!important}.landing-footer{text-align:center;padding:1.25rem;border-top:1px solid var(--border-dim);color:var(--text-3);font-size:.78rem}.landing-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.landing-modal{background:var(--bg-raised);color:var(--text-1);border:1px solid var(--border);border-radius:14px;padding:2.5rem;width:90%;max-width:340px;text-align:center;position:relative;animation:modalIn .2s ease-out}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:none}}.landing-modal h2{font-size:1.2rem;margin-bottom:.25rem}.landing-modal-subtitle{color:var(--text-3);font-size:.83rem;margin-bottom:1.5rem}.landing-modal-close{position:absolute;top:.75rem;right:1rem;background:none;border:none;font-size:1.4rem;color:var(--text-3);cursor:pointer}.landing-modal-close:hover{color:var(--text-1)}.landing-modal-buttons{display:flex;flex-direction:column;gap:.75rem}.landing-modal-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1rem;border-radius:8px;text-decoration:none;font-size:.88rem;font-weight:500;transition:opacity .15s}.landing-modal-btn:hover{opacity:.85}.landing-modal-google{background:#4285f4;color:#fff}.landing-modal-github{background:#24292e;color:#fff}@media(max-width:1000px){.landing-hero{grid-template-columns:1fr;min-height:auto;padding:3rem 2rem;gap:2.5rem}.landing-hero-right{max-width:500px}.landing-features{padding:4rem 2rem;gap:4rem}.landing-who{padding:4rem 2rem}}@media(max-width:768px){.landing-feature-row{grid-template-columns:1fr;gap:2rem}.landing-feature-row-reverse{direction:ltr}.landing-who-cards{grid-template-columns:1fr}.landing-stats-strip{padding:1.5rem}.landing-stat{padding:.5rem 1.25rem}.landing-stat-div{display:none}.landing-stats-inner{gap:.5rem;justify-content:flex-start}.landing-stat{align-items:flex-start}}@media(max-width:480px){.landing-hero{padding:2.5rem 1.25rem}.landing-buttons{flex-direction:column}.landing-cta,.landing-login-btn{width:100%;justify-content:center}}.db-page{padding:1.5rem 2rem 3rem;max-width:1200px}.db-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.db-greeting{font-size:1.4rem;font-weight:700;margin:0}.db-topbar-actions{display:flex;gap:.5rem;align-items:center}.db-action{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;text-decoration:none;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.db-action:hover{background:var(--row-stripe);border-color:var(--accent)}.db-action-primary{background:var(--accent);border-color:var(--accent);color:#fff}.db-action-primary:hover{background:var(--accent-dark, #34a07e);border-color:var(--accent-dark, #34a07e)}.db-action-cog{padding:.55rem .7rem}.db-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}.db-col{display:flex;flex-direction:column;gap:1rem}.db-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:0;box-shadow:var(--shadow-sm)}.db-widget-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}.db-widget-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);flex:1}.db-widget-sub{font-size:.75rem;color:var(--text-muted);font-weight:400;text-transform:none;letter-spacing:0}.db-widget-action{font-size:.78rem;color:var(--accent);text-decoration:none;font-weight:500;white-space:nowrap;flex-shrink:0}.db-widget-action:hover{text-decoration:underline}.db-widget-more{font-size:.75rem;color:var(--accent);text-decoration:none;opacity:.8}.db-widget-more:hover{opacity:1}.db-widget-badge{font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:#4ecda41a;border:1px solid rgba(78,205,164,.2);padding:.1rem .45rem;border-radius:4px;flex-shrink:0}.db-widget-live{margin-bottom:1rem;border-left:3px solid var(--accent)}.db-live-pulse-wrap{display:inline-flex;align-items:center;margin-right:.35rem}.db-live-pulse{display:block;width:10px;height:10px;background:var(--accent);border-radius:50%;position:relative}.db-live-pulse:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--accent);animation:pulse-ring 1.8s ease-out infinite;opacity:0}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.8}to{transform:scale(1.8);opacity:0}}.db-live-board{font-family:Courier New,monospace;font-size:.82rem}.db-live-cols{display:grid;grid-template-columns:46px 52px 1fr 1fr;gap:.4rem;padding:.3rem .4rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border);font-family:-apple-system,sans-serif;margin-bottom:.15rem}.db-live-row{display:grid;grid-template-columns:46px 52px 1fr 1fr;gap:.4rem;padding:.45rem .4rem;border-radius:5px;align-items:center;border-bottom:1px solid var(--border)}.db-live-row:last-child{border-bottom:none}.db-live-row-next{background:#4ecda412;border-bottom-color:transparent}.db-live-row-cancelled{opacity:.4;text-decoration:line-through}.db-live-time{color:var(--text-2, #94a3b8);font-size:.8rem}.db-live-delayed{color:#f59e0b}.db-live-hc{color:var(--text);font-weight:700;font-size:.8rem}.db-live-unit{color:var(--text-muted);font-size:.75rem;font-family:-apple-system,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-live-dest{color:var(--text-2, #94a3b8);font-size:.75rem;font-family:-apple-system,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-live-tabs{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.85rem}.db-live-tab{padding:.3rem .7rem;border-radius:6px;font-size:.75rem;font-weight:500;background:var(--row-stripe);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s;font-family:inherit;white-space:nowrap}.db-live-tab:hover{color:var(--text);border-color:var(--accent)}.db-live-tab-active{background:var(--accent);border-color:var(--accent);color:#fff}.db-live-no-station{font-size:.85rem;color:var(--text-muted);padding:.5rem 0}.db-live-no-station a{color:var(--accent)}.db-live-loading{font-size:.82rem;color:var(--text-muted);padding:.5rem 0}.db-live-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--accent);color:#fff;border-radius:8px;font-size:.82rem;font-weight:600;text-decoration:none;margin-left:auto;flex-shrink:0;transition:background .15s}.db-live-btn:hover{background:var(--accent-dark, #34a07e)}.db-log{display:flex;flex-direction:column}.db-log-row{display:grid;grid-template-columns:5rem 1fr auto;align-items:center;gap:.6rem;padding:.5rem .35rem;border-bottom:1px solid var(--border);border-radius:5px;transition:background .1s}.db-log-row:last-child{border-bottom:none}.db-log-row:hover{background:var(--row-stripe)}.db-log-num{font-family:SF Mono,Fira Code,Courier New,monospace;font-size:1.1rem;font-weight:700;color:var(--text);line-height:1;letter-spacing:.02em}.db-log-detail{display:flex;flex-direction:column;gap:.08rem;min-width:0}.db-log-cls{font-size:.78rem;font-weight:600;color:var(--text)}.db-log-loc{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-log-date{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.db-widget-haul{border-top:2px solid var(--accent)}.db-haul-num{font-size:3rem;font-weight:900;color:var(--accent);line-height:1;letter-spacing:-.03em;margin-bottom:.3rem}.db-haul-fleet{font-size:.82rem;color:var(--text-muted);margin-bottom:.75rem}.db-haul-fleet strong{color:var(--accent)}.db-haul-bar-wrap{height:5px;background:var(--row-stripe);border-radius:3px;overflow:hidden;margin-bottom:.6rem}.db-haul-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-dark, #2d8a6e),var(--accent));border-radius:3px;transition:width .8s ease}.db-haul-days{font-size:.75rem;color:var(--text-muted)}.db-nearly{display:flex;flex-direction:column;gap:.7rem}.db-nearly-row{text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:.28rem;padding:.6rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--row-stripe);transition:border-color .15s,transform .15s}.db-nearly-row:hover{border-color:var(--accent);transform:translate(3px)}.db-nearly-head{display:flex;align-items:baseline;gap:.5rem}.db-nearly-cls{font-size:.88rem;font-weight:700;color:var(--text)}.db-nearly-nick{font-size:.72rem;color:var(--text-muted);font-style:italic;flex:1}.db-nearly-remain{font-size:.7rem;font-weight:700;color:var(--accent);white-space:nowrap}.db-nearly-bar-wrap{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.db-nearly-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-dark, #2d8a6e),var(--accent));border-radius:2px}.db-nearly-count{font-size:.68rem;color:var(--text-muted);text-align:right}.db-classes{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}.db-cls-chip{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.65rem .35rem .5rem;border-radius:10px;text-decoration:none;background:#f5efe6;border:1px solid #e8dece;box-shadow:0 2px 6px #0003;transition:transform .15s,box-shadow .15s}.db-cls-chip:hover{transform:translateY(-3px);box-shadow:0 6px 16px #0000004d}.db-cls-ring{display:block}.db-cls-num{font-family:var(--font-display, "Bebas Neue", sans-serif);font-size:1.3rem;line-height:1;color:#1a2332}.db-cls-nick{font-size:.58rem;color:#7a6e62;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72px;text-align:center}.db-cls-pct{font-size:.68rem;font-weight:700;color:#2d8a6e}.db-types{display:flex;flex-direction:column;gap:.65rem}.db-type-card{padding:.75rem .85rem;border-radius:8px;background:var(--row-stripe);border:1px solid var(--border)}.db-type-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.35rem}.db-type-name{font-size:.85rem;font-weight:600}.db-type-pct{font-size:.8rem;font-weight:700;color:var(--accent)}.db-type-bar-wrap{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:.3rem}.db-type-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-dark, #2d8a6e),var(--accent));border-radius:2px;transition:width .8s ease}.db-type-count{font-size:.7rem;color:var(--text-muted)}.db-news{display:flex;flex-direction:column}.db-news-row{display:flex;gap:.65rem;align-items:flex-start;padding:.65rem 0;border-bottom:1px solid var(--border);text-decoration:none;cursor:pointer}.db-news-row:last-child{border-bottom:none}.db-news-row:hover .db-news-headline{color:var(--accent)}.db-news-thumb{width:60px;height:45px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--border)}.db-news-body{flex:1;min-width:0}.db-news-headline{font-size:.88rem;font-weight:500;color:var(--text);line-height:1.4;margin-bottom:.25rem;transition:color .15s}.db-news-meta{display:flex;gap:.5rem;align-items:center}.db-news-source{font-size:.7rem;font-weight:600;color:var(--accent)}.db-news-time{font-size:.7rem;color:var(--text-muted)}.db-news-loading{font-size:.85rem;color:var(--text-muted);padding:.5rem 0}.db-widget-chat{margin-bottom:1rem}.db-chat-online{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--text-muted)}.db-chat-dot{display:inline-block;width:6px;height:6px;background:var(--accent);border-radius:50%;animation:blink-dot 2s ease-in-out infinite}@keyframes blink-dot{0%,to{opacity:1}50%{opacity:.4}}.db-chat-feed{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;max-height:320px;overflow-y:auto}.db-chat-msg{display:flex;gap:.65rem;align-items:flex-start}.db-chat-msg-hot .db-chat-text{color:var(--text)}.db-chat-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.db-chat-body{flex:1;min-width:0}.db-chat-meta{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.15rem}.db-chat-user{font-size:.78rem;font-weight:700;color:var(--text)}.db-chat-time{font-size:.68rem;color:var(--text-muted)}.db-chat-text{font-size:.85rem;color:var(--text-muted);line-height:1.45}.db-chat-msg-hot .db-chat-avatar{background:#f59e0b}.db-chat-input-wrap{display:flex;gap:.5rem;border-top:1px solid var(--border);padding-top:.85rem}.db-chat-input{flex:1;background:var(--row-stripe);border:1px solid var(--border);border-radius:8px;padding:.55rem .85rem;font-size:.85rem;color:var(--text);font-family:inherit;outline:none}.db-chat-input:focus{border-color:var(--accent)}.db-chat-input:disabled{opacity:.5;cursor:not-allowed}.db-chat-send{padding:.55rem .75rem;background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;align-items:center;transition:background .15s}.db-chat-send:hover:not(:disabled){background:var(--accent-dark, #34a07e)}.db-chat-send:disabled{opacity:.4;cursor:not-allowed}.db-settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;display:flex;align-items:flex-end;justify-content:flex-end}.db-settings-panel{background:var(--surface);border-left:1px solid var(--border);border-top:1px solid var(--border);width:360px;max-width:100vw;height:100%;display:flex;flex-direction:column;animation:slide-in .22s ease-out}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.db-settings-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.db-settings-header h2{font-size:1rem;font-weight:700;margin:0}.db-settings-close{background:none;border:none;font-size:1.1rem;color:var(--text-muted);cursor:pointer;padding:.25rem}.db-settings-close:hover{color:var(--text)}.db-settings-hint{font-size:.82rem;color:var(--text-muted);padding:.85rem 1.5rem 0;margin:0}.db-settings-list{flex:1;overflow-y:auto;padding:.75rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}.db-settings-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border);cursor:pointer;gap:1rem}.db-settings-row:last-child{border-bottom:none}.db-settings-info{display:flex;flex-direction:column;gap:.15rem}.db-settings-label{font-size:.9rem;font-weight:600;color:var(--text)}.db-settings-desc{font-size:.75rem;color:var(--text-muted)}.db-toggle{width:40px;height:22px;border-radius:11px;background:var(--border);position:relative;flex-shrink:0;cursor:pointer;transition:background .2s}.db-toggle-on{background:var(--accent)}.db-toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.db-toggle-on .db-toggle-thumb{transform:translate(18px)}.db-settings-save{margin:1rem 1.5rem;padding:.75rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.db-settings-save:hover{background:var(--accent-dark, #34a07e)}.db-welcome{margin-bottom:2rem}.db-welcome h1{font-size:1.8rem;font-weight:700;margin-bottom:.25rem}.db-welcome p{color:var(--text-muted)}.db-onboarding{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.db-onboard-card{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-top:2px solid rgba(78,205,164,.2);border-radius:12px;text-decoration:none;color:inherit;transition:border-top-color .2s,transform .2s}.db-onboard-card:hover{border-top-color:var(--accent);transform:translateY(-3px)}.db-onboard-featured{border-top-color:var(--accent)}.db-onboard-num{font-family:var(--font-display, "Bebas Neue", sans-serif);font-size:1.8rem;color:var(--accent);line-height:1;margin-bottom:.25rem}.db-onboard-card h3{font-size:1rem;font-weight:600;margin:0}.db-onboard-card p{font-size:.85rem;color:var(--text-muted);line-height:1.5;margin:0}.db-onboard-cta{font-size:.82rem;color:var(--accent);font-weight:500;margin-top:auto;padding-top:.5rem}@media(max-width:800px){.db-grid{grid-template-columns:1fr}.db-settings-panel{width:100%;height:auto;max-height:85vh}.db-settings-overlay{align-items:flex-end;justify-content:center}}@media(max-width:600px){.db-page{padding:1rem 1rem 2rem}.db-haul-num{font-size:2.4rem}.db-log-num{font-size:1rem}.db-log-row{grid-template-columns:4.2rem 1fr auto}.db-classes{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}}:root{--sidebar-bg: #1e2b3e;--sidebar-text: #b8ccde;--sidebar-active: #1e7a5e;--content-bg: #1b2232;--surface: #1e2b40;--card-bg: #1e2b40;--text: #e2e8f0;--text-muted: #94a3b8;--border: rgba(255,255,255,.08);--border-light: rgba(255,255,255,.05);--row-highlight: rgba(45,138,110,.1);--row-stripe: rgba(255,255,255,.04);--row-alt: rgba(255,255,255,.04);--primary: #60a5fa;--accent: #34a07e;--accent-hover: #2d8a6e;--accent-dark: #248a6a;--accent-subtle: rgba(52,160,126,.12);--danger: #f87171;--danger-hover: #ef4444;--radius: 10px;--radius-sm: 6px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--font-display: "Bebas Neue", sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;color-scheme:dark}html.dark{--content-bg: #1b2232;--surface: #1e2b40;--card-bg: #1e2b40;--text: #e2e8f0;--text-muted: #94a3b8;--border: rgba(255,255,255,.08);--border-light: rgba(255,255,255,.07);--row-highlight: rgba(45,138,110,.1);--row-stripe: rgba(255,255,255,.04);--row-alt: rgba(255,255,255,.04);--primary: #60a5fa;--accent: #34a07e;--accent-hover: #2d8a6e;--accent-dark: #248a6a;--accent-subtle: rgba(52,160,126,.12);--danger: #f87171;--danger-hover: #ef4444;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);color-scheme:dark}html.dark .sidebar{background:#1e2b3e;background-image:linear-gradient(180deg,#223045,#1a2638);border-right:1px solid rgba(255,255,255,.08)}input,select,textarea{background:var(--surface);color:var(--text);border-color:var(--border)}input:focus,select:focus,textarea:focus{background:var(--surface)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-secondary:hover{background:var(--row-stripe)}.vehicle-table tr:hover td{background:#ffffff0d}.mobile-service-card,.detail-card{background:var(--surface);border-color:var(--border)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text);background:var(--content-bg)}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--sidebar-bg);background-image:linear-gradient(180deg,#111e2e,#0d1821);color:var(--sidebar-text);padding:1.5rem 1rem;display:flex;flex-direction:column;gap:2rem;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid rgba(255,255,255,.05)}.sidebar-header h1{font-size:1.5rem;color:#fff;letter-spacing:.05em;font-weight:800}.sidebar-header .subtitle{font-size:.7rem;color:#b8ccde80;text-transform:uppercase;letter-spacing:.12em;margin-top:.1rem}.sidebar-header{display:flex;flex-direction:column;gap:.35rem}.sync-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.2rem;height:1.2rem;padding:0 .35rem;margin-left:.5rem;background:var(--warning, #f59e0b);color:#fff;border-radius:999px;font-size:.7rem;font-weight:700;line-height:1;vertical-align:middle;animation:sync-pulse 1.5s ease-in-out infinite}@keyframes sync-pulse{0%,to{opacity:1}50%{opacity:.6}}.sidebar nav{display:flex;flex-direction:column;gap:.25rem}.nav-link{display:block;padding:.55rem .85rem;color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-sm);transition:background .15s,color .15s;font-size:.875rem}.nav-link:hover{background:#ffffff12;color:#fff}.nav-link.active{background:linear-gradient(135deg,#1e7a5e,#2d8a6e);color:#fff;font-weight:600;box-shadow:0 2px 8px #2d8a6e59}.nav-group-header{display:flex;align-items:stretch}.nav-group-header .nav-link{flex:1;min-width:0}.nav-toggle{background:none;border:none;color:var(--sidebar-text);padding:0 .6rem;cursor:pointer;font-size:.75rem;opacity:.6;border-radius:var(--radius)}.nav-toggle:hover{opacity:1;background:#ffffff14}.nav-sublist{display:flex;flex-direction:column;max-height:40vh;overflow-y:auto;padding:.15rem 0}.nav-sublink{display:block;padding:.3rem 1rem .3rem 1.8rem;color:#e0e8f0;text-decoration:none;font-size:.8rem;border-radius:var(--radius)}.nav-sublink:hover{background:#ffffff1a}.nav-sublink.active{color:#fff;font-weight:600;background:#2d8a6e80}.content{padding:2rem;overflow-y:auto;background:var(--content-bg);min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h2{font-size:1.4rem;font-weight:700;letter-spacing:-.01em}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;box-shadow:0 2px 8px #2d8a6e4d}.btn-primary:hover{background:linear-gradient(135deg,#34a07e,var(--accent));box-shadow:0 4px 12px #2d8a6e66}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--row-stripe);border-color:#c8d0da}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 6px #dc262640}.btn-danger:hover{background:var(--danger-hover)}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.toggle-group{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.toggle-group .btn{border-radius:0;border-right:1px solid var(--border);padding:.3rem .8rem;font-size:.8rem}.toggle-group .btn:last-child{border-right:none}.filter-bar{display:flex;gap:.75rem;align-items:end;margin-bottom:1.25rem;flex-wrap:wrap}.filter-bar label{display:flex;flex-direction:column;gap:.2rem;font-size:.8rem;color:var(--text-muted)}.filter-bar select,.filter-bar input{padding:.45rem .7rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.filter-bar select:focus,.filter-bar input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2d8a6e1f}.table-wrap{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto;box-shadow:var(--shadow-sm)}.vehicle-table-wrap{--text: #1a2332;--text-muted: #7a6e62;--border: #e8dece;--border-light: #e8dece;--row-stripe: rgba(0,0,0,.04);background:#f5efe6;border:1px solid #e8dece;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000002e}.vehicle-table-wrap th{background:#ede6db;color:#1a2332;border-bottom:1px solid #ddd4c4}.vehicle-table-wrap td{border-bottom:1px solid #e8dece;color:#1a2332}.vehicle-table-wrap tr:nth-child(2n) td{background:#0000000a}.vehicle-table-wrap tr:hover td{background:#00000012!important}.vehicle-table-wrap tr.spotted td{background:transparent!important;opacity:.45}.vehicle-table-wrap tr.spotted:nth-child(2n) td{background:#0000000a!important}.vehicle-table-wrap tr.spotted:hover td{opacity:.7;background:#00000012!important}table{width:100%;border-collapse:collapse}th{text-align:left;padding:.8rem 1rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--row-stripe);font-weight:600}td{padding:.7rem 1rem;border-bottom:1px solid var(--border-light);font-size:.875rem}tr:last-child td{border-bottom:none}tr:nth-child(2n) td{background:var(--row-stripe)}tr:hover td{background:#ffffff0d;transition:background .1s}td:last-child{white-space:nowrap}.mono{font-family:Courier New,Courier,monospace;font-weight:600}.actions{display:flex;gap:.4rem}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--card-bg);border-radius:var(--radius-lg);padding:1.75rem;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);border:1px solid var(--border)}.modal h3{margin-bottom:1rem;font-size:1.1rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem}.form-group{margin-bottom:.85rem}.form-group label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.2rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:inherit;background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2d8a6e1f}.form-group textarea{resize:vertical;min-height:60px}.detail-card{--text: #1a2332;--text-muted: #7a6e62;background:#f5efe6;border:1px solid #e8dece;border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000002e;color:#1a2332}.detail-card h3{margin-bottom:1rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.detail-field label{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.detail-field p{margin-top:.15rem;font-size:.95rem}.detail-field-wide{grid-column:1 / -1}.photo-section{margin-top:1.5rem}.photo-section h3{margin-bottom:1rem}.photo-upload{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.photo-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative}.photo-card img{width:100%;height:140px;object-fit:cover;display:block;cursor:pointer}.photo-card .photo-info{padding:.4rem .6rem;font-size:.75rem;color:var(--text-muted);display:flex;justify-content:space-between;align-items:center}.photo-card .photo-delete{background:var(--danger);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200;cursor:pointer}.lightbox img{max-width:90vw;max-height:90vh;border-radius:var(--radius)}a.table-link{color:var(--accent);text-decoration:none}a.table-link:hover{text-decoration:underline}.back-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--accent);text-decoration:none;font-size:.9rem;margin-bottom:1rem}.back-link:hover{text-decoration:underline}.sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:.6rem}.sidebar-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.8rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{background:none;border:none;color:var(--sidebar-text);font-size:.7rem;cursor:pointer;padding:0;text-align:left}.btn-logout:hover{color:#fff;text-decoration:underline}.user-actions{display:flex;gap:.5rem;align-items:center}.btn-preferences{color:var(--sidebar-text);font-size:.7rem;text-decoration:none}.btn-preferences:hover{color:#fff;text-decoration:underline}.sidebar-login{display:block;text-align:center;text-decoration:none}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--content-bg)}.login-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem 2.5rem 1.5rem;text-align:center;max-width:380px;width:100%}.login-card h2{margin-bottom:.25rem;font-size:1.3rem}.login-subtitle{color:var(--text-muted);font-size:.85rem;margin-bottom:1.5rem}.login-buttons{display:flex;flex-direction:column;gap:.75rem}.btn-login{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;border-radius:var(--radius);text-decoration:none;font-size:.9rem;font-weight:500;text-align:center;transition:opacity .15s}.btn-login:hover{opacity:.9}.provider-icon{flex-shrink:0}.login-error{color:#e74c3c;font-size:.85rem;margin-bottom:.5rem;text-align:center}.login-toggle{margin-top:1.5rem;font-size:.85rem;color:var(--text-muted)}.login-toggle a{color:var(--accent);font-weight:600;text-decoration:none}.login-toggle a:hover{text-decoration:underline}.btn-google{background:#4285f4;color:#fff}.btn-github{background:#24292e;color:#fff}.user-cell{display:flex;align-items:center;gap:.5rem}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600}.status-active{background:#d4edda;color:#155724}.status-disabled{background:#f8d7da;color:#721c24}.row-disabled td{opacity:.6}.dashboard{max-width:800px}.dashboard-title{font-size:1.5rem;margin-bottom:.25rem}.dashboard-subtitle{color:var(--text-muted);margin-bottom:2rem}.dashboard-stats{display:flex;gap:1rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;flex-direction:column;min-width:160px}.stat-value{font-size:2rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.dashboard-section{margin-bottom:2rem}.dashboard-section h2{font-size:1.1rem;margin-bottom:.75rem}.spots-by-type{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.type-row{display:flex;justify-content:space-between;padding:.6rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem}.type-row:last-child{border-bottom:none}.type-count{font-weight:600;color:var(--accent)}.dashboard-section .table{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius)}.dashboard-section .table a{color:var(--accent);text-decoration:none}.dashboard-section .table a:hover{text-decoration:underline}.dashboard-tutorial{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.tutorial-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.tutorial-step{width:32px;height:32px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;margin-bottom:.75rem}.tutorial-card h3{font-size:.95rem;margin-bottom:.35rem}.tutorial-card p{font-size:.85rem;color:var(--text-muted);line-height:1.4}.dashboard-cta{text-decoration:none;font-size:.95rem;padding:.6rem 1.5rem}.vehicle-badge,.usage-badge{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600;white-space:nowrap}.vehicle-badge-active{background:#d4edda;color:#155724}.vehicle-badge-scrapped{background:#dc262626;color:#f87171}.vehicle-badge-stored_serviceable{background:#f59e0b26;color:#fbbf24}.vehicle-badge-stored_unserviceable{background:#f59e0b1a;color:#f59e0b}.vehicle-badge-heritage{background:#d1ecf1;color:#0c5460}.usage-badge-mainline{background:#d4edda;color:#155724}.usage-badge-heritage{background:#d1ecf1;color:#0c5460}.usage-badge-industrial{background:#e2d9f3;color:#4a2d7a}.usage-badge-stored{background:#f59e0b26;color:#fbbf24}.usage-badge-exported{background:#f9731626;color:#fb923c}.usage-badge-electric{background:#dbeafe;color:#1e40af}.pre-tops-badge{display:inline-block;margin-left:.4rem;padding:.1rem .4rem;border-radius:10px;font-size:.65rem;font-weight:600;background:#e2d6f3;color:#5a3d8a;vertical-align:middle}.usage-badge-scrapped{background:#dc262626;color:#f87171}.mobile-topbar,.mobile-drawer,.mobile-overlay{display:none}@media(max-width:768px){.fb-fab{left:1.25rem}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;background:var(--sidebar-bg);color:#fff;padding:0 1rem;height:52px;position:sticky;top:0;z-index:300;flex-shrink:0}.mobile-topbar-title{font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:.05em}.mobile-hamburger{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1}.layout{grid-template-columns:1fr}.sidebar{display:none}.mobile-drawer{display:flex;flex-direction:column;position:fixed;top:52px;left:-280px;width:260px;height:calc(100vh - 52px);background:var(--sidebar-bg);color:var(--sidebar-text);padding:1.25rem 1rem;gap:1.5rem;overflow-y:auto;z-index:299;transition:left .25s ease}.mobile-drawer-open{left:0}.mobile-overlay{display:block;position:fixed;top:52px;right:0;bottom:0;left:0;background:#0006;z-index:298}.content{padding:1rem;min-width:0}.vehicle-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.hero-banner{max-height:160px!important}.spec-grid{grid-template-columns:1fr!important}.class-card-grid{grid-template-columns:repeat(2,1fr)!important}.filter-bar{flex-wrap:wrap;gap:.5rem}.stat-cards{grid-template-columns:repeat(2,1fr)}.col-hide-mobile{display:none}tbody tr td{padding:.75rem .6rem}.spotted-cell{white-space:nowrap;padding:.5rem!important}.details-btn{display:block;margin-top:.4rem;width:100%;text-align:center}.hero-banner{max-height:160px}.hero-banner-class{font-size:2.5rem!important}.detail-grid{grid-template-columns:1fr!important}.back-link{display:inline-block;padding:.6rem 0;font-size:1rem}.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--sidebar-bg, #0f1923);border-top:1px solid rgba(255,255,255,.08);z-index:300;padding-bottom:env(safe-area-inset-bottom,0px)}.content{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px) + 1rem)!important}.live-desktop-board{display:none!important}.live-mobile-board{display:block!important}.live-filter-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.live-filter-bar::-webkit-scrollbar{display:none}}.mobile-bottom-nav{display:none}.mobile-bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#c8d6e573;text-decoration:none;font-size:.6rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;padding:6px 4px;border:none;background:none;cursor:pointer;transition:color .15s;-webkit-tap-highlight-color:transparent;position:relative}.mobile-bottom-nav-item svg{width:22px;height:22px}.mobile-bottom-nav-item.active{color:var(--sidebar-active, #1a6b52)}.mobile-bottom-nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:2px;background:var(--sidebar-active, #1a6b52);border-radius:0 0 2px 2px}.mobile-bottom-nav-capture{color:var(--primary, #1d6b47)}.mobile-bottom-nav-capture svg{width:28px;height:28px}.mobile-service-card{background:#f5efe6;border:1px solid #e8dece;border-left:4px solid transparent;border-radius:8px;padding:.5rem .7rem;margin-bottom:.3rem;transition:border-color .15s}.mobile-service-card--seen{border-left-color:#f59e0b}.mobile-service-card--new{border-left-color:var(--accent, #1a6b52)}.msc-header{display:flex;align-items:flex-start;gap:.4rem;margin-bottom:.3rem}.msc-time{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;min-width:3.6rem}.msc-time-val{font-size:1.05rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;color:var(--text)}.msc-time-label{font-size:.6rem;color:var(--text-muted);margin-top:1px}.msc-arr{font-size:.6rem;color:var(--text-muted);margin-top:1px;font-variant-numeric:tabular-nums}.msc-route{flex:1;font-size:.82rem;font-weight:500;color:var(--text);line-height:1.3;align-self:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msc-origin{color:var(--text-muted);font-weight:400}.msc-service-type{color:var(--text-muted);font-style:italic;font-size:.85rem}.msc-cancelled{color:var(--danger);font-weight:700;font-size:.72rem;margin-left:.4rem}.msc-terminus-badge{display:inline-block;padding:1px 5px;border-radius:3px;font-size:.7rem;font-weight:700;background:#7a4f00;color:#fff;margin-left:.4rem;vertical-align:middle}.msc-platform{flex-shrink:0;display:flex;flex-direction:column;align-items:center;background:var(--sidebar-bg, #0f1923);color:#fff;border-radius:6px;padding:.2rem .5rem .25rem;min-width:2.4rem;text-align:center}.msc-platform-label{font-size:.5rem;opacity:.65;text-transform:uppercase;letter-spacing:.06em;line-height:1}.msc-platform-num{font-size:1.1rem;font-weight:700;line-height:1.15}.msc-units-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.msc-meta{flex:1;display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;min-width:0}.msc-headcode{font-family:monospace;font-weight:700;font-size:.88rem;color:var(--primary, #2563eb);cursor:pointer;flex-shrink:0}.msc-units{font-family:monospace;font-size:.8rem;color:var(--text-muted)}.msc-spot-btn{background:var(--accent, #1a6b52);color:#fff;border:none;border-radius:6px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;min-height:36px;min-width:5rem;white-space:nowrap;transition:background .15s;-webkit-tap-highlight-color:transparent}.msc-spot-btn:active{background:#155c44}.msc-spot-btn:disabled{opacity:.55;cursor:not-allowed}.msc-spot-done{color:var(--accent, #1a6b52);font-weight:700;font-size:.85rem;white-space:nowrap}.msc-spot-error{color:var(--danger);font-size:.78rem}.msc-footer{display:flex;align-items:center;gap:.4rem;margin-top:.25rem;flex-wrap:wrap}.msc-badge-seen{font-size:.7rem;color:#b45309;font-weight:600}.msc-badge-new{font-size:.7rem;color:var(--accent, #1a6b52);font-weight:700;background:#1a6b5226;padding:1px 6px;border-radius:4px}.msc-no-alloc{font-size:.72rem;color:var(--text-muted);font-style:italic}.search-input{width:100%;padding:.5rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.875rem;font-family:inherit;color:var(--text);background:var(--card-bg);outline:none;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1a6b521a}.search-input::placeholder{color:var(--text-muted)}.live-search-bar{display:flex;align-items:stretch;background:var(--card-bg);border:1.5px solid var(--border);border-radius:8px;max-width:640px;margin-bottom:1.5rem;transition:border-color .15s,box-shadow .15s}.live-search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #1a6b521a}.live-search-station{flex:1;position:relative;min-width:0}.live-search-station input{width:100%;height:100%;padding:.7rem .9rem;border:none;outline:none;font-size:.9rem;font-family:inherit;color:var(--text);background:transparent;border-radius:7px 0 0 7px}.live-search-station input::placeholder{color:var(--text-muted)}.live-search-selected{display:flex;align-items:center;gap:.4rem;padding:.7rem .75rem .7rem .9rem;cursor:pointer;min-height:44px;border-radius:7px 0 0 7px}.live-search-selected:hover{background:#00000008}.live-search-selected-name{font-size:.9rem;font-weight:500;color:var(--text)}.live-search-selected-crs{font-size:.72rem;background:#1a6b521a;color:var(--accent);padding:1px 6px;border-radius:10px;font-weight:600;letter-spacing:.03em}.live-search-clear{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1;padding:0 .2rem;opacity:.5;flex-shrink:0;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.live-search-clear:hover{opacity:1;background:#0000000f}.live-search-dropdown{position:absolute;top:calc(100% + 1px);left:-1.5px;right:-1.5px;z-index:100;background:var(--card-bg);border:1.5px solid var(--accent);border-top:none;border-radius:0 0 8px 8px;max-height:280px;overflow-y:auto;box-shadow:0 6px 24px #00000080}.live-search-dropdown button{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;padding:.55rem .9rem;background:none;border:none;cursor:pointer;color:var(--text);font-size:.875rem;font-family:inherit;transition:background .1s}.live-search-dropdown button:hover{background:#1a6b5212}.live-search-dropdown-crs{font-size:.72rem;background:#1a6b521a;color:var(--accent);padding:1px 6px;border-radius:10px;font-weight:600}.live-search-sep{width:1px;background:var(--border);flex-shrink:0;margin:8px 0}.live-search-hc{width:82px;padding:.7rem .5rem;border:none;outline:none;font-size:.9rem;font-family:Courier New,monospace;color:var(--text);background:transparent;text-align:center;letter-spacing:.1em;flex-shrink:0}.live-search-hc::placeholder{color:var(--text-muted);letter-spacing:.02em;font-size:.78rem}.live-search-gps{display:flex;align-items:center;gap:.35rem;padding:0 1rem;background:var(--accent);color:#fff;border:none;border-left:none;border-radius:0 7px 7px 0;font-size:.82rem;font-weight:500;cursor:pointer;flex-shrink:0;white-space:nowrap;transition:background .15s}.live-search-gps:hover:not(:disabled){background:var(--accent-hover)}.live-search-gps:disabled{opacity:.65;cursor:not-allowed}@media(max-width:768px){.live-search-bar{max-width:100%}.live-search-gps span{display:none}.live-search-gps{padding:0 .75rem;font-size:1rem}}.live-desktop-board{display:block}.live-mobile-board{display:none}.live-desktop-board,.live-mobile-board{--text: #1a2332;--text-muted: #6b7280;--primary: #1d4ed8;--border: #e8dece;--border-light: #e8dece;--row-stripe: rgba(0,0,0,.04);--row-alt: rgba(0,0,0,.04);--danger: #dc2626;--accent: #1a6b52}.live-desktop-board .table-wrapper{background:#f5efe6;border:1px solid #e8dece;border-radius:var(--radius);overflow-x:auto;box-shadow:0 2px 8px #0000002e}.live-desktop-board table th{background:#ede6db;color:#1a2332;border-bottom:1px solid #ddd4c4}.live-desktop-board table td{border-bottom:1px solid #e8dece;color:#1a2332}.live-desktop-board table tr:nth-child(2n) td{background:#0000000a}.live-desktop-board table tr:hover td{background:#00000012!important}.live-filter-bar{display:flex;gap:.4rem;margin-bottom:1rem;flex-wrap:wrap}.impersonation-banner{background:#f59e0b;color:#1c1917;padding:.6rem 1.5rem;display:flex;align-items:center;gap:1rem;font-size:.875rem;font-weight:500;position:sticky;top:0;z-index:200;flex-shrink:0}.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;text-align:center}.stat-card .stat-value{font-size:2rem;font-weight:700;color:var(--accent);line-height:1}.stat-card .stat-label{font-size:.8rem;color:var(--text-muted);margin-top:.4rem}.display-number{font-family:var(--font-display);font-size:4rem;line-height:1;letter-spacing:.02em;color:var(--text)}.class-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.class-card{background:#f5efe6;border:1px solid #e8dece;border-radius:var(--radius);padding:1.25rem;position:relative;transition:box-shadow .2s,transform .2s;overflow:hidden;text-decoration:none;color:#1a2332;display:flex;flex-direction:column;box-shadow:0 2px 8px #0003}.class-card:hover{box-shadow:0 8px 24px #0000004d;transform:translateY(-3px)}.class-card .card-designation{font-family:var(--font-display);font-size:3.5rem;line-height:1;letter-spacing:.02em;color:#1a2332}.class-card .card-nickname{font-style:italic;color:#7a6e62;font-size:.9rem;margin-top:.2rem;margin-bottom:.75rem}.class-card .card-meta{font-size:.78rem;color:#7a6e62;margin-bottom:.75rem;flex:1}.class-card .card-badges{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:auto}.class-card-actions{position:absolute;top:.5rem;right:.5rem;display:none;gap:.3rem}.class-card:hover .class-card-actions{display:flex}.hero-banner{position:relative;width:100%;max-height:500px;min-height:280px;overflow:hidden;border-radius:var(--radius);margin-bottom:1rem;background:var(--sidebar-bg);display:flex;align-items:flex-end}.hero-banner-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.hero-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 55%,transparent 100%)}.hero-banner-content{position:relative;z-index:1;padding:1.25rem 1.5rem;color:#fff;width:100%}.hero-banner-class{font-family:var(--font-display);font-size:4.5rem;line-height:1;letter-spacing:.03em}.hero-banner-nickname{font-size:1.2rem;font-weight:300;opacity:.85}.hero-banner-subtitle{font-size:.85rem;opacity:.7;margin-top:.25rem}.hero-banner-actions{position:absolute;top:.75rem;right:1rem;z-index:2;display:flex;gap:.5rem;align-items:center}.hero-banner-photo-credit{position:absolute;bottom:.4rem;right:.75rem;z-index:2;font-size:.7rem;color:#fff9}.progress-bar-wrap{background:var(--border);border-radius:99px;height:6px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#4ecda4);border-radius:99px;transition:width .5s ease}.stat-hero{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);text-align:center}.stat-hero .stat-hero-value{font-family:var(--font-display);font-size:3.5rem;line-height:1;color:var(--accent);letter-spacing:.02em}.stat-hero .stat-hero-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:.3rem;font-weight:600}tr.spotted td{opacity:.45;background:transparent!important}tr.spotted:nth-child(2n) td{background:var(--row-stripe)!important}tr.spotted:hover td{opacity:.7;background:#ffffff0d!important}tr.spotted .spotted-cell{opacity:1}.spot-toggle{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:var(--surface);cursor:pointer;font-size:.8rem;color:transparent;transition:background .15s,border-color .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.spot-toggle:hover{border-color:var(--accent)}.spot-toggle-on{background:var(--accent);border-color:var(--accent);color:#fff}.spotted-cell{vertical-align:middle}.spot-expand-row>td{padding:0}.spot-expand-panel{display:flex;align-items:flex-start;gap:1rem;padding:.6rem 1rem .6rem 2.5rem;background:var(--surface);border-bottom:1px solid var(--border);font-size:.82rem}.spot-expand-records{display:flex;flex-direction:column;gap:.3rem;flex:1}.spot-expand-record{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .75rem}.ser-date{color:var(--text-muted);min-width:95px;flex-shrink:0}.ser-location{font-weight:500}.ser-headcode{font-family:Courier New,monospace;font-size:.78rem;background:var(--accent-subtle);color:var(--accent);padding:.1rem .4rem;border-radius:4px}.ser-route{color:var(--text-muted)}.ser-bashed{font-size:.7rem;font-weight:600;color:var(--accent);background:var(--accent-subtle);padding:.1rem .45rem;border-radius:999px}.news-list{display:flex;flex-direction:column;gap:0}.news-item{display:block;padding:1rem 0;border-bottom:1px solid var(--border);text-decoration:none;transition:background .1s}.news-item:last-child{border-bottom:none}.news-item:hover .news-item-headline{color:var(--accent)}.news-item-headline{font-size:1rem;font-weight:500;color:var(--text);line-height:1.45;margin-bottom:.35rem;transition:color .15s}.news-item-meta{display:flex;gap:.4rem;align-items:center;font-size:.78rem}.news-item-source{font-weight:600;color:var(--accent)}.news-item-dot,.news-item-time{color:var(--text-muted)}.news-item{display:flex;gap:1rem;align-items:flex-start}.news-item-thumb{width:100px;height:67px;object-fit:cover;border-radius:6px;flex-shrink:0;background:var(--border)}.news-item-body{flex:1;min-width:0}.maint-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.7rem .9rem;border-radius:8px;margin-bottom:1rem;border:1px solid transparent}.maint-upcoming{background:#d977061a;border-color:#d9770659;color:var(--text)}.maint-active{background:#dc26261f;border-color:#dc262673;color:var(--text)}.maint-banner-body{display:flex;gap:.6rem;align-items:flex-start}.maint-banner-icon{font-size:1.1rem;line-height:1.4;flex-shrink:0}.maint-banner-text strong{font-size:.92rem}.maint-banner-msg{font-size:.82rem;opacity:.9;margin-top:.15rem;line-height:1.45}.maint-banner-when{font-size:.75rem;opacity:.7;margin-top:.25rem;font-weight:600}.maint-banner-x{background:none;border:none;cursor:pointer;font-size:1.3rem;line-height:1;color:inherit;opacity:.55;padding:0 .2rem;flex-shrink:0}.maint-banner-x:hover{opacity:1}.maint-admin-form{display:flex;flex-direction:column;gap:.6rem;background:var(--surface, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:.5rem}.maint-admin-row label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:600}.maint-admin-row input[type=text],.maint-admin-row input:not([type]),.maint-admin-row textarea,.maint-admin-row input[type=datetime-local]{font:inherit;padding:.45rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--bg, transparent);color:var(--text);font-weight:400}.maint-admin-times{flex-direction:row;gap:1rem}.maint-admin-times label{flex:1}.maint-admin-actions{flex-direction:row;align-items:center;justify-content:space-between}.maint-admin-check{flex-direction:row!important;align-items:center;gap:.45rem;font-weight:500;cursor:pointer}.maint-admin-check input{width:auto}.maint-admin-msg{padding:.5rem .75rem;border-radius:6px;font-size:.82rem;margin-top:.5rem}.maint-admin-ok{background:#22c55e1f;border:1px solid rgba(34,197,94,.4)}.maint-admin-err{background:#dc26261f;border:1px solid rgba(220,38,38,.4)}.maint-status{font-size:.7rem;font-weight:700;text-transform:uppercase;padding:.1rem .45rem;border-radius:999px}.maint-status-upcoming{background:#d9770626;color:#d97706}.maint-status-active{background:#dc262626;color:#dc2626}.maint-status-past{background:#94a3b826;color:var(--text-muted)}.maint-status-cancelled{background:#94a3b81a;color:var(--text-muted);text-decoration:line-through}.fb-fab{position:fixed;left:calc(220px + 1.25rem);z-index:880;display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;border-radius:999px;background:var(--accent, #4ecda4);color:#07261c;border:none;font-size:.8rem;font-weight:700;cursor:pointer;box-shadow:0 3px 12px #00000040}.fb-fab:hover{filter:brightness(1.05)}.fb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000073;display:flex;align-items:center;justify-content:center;padding:1rem}.fb-modal{background:var(--bg, #0f172a);color:var(--text);border:1px solid var(--border);border-radius:12px;width:100%;max-width:420px;padding:1rem 1.1rem;box-shadow:0 10px 40px #00000080}.fb-modal-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem}.fb-modal-head strong{font-size:1rem}.fb-beta{font-size:.6rem;font-weight:800;letter-spacing:.06em;background:#4ecda426;color:var(--accent);border:1px solid rgba(78,205,164,.3);border-radius:999px;padding:.05rem .4rem}.fb-close{margin-left:auto;background:none;border:none;color:var(--text-muted);font-size:1.3rem;cursor:pointer;line-height:1}.fb-kinds{display:flex;gap:.5rem;margin-bottom:.7rem}.fb-kind{flex:1;padding:.45rem;border-radius:8px;cursor:pointer;background:transparent;color:var(--text);border:1px solid var(--border);font-size:.82rem;font-weight:600}.fb-kind-on{background:#4ecda41f;border-color:var(--accent);color:var(--accent)}.fb-text{width:100%;font:inherit;padding:.6rem;border-radius:8px;border:1px solid var(--border);background:var(--surface, transparent);color:var(--text);resize:vertical;box-sizing:border-box}.fb-err{color:var(--danger, #c0392b);font-size:.8rem;margin-top:.5rem}.fb-send{width:100%;margin-top:.7rem}.fb-sent{text-align:center;padding:1.5rem 0;font-weight:600}.fb-admin-list{display:flex;flex-direction:column;gap:.6rem}.fb-admin-item{border:1px solid var(--border);border-radius:8px;padding:.7rem .85rem}.fb-admin-done{opacity:.55}.fb-admin-top{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;font-size:.78rem;margin-bottom:.35rem}.fb-admin-kind{font-weight:700;text-transform:capitalize}.fb-admin-who{font-weight:600}.fb-admin-page{color:var(--accent);font-family:monospace;font-size:.72rem}.fb-admin-when{color:var(--text-muted)}.fb-admin-top .btn{margin-left:auto}.fb-admin-msg{font-size:.9rem;line-height:1.45;white-space:pre-wrap}
