/* ==========================================================================
   Placora — design system (Krishna Dental STYLE_GUIDE, sky -> blue)
   ========================================================================== */
:root{
  --sky:#0ea5e9; --blue:#0369a1; --blue-dark:#075985; --sky-soft:#e0f2fe;
  --teal:#0d9488; --teal-soft:#ccfbf1;
  --green:#059669; --green-soft:#d1fae5;
  --amber:#d97706; --amber-soft:#fef3c7;
  --red:#dc2626; --red-soft:#fee2e2;
  --gray-badge:#64748b; --gray-soft:#f1f5f9;
  --ink:#0f172a; --ink-2:#334155; --muted:#64748b; --muted-2:#94a3b8;
  --line:#e2e8f0; --line-2:#cbd5e1; --bg:#f8fafc; --bg-2:#f1f5f9;
  --radius:14px; --radius-lg:18px; --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow:0 4px 12px -4px rgba(15,23,42,.12);
  --shadow-lg:0 12px 32px -16px rgba(15,23,42,.18);
  --brand-logo:url('/assets/img/logo.svg');
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--ink);min-height:100dvh;line-height:1.5;overflow-x:hidden}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-dark)}
img,svg{max-width:100%;height:auto;display:block}
i[class^="ri-"],i[class*=" ri-"]{font-style:normal;line-height:1;display:inline-flex;vertical-align:middle}
h1,h2,h3{letter-spacing:-.02em}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:var(--radius-sm);font-size:14.5px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:filter .15s,transform .05s,background .15s;font-family:inherit;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.6;cursor:not-allowed}
.btn-primary{background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff}
.btn-primary:hover{filter:brightness(1.05);color:#fff}
.btn-secondary{background:#fff;color:var(--ink-2);border-color:var(--line-2)}
.btn-secondary:hover{background:var(--bg-2);color:var(--ink)}
.btn-success{background:var(--green);color:#fff}
.btn-danger{background:var(--red);color:#fff}
.btn-warn{background:var(--amber);color:#fff}
.btn-ghost{background:transparent;color:var(--ink-2)}
.btn-ghost:hover{background:var(--bg-2)}
.btn-light{background:#fff;color:var(--blue)}
.btn.sm{padding:8px 13px;font-size:13px}
.btn.lg{padding:14px 24px;font-size:16px}
.btn-full{width:100%}
.icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;font-size:20px;cursor:pointer;color:var(--ink-2)}
.icon-btn:hover{background:var(--bg-2)}

/* ---- Cards ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.card.lg{padding:26px;border-radius:var(--radius-lg)}
.card-title{font-size:16px;font-weight:700;margin-bottom:14px}

/* ---- Badges ---- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.6}
.badge.gray{background:var(--gray-soft);color:var(--gray-badge)}
.badge.blue{background:var(--sky-soft);color:var(--blue)}
.badge.teal{background:var(--teal-soft);color:var(--teal)}
.badge.green{background:var(--green-soft);color:var(--green)}
.badge.amber{background:var(--amber-soft);color:var(--amber)}
.badge.red{background:var(--red-soft);color:var(--red)}

/* ---- Forms ---- */
.form-group{margin-bottom:15px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-soft)}
textarea{resize:vertical;min-height:84px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hint{font-size:12px;color:var(--muted);margin-top:5px}
@media(max-width:520px){.field-row{grid-template-columns:1fr}}

/* ---- Messages / spinner / skeleton ---- */
.msg{padding:11px 14px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:8px}
.msg.err{background:var(--red-soft);color:#b91c1c}
.msg.ok{background:var(--green-soft);color:#047857}
.msg.info{background:var(--sky-soft);color:var(--blue)}
.msg.warn{background:var(--amber-soft);color:#b45309}
.spinner{width:16px;height:16px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--blue);border-radius:50%;display:inline-block;animation:spin .7s linear infinite}
.spinner.white{border-color:rgba(255,255,255,.4);border-top-color:#fff}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:linear-gradient(90deg,var(--bg-2) 25%,#e9eef5 50%,var(--bg-2) 75%);background-size:200% 100%;animation:sk 1.3s infinite;border-radius:8px}
@keyframes sk{to{background-position:-200% 0}}

/* ---- Stats ---- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:720px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}
.stat .label{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:6px}
.stat .value{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.stat .meta{font-size:12px;color:var(--muted-2);margin-top:2px}
.stat.accent{background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;border:none}
.stat.accent .label,.stat.accent .meta{color:rgba(255,255,255,.85)}

/* ---- Tables ---- */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;padding:10px 12px;border-bottom:1px solid var(--line)}
.table td{padding:11px 12px;border-bottom:1px solid var(--line)}
.table tr:hover td{background:var(--bg)}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}

/* ---- Layout utils ---- */
.mt-1{margin-top:6px}.mt-2{margin-top:10px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mt-5{margin-top:32px}
.mb-2{margin-bottom:10px}.mb-3{margin-bottom:16px}.mb-4{margin-bottom:24px}
.row{display:flex;gap:10px;align-items:center}
.row.between{justify-content:space-between}
.row.wrap{flex-wrap:wrap}
.grow{flex:1}
.muted{color:var(--muted)}
.text-sm{font-size:13px}.text-xs{font-size:12px}
.center{text-align:center}
.split{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}}
.grid-3{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.hide-mobile{display:none}
@media(min-width:1024px){.hide-mobile{display:block}.hide-desktop{display:none}}

/* ---- Admin shell ---- */
.admin-layout{min-height:100dvh}
.admin-sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px;z-index:60;transform:translateX(-100%);transition:transform .2s}
.admin-sidebar.open{transform:translateX(0)}
.admin-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 16px;border-bottom:1px solid var(--line);margin-bottom:12px}
.admin-brand .logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;display:grid;place-items:center;font-size:22px;flex-shrink:0}
.admin-brand h1{font-size:15px;font-weight:800;line-height:1.2}
.admin-brand p{font-size:11.5px;color:var(--muted);font-weight:600}
.admin-sidebar>nav{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.admin-nav{list-style:none;display:flex;flex-direction:column;gap:3px;flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.admin-nav .nav-section{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);padding:14px 13px 5px}
.admin-nav a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:10px;color:var(--ink-2);font-size:14.5px;font-weight:600}
.admin-nav a .icon{font-size:20px}
.admin-nav a:hover{background:var(--bg-2);color:var(--ink)}
.admin-nav a.active{background:var(--sky-soft);color:var(--blue)}
.admin-nav a .count{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:1px 7px}
.admin-user-card{border-top:1px solid var(--line);padding-top:14px;margin-top:8px}
.admin-user-card .name{font-size:14px;font-weight:700}
.admin-user-card .role{font-size:12px;color:var(--muted);text-transform:capitalize}
.admin-sidebar-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:55;display:none}
.admin-sidebar-backdrop.show{display:block}
.admin-main{padding:0;min-height:100dvh}
.admin-mobile-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.admin-header{padding:20px 16px 8px}
.admin-header h1{font-size:22px;font-weight:800}
.admin-header p{font-size:14px;color:var(--muted)}
.admin-content{padding:16px}
@media(min-width:1024px){
  body.admin{background:var(--bg-2)}
  .admin-sidebar{transform:none}
  .admin-main{margin-left:260px}
  .admin-mobile-bar{display:none}
  .admin-header{padding:26px 32px 10px}
  .admin-content{padding:12px 32px 48px}
  .admin-sidebar-backdrop{display:none !important}
}

/* ---- Public landing (ld-*) ---- */
.ld-wrap{max-width:1140px;margin:0 auto;padding:0 20px}
.ld-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.ld-header .ld-wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.ld-brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:17px;color:var(--ink)}
.ld-brand .logo{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;display:grid;place-items:center;font-size:22px}
.ld-brand small{display:block;font-size:10.5px;font-weight:600;color:var(--muted);letter-spacing:.04em}
.ld-nav-links{display:none;gap:24px;margin-right:10px}
.ld-nav-links a{color:var(--ink-2);font-weight:600;font-size:14.5px}
.ld-nav-links a:hover{color:var(--blue)}
@media(min-width:860px){.ld-nav-links{display:flex}}
@media(max-width:600px){.ld-header .ld-wrap{height:58px;padding:0 14px}.ld-brand small{display:none}.ld-brand{font-size:15px}}
.ld-hero{background:linear-gradient(160deg,#f0f9ff 0%,#e0f2fe 55%,#ecfeff 100%);border-bottom:1px solid var(--line)}
.ld-hero .ld-wrap{display:grid;grid-template-columns:1fr;gap:34px;padding:48px 20px 52px;align-items:center}
@media(min-width:920px){.ld-hero .ld-wrap{grid-template-columns:1.05fr .95fr;padding:72px 20px 80px}}
.ld-pill{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--sky-soft);color:var(--blue);padding:7px 14px;border-radius:999px;font-size:13px;font-weight:700;box-shadow:var(--shadow-sm)}
.ld-hero h1{font-size:38px;line-height:1.08;font-weight:800;letter-spacing:-.025em;margin:16px 0 14px}
@media(min-width:920px){.ld-hero h1{font-size:52px}}
.ld-hero h1 .accent{background:linear-gradient(120deg,var(--sky),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent}
.ld-hero p.lead{font-size:17px;line-height:1.6;color:var(--ink-2);max-width:540px;margin-bottom:26px}
.ld-cta{display:flex;flex-wrap:wrap;gap:12px}
.ld-trust{display:flex;flex-wrap:wrap;gap:20px;margin-top:28px}
.ld-trust .item{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--ink-2)}
.ld-trust .item i{color:var(--green);font-size:19px}
.ld-hero-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow-lg)}
.ld-section{padding:60px 0}
.ld-section.alt{background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ld-head{text-align:center;max-width:620px;margin:0 auto 40px}
.ld-head .eyebrow{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--sky)}
.ld-head h2{font-size:29px;font-weight:800;margin:10px 0 12px}
.ld-head p{font-size:16px;color:var(--muted);line-height:1.6}
.ld-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.ld-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.ld-grid.cols-3{grid-template-columns:repeat(3,1fr)}.ld-grid.cols-4{grid-template-columns:repeat(4,1fr)}}
.ld-feature{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 20px;transition:transform .15s,box-shadow .15s}
.ld-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.ld-feature .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:26px;margin-bottom:14px;background:var(--sky-soft);color:var(--blue)}
.ld-feature.teal .ic{background:var(--teal-soft);color:var(--teal)}
.ld-feature.green .ic{background:var(--green-soft);color:var(--green)}
.ld-feature.amber .ic{background:var(--amber-soft);color:var(--amber)}
.ld-feature h3{font-size:17px;font-weight:700;margin-bottom:6px}
.ld-feature p{font-size:14px;color:var(--muted);line-height:1.6}
.ld-banner{background:linear-gradient(135deg,var(--sky),var(--blue));border-radius:24px;padding:46px 28px;text-align:center;color:#fff;box-shadow:0 24px 56px -24px rgba(3,105,161,.6)}
.ld-banner h2{font-size:29px;font-weight:800;margin-bottom:10px}
.ld-banner p{font-size:16px;opacity:.92;margin-bottom:22px}
.ld-footer{background:var(--ink);color:#cbd5e1;padding:46px 0 26px}
.ld-footer .ld-wrap{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:760px){.ld-footer .ld-wrap{grid-template-columns:1.4fr 1fr 1fr}}
.ld-footer .brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;font-size:17px;margin-bottom:12px}
.ld-footer .brand .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--sky),var(--blue));display:grid;place-items:center;font-size:20px;color:#fff}
.ld-footer p{font-size:13.5px;line-height:1.7;color:#94a3b8}
.ld-footer h5{color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:12px}
.ld-footer a{color:#cbd5e1;font-size:14px;display:flex;align-items:center;gap:9px;padding:5px 0}
.ld-footer a:hover{color:#fff}
.ld-footer-bottom{border-top:1px solid #1e293b;margin-top:28px;padding-top:18px;text-align:center;font-size:13px;color:#64748b}

/* ---- Public app shell + tab bar ---- */
body.public{padding-top:64px;padding-bottom:calc(68px + env(safe-area-inset-bottom))}
@media(max-width:600px){body.public{padding-top:58px}}
.public-header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.public-header .ld-wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
@media(max-width:600px){.public-header .ld-wrap{height:58px;padding:0 14px}}
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:grid;grid-template-columns:repeat(4,1fr);background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
.tabbar.tabbar-5{grid-template-columns:repeat(5,1fr)}
.tabbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 4px 8px;color:var(--muted);font-size:11px;font-weight:600}
.tabbar a i{font-size:22px}
.tabbar a.active{color:var(--blue)}
.tabbar a.book i{background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;margin-top:-22px;box-shadow:0 8px 18px -6px rgba(3,105,161,.6);font-size:22px}
@media(min-width:1024px){.tabbar{display:none}body.public{padding-bottom:0}}
.public-content{max-width:900px;margin:0 auto;padding:18px 16px 32px}

/* ---- Narrow page ---- */
.page-narrow{max-width:560px;margin:0 auto;padding:22px 16px 48px}
.page-narrow .topbar{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.page-narrow .topbar .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;display:grid;place-items:center;font-size:20px}
.page-narrow .topbar h1{font-size:18px;font-weight:800}
.page-narrow .topbar p{font-size:12px;color:var(--muted)}
.step-dot{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--blue);color:#fff;font-size:12px;font-weight:700}

/* ---- Bottom sheet ---- */
.sheet-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:200;display:none;align-items:flex-end;justify-content:center}
.sheet-backdrop.show{display:flex}
.sheet{background:#fff;width:100%;max-width:520px;border-radius:20px 20px 0 0;padding:20px;max-height:92dvh;overflow-y:auto;box-shadow:0 -10px 40px -10px rgba(0,0,0,.3);animation:sheetUp .22s}
@keyframes sheetUp{from{transform:translateY(40px);opacity:.5}to{transform:translateY(0);opacity:1}}
.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--line-2);margin:0 auto 14px}
@media(min-width:640px){.sheet-backdrop{align-items:center}.sheet{border-radius:18px}}

/* ---- Brand logo chips ---- */
.ld-brand .logo,.ld-footer .brand .logo,.admin-brand .logo,.page-narrow .topbar .logo,.public-header .ld-brand .logo{background:#fff var(--brand-logo) center/contain no-repeat !important;border:1px solid var(--line)}
.ld-brand .logo i,.ld-footer .brand .logo i,.admin-brand .logo i,.page-narrow .topbar .logo i{display:none}

/* ---- Misc components ---- */
.timeline{position:relative;padding-left:26px}
.timeline:before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline .tl-item{position:relative;padding-bottom:18px}
.timeline .tl-item:before{content:"";position:absolute;left:-21px;top:3px;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--sky)}
.timeline .tl-item.done:before{border-color:var(--green);background:var(--green)}
.timeline .tl-title{font-weight:700;font-size:14px}
.timeline .tl-meta{font-size:12px;color:var(--muted)}
.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:600;cursor:pointer}
.chip.active{border-color:var(--sky);background:var(--sky-soft);color:var(--blue)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(min-width:520px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
.cat-tile{border:1px solid var(--line);border-radius:14px;padding:14px 8px;text-align:center;cursor:pointer;background:#fff;transition:.15s}
.cat-tile:hover{border-color:var(--sky)}
.cat-tile.active{border-color:var(--sky);background:var(--sky-soft)}
.cat-tile i{font-size:26px;color:var(--blue);display:block;margin-bottom:6px}
.cat-tile span{font-size:12px;font-weight:600;color:var(--ink-2)}
#map,.map{height:340px;border-radius:var(--radius);border:1px solid var(--line);z-index:1}
.empty{text-align:center;padding:46px 20px;color:var(--muted)}
.empty i{font-size:46px;color:var(--line-2);display:block;margin-bottom:12px}
.progressbar{height:6px;background:var(--bg-2);border-radius:999px;overflow:hidden}
.progressbar>span{display:block;height:100%;background:linear-gradient(135deg,var(--sky),var(--blue))}
.divider{height:1px;background:var(--line);margin:16px 0}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--sky-soft);color:var(--blue);display:grid;place-items:center;font-weight:700;font-size:15px;flex-shrink:0}
.demo-banner{background:var(--amber);color:#fff;text-align:center;font-size:13px;font-weight:600;padding:7px 12px}
.readonly-banner{background:var(--red);color:#fff;text-align:center;font-size:13px;font-weight:600;padding:7px 12px}
.star-rate i{font-size:30px;color:var(--line-2);cursor:pointer}
.star-rate i.on{color:var(--amber)}
.kbd-link{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:10px}
.kbd-link i{font-size:22px;color:var(--blue)}

/* ==========================================================================
   Placora additions (fleet-specific components)
   ========================================================================== */
.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.toolbar .search{flex:1;min-width:180px;position:relative}
.toolbar .search i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted-2);font-size:18px}
.toolbar .search input{padding-left:38px}
.list-card{display:none}
.detail-rows{display:grid;grid-template-columns:1fr;gap:0}
.detail-rows .dr{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.detail-rows .dr:last-child{border-bottom:none}
.detail-rows .dr .k{color:var(--muted);font-weight:600}
.detail-rows .dr .v{font-weight:600;text-align:right}
.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:640px){.kv-grid{grid-template-columns:repeat(3,1fr)}}
.kv{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.kv .k{font-size:12px;color:var(--muted);font-weight:600}
.kv .v{font-size:16px;font-weight:700;margin-top:3px}
.tag-link{color:var(--blue);font-weight:600}
.map-lg{height:calc(100dvh - 230px);min-height:380px}
.map-fab{position:absolute;right:12px;z-index:500;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:13px;font-weight:600;box-shadow:var(--shadow);cursor:pointer}
.veh-marker{background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;border-radius:50% 50% 50% 0;width:30px;height:30px;transform:rotate(-45deg);display:grid;place-items:center;box-shadow:0 3px 8px rgba(0,0,0,.3);border:2px solid #fff}
.veh-marker i{transform:rotate(45deg);font-size:15px}
.veh-marker.idle{background:var(--gray-badge)}
.veh-marker.alert{background:linear-gradient(135deg,#f87171,var(--red))}
.pulse{animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(3,105,161,.5)}70%{box-shadow:0 0 0 12px rgba(3,105,161,0)}100%{box-shadow:0 0 0 0 rgba(3,105,161,0)}}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:16px;overflow-x:auto}
.tabs a{padding:10px 14px;font-size:14px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap}
.tabs a.active{color:var(--blue);border-bottom-color:var(--blue)}
.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:22px 0 10px}
.pill-row{display:flex;gap:8px;flex-wrap:wrap}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.green{background:var(--green)}.dot.amber{background:var(--amber)}.dot.red{background:var(--red)}.dot.gray{background:var(--gray-badge)}.dot.teal{background:var(--teal)}
.print-only{display:none}
.pagination{display:flex;gap:6px;justify-content:center;margin-top:18px}
.pagination a,.pagination span{padding:7px 12px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-weight:600;color:var(--ink-2);background:#fff}
.pagination .active{background:var(--sky-soft);color:var(--blue);border-color:var(--sky)}
@media(max-width:680px){
  .hide-sm{display:none}
  .table-as-cards thead{display:none}
  .table-as-cards,.table-as-cards tbody,.table-as-cards tr,.table-as-cards td{display:block;width:100%}
  .table-as-cards tr{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:6px 12px;background:#fff}
  .table-as-cards td{border:none;padding:6px 0;display:flex;justify-content:space-between;gap:12px}
  .table-as-cards td:before{content:attr(data-label);font-weight:700;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}
}
@media print{
  .no-print,.admin-sidebar,.admin-mobile-bar,.tabbar,.page-actions,.toolbar{display:none !important}
  .admin-main{margin-left:0 !important}
  .print-only{display:block}
  body{background:#fff}
  .card{box-shadow:none;border:1px solid #ddd}
}
