.rec-screen{display:flex;flex-direction:column;gap:14px;padding:4px 2px 8px}.rec-screen-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.rec-h1{font-size:24px;font-weight:700;margin:0;color:var(--text)}.rec-sub{font-size:13px;color:var(--faint)}.rec-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px}.rec-stat{background:var(--panel-2);border-radius:14px;padding:14px}.rec-stat-v{font-size:22px;font-weight:700;color:var(--text);white-space:nowrap}.rec-stat-v small{font-size:13px;color:var(--faint);font-weight:400}.rec-stat-k{font-size:12px;color:var(--faint);margin-top:3px;text-transform:uppercase;letter-spacing:.03em}.rec-add-big{width:100%;background:var(--green-bright);border:none;border-radius:14px;color:#04210f;font-size:17px;font-weight:700;padding:16px;cursor:pointer}.rec-add-big:active{transform:scale(.99)}.rec-pending-banner{background:#2e2410;color:#ffc24d;font-size:14px;border-radius:12px;padding:12px 14px}.rec-empty{text-align:center;color:var(--faint);font-size:14px;line-height:1.6;padding:28px 16px}.rec-empty-ic{font-size:36px;margin-bottom:8px}.rec-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.rec-row{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}.rec-row.pending{border-color:#5a4a1f;background:#1c1810}.rec-row-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:none;border:none;padding:15px 16px;cursor:pointer;text-align:left;color:var(--text)}.rec-row-date{font-size:13px;color:var(--muted)}.rec-row-kwh{font-size:15px;color:var(--text);margin-top:3px}.rec-row-r{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:2px}.rec-row-val{font-size:17px;font-weight:700;color:var(--green-bright)}.rec-row-ep{font-size:12px;color:var(--faint)}.rec-row-add{font-size:15px;font-weight:600;color:#ffc24d}.rec-modal-back{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0000008c;display:flex;align-items:flex-end;justify-content:center}.rec-modal{width:100%;max-width:560px;max-height:92vh;overflow-y:auto;background:var(--bg);border:1px solid var(--line-strong);border-radius:22px 22px 0 0;padding:8px 18px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column}.rec-modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 2px 16px;position:sticky;top:0;background:var(--bg)}.rec-modal-head h2{font-size:20px;font-weight:700;margin:0;color:var(--text)}.rec-modal-x{background:var(--panel-2);border:none;color:var(--muted);width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;flex-shrink:0}.rec-modal-body{display:flex;flex-direction:column;gap:20px;padding:4px 0 8px}.rec-field{display:flex;flex-direction:column;gap:8px}.rec-flabel{font-size:15px;color:var(--text);font-weight:600}.rec-inp{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:14px;padding:0 16px}.rec-inp:focus-within{border-color:var(--green-bright)}.rec-inp em{font-size:18px;color:var(--faint);font-style:normal;flex-shrink:0}.rec-input{flex:1;min-width:0;background:none;border:none;outline:none;color:var(--text);font-size:26px;font-weight:700;font-family:inherit;padding:16px 0;width:100%}.rec-input[readonly]{color:var(--muted)}.rec-fhint{font-size:12px;color:var(--faint)}.rec-modal-foot{display:flex;gap:10px;padding-top:18px;position:sticky;bottom:0;background:var(--bg)}.rec-btn-ghost{flex:0 0 38%;background:var(--panel-2);border:none;border-radius:14px;color:var(--muted);font-size:16px;padding:16px;cursor:pointer}.rec-btn-save{flex:1;background:var(--green-bright);border:none;border-radius:14px;color:#04210f;font-size:17px;font-weight:700;padding:16px;cursor:pointer}.rec-btn-save:disabled{opacity:.45}.rec-cost{background:linear-gradient(135deg,#10241c,#13211a);border:1px solid #1bb673;border-radius:16px;padding:16px}.rec-cost.hint{background:var(--panel-2);border-color:var(--line)}.rec-cost-main{font-size:30px;font-weight:700;color:var(--green-bright)}.rec-cost-main small{font-size:15px;color:var(--faint);font-weight:400}.rec-cost-sub{font-size:12.5px;color:var(--muted);margin-top:4px;line-height:1.4}nav.tabbar{grid-auto-flow:column;grid-auto-columns:1fr}.vital-btn{background:none;border:none;cursor:pointer;font:inherit;color:inherit;padding:0}.vital-btn .vital-k{color:var(--green-bright)}.bat-back{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0000008c;display:flex;align-items:flex-end;justify-content:center}.bat-modal{width:100%;max-width:560px;max-height:92vh;overflow-y:auto;background:var(--bg);border:1px solid var(--line-strong);border-radius:22px 22px 0 0;padding:8px 18px calc(22px + env(safe-area-inset-bottom))}.bat-head{display:flex;align-items:center;justify-content:space-between;padding:12px 2px;position:sticky;top:0;background:var(--bg)}.bat-head h2{font-size:20px;font-weight:700;margin:0;color:var(--text)}.bat-x{background:var(--panel-2);border:none;color:var(--muted);width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;flex-shrink:0}.bat-empty{color:var(--faint);font-size:14px;padding:24px 4px;text-align:center}.bat-hero{text-align:center;padding:8px 0 12px}.bat-main{font-size:46px;font-weight:700;color:var(--green-bright);line-height:1}.bat-main-k{font-size:12px;color:var(--faint);margin-top:5px;text-transform:uppercase;letter-spacing:.04em}.bat-verdict{background:#10241c;border:1px solid #1bb673;border-radius:12px;padding:13px 14px;font-size:14px;color:var(--text);line-height:1.5;margin-bottom:14px}.bat-verdict.pend{background:var(--panel-2);border-color:var(--line);color:var(--muted)}.bat-rows{display:flex;flex-direction:column}.bat-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 2px;border-bottom:1px solid var(--line);font-size:14px}.bat-row span{color:var(--muted)}.bat-row b{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums}.bat-foot{font-size:11px;color:var(--faint);text-align:center;margin-top:14px;line-height:1.4}.dir-screen{display:flex;flex-direction:column;gap:14px;padding:4px 2px 8px}.dir-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.dir-h1{font-size:24px;font-weight:700;margin:0;color:var(--text)}.dir-sub{font-size:13px;color:var(--faint)}.dir-block{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px}.dir-block-h{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px}.spd-hero{text-align:center;padding:6px 0 12px}.spd-max{font-size:40px;font-weight:700;color:var(--text);line-height:1}.spd-max small{font-size:16px;color:var(--faint);font-weight:400}.spd-max-k{font-size:12px;color:var(--faint);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.spd-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}.spd-stat{background:var(--panel-2);border-radius:12px;padding:11px 8px;text-align:center}.spd-stat-v{font-size:19px;font-weight:700;color:var(--text);white-space:nowrap}.spd-stat-v.warn{color:#ffc24d}.spd-stat-v small{font-size:12px;color:var(--faint);font-weight:400}.spd-stat-k{font-size:11px;color:var(--faint);margin-top:3px}.spd-chart{position:relative;display:flex;align-items:flex-end;gap:2px;height:92px;padding:4px 0;margin-bottom:14px}.spd-bar-wrap{flex:1;height:100%;display:flex;align-items:flex-end;min-width:2px}.spd-bar{width:100%;background:var(--green-bright);border-radius:2px 2px 0 0}.spd-bar.over{background:#ff6b6b}.spd-limit-line{position:absolute;left:0;right:0;border-top:1px dashed #6a5424;pointer-events:none}.spd-limit-line span{position:absolute;right:0;top:-8px;font-size:9px;color:#ffc24d;background:var(--panel);padding:0 3px}.spd-events{background:var(--panel-2);border-radius:12px;padding:10px 12px}.spd-events-h{font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px}.spd-events ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px;max-height:230px;overflow-y:auto}.spd-events li{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:14px}.spd-ev-t{color:var(--muted)}.spd-ev-v{color:#ff6b6b;font-weight:700}.spd-ok{font-size:14px;color:var(--green-bright);padding:4px 0 8px}.cop-card{padding:14px;cursor:pointer}.cop-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cop-title{font-size:15px;font-weight:700;color:var(--text)}.cop-more{font-size:13px;color:var(--teal);font-weight:600}.cop-loading,.cop-empty{font-size:14px;color:var(--faint);line-height:1.5}.cop-tip{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--text);line-height:1.5}.cop-tip-ic{flex-shrink:0}.cop-tip-lead{font-size:15px}.cop-more-n{font-size:12px;color:var(--faint);margin-top:8px;padding-left:26px}.cop-modal-back{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0000008c;display:flex;align-items:flex-end;justify-content:center}.cop-modal{width:100%;max-width:560px;max-height:92vh;overflow-y:auto;background:var(--bg);border:1px solid var(--line-strong);border-radius:22px 22px 0 0;padding:8px 18px calc(22px + env(safe-area-inset-bottom))}.cop-modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 2px 14px;position:sticky;top:0;background:var(--bg)}.cop-modal-head h2{font-size:20px;font-weight:700;margin:0;color:var(--text)}.cop-x{background:var(--panel-2);border:none;color:var(--muted);width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;flex-shrink:0}.cop-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.cop-stat{background:var(--panel-2);border-radius:12px;padding:12px}.cop-stat-v{font-size:20px;font-weight:700;color:var(--text);white-space:nowrap}.cop-stat-v small{font-size:12px;color:var(--faint);font-weight:400}.cop-stat-k{font-size:11px;color:var(--faint);margin-top:3px}.cop-tips{display:flex;flex-direction:column;gap:14px}.cop-modal .cop-tip{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 14px;font-size:15px}.cop-foot{font-size:11px;color:var(--faint);text-align:center;margin-top:18px;line-height:1.4}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-cyrillic-ext-wght-normal-DjL33-gN.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-cyrillic-wght-normal-BEAKL7Jp.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-vietnamese-wght-normal-6IgcOCM7.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-ext-wght-normal-DC-KSUi6.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-wght-normal-BgDaEnEv.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-cyrillic-ext-wght-normal-I4S5GZfc.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-cyrillic-wght-normal-BmXc_FBt.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-symbols2-wght-normal-GZpp1pK2.woff2) format("woff2-variations");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-vietnamese-wght-normal-D8KDMBhC.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-latin-ext-wght-normal-DrnZ1wKl.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-mono-latin-wght-normal-B_7UjwxQ.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #090d16;--panel: #121a2a;--panel-2: #19233a;--line: #24314c;--line-strong: #364868;--text: #eef2fb;--muted: #8893ad;--faint: #586480;--teal: #4f86ff;--teal-dim: #335fd6;--orange: #f3ab43;--green: #1bb673;--green-bright: #2bd684;--shadow-sm: 0 2px 8px -2px rgba(2, 6, 20, .6);--shadow-md: 0 14px 34px -10px rgba(2, 8, 26, .7);--glow: 0 0 20px -3px rgba(79, 134, 255, .55);--r-sm: 10px;--r-md: 14px;--r-lg: 18px;--ease: cubic-bezier(.2, .8, .2, 1);--z-map: 1;--z-overlay: 500;--z-camera: 600;--z-toast: 1000;--font: "Geist Variable", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono: "Geist Mono Variable", ui-monospace, "SF Mono", Menlo, monospace;font-family:var(--font);font-synthesis:none;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{background:var(--bg);color:var(--text);overscroll-behavior:none}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}button{font-family:inherit}.app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative}.app:before{content:"";position:absolute;top:-120px;left:50%;transform:translate(-50%);width:380px;height:280px;pointer-events:none;z-index:0;background:radial-gradient(circle,rgba(52,227,166,.1),transparent 70%)}.header{display:flex;align-items:center;gap:12px;padding:15px 16px;position:sticky;top:0;z-index:700;background:#121a2ae6;backdrop-filter:blur(14px) saturate(1.3);border-bottom:1px solid var(--line)}.header .menu{font-size:22px;color:var(--muted)}.logo-dots{display:grid;grid-template-columns:1fr 1fr;gap:3px}.logo-dots span{width:7px;height:7px;border-radius:2px;background:var(--teal)}.brandmark{display:inline-grid;place-items:center;flex-shrink:0;width:32px;height:32px;border-radius:9px;background:linear-gradient(140deg,var(--teal),var(--teal-dim));color:#fff;font-weight:800;font-size:13px;letter-spacing:-.5px;box-shadow:var(--glow),inset 0 1px #ffffff40}.brandmark.big{width:66px;height:66px;border-radius:19px;font-size:27px}.header .title{flex:1}.header .title h1{font-size:16px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:6px}.header .title .chev{color:var(--faint);font-size:12px}.header .title .ver{font-size:11px;color:var(--faint);font-family:var(--mono);letter-spacing:.02em}.status-dot{width:10px;height:10px;border-radius:50%;background:var(--teal);box-shadow:var(--glow);animation:pulse 2.4s var(--ease) infinite}@keyframes pulse{0%,to{box-shadow:0 0 #34e3a673}50%{box-shadow:0 0 0 5px #34e3a600}}.status-dot.off{background:#555;box-shadow:none}.stage{position:relative;height:360px;background:#0e1413;overflow:hidden}.map{position:absolute;top:0;right:0;bottom:0;left:0;background:#0c100f}.leaflet-map{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:#0c100f}.leaflet-container{background:#0c100f!important;font:inherit}.car-marker .car-dot{width:26px;height:26px;border-radius:50%;background:#eef2f1;color:#0b0f0e;display:grid;place-items:center;font-size:12px;box-shadow:0 0 0 6px #eef2f133,0 4px 12px #0008}.map .road{position:absolute;background:#222a2c}.map .car-pin{position:absolute;left:50%;top:62%;transform:translate(-50%,-50%);width:26px;height:26px;border-radius:50%;background:#eef2f1;display:grid;place-items:center;box-shadow:0 0 0 6px #eef2f133,0 4px 12px #0008;font-size:13px;color:#0b0f0e}.map .wifi-chip{position:absolute;right:12px;bottom:12px;z-index:500;display:flex;align-items:center;gap:6px;background:#0c1110cc;border:1px solid var(--line);border-radius:999px;padding:7px 12px;font-size:12px;color:var(--teal);backdrop-filter:blur(4px)}.fab{position:absolute;right:12px;z-index:500;width:44px;height:44px;border-radius:50%;background:var(--teal);color:#052017;border:none;display:grid;place-items:center;font-size:18px;box-shadow:0 4px 14px #0009}.fab.locate{bottom:56px}.fab.people{right:14px;bottom:110px;background:#2a3236;color:var(--text)}.camera{position:absolute;left:50%;top:16px;transform:translate(-50%);z-index:600;width:300px;height:200px;border-radius:14px;overflow:hidden;border:1px solid #000;box-shadow:0 10px 30px #000a;background:#05201b}.camera .feed{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 90% at 50% 55%,#6f7d72,#3c4a44 45%,#11201a)}.camera .feed:after{content:"CÂMERA " attr(data-cam);position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);color:#eafff5;font-size:12px;letter-spacing:2px;opacity:.65}.camera .feed .fish{position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:50%;box-shadow:inset 0 0 60px #0009;border:2px solid #0006}.camera .close{position:absolute;right:8px;top:8px;width:26px;height:26px;border-radius:50%;background:#0008;color:#fff;border:none;font-size:14px}.camera .cam-ctrls{position:absolute;right:8px;top:42px;display:flex;flex-direction:column;gap:7px}.camera .cam-ctrls button{width:30px;height:30px;border-radius:50%;border:none;background:#0c1110cc;color:var(--teal);font-size:14px;display:grid;place-items:center}.camera .cam-ctrls button.active{background:var(--teal);color:#052017}.camera .feed-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;background:#05201b}.camera .cam-demo{position:absolute;left:50%;top:58%;transform:translate(-50%);background:var(--teal);color:#052017;border:none;border-radius:999px;padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 4px 14px #0009}.camera .cam-connecting{position:absolute;left:50%;top:60%;transform:translate(-50%);color:#cfe;font-size:12px;opacity:.8}.camera .badges .livecam{background:#0009;color:var(--teal);font-weight:700}.camera .badges{position:absolute;right:8px;bottom:8px;display:flex;gap:6px}.camera .badges span{background:#0009;color:#cfe;font-size:10px;padding:3px 6px;border-radius:5px}.app>*{position:relative;z-index:1}.app>.header{position:sticky;top:0;z-index:700}.cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;position:relative;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),border-color .25s var(--ease)}.card:hover{transform:translateY(-2px);border-color:var(--line-strong)}.card .label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}.card .big{font-family:var(--mono);font-size:33px;font-weight:600;line-height:1.05;margin-top:6px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.card .big small{font-family:var(--font);font-size:14px;font-weight:500;color:var(--muted);letter-spacing:0}.card .rows{margin-top:14px;display:grid;gap:6px}.card .row{display:flex;justify-content:space-between;align-items:baseline;font-size:13px}.card .row .k{color:var(--faint);text-transform:uppercase;font-size:10px;letter-spacing:.5px}.card .row .v{color:var(--text);font-weight:500;font-family:var(--mono);font-size:12.5px;font-variant-numeric:tabular-nums}.card .corner{position:absolute;top:14px;right:14px;color:var(--muted)}.card .corner.icon{width:26px;height:26px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;font-size:13px}.card.teal .label{color:var(--teal)}.card.teal .big{color:var(--text)}.card.orange .label{color:var(--orange)}.card.charging{background:linear-gradient(135deg,var(--green) 0%,var(--green-bright) 100%);border:none;color:#042}.card.charging .label{color:#eafff2}.card.charging .big{color:#fff;display:flex;align-items:center;gap:8px}.card.charging .sub{margin-top:8px;font-size:12px;color:#eafff2cc}.link-pill{font-size:10px;font-weight:800;letter-spacing:.8px;padding:3px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}.link-pill.live{color:#052017;background:var(--teal);border-color:var(--teal)}.link-pill.sim{color:var(--orange);border-color:#5a4322}.controls{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px 12px 0}.ctrl{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:14px;color:var(--text);font-size:12px;font-weight:600;padding:14px 8px;cursor:pointer;transition:transform .08s ease,border-color .2s ease,background .2s ease}.ctrl:active{transform:scale(.96)}.ctrl .ico{font-size:20px}.ctrl.on{border-color:var(--teal);background:#11201a;color:var(--teal)}.climate-panel{display:flex;flex-direction:column;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px}.cp-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.cp-label{font-size:13px;font-weight:600;color:var(--text)}.cp-stepper{display:flex;align-items:center;gap:12px}.cp-btn{width:38px;height:38px;border-radius:var(--r-sm);font-size:22px;line-height:1;background:var(--panel-2);border:1px solid var(--line);color:var(--text);cursor:pointer;transition:transform .14s var(--ease),border-color .2s var(--ease),background .2s var(--ease)}.cp-btn:hover{border-color:var(--line-strong)}.cp-btn:active{transform:scale(.92)}.cp-val{min-width:48px;text-align:center;font-size:17px;font-weight:700;color:var(--teal)}.cp-fan{display:flex;gap:6px}.cp-seg{width:30px;height:36px;border-radius:9px;font-size:13px;font-weight:700;background:var(--panel-2);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:transform .14s var(--ease),border-color .2s var(--ease),background .2s var(--ease),color .2s var(--ease)}.cp-seg:hover{border-color:var(--line-strong)}.cp-seg:active{transform:scale(.9)}.cp-seg.on{border-color:var(--teal);background:#11201a;color:var(--teal)}.toast{position:fixed;left:50%;bottom:22px;transform:translate(-50%);background:#11171a;border:1px solid var(--teal-dim);color:var(--text);padding:10px 18px;border-radius:999px;font-size:13px;font-weight:600;box-shadow:0 8px 24px #000a;z-index:50;animation:rise .25s ease}@keyframes rise{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.footer-note{text-align:center;color:var(--muted);font-size:11px;padding:12px 16px 24px}.sentry-bar{display:flex;align-items:center;justify-content:space-between;margin:12px;padding:14px 16px;border-radius:16px;background:var(--panel);border:1px solid var(--line);transition:border-color .2s,background .2s}.sentry-bar.on{border-color:var(--teal);background:#11201a}.sentry-info{display:flex;align-items:center;gap:12px}.sentry-ico{font-size:24px;filter:grayscale(1) opacity(.6)}.sentry-bar.on .sentry-ico{filter:none}.sentry-title{font-size:14px;font-weight:700}.sentry-sub{font-size:12px;color:var(--muted)}.sentry-toggle{background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:999px;padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer}.sentry-toggle.on{background:var(--teal);color:#052017;border-color:var(--teal)}.section{margin:8px 12px}.section h3{font-size:14px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}.section h3 .count{background:var(--panel-2);color:var(--muted);font-size:11px;padding:2px 8px;border-radius:999px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-head h3{margin:0}.rec-btn{background:#2a1416;border:1px solid #5a2327;color:#ff6b6b;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer}.empty{color:var(--muted);font-size:12px;padding:14px;text-align:center;background:var(--panel);border:1px dashed var(--line);border-radius:12px}.clips-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.clip-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}.clip-thumb{position:relative;aspect-ratio:16/10}.clip-thumb .clip-fish{position:absolute;top:18%;right:28%;bottom:18%;left:28%;border-radius:50%;box-shadow:inset 0 0 30px #0008}.clip-cam{position:absolute;left:8px;top:7px;font-size:10px;font-weight:700;color:#eafff5;text-transform:uppercase;letter-spacing:.5px;opacity:.85}.clip-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:32px;height:32px;border-radius:50%;background:#000a;color:#fff;display:grid;place-items:center;font-size:13px}.clip-dur{position:absolute;right:7px;bottom:7px;font-size:10px;color:#cfe;background:#0009;padding:2px 6px;border-radius:5px}.clip-badge{position:absolute;right:7px;top:7px;font-size:12px}.clip-meta{padding:8px 10px;display:flex;flex-direction:column;gap:2px}.clip-reason{font-size:12px;font-weight:600}.clip-time{font-size:11px;color:var(--muted)}.timeline{display:flex;flex-direction:column}.tl-item{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line)}.tl-item:last-child{border-bottom:none}.tl-ico{width:26px;text-align:center}.tl-msg{flex:1;font-size:13px}.tl-time{font-size:11px;color:var(--muted)}.header .menu{background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:0;line-height:1}.pairing,.car-screen{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 24px;gap:12px}.car-brand{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:14px}.logo-dots.big span{width:11px;height:11px}.pairing h2,.car-screen h2{font-size:22px;font-weight:700}.pairing p,.car-screen p{color:var(--muted);font-size:14px;max-width:320px;line-height:1.5}.qr-box{background:#fff;border-radius:16px;padding:14px;margin:10px 0;box-shadow:0 10px 30px #0008}.qr-box img{display:block;width:240px;height:240px}.qr-load{width:240px;height:240px;display:grid;place-items:center;color:#555}.pair-code{font-size:38px;font-weight:800;letter-spacing:10px;color:var(--teal);padding-left:10px}.code-input{width:220px;text-align:center;font-size:30px;font-weight:800;letter-spacing:10px;background:var(--panel);border:1px solid var(--line);border-radius:14px;color:var(--text);padding:14px;margin:6px 0;outline:none}.code-input:focus{border-color:var(--teal)}.btn-primary{width:240px;background:var(--teal);color:#052017;border:none;border-radius:12px;padding:14px;font-size:15px;font-weight:800;cursor:pointer}.btn-primary:disabled{opacity:.5}.btn-ghost{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:8px;text-decoration:underline}.pair-err,.car-err{color:#ff6b6b;font-size:13px}.car-paired{display:flex;flex-direction:column;align-items:center;gap:8px}.car-paired .check{width:84px;height:84px;border-radius:50%;background:var(--teal);color:#052017;display:grid;place-items:center;font-size:44px;font-weight:700;box-shadow:var(--glow);animation:pop .4s var(--ease)}@keyframes pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.ctrl,.fab,.sentry-toggle,.btn-primary,.btn-ghost,.rec-btn,.clip-card,.cam-ctrls button,.cam-demo,.menu,.corner.icon,.camera .close{transition:transform .18s var(--ease),background .2s var(--ease),border-color .2s var(--ease),box-shadow .2s var(--ease)}.ctrl:hover{border-color:var(--line-strong);background:var(--panel-2)}.fab{box-shadow:var(--shadow-md)}.fab:hover{transform:scale(1.06)}.fab:active{transform:scale(.94)}.fab.locate:hover{box-shadow:var(--glow),var(--shadow-md)}.sentry-toggle:hover{border-color:var(--line-strong)}.sentry-toggle:active,.btn-primary:active,.rec-btn:active{transform:scale(.96)}.btn-primary:hover:not(:disabled){box-shadow:var(--glow)}.clip-card{cursor:pointer}.clip-card:hover{transform:translateY(-2px);border-color:var(--line-strong);box-shadow:var(--shadow-sm)}.clip-card:hover .clip-play{background:var(--teal);color:#052017}.menu:hover{color:var(--text)}.pair-code,.code-input,.clip-dur,.tl-time,.clip-time,.wifi-chip{font-family:var(--mono);font-variant-numeric:tabular-nums}.pair-code{letter-spacing:8px}.wifi-chip{background:#0c1110cc;backdrop-filter:blur(10px) saturate(1.4);box-shadow:inset 0 1px #ffffff0d}.camera{box-shadow:var(--shadow-md),inset 0 1px #ffffff0f;border:1px solid rgba(255,255,255,.07)}.camera .cam-ctrls button{background:#0c1110bf;backdrop-filter:blur(8px)}.camera .close:hover{background:#000c}.sentry-bar,.section,.cards{animation:rise-in .5s var(--ease) both}.section:nth-of-type(odd){animation-delay:.04s}@keyframes rise-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.section h3{letter-spacing:-.01em}.clip-reason,.tl-msg,.sentry-title{letter-spacing:-.005em}.card.charging{box-shadow:0 8px 28px -10px #25bd6880}.card.charging .big{font-family:var(--mono)}.footer-note{color:var(--faint);letter-spacing:.01em}.text-input{width:280px;max-width:80vw;text-align:center;font-size:16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);color:var(--text);padding:14px 16px;margin:6px 0;outline:none;transition:border-color .2s var(--ease)}.text-input:focus{border-color:var(--teal)}.skeleton-msg{color:var(--muted);font-size:14px;margin-top:20px}.title-btn{background:none;border:none;text-align:left;cursor:pointer;padding:0;color:inherit;flex:1}.title-btn:hover .chev{color:var(--teal)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-toast);background:#0006048c;backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;animation:fade-in .2s var(--ease)}.sheet{width:100%;max-width:480px;background:var(--panel);border:1px solid var(--line);border-bottom:none;border-radius:var(--r-lg) var(--r-lg) 0 0;padding:12px 14px 22px;box-shadow:var(--shadow-md);animation:sheet-up .28s var(--ease)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-grip{width:38px;height:4px;border-radius:2px;background:var(--line-strong);margin:2px auto 14px}.sheet-title{font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);padding:0 6px 8px}.veh-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:1px solid transparent;border-radius:var(--r-md);padding:13px 12px;color:var(--text);font-size:15px;font-weight:500;cursor:pointer;transition:background .15s var(--ease)}.veh-row:hover{background:var(--panel-2)}.veh-row.active{background:#11201a;border-color:var(--teal-dim)}.veh-ico{font-size:18px}.veh-name{flex:1}.veh-check{color:var(--teal);font-weight:700}.veh-add{width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);color:var(--teal);padding:13px;font-size:14px;font-weight:600;cursor:pointer;margin-top:10px;transition:border-color .2s var(--ease)}.veh-add:hover{border-color:var(--teal-dim)}.veh-logout{width:100%;background:none;border:none;color:var(--faint);padding:14px;font-size:13px;cursor:pointer;margin-top:2px}.veh-logout:hover{color:#ff6b6b}.dash{padding:16px 14px 0;display:flex;flex-direction:column;gap:14px}.dash .controls{padding:0}.dash .sentry-bar,.dash .section{margin:0}.shell{background:linear-gradient(180deg,rgba(255,255,255,.025),transparent),var(--panel);border:1px solid var(--line);border-radius:24px;padding:6px;box-shadow:var(--shadow-md)}.hero-core,.cam-core,.map-core{border-radius:18px;background:var(--bg);overflow:hidden;box-shadow:inset 0 1px #ffffff0f}.hero-core{display:flex;align-items:center;gap:10px;padding:18px;background:radial-gradient(130% 120% at 0% 0%,rgba(79,134,255,.12),transparent 55%),var(--bg)}.ring{width:134px;height:134px;flex-shrink:0}.ring-track{fill:none;stroke:var(--line);stroke-width:9}.ring-fill{fill:none;stroke:var(--teal);stroke-width:9;stroke-linecap:round;transform:rotate(-90deg);transform-origin:60px 60px;transition:stroke-dashoffset .9s var(--ease);filter:drop-shadow(0 0 5px rgba(79,134,255,.55))}.ring.charging .ring-fill{stroke:var(--green-bright);filter:drop-shadow(0 0 5px rgba(43,214,132,.55))}.ring-pct{fill:var(--text);font-family:var(--mono);font-size:29px;font-weight:600;text-anchor:middle}.ring-unit{font-size:13px;fill:var(--muted)}.ring-lbl{fill:var(--faint);font-size:8px;letter-spacing:2px;text-anchor:middle}.hero-side{flex:1;display:flex;flex-direction:column;gap:16px;padding-left:4px}.hs-v{font-size:29px;font-weight:600;letter-spacing:-.02em;line-height:1}.hs-v small{font-size:13px;font-weight:500;color:var(--muted);font-family:var(--font)}.hs-k{font-size:11px;color:var(--faint);margin-top:5px}.hero-charge{font-family:var(--mono);font-size:23px;font-weight:600;color:var(--green-bright);display:flex;align-items:center;gap:8px}.hero-charge .bolt{filter:drop-shadow(0 0 6px rgba(43,214,132,.6))}.vitals{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:1px}.vitals::-webkit-scrollbar{display:none}.vital{flex:1 0 auto;min-width:70px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:11px 13px}.vital-v{font-size:18px;font-weight:600;letter-spacing:-.01em}.vital-k{font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:.6px;margin-top:3px}.cam-core{aspect-ratio:16 / 10;position:relative;background:#06121f}.cam-core .feed-video{width:100%;height:100%;object-fit:cover}.cam-core .feed{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 90% at 50% 55%,#38506e,#182840 45%,#0a1420)}.cam-core .feed:after{content:"CÂMERA " attr(data-cam);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:#cfe0ff;font-size:11px;letter-spacing:2px;opacity:.5}.cam-core .fish{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border-radius:50%;box-shadow:inset 0 0 50px #0009}.cam-core .cam-demo{position:absolute;left:50%;top:58%;transform:translate(-50%);background:var(--teal);color:#fff;border:none;border-radius:999px;padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;box-shadow:var(--glow)}.cam-core .cam-connecting{position:absolute;left:50%;top:60%;transform:translate(-50%);color:#cfe0ff;font-size:12px}.cam-core .livecam{position:absolute;left:12px;top:11px;background:#000a;color:var(--teal);font-size:10px;font-weight:800;letter-spacing:.5px;padding:4px 9px;border-radius:999px;backdrop-filter:blur(6px)}.seg{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;padding:6px}.seg button{background:transparent;border:none;color:var(--muted);font-size:12px;font-weight:600;padding:9px 4px;border-radius:12px;cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease)}.seg button.on{background:var(--teal);color:#fff;box-shadow:var(--glow)}.seg button:not(.on):active{transform:scale(.96)}.map-core{height:190px;position:relative}.map-core .leaflet-map{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.map-core .wifi-chip{position:absolute;right:10px;bottom:10px;z-index:5}.admin{max-width:680px;margin:0 auto;padding:18px 14px 40px;display:flex;flex-direction:column;gap:14px}.admin-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-head h2{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0}.btn-primary.sm,.btn-ghost.sm{padding:7px 14px;font-size:13px;border-radius:999px;width:auto}.veh-admin{width:100%;margin-top:6px;padding:12px;border-radius:14px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-weight:600;font-size:14px;cursor:pointer}.veh-admin:hover{background:var(--panel-2)}.admin-form-core{display:flex;flex-direction:column;gap:10px;padding:16px}.admin-form-core .text-input{margin:0}.user-list{display:flex;flex-direction:column;gap:10px}.user-card-core{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px}.user-main{min-width:0}.user-name{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.badge-admin{font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:var(--teal);padding:2px 7px;border-radius:999px}.user-email{font-size:12px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis}.user-cars{font-size:12px;color:var(--faint);margin-top:4px}.user-actions{display:flex;gap:6px;flex-shrink:0}.btn-ghost.sm.danger{color:#ff6b6b;border-color:#ff6b6b4d}.btn-ghost.sm.danger:hover{background:#ff6b6b1a}.user-reset{display:flex;gap:8px;align-items:center;padding:0 16px 14px}.user-reset .text-input{margin:0;flex:1}.admin-ok{color:var(--teal);font-size:13px;text-align:center}.admin-count{font-size:11px;color:var(--faint);text-align:center;padding-top:4px}.senha-out{margin-top:4px;width:100%;max-width:320px;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;text-align:center;box-shadow:var(--glow)}.senha-lbl{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.6px}.senha-val{font-family:var(--mono);font-size:34px;font-weight:700;letter-spacing:.04em;color:var(--teal);margin:6px 0 12px}.senha-hint{font-size:12px;color:var(--muted);max-width:340px;line-height:1.5}.login-link{background:none;border:none;color:var(--teal);font-size:13px;cursor:pointer;text-decoration:underline;margin-top:4px}.header-right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.header-right-row{display:flex;align-items:center;gap:8px}.last-update{font-size:10px;color:var(--faint);font-family:var(--mono);font-variant-numeric:tabular-nums;white-space:nowrap}.last-update.stale{color:var(--orange)}.route-fab{position:absolute;left:12px;bottom:12px;z-index:500;display:flex;align-items:center;gap:6px;background:#3f6fd9;color:#fff;border:none;border-radius:999px;padding:9px 14px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--glow),var(--shadow-sm)}.route-fab:active{transform:scale(.97)}.rm-radar .rm-radar-dot{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;background:#2a1c05;border:1px solid #f3ab43;font-size:12px;box-shadow:0 2px 8px #0009}.map-style{position:absolute;left:12px;top:12px;z-index:500;display:flex;gap:4px;background:#0b1120dd;border:1px solid var(--line);border-radius:999px;padding:3px}.map-style .ms{background:transparent;border:none;color:#8893ad;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer}.map-style .ms.on{background:var(--teal);color:#fff}.radar-chip{position:absolute;left:12px;top:56px;z-index:500;display:flex;align-items:center;gap:6px;background:#2a1c05ee;border:1px solid #f3ab43;color:#f3ab43;border-radius:999px;padding:6px 13px;font-size:13px;font-weight:600;box-shadow:var(--shadow-sm);animation:radarpulse 1s ease infinite}@keyframes radarpulse{0%,to{opacity:1}50%{opacity:.6}}.reroute-chip{position:absolute;left:50%;top:12px;transform:translate(-50%);z-index:550;background:#0b1120ee;border:1px solid var(--teal);color:var(--teal);border-radius:999px;padding:7px 15px;font-size:13px;font-weight:600;white-space:nowrap;backdrop-filter:blur(6px);box-shadow:var(--shadow-sm)}.reroute-chip.off{border-color:#6a5424;color:#ffc24d}.nav-stop-float{position:absolute;left:12px;bottom:14px;z-index:600;background:#1a0c10ee;border:1px solid #6a2436;color:#ff9bb0;border-radius:999px;padding:10px 18px;font-size:15px;font-weight:600;cursor:pointer;backdrop-filter:blur(6px);box-shadow:var(--shadow-sm)}.nav-stop-float:active{transform:scale(.97)}.rm-recenter{position:absolute;right:12px;bottom:12px;z-index:500;background:#0b1120ee;border:1px solid var(--teal);color:var(--teal);border-radius:999px;padding:9px 15px;font-size:13px;font-weight:600;cursor:pointer;backdrop-filter:blur(6px)}.rm-recenter.active{background:var(--teal);color:#04181a;box-shadow:var(--glow)}.speed-badge{position:absolute;right:12px;top:12px;z-index:500;width:60px;height:60px;border-radius:50%;background:#0b1120;border:3px solid #eef2fb;color:#eef2fb;display:grid;place-items:center;font-family:var(--mono);font-size:21px;font-weight:700;line-height:1}.speed-badge small{font-size:9px;font-weight:500;color:#8893ad}.speed-badge.over{border-color:#ff3b5c;color:#ff6b87;animation:radarpulse 1s ease infinite}.map-tools{position:absolute;left:12px;bottom:12px;z-index:500;display:flex;gap:8px}.map-tools .mt{min-width:42px;height:42px;border-radius:10px;background:#0b1120ee;border:1px solid var(--line);color:#586480;font-size:17px;cursor:pointer;display:grid;place-items:center}.map-tools .mt.on{color:#eef2fb;border-color:var(--line-strong)}.map-tools .mt.add{color:#f3ab43;border-color:#f3ab43;padding:0 12px;font-size:14px;font-weight:600}.radar-added{position:absolute;left:50%;bottom:64px;transform:translate(-50%);z-index:500;background:#10241c;border:1px solid #1bb673;color:#2bd684;border-radius:999px;padding:6px 14px;font-size:12px}.route-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;max-width:480px;margin:0 auto;background:var(--bg);display:flex;flex-direction:column;overflow-y:auto}.route-head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel);z-index:2}.route-back{background:none;border:none;color:var(--text);font-size:22px;cursor:pointer;line-height:1}.route-title{font-size:16px;font-weight:600;display:flex;flex-direction:column}.route-title small{font-size:11px;color:var(--faint);font-family:var(--mono)}.route-map-wrap{position:relative;height:300px;flex-shrink:0}.route-map{position:absolute;top:0;right:0;bottom:0;left:0}.route-hint{position:absolute;left:50%;bottom:14px;transform:translate(-50%);z-index:500;background:#0c1110cc;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:12px;color:var(--muted);backdrop-filter:blur(4px);white-space:nowrap}.rm-dot{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:12px;box-shadow:0 4px 12px #0008}.rm-origin .rm-dot{background:#2f6bed;color:#fff;border:3px solid #fff;animation:origpulse 2s ease-out infinite}@keyframes origpulse{0%,to{box-shadow:0 0 0 4px #2f6bed80,0 4px 12px #000a}50%{box-shadow:0 0 0 13px #2f6bed00,0 4px 12px #000a}}.rm-dest .rm-dot{background:var(--teal);color:#fff;box-shadow:var(--glow),0 4px 12px #0008}.route-od{padding:12px 16px 0;display:flex;flex-direction:column;gap:8px}.od-row{display:flex;align-items:center;gap:10px}.od-pin{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff}.od-pin.origin{background:#6b7689}.od-pin.dest{background:var(--teal);box-shadow:var(--glow)}.od-text{flex:1;display:flex;flex-direction:column;line-height:1.2;min-width:0}.od-text b{font-size:13px}.od-text small{font-size:11px;color:var(--faint)}.od-gps{flex-shrink:0;background:var(--panel-2);color:var(--teal);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer}.od-gps:active{transform:scale(.97)}.od-search{flex:1;display:flex;gap:8px;min-width:0}.od-input{flex:1;min-width:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px;color:var(--text);font-size:14px;font-family:inherit}.od-input::placeholder{color:var(--faint)}.od-go{flex-shrink:0;background:var(--panel-2);color:var(--text);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 14px;font-size:13px;font-weight:600;cursor:pointer}.od-go:disabled{opacity:.5;cursor:default}.geo-results{list-style:none;display:flex;flex-direction:column;gap:4px;margin-left:32px}.geo-results button{width:100%;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 12px;color:var(--text);font-size:13px;cursor:pointer}.geo-results button:hover{border-color:var(--line-strong);background:var(--panel-2)}.od-dest-ok{margin-left:32px;font-size:12px;color:var(--green-bright)}.od-dest-ok .mono{color:var(--faint)}.rm-car .rm-car-dot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#ff3b5c;color:#fff;font-size:14px;box-shadow:0 0 0 6px #ff3b5c4d,0 4px 12px #0008;animation:carpulse 2s var(--ease) infinite}@keyframes carpulse{0%,to{box-shadow:0 0 0 5px #ff3b5c59,0 4px 12px #0008}50%{box-shadow:0 0 0 11px #ff3b5c00,0 4px 12px #0008}}.route-map.chase .rm-car{display:none}.rm-chase-car{position:absolute;left:50%;top:50%;z-index:480;transform:translate(-50%,-50%);width:46px;height:46px;display:grid;place-items:center;pointer-events:none}.rm-chase-car .rmc-svg{position:relative;filter:drop-shadow(0 2px 5px #000a)}.rm-chase-car .rmc-disc{fill:#2f6bed;stroke:#fff;stroke-width:2.5}.rm-chase-car .rmc-chev{fill:#fff}.rm-chase-car .rmc-pulse{position:absolute;left:50%;top:50%;width:46px;height:46px;margin:-23px 0 0 -23px;border-radius:50%;background:#2f6bed;opacity:.3;animation:rmcpulse 1.8s ease-out infinite}@keyframes rmcpulse{0%{transform:scale(.45);opacity:.5}to{transform:scale(1.6);opacity:0}}.live-chip{position:absolute;left:50%;top:12px;transform:translate(-50%);z-index:500;background:#1a0c10cc;border:1px solid #6a2436;color:#ff9bb0;border-radius:999px;padding:6px 13px;font-size:12px;font-weight:600;backdrop-filter:blur(4px);white-space:nowrap}.live-panel{background:#1f1119;border:1px solid #6a2436;border-radius:var(--r-md);padding:12px 14px;margin-bottom:12px}.live-panel.bad{background:#3a1620;border-color:#6a2436}.live-head{font-size:12px;font-weight:600;color:#ff9bb0;margin-bottom:10px}.live-off{color:var(--orange);font-weight:500}.live-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.live-grid .lv{font-size:18px;color:var(--text)}.live-grid .lv small{font-size:11px;color:var(--muted)}.live-grid .lv.bad{color:#ff6b87}.live-grid .lk{font-size:10px;color:var(--faint);margin-top:2px;text-transform:uppercase;letter-spacing:.03em}.rf-livebadge{font-style:normal;font-size:9px;font-weight:700;color:#ff9bb0;background:#ff3b5c22;border:1px solid #ff3b5c55;border-radius:999px;padding:1px 6px;margin-left:6px;text-transform:uppercase;letter-spacing:.04em}.route-form{display:flex;align-items:center;gap:10px;padding:14px 16px;flex-wrap:wrap}.rf-field{flex:1;min-width:160px;display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}.rf-model{flex:1;min-width:140px;display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}.rf-model select{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px;color:var(--text);font-size:14px;font-family:inherit;cursor:pointer}.rf-soc{display:flex;align-items:center;gap:10px}.rf-soc input[type=range]{flex:1;accent-color:var(--teal)}.rf-soc-v{font-size:15px;color:var(--text);min-width:42px;text-align:right}.rf-hvac{background:var(--panel-2);color:var(--muted);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px;font-size:13px;cursor:pointer}.rf-hvac.on{background:#1d2c4a;color:var(--text);border-color:var(--line-strong)}.rf-plan{background:var(--teal);color:#fff;border:none;border-radius:var(--r-sm);padding:11px 20px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--glow)}.rf-plan:disabled{opacity:.5;box-shadow:none;cursor:default}.rf-go{width:100%;margin:8px 0 4px;background:var(--green-bright);color:#052017;border:none;border-radius:var(--r-sm);padding:13px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 0 16px -4px #2bd68499}.rf-go:active{transform:scale(.99)}.rf-stop{width:100%;margin:8px 0 4px;background:#2a1118;color:#ff9bb0;border:1px solid #6a2436;border-radius:var(--r-sm);padding:11px;font-size:14px;font-weight:600;cursor:pointer}.peek-nav{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}.peek-nav b{color:var(--teal)}.peek-stop{background:#2a1118;color:#ff9bb0;border:1px solid #6a2436;border-radius:999px;padding:4px 12px;font-size:12px;cursor:pointer}.speed-curve-box.compact{padding:8px}.speed-curve-box.compact .scb-head{margin-bottom:6px;font-size:11px}.speed-curve-box.compact .scb-rows{gap:3px}.speed-curve-box.compact .scb-foot{display:none}.route-sheet .route-form{gap:8px}.route-sheet .rf-field{min-width:120px;font-size:11px}.route-sheet .rf-hvac,.route-sheet .rf-plan{padding:10px 14px}.route-err{margin:0 16px 12px;padding:10px 12px;background:#3a1620;border:1px solid #6a2436;border-radius:var(--r-sm);color:#ff9bb0;font-size:13px}.route-result{padding:4px 16px 24px}.route-warn{background:#3a2e16;border:1px solid #6a5524;border-radius:var(--r-sm);padding:10px 12px;color:var(--orange);font-size:13px;margin-bottom:12px}.route-verdict{font-size:16px;font-weight:600;padding:12px 14px;border-radius:var(--r-md);margin-bottom:12px}.route-verdict.ok{background:#10241c;color:var(--green-bright);border:1px solid #1bb673}.route-verdict.bad{background:#3a1620;color:#ff9bb0;border:1px solid #6a2436}.soc-curve{width:100%;height:110px;display:block;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md)}.soc-area{fill:#4f86ff24}.soc-line{fill:none;stroke:var(--teal);stroke-width:2.5;stroke-linejoin:round;vector-effect:non-scaling-stroke}.soc-line.low{stroke:#ff6b87}.soc-reserve{stroke:var(--faint);stroke-width:1;stroke-dasharray:4 4;vector-effect:non-scaling-stroke}.soc-end{fill:var(--teal)}.soc-end.low{fill:#ff6b87}.route-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0}.rs{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 8px;text-align:center}.rs-v{font-size:17px;color:var(--text)}.rs-v small{font-size:11px;color:var(--muted)}.rs-v.bad{color:#ff6b87}.rs-k{font-size:10px;color:var(--faint);margin-top:3px;text-transform:uppercase;letter-spacing:.04em}.speed-curve-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:12px;margin:12px 0}.scb-head{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.scb-live{font-style:normal;font-size:10px;font-weight:700;color:#ff9bb0;background:#ff3b5c22;border:1px solid #ff3b5c55;border-radius:999px;padding:2px 8px;text-transform:uppercase;letter-spacing:.03em}.scb-rows{display:flex;flex-direction:column;gap:5px}.scb-row{display:grid;grid-template-columns:66px 1fr 60px 46px;align-items:center;gap:8px;padding:5px 6px;border-radius:var(--r-sm)}.scb-row.now{background:#0e1c2e;box-shadow:inset 0 0 0 1px var(--teal)}.scb-spd{font-size:13px;color:var(--text)}.scb-spd small,.scb-kwh small,.scb-arr small{font-size:9px;color:var(--faint)}.scb-bar{height:8px;background:#1a2335;border-radius:999px;overflow:hidden}.scb-fill{display:block;height:100%;background:var(--green-bright);border-radius:999px}.scb-fill.bad{background:#ff6b87}.scb-kwh{font-size:13px;color:var(--muted);text-align:right}.scb-arr{font-size:15px;color:var(--green-bright);text-align:right}.scb-arr.bad{color:#ff6b87}.scb-foot{font-size:10px;color:var(--faint);margin-top:8px;line-height:1.4}.rf-chargers{width:100%;background:var(--panel-2);color:var(--green-bright);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px;font-size:14px;font-weight:600;cursor:pointer}.charger-list{list-style:none;margin-top:10px;display:flex;flex-direction:column;gap:6px}.charger-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 12px;font-size:13px}.cl-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cl-pow{color:var(--green-bright);flex-shrink:0}.route-screen.immersive{display:block;max-width:none;overflow:hidden;background:#0b1120}.route-screen.immersive .route-map{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.route-top{position:absolute;top:0;left:0;right:0;z-index:700;padding:10px;display:flex;flex-direction:column;gap:8px;pointer-events:none}.route-top-bar{display:flex;align-items:stretch;gap:8px;pointer-events:auto}.route-top .route-back{width:44px;flex-shrink:0;background:#0b1120ee;border:1px solid var(--line);border-radius:13px;color:var(--text);font-size:20px;cursor:pointer;backdrop-filter:blur(8px)}.route-od-float{flex:1;min-width:0;background:#0b1120ee;border:1px solid var(--line);border-radius:14px;padding:8px 10px;display:flex;flex-direction:column;gap:6px;backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}.route-od-float .od-text small{font-size:10px}.route-od-float .od-gps{padding:6px 10px;font-size:15px}.route-top-plan{pointer-events:auto;align-self:flex-start;background:#2f6bed;border:none;border-radius:13px;color:#fff;font-size:17px;font-weight:700;padding:13px 24px;cursor:pointer;box-shadow:var(--shadow-sm)}.route-top-plan:disabled{opacity:.6}.route-top-plan:active{transform:scale(.98)}.route-top-err{pointer-events:auto;align-self:flex-start;background:#3a1620;color:#ff9bb0;border:1px solid #6a2436;border-radius:10px;padding:8px 12px;font-size:13px;max-width:440px}.geo-results.float{list-style:none;pointer-events:auto;margin:0 0 0 52px;display:flex;flex-direction:column;gap:2px;background:#0b1120f5;border:1px solid var(--line);border-radius:12px;padding:6px;max-height:244px;overflow-y:auto;backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}.geo-results.float button{width:100%;text-align:left;background:transparent;border:none;border-radius:8px;padding:9px 10px;color:var(--text);font-size:13px;cursor:pointer}.geo-results.float button:hover{background:var(--panel-2)}.route-sheet{position:absolute;left:0;right:0;bottom:0;z-index:600;max-height:60%;overflow-y:auto;background:#0b1120f2;border-top:1px solid var(--line-strong);border-radius:18px 18px 0 0;padding:8px 14px 18px;backdrop-filter:blur(10px);box-shadow:0 -8px 30px #0009}.route-sheet:before{display:none}.sheet-grab{display:block;width:100%;background:none;border:none;padding:5px 0 7px;cursor:pointer}.sheet-grab span{display:block;width:44px;height:5px;border-radius:3px;background:var(--line-strong);margin:0 auto}.sheet-grab:active span{background:var(--teal)}.sheet-peek{font-size:13px;color:var(--text);text-align:center;padding:0 4px 8px;cursor:pointer}.sheet-peek b{color:var(--teal)}.route-sheet.collapsed{max-height:none}.route-sheet.collapsed .sheet-body{display:none}.route-roads{font-size:12px;color:var(--muted);line-height:1.5;margin:0 0 8px}.route-roads .rv-ic{color:var(--orange);margin-right:4px}.route-sheet .route-form{padding:6px 0 4px}.route-sheet .route-err{margin:6px 0}.route-sheet .route-result{padding:6px 0 4px}.route-sheet .od-dest-ok{margin:0 0 6px}.route-opts{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px}.ro{display:flex;flex-direction:column;gap:7px;width:100%;text-align:left;cursor:pointer;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:11px 13px;color:var(--text)}.ro.on{border-color:var(--teal);background:#0e1c2e;box-shadow:var(--glow)}.ro:active{transform:scale(.99)}.ro-top{display:flex;align-items:center;gap:10px}.ro-tag{font-size:15px;font-weight:700;white-space:nowrap}.ro-meta{font-size:12px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ro-arr{font-size:22px;color:var(--green-bright);line-height:1.05;flex-shrink:0;margin-left:auto}.ro-arr small{font-size:12px;color:var(--faint)}.ro.bad .ro-arr{color:#ff6b87}.ro-arr-k{font-size:9px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em}.ro-metro{margin-top:9px}.rm-track{display:flex;align-items:center;padding:0 3px}.rm-dot{width:11px;height:11px;border-radius:50%;background:#7d8a92;flex:none}.rm-dot.s{background:var(--green-bright)}.rm-dot.e{background:#fff;outline:2px solid var(--green-bright);outline-offset:2px}.rm-seg{flex:1;height:2px;background:var(--line)}.rm-labs{display:flex;justify-content:space-between;margin-top:6px}.rm-labs span{flex:1;font-size:13px;color:#cfd8de;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px}.rm-labs span:first-child{text-align:left}.rm-labs span.dest{text-align:right;color:#fff;font-weight:600}.rm-road{font-size:12px;color:var(--faint);margin-top:7px}.route-via{font-size:12px;color:var(--muted);line-height:1.5;margin:2px 0 8px}.route-via .rv-ic{color:var(--teal);margin-right:4px}.leaflet-tooltip.rm-via-label{background:#0b1120ee;border:1px solid var(--line);color:var(--text);font-size:11px;font-weight:600;padding:2px 7px;border-radius:6px;box-shadow:0 2px 6px #0009}.leaflet-tooltip.rm-via-label:before{display:none}.route-screen.immersive .map-style{top:98px;left:10px}.route-screen.immersive .radar-chip{top:150px;left:10px}.route-screen.immersive .live-chip{top:100px}.route-screen.immersive .speed-badge{top:12px;right:10px}.route-screen.immersive .map-tools{left:auto;right:10px;top:86px;bottom:auto;flex-direction:column}.route-screen.immersive .radar-added{bottom:auto;top:250px}.route-screen.immersive .rm-recenter{bottom:auto;top:200px;right:10px}@media (min-width: 760px){.route-top{right:auto;width:440px}.route-screen.immersive .map-style{left:50%;transform:translate(-50%);top:12px}.route-screen.immersive .map-tools{left:auto;right:12px;top:118px;bottom:auto;flex-direction:column}.route-screen.immersive .radar-chip{left:12px;top:190px}.route-screen.immersive .rm-recenter{right:12px;top:214px;bottom:auto}.route-hud{position:absolute;z-index:600;display:flex;gap:8px}.route-hud.tl{left:12px;top:104px}.route-hud.tr{right:12px;top:12px;flex-direction:column;align-items:flex-end;text-align:right;min-width:150px;background:#0b1120ee;border:1px solid var(--line);border-radius:22px;padding:18px 28px;backdrop-filter:blur(8px)}.route-hud.tr.bad{border-color:#6a2436}.hud-w{min-width:62px;background:#0b1120e6;border:1px solid var(--line);border-radius:16px;padding:9px 12px;text-align:center;backdrop-filter:blur(8px)}.hud-w.over{border-color:#ff3b5c}.hud-v{font-size:22px;color:var(--text);line-height:1;font-family:var(--mono)}.hud-v small{font-size:11px;color:var(--muted)}.hud-v.big{font-size:60px;font-weight:700;color:var(--green-bright)}.hud-v.big small{font-size:24px}.route-hud.tr.bad .hud-v.big,.hud-w.over .hud-v{color:#ff6b87}.hud-k{font-size:13px;color:var(--faint);margin-top:3px}.route-hud.tr.tap{cursor:pointer}.route-hud.tr.tap:active{transform:scale(.98)}.hud-tap{font-size:12px;color:var(--teal);margin-top:6px;font-weight:600}.hud-speed{font-size:16px;color:var(--text);font-family:var(--mono)}.hud-speed small{font-size:10px;color:var(--muted)}.hud-speed.over{color:#ff6b87}.hud-batt{font-size:26px;font-weight:700;color:var(--green-bright);line-height:1;font-family:var(--mono)}.hud-batt small{font-size:12px;color:var(--muted)}.hud-batt.batt-tight{color:#ffc24d}.hud-batt.batt-no{color:#ff6b87}.hud-warn{font-size:18px;font-weight:600;color:#ff6b87;line-height:1.15}.route-screen.immersive .route-dock{position:absolute;left:0;right:0;bottom:0;z-index:600;display:flex;flex-direction:column;gap:6px;background:#0b1120f2;border-top:1px solid var(--line-strong);padding:8px 14px calc(8px + env(safe-area-inset-bottom));backdrop-filter:blur(10px);box-shadow:0 -8px 30px #0009;max-height:86vh;overflow-y:auto}.dock-cols{display:flex;align-items:stretch;gap:12px}.route-screen.immersive .route-via,.route-screen.immersive .route-roads{margin:3px 0;white-space:nowrap;overflow-x:auto;font-size:15px;line-height:1.4;scrollbar-width:none}.route-screen.immersive .route-via{color:#d2dbe1;font-weight:500}.route-screen.immersive .route-via::-webkit-scrollbar,.route-screen.immersive .route-roads::-webkit-scrollbar{display:none}.dock-grab{padding:2px 0 4px}.route-screen.immersive .route-dock.collapsed .dock-cols{display:none}.dock-controls{flex:0 0 218px;display:flex;flex-direction:column;gap:8px}.dock-controls .od-dest-ok{font-size:12px;margin:0;color:var(--green-bright)}.dock-controls .route-form{flex-direction:column;align-items:stretch;gap:8px;padding:0}.dock-controls .rf-field{min-width:0}.dock-controls .rf-hvac,.dock-controls .rf-plan{width:100%;text-align:center;padding:11px;font-size:14px}.dock-routes{width:100%}.dock-routes .route-opts{flex-direction:column;gap:8px;margin:0;width:100%}.dock-routes .ro{width:100%;padding:12px 16px}.dock-routes .ro-tag{font-size:19px}.dock-routes .ro-meta{font-size:14px}.dock-routes .ro-arr{font-size:30px}.dock-routes .ro-arr small{font-size:14px}.dock-routes .rm-dot{width:13px;height:13px}.dock-routes .rm-dot.e{outline-width:3px}.dock-routes .rm-seg{height:3px}.dock-routes .rm-labs{margin-top:8px}.dock-routes .rm-labs span{font-size:15px}.dock-routes .rm-road{font-size:13px}.ro-arr-no{font-size:16px;font-weight:600;color:#ff6b87;white-space:nowrap}.ds-no{font-size:12px;color:#ff9bb0;align-self:center;text-align:center;padding:10px 4px;line-height:1.4}.dock-chg{margin-top:auto;background:var(--panel-2);color:var(--green-bright);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 10px;font-size:13px;font-weight:600;cursor:pointer}.dock-chg:disabled{opacity:.6;cursor:default}.dock-speed{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;border-left:1px solid var(--line);padding-left:12px}.ds-head{font-size:11px;color:var(--text);display:flex;align-items:center;gap:8px}.dock-warn{font-size:11px;color:var(--orange)}.dock-err{align-self:center}.speed-strip{flex:1;display:flex;flex-direction:column;gap:4px;min-height:0}.ss-svg{width:100%;flex:1;min-height:46px;display:block}.ss-line{fill:none;stroke:var(--green-bright);stroke-width:2.5;stroke-linejoin:round;vector-effect:non-scaling-stroke}.ss-line.low{stroke:#ff6b87}.ss-dot{fill:var(--teal)}.ss-dot.low{fill:#ff6b87}.ss-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--faint)}.ss-labels .low{color:var(--orange)}.od-input{height:46px;font-size:16px}.od-go,.od-gps{padding:12px 16px;font-size:14px}.od-pin{width:26px;height:26px;font-size:13px}.od-text b{font-size:14px}.geo-results button{padding:13px 14px;font-size:15px}.rf-soc-v{font-size:16px}.map-style .ms{padding:9px 16px;font-size:14px}.map-tools .mt{min-width:48px;height:48px;font-size:19px}}@media (min-width: 1500px){.route-screen{grid-template-columns:1.6fr 1fr 0;max-width:1500px;margin:0 auto}}.dash{padding-bottom:calc(78px + env(safe-area-inset-bottom))}.controls{grid-template-columns:repeat(2,1fr)}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:750;display:grid;grid-template-columns:repeat(4,1fr);background:#0b1120f2;border-top:1px solid var(--line-strong);padding:6px 6px calc(6px + env(safe-area-inset-bottom));backdrop-filter:blur(10px)}.tabb{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;color:var(--faint);font-size:11px;padding:7px 0;cursor:pointer}.tabb-ico{font-size:20px;line-height:1;filter:grayscale(1) opacity(.7)}.tabb.on{color:var(--teal)}.tabb.on .tabb-ico{filter:none}.tabb:active{transform:scale(.95)}.climate-screen{display:flex;flex-direction:column;gap:14px}.cl-card{padding:14px;display:flex;flex-direction:column;gap:14px}.cl-head{display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:600;color:var(--text)}.cl-state{font-size:12px;font-weight:600;color:var(--faint)}.cl-state.on{color:var(--green-bright)}.cl-power{background:var(--panel-2);color:var(--text);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:14px;font-size:15px;font-weight:600;cursor:pointer}.cl-power.on{background:#11201a;color:var(--green-bright);border-color:#1bb673}.cl-power:active{transform:scale(.99)}.cl-card .cp-fan{flex-wrap:wrap}.cl-card .cp-seg{flex:1;min-width:38px}.model-card{padding:14px}.mc-label{font-size:13px;color:var(--muted);margin-bottom:10px}.mc-label small{color:var(--faint)}.mc-select{width:100%;background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:12px;color:var(--text);font-size:15px;font-family:inherit;cursor:pointer}@media (min-width: 760px){.tabb{flex-direction:row;gap:8px;font-size:14px}.tabb-ico{font-size:22px}.climate-screen{max-width:720px;margin:0 auto;width:100%}.app{max-width:960px}.car-screen{max-width:900px}.car-screen .vitals{justify-content:center}}.route-verdict.tight{background:#2e2410;color:#ffd479;border:1px solid #6a5424}.live-panel.tight{background:#2e2410;border-color:#6a5424}.live-grid .lv.tight,.rs-v.tight,.scb-arr.tight{color:#ffc24d}.scb-fill.tight{background:#ffc24d}.scb-row.tight .scb-spd{color:#ffc24d}.ro.tight{border-color:#6a5424}.ro.tight .ro-arr,.ro.tight .ro-arr-k{color:#ffc24d}@media (min-width: 760px){.route-hud.tr.tight{border-color:#6a5424}.route-hud.tr.tight .hud-v.big,.route-hud.tr.tight .hud-k{color:#ffc24d}}.speedbig-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:800;background:#060a12cc;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.speedbig{position:relative;width:min(560px,88%);background:#0e1422;border:1px solid var(--line-strong);border-radius:24px;padding:26px 30px 22px;text-align:center;box-shadow:0 20px 60px #000a;touch-action:pan-y}.sb-close{position:absolute;right:12px;top:10px;background:transparent;border:none;color:var(--faint);font-size:24px;cursor:pointer;line-height:1}.sb-head{font-size:16px;color:var(--faint)}.sb-speed{font-size:42px;font-weight:700;color:var(--text);margin:2px 0 6px}.sb-speed small{font-size:18px;color:var(--muted);font-weight:400}.sb-arr{font-size:96px;font-weight:700;line-height:1;color:var(--green-bright)}.sb-arr small{font-size:34px;color:var(--muted);font-weight:400}.sb-arr.tight{color:#ffc24d}.sb-arr.no{color:#ff6b87}.sb-sub{font-size:15px;color:var(--muted);margin-top:10px}.sb-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:20px}.sb-nav button{width:56px;height:56px;border-radius:50%;background:#1a2335;border:1px solid var(--line-strong);color:var(--text);font-size:28px;cursor:pointer}.sb-nav button:disabled{opacity:.3}.sb-dots{display:flex;gap:7px}.sb-dots span{width:9px;height:9px;border-radius:50%;background:#34405a}.sb-dots span.on{background:var(--teal)}.sb-hint{font-size:13px;color:var(--faint);margin-top:14px}.help-card{position:relative;width:min(560px,90%);background:#0e1422;border:1px solid var(--line-strong);border-radius:20px;padding:22px 26px;box-shadow:0 20px 60px #000a}.help-card h3{margin:0 0 14px;font-size:19px;color:var(--text)}.help-card ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:11px}.help-card li{font-size:15px;color:var(--muted);line-height:1.5}.help-card b{color:var(--text)}.help-card b.ok{color:var(--green-bright)}.help-card b.tight{color:#ffc24d}.help-card b.bad{color:#ff6b87}.elev-card{position:relative;width:min(1040px,96%);max-height:92vh;overflow-y:auto;background:#0e1422;border:1px solid var(--line-strong);border-radius:22px;padding:26px 32px;box-shadow:0 20px 60px #000a}.elev-card h3{margin:0 0 14px;font-size:26px;color:var(--text)}.elev-stats{display:flex;gap:24px;font-size:18px;color:var(--muted);margin-bottom:16px;flex-wrap:wrap}.elev-svg{width:100%;height:300px;display:block;background:#0b1018;border:1px solid var(--line);border-radius:14px}.elev-area{fill:#2f6bed2e}.elev-line{fill:none;stroke:#4f86ff;stroke-width:2.5}.elev-mark{stroke:#ff6b87;stroke-width:2;stroke-dasharray:4 4}.elev-dot{fill:#ff6b87;stroke:#fff;stroke-width:2}.elev-list{margin-top:18px}.elev-list-h{font-size:17px;color:var(--muted);margin-bottom:10px}.elev-row{display:flex;flex-direction:column;gap:2px;padding:12px 0;border-top:1px solid var(--line)}.elev-row b{color:#ffc24d;font-size:20px}.resume-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:820;background:#060a12cc;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.resume-card{width:min(460px,88%);background:#0e1422;border:1px solid var(--line-strong);border-radius:20px;padding:24px 26px;box-shadow:0 20px 60px #000a;text-align:center}.resume-h{font-size:20px;font-weight:600;color:var(--text)}.resume-dest{font-size:16px;color:var(--muted);margin:12px 0 22px}.resume-dest b{color:var(--text)}.resume-btns{display:flex;gap:12px}.resume-btns button{flex:1;padding:14px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer}.resume-yes{background:var(--teal);color:#04181a;border:none}.resume-no{background:transparent;color:var(--muted);border:1px solid var(--line-strong)}.elev-row-sub{font-size:15px;color:var(--muted)}.elev-card .sb-close{font-size:28px;right:16px;top:14px}@media (prefers-reduced-motion: reduce){*{animation:none!important}}
