:root{--bg:#f3f6fb;--card:#fff;--text:#08142c;--muted:#687589;--blue:#2563eb;--blue2:#0b5cff;--nav:#07162d;--line:#dfe6f0;--green:#16a34a;--orange:#f97316;--purple:#7c3aed;--red:#dc2626;--teal:#14b8a6;--shadow:0 18px 45px rgba(18,34,66,.08);--radius:24px}*{box-sizing:border-box}html,body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:16px}button,.button,input,select,textarea{font:inherit}button,.button{border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--text);font-weight:800;padding:12px 18px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.15s}button:hover,.button:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(28,45,75,.08)}button.primary,.button.primary,.primary{background:linear-gradient(135deg,#2563eb,#0b5cff);color:#fff;border-color:#2563eb}.ghost{background:#fff}.danger{background:#fff1f2!important;color:#b91c1c!important;border-color:#fecdd3!important}.wide{width:100%}.muted{color:var(--muted)}.login-page{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;background:#fff}.login-brand{background:radial-gradient(circle at 30% 80%,#183c70,transparent 28%),linear-gradient(135deg,#051328,#071f40);color:#fff;padding:70px 90px;position:relative;overflow:hidden}.login-brand:after{content:"";position:absolute;inset:auto -20% -20% 0;height:220px;background:linear-gradient(45deg,#0b5cff,#00a3ff);opacity:.22;transform:skewY(-8deg)}.brand-mark,.brand-mini{width:76px;height:76px;border-radius:24px;background:#eaf2ff;color:#2563eb;display:grid;place-items:center;font-size:42px;font-weight:900}.login-brand h1{font-size:46px;line-height:.85;letter-spacing:1px}.login-brand h1 span,.login-brand h2 span,.logo span,.sidebar-card span{color:#36a2ff}.login-brand p{font-size:18px;color:#d8e3f3}.login-brand h2{font-size:48px;line-height:1.15;margin-top:70px}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:50px;position:relative;z-index:2}.feature-grid div{border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);border-radius:20px;padding:22px}.feature-grid small{display:block;color:#cbd7e8;margin-top:8px}.login-card{align-self:center;margin:40px auto;padding:55px;width:min(620px,86%);border-radius:34px;background:#fff;box-shadow:var(--shadow);text-align:center}.login-card h2{font-size:36px;margin-bottom:8px}.login-card label{display:block;text-align:left;font-weight:800;margin:18px 0 8px}.login-card input{width:100%;padding:17px 18px;border-radius:14px;border:1px solid var(--line)}.msg{color:var(--red);font-weight:800;margin-top:15px}.app-shell{display:grid;grid-template-columns:300px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#07182f,#071326);color:#eaf2ff;padding:24px;position:sticky;top:0;height:100vh;overflow-y:auto}.logo{display:flex;gap:12px;align-items:center;margin-bottom:35px}.logo-icon{width:54px;height:54px;border-radius:18px;background:#2563eb;display:grid;place-items:center;font-size:30px}.logo b{font-size:28px;line-height:.83;letter-spacing:1px}.logo small{display:block;color:#bfd0e8;margin-top:5px;font-size:13px}nav{display:flex;flex-direction:column;gap:8px}nav button{background:transparent;color:#dce8f8;border:0;justify-content:flex-start;border-radius:14px;font-size:17px;padding:15px 15px}nav button.active{background:#2563eb;color:#fff}nav button:hover{background:rgba(255,255,255,.08);box-shadow:none}.sidebar-card{margin:34px 0;border:1px solid rgba(255,255,255,.1);border-radius:20px;background:rgba(255,255,255,.06);padding:24px;text-align:center;font-size:20px;font-weight:900;line-height:1.45}.user-box{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;gap:12px;align-items:center}.user-box .avatar{width:46px;height:46px;background:#fff;color:#2563eb;border-radius:50%;display:grid;place-items:center;font-weight:900}.user-box small{display:block;color:#bdd0e7}.user-box a{margin-left:auto;color:#bdd0e7;text-decoration:none;font-weight:800}.main{padding:32px 36px 80px;min-width:0}.topbar{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:26px}.topbar h1{font-size:38px;margin:0}.topbar p{color:var(--muted);font-weight:700;margin-top:8px}.top-actions{display:flex;gap:12px;align-items:center}.top-actions input{width:360px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 18px;font-weight:700}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:22px}.kpi-grid.five{grid-template-columns:repeat(5,1fr)}.kpi{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:26px;display:flex;gap:18px;align-items:center;min-height:116px}.kpi-icon{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:24px;font-weight:900}.kpi-icon.blue{background:var(--blue)}.kpi-icon.green{background:var(--green)}.kpi-icon.orange{background:var(--orange)}.kpi-icon.purple{background:var(--purple)}.kpi-icon.red{background:var(--red)}.kpi-icon.teal{background:var(--teal)}.kpi small{display:block;color:#24324a;font-weight:800}.kpi b{display:block;font-size:32px;margin:4px 0}.kpi span{color:var(--muted);font-weight:700}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-bottom:22px;min-width:0}.section-title{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.section-title h2{margin:0;font-size:28px}.section-title p{margin:8px 0 0;color:var(--muted);font-weight:700}.section-actions{display:flex;gap:10px;flex-wrap:wrap}.dashboard-grid{display:grid;grid-template-columns:1fr 380px;gap:24px}.route-map-layout{display:grid;grid-template-columns:420px 1fr;gap:24px}.stop-list{display:flex;flex-direction:column;gap:14px}.stop-row{display:flex;align-items:center;justify-content:space-between;gap:15px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:18px}.stop-row b{font-size:18px}.stop-row small{display:block;color:var(--muted);font-weight:700;margin-top:4px}.footer-stats{display:flex;align-items:center;justify-content:space-between;margin-top:20px}.side-stack{display:flex;flex-direction:column;gap:22px}.status-list{display:grid;gap:12px}.status-list div{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:14px;padding:14px}.snapshot{background:#effdf5;border:1px solid #bbf7d0;border-radius:18px;color:#166534;padding:18px;font-weight:800;margin:14px 0}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 12px;font-weight:900;font-size:13px}.pill.green{background:#dcfce7;color:#166534}.pill.red{background:#fee2e2;color:#991b1b}.pill.yellow{background:#fef3c7;color:#92400e}.pill.blue{background:#dbeafe;color:#1d4ed8}.pill.gray{background:#f1f5f9;color:#475569}.score{width:42px;height:42px;border-radius:50%;border:1px solid #86efac;color:#166534;background:#f0fdf4;display:grid;place-items:center;font-weight:900}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:18px}.table-wrap.small{max-height:520px;overflow:auto}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:18px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{font-size:14px;color:#334155;background:#f8fafc}td b{display:block}td small{display:block;color:var(--muted);font-weight:700;margin-top:4px}.actions{display:flex;gap:8px;flex-wrap:wrap}.actions button{padding:9px 11px;font-size:13px}.mini-map{width:150px;height:72px;background:#e8f3ff;border-radius:12px;position:relative;overflow:hidden}.mini-map i{position:absolute;width:20px;height:20px;border-radius:50%;background:#2563eb;color:#fff;font-style:normal;font-size:11px;display:grid;place-items:center}.route-detail-header{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}.route-detail-grid{display:grid;grid-template-columns:520px 1fr;gap:24px}.route-stop{align-items:center}.stop-num{min-width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:900}.stop-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.map-real{width:100%;min-height:500px;height:500px;border-radius:22px;border:1px solid #cfe0f5;overflow:hidden;background:#e8f2ff;position:relative}.dashboard-map{height:400px;min-height:400px}.route-map-big{height:580px;min-height:580px}.network-map{height:520px;min-height:520px}.map-main{height:620px;min-height:620px}.map-loading{position:absolute;inset:0;display:grid;place-items:center;font-size:20px;font-weight:900;color:#475569}.map-iframe{width:100%;height:100%;border:0;display:block}.map-fallback-note{position:absolute;left:18px;bottom:18px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-weight:800;color:#334155;box-shadow:0 8px 16px rgba(0,0,0,.08)}.map-actions{margin-top:14px}.map-page-grid{display:grid;grid-template-columns:1fr 430px;gap:24px}.network-grid{display:grid;grid-template-columns:1fr 480px;gap:24px}.map-legend{display:flex;gap:22px;margin-top:14px;font-weight:900;align-items:center}.dot{display:inline-block;width:14px;height:14px;border-radius:50%;margin-right:6px;vertical-align:middle}.dot.blue,.c0{background:#2563eb}.dot.green,.c1{background:#16a34a}.dot.purple,.c2{background:#7c3aed}.dot.red{background:#dc2626}.nearby-list{display:grid;gap:12px}.nearby-list div{border:1px solid var(--line);border-radius:16px;padding:15px;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.nearby-list small{display:block;color:var(--muted);font-weight:700}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid.single{grid-template-columns:1fr}.form-grid label{font-weight:900;color:#26344c}.form-grid input,.form-grid select,.form-grid textarea{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff;width:100%}.form-grid textarea{min-height:110px}.wide-field{grid-column:1/-1}.button-row{display:flex;gap:12px;margin-bottom:16px}.result-box{background:#f1f5f9;border-radius:16px;padding:16px;margin-top:15px;font-weight:900;line-height:1.5}.danger-zone{border-color:#fecaca}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.analytics-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:24px}.bar-chart{height:260px;display:flex;align-items:flex-end;gap:18px;border-left:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px}.bar-chart i{flex:1;background:#2563eb;border-radius:10px 10px 0 0}.donut-wrap{display:flex;align-items:center;gap:25px}.donut{width:130px;height:130px;border-radius:50%;background:conic-gradient(#2563eb 0 45%,#16a34a 45% 70%,#f97316 70% 85%,#7c3aed 85%);position:relative}.donut:after{content:"";position:absolute;inset:30px;border-radius:50%;background:#fff}.clean{line-height:2}.modal{position:fixed;inset:0;background:rgba(4,12,30,.55);display:grid;place-items:center;padding:20px;z-index:99}.modal.hidden{display:none}.modal-card{width:100%;max-width:720px;max-height:90vh;overflow:auto;background:#fff;border-radius:28px;box-shadow:0 30px 80px rgba(0,0,0,.25);padding:28px;position:relative}.modal-close{position:absolute;right:18px;top:18px;border:0;background:#f1f5f9;width:38px;height:38px;border-radius:50%;padding:0}.toast{position:fixed;right:30px;bottom:30px;background:#0f172a;color:#fff;border-radius:18px;padding:18px 22px;font-weight:900;box-shadow:0 20px 45px rgba(0,0,0,.2);opacity:0;transform:translateY(12px);transition:.2s;z-index:200}.toast.show{opacity:1;transform:translateY(0)}.toast.bad{background:#b91c1c}.empty{padding:25px;border:1px dashed var(--line);border-radius:16px;color:var(--muted);font-weight:800}.loader,.error{font-size:20px;font-weight:900}hr{border:0;border-top:1px solid var(--line);margin:22px 0}@media(max-width:1200px){.app-shell{grid-template-columns:245px 1fr}.kpi-grid,.kpi-grid.five{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.route-map-layout,.route-detail-grid,.map-page-grid,.network-grid,.settings-grid,.analytics-grid{grid-template-columns:1fr}.topbar{flex-direction:column}.top-actions{width:100%;flex-wrap:wrap}.top-actions input{width:100%}.map-main,.route-map-big,.network-map{height:430px;min-height:430px}}@media(max-width:760px){.login-page{grid-template-columns:1fr}.login-brand{display:none}.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.main{padding:22px}.top-actions{display:grid;grid-template-columns:1fr}.kpi-grid,.kpi-grid.five,.kpi-grid.four{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.wide-field{grid-column:auto}.route-map-layout{grid-template-columns:1fr}.dashboard-map,.map-real{height:360px;min-height:360px}table,thead,tbody,tr,th,td{display:block}thead{display:none}tr{border-bottom:1px solid var(--line);padding:12px}td{border:0;padding:8px}.footer-stats{flex-direction:column;align-items:flex-start;gap:12px}.nearby-list div{grid-template-columns:1fr}}

/* v10 route edit + map reliability fixes */
.map-headline{margin-bottom:14px}.map-headline h3{margin:0 0 4px;font-size:24px}.map-headline p{margin:0;color:var(--muted);font-weight:700}.route-map-card .map-real{background:#eaf3ff}.route-stops-card .section-actions{display:flex;gap:10px;flex-wrap:wrap}.stop-actions button{min-width:44px}.route-detail-header{position:sticky;top:0;z-index:4;background:rgba(243,246,251,.96);padding:10px 0;border-radius:18px}.map-iframe{background:#eaf3ff}.route-stop .pill{margin-top:8px}

.map-fallback-note.bad{background:#fff7ed;border-color:#fed7aa;color:#9a3412;}

/* v15 Visit Coach AI tab */
.visitcoach-grid{display:grid;grid-template-columns:460px 1fr;gap:24px}.coach-snapshot h3{font-size:26px;margin:0 0 12px}.coach-snapshot h4{margin:18px 0 8px}.checkline{display:flex!important;gap:10px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:13px;background:#f8fafc}.checkline input{width:auto!important}.ai-result-card{min-height:320px}.ai-output{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:20px;font-weight:700;line-height:1.55;white-space:normal}.ai-output pre{white-space:pre-wrap;margin:0;font-family:inherit;font-size:15.5px;line-height:1.62}.ai-output.error-box{background:#fff1f2;border-color:#fecdd3;color:#991b1b}.ai-sources{border-top:1px solid var(--line);margin-top:18px;padding-top:14px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.ai-sources a{background:#eaf2ff;border:1px solid #bfdbfe;border-radius:999px;padding:8px 12px;text-decoration:none;color:#1d4ed8;font-weight:900}
@media(max-width:1200px){.visitcoach-grid{grid-template-columns:1fr}}

/* v16 Quick Visit AI Voice Summary */
.voice-tools{background:#f8fbff;border:1px solid #bfdbfe;border-radius:18px;padding:16px;display:grid;gap:12px}.voice-tools-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.voice-tools-head small{display:block;color:var(--muted);font-weight:700;margin-top:4px;line-height:1.35}.voice-chip{background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.voice-actions{display:flex;gap:10px;flex-wrap:wrap}.voice-status{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-weight:800;color:#334155}.voice-status.recording{background:#fff1f2;border-color:#fecdd3;color:#b91c1c}.voice-status.loading{background:#fffbeb;border-color:#fde68a;color:#92400e}.voice-status.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.voice-status.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}.voice-playback{width:100%}.hidden-field{display:none!important}button.secondary{background:#eef6ff;color:#1d4ed8;border-color:#bfdbfe}

/* v17 voice recorder visible hotfix */
.voice-tools{background:linear-gradient(135deg,#eff6ff,#f8fbff)!important;border:2px solid #60a5fa!important;box-shadow:0 12px 28px rgba(37,99,235,.12)!important}.voice-tools-head b{font-size:20px}.voice-actions button{min-height:46px}.voice-status{font-size:15px}.voice-tools textarea{min-height:86px}
