:root{
  --bg:#08111f;--bg2:#0f172a;--card:#111827;--card2:#172033;--muted:#94a3b8;--text:#f8fafc;--line:rgba(255,255,255,.12);
  --primary:#22c55e;--primary2:#16a34a;--accent:#38bdf8;--warn:#f59e0b;--danger:#ef4444;--ok:#22c55e;
  --shadow:0 18px 45px rgba(0,0,0,.32);--radius:18px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Roboto,Arial,sans-serif;overscroll-behavior:none}
body{touch-action:manipulation}
button,input,select,textarea{font:inherit;color:inherit}
button{border:0;cursor:pointer;touch-action:manipulation}
input,select,textarea{width:100%;background:#0b1220;border:1px solid var(--line);border-radius:14px;padding:13px 14px;outline:none;color:var(--text)}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(56,189,248,.18)}
label{display:block;color:#cbd5e1;font-size:.9rem;font-weight:650;margin:12px 0 7px}textarea{resize:vertical;min-height:52px}
.app-shell{min-height:100%;padding:calc(var(--safe-top) + 7px) 10px calc(76px + var(--safe-bottom));max-width:900px;margin:0 auto;background:radial-gradient(circle at top left,rgba(56,189,248,.11),transparent 35%),var(--bg)}
.topbar{position:sticky;top:0;z-index:20;background:linear-gradient(180deg,rgba(8,17,31,.98),rgba(8,17,31,.92));backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:8px 2px 9px;margin:0 -2px 7px}
.brand-row{display:flex;align-items:center;gap:10px}.brand-copy{min-width:0;flex:1}.app-logo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#22c55e,#38bdf8);display:grid;place-items:center;color:#07111f;font-weight:900;letter-spacing:-.5px;box-shadow:0 8px 24px rgba(34,197,94,.2)}
h1{font-size:1.12rem;line-height:1;margin:0 0 4px}.topbar p{margin:0;color:var(--muted);font-size:.83rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.install-btn{min-height:34px;border-radius:999px;padding:7px 11px;background:#1e3a8a;color:#dbeafe;font-size:.78rem;font-weight:800}
.status-row{display:flex;gap:6px;overflow:auto;padding-top:8px;scrollbar-width:none}.status-row::-webkit-scrollbar{display:none}.pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:6px 9px;font-size:.73rem;font-weight:800;white-space:nowrap;background:#1f2937;color:#dbeafe;border:1px solid var(--line)}
.pill.ok{background:rgba(34,197,94,.14);color:#bbf7d0;border-color:rgba(34,197,94,.36)}.pill.warn{background:rgba(245,158,11,.14);color:#fde68a;border-color:rgba(245,158,11,.36)}.pill.bad{background:rgba(239,68,68,.14);color:#fecaca;border-color:rgba(239,68,68,.36)}
.screen{display:none;animation:fade .16s ease}.screen.active{display:block}@keyframes fade{from{opacity:.6;transform:translateY(4px)}to{opacity:1;transform:none}}
.map-wrap{position:relative;height:58vh;min-height:410px;max-height:670px;border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#0b1220}.map{height:100%;width:100%;background:linear-gradient(135deg,#12213b,#0f172a)}
.navigation-hud{position:absolute;left:10px;right:10px;top:10px;z-index:12;background:rgba(8,17,31,.94);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:12px;box-shadow:var(--shadow);backdrop-filter:blur(16px)}.hud-top{display:flex;gap:11px;align-items:center}.maneuver-icon{width:48px;height:48px;border-radius:16px;background:#22c55e;color:#052e16;display:grid;place-items:center;font-size:1.35rem;font-weight:950}.hud-copy{min-width:0}.hud-copy strong{display:block;font-size:1.02rem;line-height:1.22}.hud-copy span{display:block;color:#cbd5e1;font-size:.85rem;margin-top:3px}.hud-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px}.hud-bottom span{background:#0b1220;border:1px solid var(--line);border-radius:12px;padding:7px 6px;text-align:center;font-size:.78rem;font-weight:800;color:#dbeafe}
.map-controls{position:absolute;z-index:13;display:flex;gap:7px}.top-left{left:10px;top:10px}.top-right{right:10px;top:10px}.navigation-hud:not([hidden])~.top-left,.navigation-hud:not([hidden])~.top-right{top:112px}.bottom-left{left:10px;bottom:10px;right:10px}.map-btn{min-height:38px;border-radius:999px;padding:9px 12px;background:rgba(8,17,31,.92);color:#e2e8f0;border:1px solid rgba(255,255,255,.16);box-shadow:0 8px 22px rgba(0,0,0,.24);font-weight:850;font-size:.82rem}.map-btn.active{background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.45);color:#bbf7d0}.map-btn.primary{background:#22c55e;color:#052e16}.map-btn.danger{background:rgba(239,68,68,.92);color:#fff}.bottom-left .map-btn{flex:1}
.sheet{margin-top:10px}.panel,.route-summary{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:12px;box-shadow:var(--shadow)}.panel h2{margin:0 0 10px;font-size:1rem}.hint{color:var(--muted);font-size:.85rem;line-height:1.35}.label{display:block;color:var(--muted);font-size:.74rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.route-summary{display:flex;align-items:center;justify-content:space-between;gap:12px}.route-summary strong{font-size:1rem}.route-summary p{margin:.28rem 0 0;color:#cbd5e1;font-size:.86rem;line-height:1.35}.risk-badge{min-width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-weight:950;background:#1f2937;color:#e5e7eb;border:1px solid var(--line)}.risk-badge.ok{background:rgba(34,197,94,.15);color:#bbf7d0;border-color:rgba(34,197,94,.45)}.risk-badge.warn{background:rgba(245,158,11,.15);color:#fde68a;border-color:rgba(245,158,11,.45)}.risk-badge.bad{background:rgba(239,68,68,.15);color:#fecaca;border-color:rgba(239,68,68,.45)}
.safety-strip{border-radius:14px;padding:10px 12px;margin:0 0 10px;font-size:.83rem;line-height:1.32;border:1px solid var(--line)}.safety-strip.amber{background:rgba(120,53,15,.3);border-color:rgba(245,158,11,.42);color:#fde68a}.safety-strip.red{background:rgba(127,29,29,.32);border-color:rgba(239,68,68,.5);color:#fecaca}.safety-strip.green{background:rgba(20,83,45,.24);border-color:rgba(34,197,94,.38);color:#bbf7d0}
.warnings-list{display:grid;gap:8px}.warning-card{border:1px solid var(--line);border-radius:16px;padding:12px;background:#111827}.warning-card h3{margin:0 0 5px;font-size:.95rem}.warning-card p{margin:2px 0;color:#cbd5e1;font-size:.84rem;line-height:1.35}.warning-card.red{border-color:rgba(239,68,68,.55);background:rgba(127,29,29,.32)}.warning-card.amber{border-color:rgba(245,158,11,.55);background:rgba(120,53,15,.32)}.warning-card.green{border-color:rgba(34,197,94,.35);background:rgba(20,83,45,.22)}
.primary,.secondary,.ghost,.file-btn{min-height:46px;border-radius:15px;padding:12px 14px;font-weight:850;display:inline-flex;align-items:center;justify-content:center;text-align:center;user-select:none}.primary{background:var(--primary);color:#052e16}.primary:active{background:var(--primary2)}.secondary{background:#1e3a8a;color:#dbeafe;border:1px solid rgba(96,165,250,.3)}.ghost{background:#0b1220;color:#e2e8f0;border:1px solid var(--line)}.danger{color:#fecaca;border-color:rgba(239,68,68,.35)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.row-stack{display:grid;grid-template-columns:1fr auto;gap:9px;align-items:end}.place-row{grid-template-columns:1fr 1fr}.actions-row{margin-top:12px}.download-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:12px 0}.external-nav-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.check-row{display:flex;gap:10px;align-items:center;margin:14px 0}.check-row input{width:22px;height:22px;accent-color:var(--primary)}
.notice{border-radius:16px;padding:12px;margin-top:12px;font-size:.86rem;line-height:1.35;border:1px solid var(--line)}.notice.red{background:rgba(127,29,29,.28);border-color:rgba(239,68,68,.4);color:#fecaca}.notice.amber{background:rgba(120,53,15,.28);border-color:rgba(245,158,11,.4);color:#fde68a}.notice.green{background:rgba(20,83,45,.24);border-color:rgba(34,197,94,.36);color:#bbf7d0}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.stats-grid div{background:#0b1220;border:1px solid var(--line);border-radius:16px;padding:11px}.stats-grid span{display:block;color:var(--muted);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.stats-grid strong{display:block;margin-top:4px;font-size:1rem}.directions-list{display:grid;gap:8px}.directions-list.empty{color:var(--muted);font-size:.9rem}.step-card{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;background:#0b1220;border:1px solid var(--line);border-radius:16px;padding:10px}.step-icon{width:34px;height:34px;border-radius:12px;background:#1e293b;display:grid;place-items:center;font-weight:950}.step-card.active{border-color:rgba(34,197,94,.5);background:rgba(20,83,45,.22)}.step-card small{color:var(--muted);font-weight:800}.step-card strong{font-size:.9rem;line-height:1.25}
.list{display:grid;gap:9px;margin-top:12px}.list-card{background:#0b1220;border:1px solid var(--line);border-radius:16px;padding:12px;display:grid;gap:8px}.list-card strong{font-size:.95rem}.list-card p{margin:0;color:#cbd5e1;font-size:.84rem;line-height:1.35}.list-actions{display:flex;gap:8px;flex-wrap:wrap}.list-actions button{min-height:34px;border-radius:10px;padding:8px 10px;font-size:.78rem}
.bottom-tabs{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(8,17,31,.96);backdrop-filter:blur(16px);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(6,1fr);padding:7px 5px calc(7px + var(--safe-bottom));max-width:900px;margin:0 auto}.tab{background:transparent;color:var(--muted);border-radius:13px;padding:9px 2px;font-size:.72rem;font-weight:850}.tab.active{background:#1e293b;color:#f8fafc}.toast{position:fixed;left:50%;bottom:calc(78px + var(--safe-bottom));transform:translateX(-50%) translateY(12px);background:#020617;color:#f8fafc;border:1px solid var(--line);border-radius:999px;padding:11px 16px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.18s ease;z-index:50;max-width:88vw;text-align:center}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.leaflet-container{font-family:inherit}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#0f172a;color:#f8fafc}.leaflet-control-attribution{font-size:9px}.gps-dot{width:22px;height:22px;border-radius:50%;background:#38bdf8;border:4px solid #f8fafc;box-shadow:0 0 0 8px rgba(56,189,248,.28)}.gps-arrow{width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:24px solid #38bdf8;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35));transform-origin:center}.bridge-marker{width:28px;height:28px;border-radius:12px;background:#ef4444;color:#fff;display:grid;place-items:center;font-weight:950;border:2px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.35)}
@media (min-width:720px){.app-shell{padding-left:16px;padding-right:16px}.download-grid{grid-template-columns:repeat(3,1fr)}.bottom-tabs{border-radius:22px 22px 0 0;left:50%;transform:translateX(-50%);width:min(900px,100%)}}
@media (max-width:520px){.grid2,.external-nav-grid,.stats-grid,.place-row{grid-template-columns:1fr}.map-wrap{height:57vh;min-height:390px}.row-stack{grid-template-columns:1fr}.bottom-tabs{gap:1px}.tab{font-size:.68rem}.route-summary{align-items:flex-start}.risk-badge{min-width:52px;height:52px}.download-grid{grid-template-columns:1fr 1fr}.navigation-hud:not([hidden])~.top-left,.navigation-hud:not([hidden])~.top-right{top:126px}.hud-bottom{grid-template-columns:1fr 1fr}.hud-bottom span:last-child{grid-column:1/-1}.top-right{flex-direction:column}.top-left{flex-direction:column}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
