:root{--bg: #0f172a;--panel: #ffffff;--text: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-dark: #1d4ed8;--danger: #dc2626;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}.app{position:relative;height:100dvh;width:100%;overflow:hidden}.map{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.topbar{position:absolute;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(to bottom,#0f172ad9,#0f172a00);color:#fff}.brand{font-weight:700;letter-spacing:.2px}.icon-btn{background:#ffffff26;color:#fff;border:none;width:36px;height:36px;border-radius:10px;font-size:18px;cursor:pointer}.sheet .icon-btn{background:#f1f5f9;color:var(--text)}.controls{position:absolute;z-index:500;left:16px;bottom:42dvh;display:flex;gap:8px}.track-btn{background:var(--accent);color:#fff;border:none;padding:12px 18px;border-radius:999px;font-weight:700;font-size:15px;box-shadow:0 4px 14px #2563eb66;cursor:pointer}.track-btn.on{background:var(--danger);box-shadow:0 4px 14px #dc262666}.ghost-btn{background:#fff;color:var(--text);border:1px solid #e2e8f0;padding:12px 16px;border-radius:999px;font-weight:600;cursor:pointer}.ghost-btn:disabled{opacity:.6}.toast{position:absolute;z-index:600;left:50%;top:64px;transform:translate(-50%);background:#0f172aeb;color:#fff;padding:10px 16px;border-radius:10px;font-size:14px;max-width:90%}.toast.error{background:var(--danger)}.panel{position:absolute;z-index:500;left:0;right:0;bottom:0;background:var(--panel);border-radius:18px 18px 0 0;box-shadow:0 -6px 24px #0000002e;padding:8px 0 18px;overflow:hidden}.panel .trial-banner,.panel .empty{margin-left:14px;margin-right:14px}.carousel{--card-w: min(86vw, 380px);display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-block:4px;padding-inline:calc(50% - var(--card-w) / 2);scroll-padding-inline:calc(50% - var(--card-w) / 2)}.carousel::-webkit-scrollbar{display:none}.carousel{cursor:grab}.carousel:active{cursor:grabbing}.carousel-item{flex:0 0 var(--card-w);scroll-snap-align:center;transition:transform .3s ease,opacity .3s ease}.carousel-item .card,.carousel-item .locked-card{margin-bottom:0;height:100%}.panel-grip{width:40px;height:4px;background:#cbd5e1;border-radius:2px;margin:6px auto 12px}.empty{color:var(--muted);text-align:center;padding:12px;line-height:1.5}.card{display:block;width:100%;text-align:left;background:#f8fafc;border:1px solid #eef2f7;border-radius:14px;padding:12px 14px;margin-bottom:10px;cursor:pointer}.card:active{background:#eef2f7}.card-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.card-title{font-weight:700;color:var(--text)}.card-dist{color:var(--accent);font-size:13px;font-weight:600;white-space:nowrap}.card-cat{display:inline-block;margin:4px 0 6px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.card-desc{margin:0;color:#334155;font-size:14px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0f172a80;display:flex;align-items:flex-end}.sheet{width:100%;background:#fff;border-radius:18px 18px 0 0;padding:18px 18px 28px;max-height:85dvh;overflow-y:auto}.sheet-head{display:flex;align-items:center;justify-content:space-between}.sheet-head h2{margin:0;font-size:20px}.sheet p{color:#334155;line-height:1.6}.field{display:flex;flex-direction:column;gap:6px;margin-top:16px}.field>span{font-weight:600;font-size:14px}.field small{color:var(--muted)}.field input[type=text],.field input[type=password]{padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:8px 14px;font-size:14px;cursor:pointer}.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}@media (min-width: 720px){.sheet{max-width:520px;margin:0 auto;border-radius:18px;align-self:center}.sheet-backdrop{align-items:center}.panel{left:0;right:0;bottom:0;max-width:none;border-radius:18px 18px 0 0}}.links{display:flex;gap:8px;margin-top:14px}.link-btn{flex:1;text-align:center;text-decoration:none;background:var(--accent);color:#fff;padding:10px 12px;border-radius:10px;font-size:14px;font-weight:600}.link-btn:active{background:var(--accent-dark)}.link-btn+.link-btn{background:#fff;color:var(--text);border:1px solid #e2e8f0}.login-screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:24px;background:var(--bg)}.login-brand{color:#fff;font-size:26px;font-weight:700}.login-sub{color:#cbd5e1;margin:0 0 18px}.topbar-right{display:flex;align-items:center;gap:10px}.trial-banner{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--color, #eef2ff);background:#eef2ff;color:#3730a3;border-radius:10px;padding:8px 12px;margin-bottom:10px;font-size:13px}.link-inline{background:none;border:none;color:#4338ca;font-weight:700;font-size:13px;cursor:pointer;text-decoration:underline}.field select{padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px;background:#fff}.locked-card{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;text-align:left;background:#f8fafc;border:1px dashed #c7d2fe;border-radius:12px;padding:12px 14px;margin-bottom:10px;cursor:pointer}.locked-title{font-weight:700;font-size:14px;color:#3730a3}.locked-sub{font-size:13px;color:#6366f1}.map-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.map-canvas.rotating{top:-30%;left:-30%;width:160%;height:160%;transform:rotate(var(--rot, 0deg));transform-origin:center center;transition:transform .4s ease-out}.map-tools{position:absolute;z-index:450;right:14px;bottom:42dvh;display:flex;flex-direction:column;gap:8px}.map-tool{width:44px;height:44px;border:none;border-radius:12px;background:#fff;color:#0f172a;font-size:22px;font-weight:700;line-height:1;box-shadow:0 2px 10px #00000040;cursor:pointer;display:flex;align-items:center;justify-content:center}.map-tool:active{background:#f1f5f9}.map-attr{position:absolute;z-index:450;right:0;bottom:0;background:#ffffffb3;color:#334155;font-size:10px;padding:1px 5px;border-radius:4px 0 0}.poi-pin{background:none;border:none}.poi-dot{display:block;width:14px;height:14px;border-radius:50%;background:#ef4444;border:2px solid #fff;box-shadow:0 0 0 1px #00000040}
