:root{
  --navy:#102033;
  --blue:#1f6feb;
  --teal:#15a6a6;
  --green:#2eae64;
  --orange:#f59e0b;
  --red:#dc3545;
  --purple:#6f42c1;
  --bg:#f4f7fb;
  --card:#ffffff;
  --muted:#667085;
  --border:#d9e2ef;
  --dark:#1f2937;
  --shadow:0 12px 30px rgba(16,32,51,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--dark)}
a{color:inherit;text-decoration:none}.app{min-height:100vh;display:flex}.sidebar{width:270px;background:var(--navy);color:#fff;padding:24px 18px;position:fixed;top:0;left:0;bottom:0;overflow-y:auto}.brand{display:flex;gap:12px;align-items:center;margin-bottom:26px}.brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--teal));display:grid;place-items:center;font-weight:800}.brand h1{font-size:18px;margin:0}.brand p{font-size:12px;color:#b9c4d4;margin:2px 0 0}.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#91a0b5;margin:22px 10px 8px}.nav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;margin:4px 0;color:#d9e6f5;font-size:14px}.nav a.active,.nav a:hover{background:rgba(255,255,255,.12);color:#fff}.main{margin-left:270px;width:calc(100% - 270px);padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:16px}.page-title h2{font-size:28px;margin:0;color:var(--navy)}.page-title p{margin:4px 0 0;color:var(--muted)}.user-pill{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px 12px;box-shadow:var(--shadow);white-space:nowrap}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--blue));color:#fff;display:grid;place-items:center;font-weight:700}.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:20px;box-shadow:var(--shadow)}.card h3{margin:0 0 12px;color:var(--navy);font-size:18px}.metric{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.metric strong{font-size:30px;color:var(--navy)}.metric span{color:var(--muted);font-size:13px}.icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#e9f2ff;color:var(--blue);font-size:20px}.icon.green{background:#eaf8f0;color:var(--green)}.icon.orange{background:#fff5df;color:var(--orange)}.icon.red{background:#fff0f0;color:var(--red)}.icon.purple{background:#f2ebff;color:var(--purple)}.btn{border:0;border-radius:12px;padding:11px 14px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:8px;justify-content:center;background:var(--blue);color:#fff}.btn.secondary{background:#e9eef6;color:var(--navy)}.btn.green{background:var(--green)}.btn.orange{background:var(--orange)}.btn.red{background:var(--red)}.btn.danger{background:var(--red);color:#fff}.btn.teal{background:var(--teal)}.btn.dark{background:var(--navy)}.btn.block{width:100%}.btn-row{display:flex;flex-wrap:wrap;gap:10px}.input,.select,textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:12px 13px;font:inherit;background:#fff}label{display:block;font-size:13px;font-weight:700;margin-bottom:7px;color:#344054}.field{margin-bottom:14px}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table th{text-align:left;color:var(--muted);font-size:12px;padding:0 12px}.table td{background:#fff;padding:14px 12px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.table td:first-child{border-left:1px solid var(--border);border-radius:14px 0 0 14px}.table td:last-child{border-right:1px solid var(--border);border-radius:0 14px 14px 0}.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:800}.pill.blue{background:#e9f2ff;color:var(--blue)}.pill.green{background:#eaf8f0;color:var(--green)}.pill.orange{background:#fff5df;color:#a86400}.pill.red{background:#fff0f0;color:var(--red)}.pill.gray{background:#eef2f7;color:#475467}.pill.purple{background:#f2ebff;color:var(--purple)}.map-box{min-height:420px;border-radius:22px;background:linear-gradient(135deg,#dbeafe,#ecfeff);border:1px solid var(--border);position:relative;overflow:hidden}.map-box:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(16,32,51,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(16,32,51,.05) 1px,transparent 1px);background-size:34px 34px}.map-label{position:absolute;top:18px;left:18px;background:#fff;border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);max-width:310px}.pin{position:absolute;width:34px;height:34px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--red);box-shadow:0 8px 18px rgba(0,0,0,.18)}.pin:after{content:"";position:absolute;width:12px;height:12px;border-radius:50%;background:#fff;top:11px;left:11px}.pin.one{top:45%;left:35%;background:var(--blue)}.pin.two{top:58%;left:52%;background:var(--green)}.pin.three{top:33%;left:64%;background:var(--orange)}.pin.four{top:66%;left:72%;background:var(--purple)}.route-line{position:absolute;height:4px;background:rgba(31,111,235,.5);transform-origin:left center;border-radius:999px}.route-line.a{width:210px;top:48%;left:38%;transform:rotate(20deg)}.route-line.b{width:180px;top:58%;left:53%;transform:rotate(-32deg)}.route-line.c{width:170px;top:39%;left:65%;transform:rotate(62deg)}.stop-list{display:grid;gap:10px}.stop{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:13px}.drag{width:28px;height:28px;border-radius:10px;background:#eef2f7;display:grid;place-items:center;color:#667085}.stop-num{width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:800}.stop-info{flex:1}.stop-info strong{display:block}.stop-info small{color:var(--muted)}.timeline{border-left:3px solid #d8e3f2;margin-left:12px;padding-left:20px;display:grid;gap:18px}.timeline-item{position:relative}.timeline-item:before{content:"";position:absolute;left:-30px;top:2px;width:16px;height:16px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 0 0 2px #d8e3f2}.mobile-route{max-width:520px;margin:auto}.route-status{background:linear-gradient(135deg,var(--navy),#1f3b5c);color:#fff;border-radius:26px;padding:22px;box-shadow:var(--shadow)}.route-status h3{color:#fff;margin:0 0 6px;font-size:22px}.route-status p{margin:0;color:#cbd7e7}.big-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}.big-actions .btn{min-height:58px;font-size:16px}.form-preview .conditional{border-left:4px solid var(--teal);padding-left:14px}.alert{border-radius:16px;padding:14px 16px;border:1px solid var(--border);background:#fff}.alert.warning{background:#fff8e8;border-color:#ffe5a3}.alert.danger{background:#fff1f1;border-color:#ffc7c7}.alert.success{background:#ebfff4;border-color:#bae8cc}.footer-note{color:var(--muted);font-size:13px;margin-top:22px;text-align:center}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top left,#dff8ff,transparent 35%),linear-gradient(135deg,#f4f7fb,#e8eef7)}.login-card{max-width:430px;width:100%;background:#fff;border:1px solid var(--border);border-radius:28px;padding:30px;box-shadow:var(--shadow)}.login-card .brand{color:var(--navy);margin-bottom:20px}.quick-links{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.quick-links a{background:#fff;border:1px solid var(--border);border-radius:18px;padding:16px;box-shadow:var(--shadow)}.quick-links strong{display:block;color:var(--navy)}.quick-links span{display:block;color:var(--muted);font-size:13px;margin-top:4px}.mobile-menu{display:none;background:var(--navy);color:#fff;padding:14px 18px;align-items:center;justify-content:space-between;gap:12px;position:sticky;top:0;z-index:20}.mock-note{background:#ecfeff;border:1px solid #b9f4f4;color:#0f5f63;border-radius:16px;padding:12px 14px;margin-bottom:16px;font-size:14px}

.mobile-brand a{font-weight:800;display:block}.mobile-brand small{display:block;color:#b9c4d4}.menu-toggle,.menu-close{border:0;border-radius:12px;background:rgba(255,255,255,.12);color:#fff;padding:10px 12px;font:inherit;font-weight:700;cursor:pointer}.menu-close{background:#e9eef6;color:var(--navy);padding:8px 12px}.mobile-drawer-backdrop{display:none;position:fixed;inset:0;background:rgba(16,32,51,.45);z-index:24}.mobile-drawer{display:none;position:fixed;top:0;right:0;bottom:0;width:min(88vw,360px);background:#fff;z-index:25;box-shadow:-12px 0 30px rgba(16,32,51,.18);padding:18px 16px;overflow-y:auto}.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.mobile-drawer-header strong{display:block;color:var(--navy);font-size:18px}.mobile-drawer-header small{display:block;color:var(--muted);margin-top:2px}.mobile-nav .nav-section{margin:18px 4px 8px}.mobile-nav a{display:flex;align-items:center;gap:10px;padding:12px 12px;border-radius:12px;margin:4px 0;background:#f7f9fc;border:1px solid var(--border);color:var(--navy);font-size:14px;font-weight:600}.mobile-nav a:hover{background:#eef4ff}.menu-open{overflow:hidden}.menu-open .mobile-drawer-backdrop,.menu-open .mobile-drawer{display:block}.menu-open .mobile-drawer{animation:slideInMenu .2s ease-out}@keyframes slideInMenu{from{transform:translateX(16px);opacity:.6}to{transform:translateX(0);opacity:1}}
.stack{display:grid;gap:10px}.list-card{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:13px 14px}.list-card:hover{background:#f7faff}.muted{color:var(--muted)}
@media(max-width:920px){.sidebar{display:none}.main{margin-left:0;width:100%;padding:18px 14px 86px}.mobile-menu{display:flex}.topbar{align-items:flex-start}.user-pill{display:none}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-title h2{font-size:24px}.map-box{min-height:330px}.big-actions{grid-template-columns:1fr}.quick-links{grid-template-columns:1fr}.table th:nth-child(4),.table td:nth-child(4){display:none}}

/* v6 navigation visibility fix: desktop uses only sidebar; mobile uses only drawer */
@media (min-width: 921px){
  .mobile-menu,
  .mobile-drawer,
  .mobile-drawer-backdrop{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
    height:0 !important;
    max-height:0 !important;
    overflow:hidden !important;
  }
  body.menu-open{overflow:auto !important;}
}
@media (max-width: 920px){
  .mobile-drawer{
    display:block !important;
    visibility:hidden;
    opacity:0;
    transform:translateX(110%);
    transition:transform .2s ease-out, opacity .2s ease-out, visibility .2s ease-out;
  }
  .mobile-drawer-backdrop{
    display:none !important;
  }
  body.menu-open .mobile-drawer{
    visibility:visible;
    opacity:1;
    transform:translateX(0);
  }
  body.menu-open .mobile-drawer-backdrop{
    display:block !important;
    visibility:visible;
    opacity:1;
    pointer-events:auto;
  }
}
.small-muted{color:var(--muted);font-size:13px}.stack{display:grid;gap:12px}.split{display:flex;align-items:center;justify-content:space-between;gap:12px}.code-note{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f7f9fc;border:1px solid var(--border);border-radius:12px;padding:12px;overflow:auto}.empty-state{text-align:center;padding:28px;color:var(--muted)}.inline-form{display:inline}.search-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:10px}.role-filter{display:flex;gap:8px;flex-wrap:wrap}.mini-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff}@media(max-width:920px){.search-row{grid-template-columns:1fr}.split{align-items:flex-start;flex-direction:column}.btn-row .btn{width:100%}}
.route-search-results{margin-top:12px;display:grid;gap:10px;max-height:360px;overflow:auto}.route-result{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border:1px solid var(--border);background:#fff;border-radius:16px;padding:12px}.route-result strong{display:block;color:var(--navy)}.route-result small{color:var(--muted)}.stop-actions{display:flex;gap:6px;flex-wrap:wrap}.mini-btn{border:0;border-radius:10px;background:#e9eef6;color:var(--navy);padding:7px 9px;font-weight:800;cursor:pointer}.mini-btn.danger{background:#fff0f0;color:var(--red)}
@media(max-width:920px){.route-result{display:block}.route-result .btn{margin-top:10px}.stop{align-items:flex-start}.stop-actions{width:100%;margin-top:8px}}
.current-stop{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,111,235,.10)}
button:disabled,.btn:disabled{opacity:.55;cursor:not-allowed}
.route-action-status{margin-top:12px;color:#d7e4f5!important}
.required{color:var(--red);font-weight:800}.choice-list{display:grid;gap:8px}.choice{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--dark)}.choice input{width:auto}.card-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.soft-hr{border:0;border-top:1px solid var(--border);margin:18px 0}.option-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.builder-inline-form,.compact-form{margin-top:12px}.option-list{display:grid;gap:8px;margin-bottom:12px}.checkin-question[style*="display: none"]{opacity:.65}@media(max-width:920px){.card-header-row,.option-row{align-items:stretch;flex-direction:column}.grid-4{grid-template-columns:1fr}}

/* Check-In Builder usability upgrades */
.builder-top-grid{align-items:start}.builder-tip-list{display:grid;gap:12px}.builder-tip-list div{border:1px solid var(--border);background:#f8fbff;border-radius:16px;padding:12px}.builder-tip-list strong{display:block;color:var(--navy)}.builder-tip-list span{display:block;color:var(--muted);font-size:13px;margin-top:3px}.builder-toolbar{align-items:center}.question-builder-list{display:grid;gap:12px;margin-top:16px}.question-builder-card{border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 8px 22px rgba(16,32,51,.05);overflow:hidden}.question-builder-card.is-dragging{opacity:.55;box-shadow:0 12px 28px rgba(16,32,51,.16)}.question-summary{display:flex;align-items:center;gap:12px;padding:14px}.drag-handle{width:36px;height:36px;border-radius:12px;background:#eef2f7;display:grid;place-items:center;color:#667085;font-weight:900;cursor:grab;flex:0 0 auto}.question-builder-card:active .drag-handle{cursor:grabbing}.question-summary-main{flex:1;min-width:0}.question-title-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.question-title-line strong{color:var(--navy);font-size:16px}.question-edit-toggle{white-space:nowrap}.question-edit-panel{border-top:1px solid var(--border);background:#fbfdff;padding:16px}.builder-section-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}.builder-section-title h4{margin:0;color:var(--navy)}.builder-add-row{background:#fff;border:1px dashed var(--border);border-radius:16px;padding:14px}.drag-placeholder{border:2px dashed var(--blue);border-radius:18px;min-height:68px;background:#f0f6ff}@media(max-width:920px){.builder-toolbar{align-items:stretch;flex-direction:column}.builder-toolbar form,.builder-toolbar .btn{width:100%}.question-summary{align-items:flex-start}.question-title-line{gap:6px}.question-edit-toggle{margin-left:auto}.drag-handle{width:34px;height:34px}.builder-section-title{align-items:flex-start;flex-direction:column}}

.selected-account-box{background:#f7f9fc;border:1px solid var(--border);border-radius:14px;padding:12px 14px;color:var(--navy)}

.check-row{display:flex;align-items:center;gap:8px;background:#f7f9fc;border:1px solid var(--border);border-radius:12px;padding:10px;margin:0;font-weight:600}.check-row input{width:auto}

.map-box.live-google:before{display:none}.map-box.live-google{background:#e9eef6}.map-box.live-google .map-label{z-index:2}.pagination{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.route-cart-badge{position:fixed;right:18px;bottom:18px;z-index:30;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:999px;padding:10px 14px;font-weight:800;color:var(--navy)}.route-result{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border);border-radius:16px;padding:12px;margin-top:10px;background:#fff}.route-result small{display:block;color:var(--muted);margin-top:4px}.stop-actions{display:flex;gap:6px;flex-wrap:wrap}.mini-btn{border:0;border-radius:9px;background:#e9eef6;color:var(--navy);padding:7px 9px;font-weight:800;cursor:pointer}.mini-btn:disabled{opacity:.5;cursor:not-allowed}.mini-btn.danger{background:#fff0f0;color:var(--red)}
@media(max-width:920px){.route-cart-badge{left:14px;right:14px;text-align:center;border-radius:16px}.route-result{align-items:flex-start;flex-direction:column}.route-result .btn{width:100%}}

.search-overlay{position:fixed;inset:0;background:rgba(16,32,51,.55);display:grid;place-items:center;z-index:9999;padding:20px}.search-overlay-card{width:min(420px,92vw);background:#fff;border-radius:24px;padding:26px;text-align:center;box-shadow:0 20px 60px rgba(16,32,51,.28);border:1px solid var(--border)}.search-overlay-card h3{margin:12px 0 6px;color:var(--navy)}.search-overlay-card p{margin:0;color:var(--muted);line-height:1.45}.spinner{width:42px;height:42px;border-radius:50%;border:4px solid #d9e2ef;border-top-color:var(--blue);margin:0 auto;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}


/* v9K mobile-friendly result tables */
.table.mobile-cards{min-width:0}
@media(max-width:920px){
  .table-wrap.no-mobile-scroll{overflow:visible}
  .table.mobile-cards{border-spacing:0;display:block;width:100%}
  .table.mobile-cards thead{display:none}
  .table.mobile-cards tbody{display:grid;gap:12px;width:100%}
  .table.mobile-cards tr{display:block;background:#fff;border:1px solid var(--border);border-radius:18px;padding:12px;box-shadow:0 8px 20px rgba(16,32,51,.05)}
  .table.mobile-cards td{display:grid;grid-template-columns:104px 1fr;gap:10px;align-items:start;border:0!important;border-radius:0!important;background:transparent!important;padding:7px 0!important;word-break:break-word}
  .table.mobile-cards td:before{content:attr(data-label);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:800;padding-top:2px}
  .table.mobile-cards td.actions-cell{display:block;padding-top:10px!important;border-top:1px solid var(--border)!important;margin-top:5px}
  .table.mobile-cards td.actions-cell:before{display:block;margin-bottom:8px}
  .table.mobile-cards td[colspan]{display:block;text-align:center}
  .table.mobile-cards td[colspan]:before{content:'';display:none}
  .table.mobile-cards .btn-row .btn,.table.mobile-cards .btn-row a{width:100%}
  .map-box.live-google{min-height:360px}
}

.search-overlay.is-active{display:grid!important;}

/* Active route stop controls */
.active-route-top-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.active-route-stop{align-items:flex-start}.active-route-stop.dragging{opacity:.55;border-style:dashed}.active-route-stop.completed-stop{background:#f8fafc}.active-route-stop .active-drag-handle{cursor:grab;border:0}.active-route-stop .active-drag-handle:disabled{opacity:.45;cursor:not-allowed}.active-stop-actions{justify-content:flex-end;max-width:230px}.mini-btn.orange{background:#fff5df;color:#a86400}.mini-btn.teal{background:#e6fffb;color:#0f766e}.active-route-savebar{margin-top:14px;border-top:1px solid var(--border);padding-top:14px;display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.active-route-savebar[hidden]{display:none!important}
@media(max-width:680px){.active-route-stop{display:grid;grid-template-columns:auto auto 1fr;align-items:start}.active-route-stop .pill{grid-column:2 / 4}.active-stop-actions{grid-column:1 / 4;max-width:none;width:100%;justify-content:flex-start}.active-route-top-actions{grid-template-columns:1fr}.active-route-savebar{position:sticky;bottom:74px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:12px;z-index:15;box-shadow:var(--shadow)}}

/* v10c active route cleanup */
.mobile-route{max-width:1120px;width:100%;margin:0 auto}.route-status{padding:26px}.route-status h3{font-size:26px}.route-status p{line-height:1.55}.active-route-stop{display:grid;grid-template-columns:34px 38px minmax(260px,1fr) auto minmax(260px,auto);align-items:center;gap:14px;padding:16px;border-radius:20px}.active-route-stop .stop-info small{display:block;line-height:1.45;margin-top:4px}.active-stop-actions{max-width:none;justify-content:flex-end}.active-stop-actions .mini-btn{min-width:88px;text-align:center}.active-route-stop .pill{justify-self:start}.active-route-savebar{background:#fff;border:1px solid var(--border);border-radius:18px;padding:14px 16px;box-shadow:0 10px 25px rgba(16,32,51,.08)}.active-route-savebar .small-muted{font-weight:700;color:var(--navy)}.route-preview-map{min-height:360px}.active-stop-list{gap:14px}@media(max-width:980px){.active-route-stop{grid-template-columns:34px 38px 1fr;align-items:start}.active-route-stop .pill{grid-column:2 / 4}.active-stop-actions{grid-column:1 / 4;justify-content:flex-start;width:100%}.active-stop-actions .mini-btn{flex:1;min-width:120px}.mobile-route{max-width:100%}}@media(max-width:560px){.route-status{border-radius:22px;padding:20px}.route-status h3{font-size:22px}.active-route-stop{grid-template-columns:30px 34px 1fr;padding:14px;gap:10px}.active-stop-actions{display:grid;grid-template-columns:1fr 1fr}.active-stop-actions .mini-btn{min-width:0;width:100%}.active-route-savebar .btn-row{width:100%}.active-route-savebar .btn-row .btn{flex:1}.big-actions .btn{min-height:54px}}

/* v10d active route polish */
.route-is-complete{filter:grayscale(.18);}
.completed-route-status{background:#eef1f5!important;border:1px solid #cbd5e1!important;box-shadow:inset 0 0 0 9999px rgba(15,23,42,.035), var(--shadow)!important;}
.completed-route-status h3,.completed-route-status p{color:#475569!important;}
.route-is-complete .card,.route-is-complete .route-preview-map{background:#f1f5f9!important;border-color:#cbd5e1!important;}
.active-route-stop.completed-stop{background:#e9eef4!important;border:1px solid #cbd5e1!important;opacity:.78;}
.active-route-stop.completed-stop .stop-info strong,.active-route-stop.completed-stop .stop-info small{color:#64748b!important;}
.active-route-savebar{position:fixed!important;left:50%!important;right:auto!important;bottom:18px!important;transform:translateX(-50%)!important;width:min(1040px,calc(100vw - 28px))!important;margin:0!important;z-index:9999!important;border:1px solid #bfdbfe!important;box-shadow:0 18px 45px rgba(15,23,42,.22)!important;background:#fff!important;padding:14px 16px!important;}
.active-route-savebar-copy{line-height:1.25;}
.active-route-savebar-copy strong{color:var(--navy);font-size:15px;}
.active-route-savebar .btn-row{margin-left:auto;}
.active-route-savebar[hidden]{display:none!important;}
@media(max-width:680px){.active-route-savebar{bottom:calc(82px + env(safe-area-inset-bottom))!important;align-items:stretch!important;}.active-route-savebar .btn-row{width:100%;}.active-route-savebar .btn-row .btn{flex:1;}}

/* v10e: true footer-sticky active route save bar */
.active-route-savebar{
  position:fixed!important;
  left:0!important;
  right:0!important;
  bottom:0!important;
  transform:none!important;
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  z-index:2147483000!important;
  border:0!important;
  border-top:3px solid #2563eb!important;
  border-radius:18px 18px 0 0!important;
  background:#ffffff!important;
  box-shadow:0 -18px 45px rgba(15,23,42,.26)!important;
  padding:16px max(18px, env(safe-area-inset-left)) calc(16px + env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-right))!important;
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  gap:18px!important;
}
.active-route-savebar[hidden]{display:none!important;}
.active-route-savebar-copy{max-width:620px;line-height:1.28!important;}
.active-route-savebar-copy strong{font-size:16px!important;color:#0f172a!important;}
.active-route-savebar .small-muted{color:#334155!important;font-weight:700!important;}
.active-route-savebar .btn-row{margin-left:0!important;display:flex!important;gap:10px!important;align-items:center!important;}
body.has-active-route-unsaved{padding-bottom:126px!important;}
@media(max-width:680px){
  .active-route-savebar{
    bottom:0!important;
    flex-direction:column!important;
    align-items:stretch!important;
    gap:12px!important;
    padding:14px 14px calc(14px + env(safe-area-inset-bottom)) 14px!important;
  }
  .active-route-savebar-copy{max-width:none!important;text-align:left!important;}
  .active-route-savebar .btn-row{width:100%!important;}
  .active-route-savebar .btn-row .btn{flex:1!important;min-height:48px!important;}
  body.has-active-route-unsaved{padding-bottom:170px!important;}
}

/* v10f friendly Check-In/Form Builder */
.builder-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;background:linear-gradient(135deg,#ffffff,#f4f9ff)}
.builder-hero-main h3{font-size:24px;margin:10px 0 6px}.builder-hero-main p{max-width:720px;line-height:1.45}.builder-stats{display:grid;grid-template-columns:repeat(4,minmax(92px,1fr));gap:10px;min-width:min(520px,100%)}
.builder-stats div{background:#fff;border:1px solid var(--border);border-radius:18px;padding:14px;text-align:center;box-shadow:0 8px 18px rgba(16,32,51,.04)}.builder-stats strong{display:block;color:var(--navy);font-size:26px}.builder-stats span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.builder-layout-grid{grid-template-columns:minmax(320px,1.15fr) minmax(280px,.85fr);align-items:start}.builder-create-card{position:sticky;top:18px}.builder-title-input{font-size:16px;font-weight:650}.builder-type-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.builder-type-option{display:block;border:1px solid var(--border);background:#fff;border-radius:16px;padding:12px;cursor:pointer;margin:0;transition:.15s ease}.builder-type-option:hover,.builder-type-option.is-selected{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,111,235,.10);background:#f8fbff}.builder-type-option input{position:absolute;opacity:0;pointer-events:none}.builder-type-option strong{display:block;color:var(--navy);font-size:14px}.builder-type-option small{display:block;color:var(--muted);font-weight:500;margin-top:2px;line-height:1.25}.builder-required-field .check-row{height:45px;align-items:center}.builder-guide-card{background:linear-gradient(135deg,#102033,#1f3b5c);color:#fff}.builder-guide-card h3{color:#fff}.builder-guide-card .small-muted,.builder-guide-card .builder-tip-list span{color:#d5deeb}.builder-guide-card .builder-tip-list div{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16)}.builder-guide-card .builder-tip-list strong{color:#fff}.condition-example-card{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:10px;align-items:center;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:14px;margin:12px 0 16px}.condition-example-card strong,.condition-example-card span{display:block}.condition-example-card span{color:#d5deeb;font-size:13px;margin-top:2px}.condition-if,.condition-then,.condition-badge{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#e9f2ff;color:var(--blue);font-weight:900}.condition-then{background:#eaf8f0;color:var(--green)}
.builder-question-shell{margin-top:18px}.builder-toolbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.builder-question-search{width:240px}.friendly-builder-list{gap:14px}.friendly-question-card{transition:.15s ease;border-left:5px solid var(--blue)}.friendly-question-card:hover{box-shadow:0 12px 28px rgba(16,32,51,.09)}.friendly-question-card.is-inactive{border-left-color:#98a2b3;opacity:.82}.friendly-question-card.is-hidden-by-search{display:none}.friendly-question-summary{padding:16px}.question-number-bubble{width:44px;height:44px;border-radius:16px;background:#f2f6fb;color:var(--navy);display:grid;place-items:center;font-weight:900;font-size:12px;flex:0 0 auto}.friendly-edit-panel{padding:18px;background:linear-gradient(180deg,#fbfdff,#ffffff)}.builder-panel-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(270px,.75fr);gap:16px;align-items:start}.builder-edit-box,.builder-preview-box{background:#fff;border:1px solid var(--border);border-radius:18px;padding:16px}.builder-form-actions{margin-top:14px}.checkin-preview-card{border:1px dashed var(--border);background:#f8fbff;border-radius:18px;padding:16px}.preview-choices{margin-top:8px}.option-chip-list{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0}.option-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:#fff;border-radius:999px;padding:8px 8px 8px 12px}.option-chip strong{color:var(--navy);font-size:13px}.option-chip small{display:block;color:var(--muted);font-size:11px;margin-top:1px}.empty-mini{background:#f8fbff;border:1px dashed var(--border);border-radius:16px;padding:13px;color:var(--muted);font-size:13px;margin:8px 0}.friendly-add-row{background:#fbfdff}.condition-rule-list{display:grid;gap:10px;margin:12px 0}.condition-rule-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto minmax(0,.7fr) auto;gap:10px;align-items:center;border:1px solid var(--border);border-radius:18px;padding:12px;background:#fff}.condition-rule-card.show-rule{border-left:5px solid var(--green)}.condition-rule-card.hide-rule{border-left:5px solid var(--orange)}.condition-rule-card .then{background:#eaf8f0;color:var(--green)}.condition-rule-text strong,.condition-rule-text span{display:block}.condition-rule-text strong{color:var(--navy)}.condition-rule-text span{color:var(--muted);font-size:13px;margin-top:2px}.condition-builder-box{background:#f8fbff;border:1px solid var(--border);border-radius:18px;padding:14px}.condition-builder-flow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}.condition-step{background:#fff;border:1px solid var(--border);border-radius:16px;padding:12px}.condition-step span{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:#e9f2ff;color:var(--blue);font-weight:900;margin-bottom:8px}.condition-step strong{display:block;color:var(--navy);font-size:13px;margin-bottom:8px}.condition-step .select,.condition-step .input{padding:10px 11px}.question-edit-toggle{min-width:78px}
@media(max-width:1100px){.builder-hero{align-items:stretch;flex-direction:column}.builder-stats{min-width:0}.builder-layout-grid,.builder-panel-grid{grid-template-columns:1fr}.builder-create-card{position:static}.condition-builder-flow{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:920px){.builder-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.builder-type-grid{grid-template-columns:1fr}.builder-toolbar-actions{align-items:stretch;flex-direction:column;width:100%}.builder-toolbar-actions .input,.builder-toolbar-actions .btn,.builder-toolbar-actions form{width:100%}.friendly-question-summary{display:grid;grid-template-columns:auto auto 1fr;align-items:start}.friendly-question-summary .question-edit-toggle{grid-column:1/-1;width:100%;margin-left:0}.condition-example-card,.condition-rule-card{grid-template-columns:1fr}.condition-if,.condition-then,.condition-badge{width:auto;height:auto;padding:7px 10px}.condition-builder-flow{grid-template-columns:1fr}.option-chip{width:100%;border-radius:16px;justify-content:space-between}.builder-hero-main h3{font-size:21px}}

/* v10g Account Details Builder + account-view polish */
.account-detail-card .card-header-row{align-items:flex-start;gap:14px}
.account-detail-form{display:grid;gap:14px;margin-top:14px}
.account-detail-question{padding:12px;border:1px solid rgba(16,32,51,.08);border-radius:16px;background:rgba(248,250,252,.72)}
.account-detail-question label:first-child{font-weight:800;color:#102033}
.account-detail-question textarea,.account-detail-question input,.account-detail-question select{margin-top:6px}
@media (max-width: 980px){.account-profile-grid{grid-template-columns:1fr!important}.account-detail-card .card-header-row{display:block}.account-detail-card .card-header-row .btn{margin-top:10px}}

/* v10h Weekly Reports + native mobile app polish */
.weekly-report-grid{align-items:start}.weekly-field-list,.weekly-question-list{display:grid;gap:10px;margin-top:12px}.weekly-field-option,.weekly-question-option{display:flex;align-items:center;gap:12px;border:1px solid var(--border);background:#fff;border-radius:16px;padding:12px;cursor:pointer;transition:.15s ease}.weekly-field-option:hover,.weekly-question-option:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,111,235,.08)}.weekly-field-option input,.weekly-question-option input{width:18px;height:18px;flex:0 0 auto}.weekly-field-option span,.weekly-question-option span{display:block}.weekly-field-option strong,.weekly-question-option strong{display:block;color:var(--navy);font-size:14px}.weekly-field-option small,.weekly-question-option small{display:block;color:var(--muted);font-size:12px;margin-top:2px}.weekly-question-option.is-inactive{opacity:.62;background:#f8fafc}.check-row{display:flex;align-items:center;gap:10px}.check-row input{width:18px;height:18px;flex:0 0 auto}
.mobile-tabbar{display:none}
@media(max-width:920px){
  html{background:#0b1726;min-height:100%;}
  body{background:linear-gradient(180deg,#0b1726 0,#102033 118px,#f4f7fb 118px);padding-top:env(safe-area-inset-top);overscroll-behavior-y:none;}
  .mobile-menu{position:sticky;top:0;z-index:50;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 12px 30px rgba(15,23,42,.22);}
  .mobile-brand a{font-size:18px}.mobile-brand small{font-size:11px}.menu-toggle{border-radius:999px;min-height:42px;padding:10px 14px;background:rgba(255,255,255,.14)}
  .main{padding:16px 14px calc(102px + env(safe-area-inset-bottom));}
  .topbar{background:rgba(255,255,255,.96);border:1px solid rgba(217,226,239,.92);box-shadow:0 16px 34px rgba(16,32,51,.12);border-radius:24px;padding:16px;margin-bottom:16px;}
  .page-title h2{font-size:23px;line-height:1.12}.page-title p{font-size:13px;line-height:1.35}.card{border-radius:24px;padding:18px;box-shadow:0 10px 28px rgba(16,32,51,.08)}
  .btn{min-height:46px;border-radius:15px}.input,.select,textarea{min-height:46px;border-radius:15px;font-size:16px}.table td{padding:13px 10px}.map-box{border-radius:24px;min-height:360px}.list-card,.stop,.route-result{border-radius:20px}
  .mobile-tabbar{position:fixed;left:0;right:0;bottom:0;z-index:2147482000;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:8px 10px calc(8px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-top:1px solid rgba(217,226,239,.95);box-shadow:0 -12px 30px rgba(15,23,42,.16)}
  .mobile-tabbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:54px;border-radius:18px;color:#667085;font-weight:800}.mobile-tabbar a span{font-size:20px;line-height:1}.mobile-tabbar a small{font-size:10px;letter-spacing:.01em}.mobile-tabbar a.active{background:#e9f2ff;color:var(--blue)}
  .mobile-drawer{border-radius:24px 0 0 24px;padding-top:calc(18px + env(safe-area-inset-top))}.mobile-nav a{min-height:48px;border-radius:16px}.grid.weekly-report-grid{grid-template-columns:1fr}.weekly-field-option,.weekly-question-option{border-radius:18px;padding:14px}.builder-hero{border-radius:24px}.builder-stats div{border-radius:20px}
}

/* AI Assistant */
.quick-prompt-list{display:grid;gap:10px}.quick-prompt-list .btn{justify-content:flex-start;text-align:left;white-space:normal}.ai-answer{background:#f8fafc;border:1px solid var(--border);border-radius:18px;padding:18px;line-height:1.55;color:#26364a}.ai-answer-card{border-color:#cfe1ff}.soft-panel{background:#f8fafc;border:1px solid var(--border);border-radius:18px;padding:16px}.row-between{display:flex;align-items:center;justify-content:space-between}.stack{display:grid}.gap-12{gap:12px}.muted,.small-muted{color:var(--muted)}.form-label{margin-bottom:0}


/* Route Builder selected stop last check-in badge */
.stop-last-checkin{
  margin-top:8px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.stop .stop-info small{
  display:block;
  margin-top:3px;
}

/* 2026-06-10: Field test mobile cleanup
   Hide the bottom mobile icon tab bar so it does not cover page actions/forms.
   The slide-out mobile menu remains the only mobile navigation. */
.mobile-tabbar,
nav.mobile-tabbar {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  body,
  .main {
    padding-bottom: env(safe-area-inset-bottom) !important;
  }
}

/* v9 Leaflet safe mobile layering: keep app navigation above maps without hiding maps. */
.leaflet-container{z-index:1;position:relative;}
.mobile-menu{z-index:2147482500!important;}
.mobile-tabbar{z-index:2147482400!important;}
.mobile-drawer-backdrop{z-index:2147483000!important;}
.mobile-drawer{z-index:2147483100!important;}
body.menu-open .mobile-drawer-backdrop{z-index:2147483000!important;}
body.menu-open .mobile-drawer{z-index:2147483100!important;}
body.menu-open .leaflet-container{pointer-events:none;}
body.menu-open .mobile-drawer,
body.menu-open .mobile-drawer *{pointer-events:auto;}
