:root{--bg:#f4f7fb;--card:#fff;--text:#17202a;--muted:#5b6673;--line:#d8e0ea;--primary:#1e63ff;--danger:#c0392b;--success:#1e8449;--warning:#b9770e;--soft-surface:#fbfcfe;--field-bg:#fff;--field-border:#d8e0ea;--field-focus:#b8d0ff;--field-shadow:0 0 0 3px rgba(30,99,255,.08);--summary-bg:linear-gradient(180deg,#fff 0%,#fbfcff 100%)}
*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:var(--primary)}
.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#0f1720;color:#fff;padding:24px}.brand{font-weight:700;font-size:22px;margin-bottom:24px}.nav a{display:block;color:#d9e4f2;padding:10px 12px;border-radius:10px;margin-bottom:6px}.nav a:hover{background:#1b2735}.main-content{padding:28px}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:0 8px 24px rgba(16,24,40,.05)}.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))}.kpi{font-size:28px;font-weight:700}.muted{color:var(--muted)}
.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-title{margin:0 0 6px 0}.page-subtitle{margin:0;color:var(--muted)}
.alert{padding:14px 16px;border-radius:12px;margin-bottom:16px}.alert-error{background:#fdecea;color:#8a1f17}.alert-success{background:#eaf7ef;color:#146534}.alert-warning{background:#fff4df;color:#8a5a00}
.form-group{margin-bottom:14px}.form-grid{display:grid;gap:14px}.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}input,select{width:100%;padding:12px 13px;border:1px solid var(--field-border);border-radius:12px;background:var(--field-bg);color:var(--text);box-shadow:none;transition:border-color .15s ease, box-shadow .15s ease, background .15s ease}button,.btn{display:inline-block;border:0;border-radius:12px;padding:12px 16px;font-weight:700;cursor:pointer}.btn-primary{background:var(--primary);color:#fff}.btn-secondary{background:#e9eef6;color:#0f1720}.btn-danger{background:var(--danger);color:#fff}
.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--line);text-align:left}.badge{display:inline-block;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:700}.badge-admin{background:#e7efff;color:#1747b7}.badge-dispatcher{background:#e8f8ef;color:#186a3b}.badge-viewer{background:#f3f4f6;color:#4b5563}.badge-theme{background:var(--soft-surface);color:var(--text);border-color:var(--line)}
.guest-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px;background:var(--bg)}
.guest-main{width:min(100%,540px)}
.guest-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;margin:0 auto 24px;text-align:center}
.guest-brand .brand-logo{max-width:min(100%,280px);max-height:84px;margin:0 auto}
.guest-brand .brand-name{font-size:2rem;font-weight:800;letter-spacing:-.02em}
.guest-main>.alert{margin-bottom:16px}
.login-wrap{max-width:none;margin:0}
.helper{font-size:13px;color:var(--muted)}.mt-16{margin-top:16px}.text-right{text-align:right}
input:hover,select:hover,textarea:hover{border-color:color-mix(in srgb, var(--field-border) 60%, var(--primary) 40%)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--field-focus);box-shadow:var(--field-shadow)}
input::placeholder,textarea::placeholder{color:color-mix(in srgb, var(--muted) 82%, white 18%)}
select{appearance:auto}

@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{padding:16px}.grid-2,.grid-3,.two-col{grid-template-columns:1fr}.main-content{padding:16px}}

textarea{width:100%;padding:12px 13px;border:1px solid var(--field-border);border-radius:12px;background:var(--field-bg);color:var(--text);min-height:110px;resize:vertical;transition:border-color .15s ease, box-shadow .15s ease, background .15s ease}.quick-actions{display:flex;gap:10px;flex-wrap:wrap}.plain-list{margin:0;padding-left:18px}.status-active{color:var(--success);font-weight:700}.status-inactive{color:var(--danger);font-weight:700}.search-form{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}.inline-form{display:inline-flex;gap:8px;align-items:center;flex-wrap:wrap}.table-actions{display:flex;gap:8px;flex-wrap:wrap}.card h2{margin-top:0}.mono{font-family:Consolas,Monaco,monospace}@media(max-width:900px){.search-form{grid-template-columns:1fr}}
.status-warning{color:var(--warning);font-weight:700}.status-planned{color:#1f4eb3;font-weight:700}.mt-8{margin-top:8px}.planning-table th{vertical-align:top;min-width:200px}.planning-cell{vertical-align:top;background:#fbfcfe}.planning-vehicle-cell{min-width:190px;vertical-align:top}.planning-form{display:block}.planning-form .form-group{margin-bottom:10px}.planning-form label{font-size:12px}.planning-form input,.planning-form select,.planning-form textarea{padding:10px 11px;border-radius:10px;font-size:14px}.planning-notes{min-height:72px}.planning-save{width:100%}@media(max-width:1200px){.planning-table th{min-width:180px}}


.grid-6{grid-template-columns:repeat(6,minmax(0,1fr))}
.page-head-compact{margin-bottom:14px}
.compact-card{padding:16px}
.card-kpi{display:flex;flex-direction:column;gap:6px;min-height:122px}
.dashboard-kpis{gap:14px}
.kpi{font-size:24px;line-height:1.1}
.kpi-foot{font-size:12px;color:var(--muted)}
.chart-card{padding:16px 18px}
.chart-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.chart-head h2{margin:0;font-size:18px}
.chart-box{position:relative;width:100%}.chart-box-wide{height:320px}.chart-box-medium{height:280px}
.mini-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.mini-stat{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fbfcfe;display:flex;flex-direction:column;gap:6px}
.mini-label{font-size:12px;color:var(--muted)}
.mini-stat strong{font-size:20px}
@media(max-width:1300px){.grid-6{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:900px){.grid-6{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-box-wide,.chart-box-medium{height:260px}.mini-stats{grid-template-columns:1fr}}
@media(max-width:640px){.grid-6{grid-template-columns:1fr}}


.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid-5{grid-template-columns:repeat(5,minmax(0,1fr))}
.four-col{grid-template-columns:repeat(4,minmax(0,1fr))}.five-col{grid-template-columns:repeat(5,minmax(0,1fr))}
.form-group-span{grid-column:span 2}
.table-head-inline{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.justify-end{justify-content:flex-end}
@media(max-width:1300px){.grid-5{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4,.four-col{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.grid-5,.grid-4,.four-col{grid-template-columns:1fr}.form-group-span{grid-column:span 1}}
.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}
.inline-check{display:flex;gap:8px;align-items:center;font-size:14px;color:var(--text)}
.inline-check input{width:auto;margin:0}
.section-title{margin:0 0 8px 0;font-size:18px}
@media(max-width:900px){.three-col{grid-template-columns:1fr}}

.badge-driver{background:#fff4df;color:#8a5a00}.app-shell-driver{grid-template-columns:200px 1fr}.app-shell-driver .sidebar{padding:18px}.app-shell-driver .nav a{padding:12px 14px}.driver-card{padding:18px}@media(max-width:900px){.app-shell-driver{grid-template-columns:1fr}}


/* Responsive UX improvements */
html{font-size:16px}body{line-height:1.45}
input[type="number"]::-webkit-outer-spin-button,input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type="number"]{appearance:textfield}
button,.btn{min-height:46px}.btn-sm{padding:10px 14px;min-height:40px;border-radius:10px}
.sidebar{position:sticky;top:0;align-self:start;min-height:100vh}.nav{display:flex;flex-direction:column;gap:4px}
.content-narrow{max-width:1120px}.driver-content{max-width:960px}.section-stack{display:flex;flex-direction:column;gap:16px}
.driver-kpi{min-height:108px}.driver-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.driver-actions .btn{text-align:center}
.driver-primary-action{font-size:18px;min-height:54px}
.driver-form{display:flex;flex-direction:column;gap:14px}.driver-form .form-group{margin-bottom:0}.driver-form input,.driver-form select,.driver-form textarea{font-size:16px;min-height:50px;padding:14px 14px;border-radius:14px}.driver-form textarea{min-height:96px}.driver-form label{font-size:13px;letter-spacing:.01em}.driver-submit-bar{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(244,247,251,0),rgba(244,247,251,.92) 16%,rgba(244,247,251,1) 45%);padding-top:10px}.driver-submit-bar .btn{width:100%;min-height:56px;font-size:18px}
.driver-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.driver-form-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.driver-hint{font-size:12px;color:var(--muted)}.touch-note{font-size:12px;color:var(--muted);margin-top:4px}
.kbd-muted{font-size:12px;color:var(--muted)}
.driver-tour-list{display:grid;gap:12px}.tour-card{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff;box-shadow:0 6px 16px rgba(16,24,40,.04)}.tour-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.tour-title{font-size:18px;font-weight:700;margin:0}.tour-route{font-size:15px}.tour-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;margin-top:12px}.tour-meta-item span{display:block}.tour-meta-label{font-size:12px;color:var(--muted)}.tour-meta-value{font-size:15px;font-weight:600}
.mobile-card-list{display:grid;gap:12px}.mobile-card{border:1px solid var(--line);border-radius:16px;padding:14px;background:#fff}.mobile-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 14px}.mobile-card-label{font-size:12px;color:var(--muted)}.mobile-card-value{font-weight:600}
.show-mobile{display:none}.show-desktop{display:block}
.map-suggestions{display:grid;gap:8px;margin-top:10px}.map-suggestions button{justify-content:flex-start;text-align:left;font-weight:600;background:#f7faff;border:1px solid var(--line);padding:12px 14px;border-radius:12px}.station-actions{display:flex;gap:10px;flex-wrap:wrap}.station-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--line);border-radius:999px;background:#fbfcfe;font-size:12px;color:var(--muted)}
.responsive-form-actions{display:flex;gap:10px;flex-wrap:wrap}.table-card-mode{display:none}
@media(max-width:1200px){.driver-actions{grid-template-columns:1fr 1fr 1fr}.page-head{gap:12px;align-items:flex-start;flex-direction:column}.sidebar{position:static;min-height:auto}}
@media(max-width:900px){body{font-size:15px}.main-content{padding:14px}.sidebar{padding:12px;border-bottom:1px solid rgba(255,255,255,.08)}.brand{margin-bottom:12px;font-size:20px}.nav{flex-direction:row;overflow:auto;padding-bottom:2px}.nav a{white-space:nowrap;margin-bottom:0}.card{border-radius:16px;padding:16px}.compact-card{padding:14px}.table th,.table td{padding:10px 8px}.driver-content,.content-narrow{max-width:none}.driver-actions{grid-template-columns:1fr}.driver-form-grid,.driver-form-grid-3,.tour-meta,.mobile-card-grid{grid-template-columns:1fr}.driver-form input,.driver-form select,.driver-form textarea{font-size:16px}.show-mobile{display:block}.show-desktop{display:none}.table-card-mode{display:grid;gap:12px}.table-mobile-hide{display:none}}
@media(max-width:640px){.main-content{padding:12px}.page-title{font-size:26px}.page-subtitle{font-size:14px}.kpi{font-size:22px}.driver-kpi{min-height:96px}.chart-card{padding:14px}.chart-box-wide,.chart-box-medium{height:240px}.driver-primary-action{font-size:17px}.tour-title{font-size:17px}}


/* v2.1.1 wide content layout */
.app-shell{width:100%;max-width:none;min-width:0}
.main-content{width:100%;max-width:none;min-width:0;overflow-x:auto}
.main-content > *{max-width:none}
.content-narrow{max-width:none}
.card,.chart-card,.table-wrap{max-width:100%;min-width:0}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table{min-width:max-content}
@media(min-width:901px){.main-content{padding:24px 28px 28px}.page-head{align-items:flex-start}.grid,.form-grid{min-width:0}}


/* v2.1.2 compact collapsible forms */
.split-focus{display:grid;grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:16px;align-items:start}
.side-stack{display:flex;flex-direction:column;gap:16px}
.details-card{padding:0;overflow:hidden}.details-card summary{list-style:none;cursor:pointer;padding:14px 16px;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:12px}.details-card summary::-webkit-details-marker{display:none}.details-card summary::after{content:"＋";font-size:20px;line-height:1;color:var(--muted)}.details-card[open] summary::after{content:"–"}.details-body{padding:0 16px 16px 16px;border-top:1px solid var(--line);background:#fcfdff}.details-meta{font-size:12px;color:var(--muted);font-weight:400}.compact-form .form-grid,.compact-form .search-form{gap:10px}.compact-form .form-group{margin-bottom:10px}.compact-form label{font-size:12px;margin-bottom:4px}.compact-form input,.compact-form select,.compact-form textarea{padding:9px 11px;border-radius:10px;font-size:14px}.compact-form textarea{min-height:82px}.compact-form .btn{min-height:40px;padding:10px 14px}.focus-table-card{min-width:0}.focus-table-card .table-wrap{max-height:none}.toolbar-line{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.toolbar-line .helper{margin:0}.status-chip-row{display:flex;gap:8px;flex-wrap:wrap}.status-chip{display:inline-flex;align-items:center;padding:6px 10px;border:1px solid var(--line);border-radius:999px;background:#fbfcfe;font-size:12px;color:var(--muted)}
@media(max-width:1100px){.split-focus{grid-template-columns:1fr}.side-stack{order:-1}}


/* v2.1.3 vertical filter layout */
.split-focus{display:flex;flex-direction:column;gap:16px}.side-stack{width:100%}.focus-table-card{width:100%}
@media(min-width:901px){.split-focus{display:flex;flex-direction:column;gap:18px}.side-stack{max-width:none}}


/* v2.1.4 compact form ergonomics */
.details-card summary{padding:12px 14px}
.details-body.compact-form{padding:12px 14px 14px}
.compact-form form{display:flex;flex-direction:column;gap:10px}
.compact-form .form-grid{gap:10px}
.compact-form .form-grid.two-col{grid-template-columns:repeat(3,minmax(0,1fr))}
.compact-form .form-grid.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}
.compact-form .form-grid.four-col{grid-template-columns:repeat(4,minmax(0,1fr))}.compact-form .form-grid.five-col{grid-template-columns:repeat(5,minmax(0,1fr))}.five-col{grid-template-columns:repeat(5,minmax(0,1fr))}
.compact-form .form-group{margin-bottom:0}
.compact-form label{font-size:12px;font-weight:700;letter-spacing:.01em;margin-bottom:4px}
.compact-form input,.compact-form select,.compact-form textarea{padding:8px 10px;border-radius:10px;font-size:14px;min-height:40px}
.compact-form textarea{min-height:72px;resize:vertical}
.compact-form .plain-list{display:flex;flex-wrap:wrap;gap:8px}
.compact-form .inline-check{padding:8px 10px;border:1px solid var(--line);border-radius:999px;background:#fff;font-weight:600}
.compact-form .inline-check input{margin:0}
.compact-form .form-group-span{grid-column:span 2}
.compact-form .form-group-span-full{grid-column:1/-1}
.compact-form .helper-inline{font-size:12px;color:var(--muted);margin-top:2px}
.compact-form .compact-inline-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:2px}
.compact-form .compact-inline-row .inline-check{border:none;background:transparent;padding:0;font-weight:600}
.compact-form .compact-inline-row .quick-actions{margin:0}
.compact-form .quick-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}
.compact-form .btn{min-height:38px;padding:9px 12px}
.compact-form .search-form{grid-template-columns:minmax(0,1fr) auto auto;align-items:end;gap:10px}
.compact-form .search-form .table-actions,.compact-form .search-form .quick-actions{margin:0;justify-content:flex-end}
@media(max-width:1180px){
  .compact-form .form-grid.two-col,.compact-form .form-grid.three-col,.compact-form .form-grid.five-col{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .details-card summary{padding:12px}
  .details-body.compact-form{padding:12px}
  .compact-form .form-grid.two-col,.compact-form .form-grid.three-col,.compact-form .form-grid.four-col,.compact-form .form-grid.five-col,.compact-form .search-form{grid-template-columns:1fr}
  .compact-form .form-group-span,.compact-form .form-group-span-full{grid-column:span 1}
  .compact-form .compact-inline-row{align-items:flex-start}
}


/* v2.1.6 layout B + theme switcher */
.theme-switcher{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px}
.theme-switcher label{font-size:12px;font-weight:700;color:#b7c4d6;letter-spacing:.03em;text-transform:uppercase}
.theme-switcher select{width:100%;min-height:40px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#fff;padding:8px 10px}
.theme-switcher option{color:#17202a}
.page-head-tight{margin-bottom:16px}
.admin-section-card{padding:18px}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}
.section-text{margin:4px 0 0 0;color:var(--muted);font-size:14px}
.section-badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#eef4ff;color:var(--primary);font-weight:700;font-size:13px;border:1px solid #d8e5ff}
.admin-form-stack{display:flex;flex-direction:column;gap:14px}
.admin-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.info-tile{border:1px solid var(--line);border-radius:14px;background:#fbfcfe;padding:12px 14px;display:flex;flex-direction:column;gap:6px;min-height:74px;justify-content:center}
.info-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.info-value{font-size:15px}
.inline-check-switch{font-weight:700}
.inline-check-switch input{accent-color:var(--primary)}
.admin-subdetails{margin-top:2px}
.section-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;padding-top:4px}
.danger-zone{border-color:#f1d0cb;background:linear-gradient(180deg,#fff 0%,#fff8f7 100%)}
.danger-zone .section-head{margin-bottom:12px}
.theme-soft{--bg:#f6f4ff;--card:#ffffff;--text:#1f2440;--muted:#6b7190;--line:#e3ddfa;--primary:#6c63ff;--danger:#d14b3f;--success:#2d9d78;--warning:#c58512;--soft-surface:#f7f4ff;--field-bg:#fcfbff;--field-border:#ddd8ff;--field-focus:#d8d2ff;--field-shadow:0 0 0 3px rgba(108,99,255,.10);--summary-bg:linear-gradient(180deg,#ffffff 0%,#f7f4ff 100%)}
.theme-soft .sidebar{background:#261f4b}
.theme-soft .nav a{color:#ebe8ff}
.theme-soft .nav a:hover,.theme-soft .nav a:focus{background:rgba(255,255,255,.09)}
.theme-soft .card,.theme-soft .chart-card,.theme-soft .mobile-card,.theme-soft .tour-card{box-shadow:0 10px 24px rgba(68,46,133,.06)}
.theme-soft .btn-primary{background:var(--primary)}
.theme-soft .section-badge{background:#f1efff;color:#584ff4;border-color:#ddd8ff}
.theme-contrast{--bg:#eef2f6;--card:#ffffff;--text:#111827;--muted:#4b5563;--line:#cbd5e1;--primary:#0057d9;--danger:#b42318;--success:#027a48;--warning:#b54708;--soft-surface:#edf2f7;--field-bg:#ffffff;--field-border:#94a3b8;--field-focus:#60a5fa;--field-shadow:0 0 0 3px rgba(0,87,217,.12);--summary-bg:linear-gradient(180deg,#ffffff 0%,#edf2f7 100%)}
.theme-contrast .sidebar{background:#0b1220}
.theme-contrast .nav a{color:#e5eef9}
.theme-contrast .card,.theme-contrast .chart-card,.theme-contrast .mobile-card,.theme-contrast .tour-card{box-shadow:none}
.theme-contrast input,.theme-contrast select,.theme-contrast textarea{border-width:2px}
.theme-contrast .btn{font-weight:700}
@media(max-width:900px){.theme-switcher{margin-top:12px;padding-top:12px}.admin-meta-grid{grid-template-columns:1fr}.section-head{flex-direction:column;align-items:flex-start}.section-actions{justify-content:flex-start}}


/* v2.1.7 global admin theme roll-out */
:root{
  --card-radius:18px;
  --card-padding:18px;
}
.page-head{margin-bottom:18px}
.page-title{font-size:28px;line-height:1.1;font-weight:800}
.page-subtitle{max-width:860px}
.card,.chart-card,.focus-table-card,.mobile-card,.tour-card,.details-card{
  border-radius:var(--card-radius);
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:0 8px 24px rgba(16,24,40,.04);
}
.card,.chart-card,.focus-table-card,.mobile-card,.tour-card{padding:var(--card-padding)}
.card h2,.chart-card h2,.focus-table-card h2,.details-card h2{font-size:18px;line-height:1.2;margin:0 0 12px 0}
.section-title{font-size:18px;font-weight:800}
.section-text,.helper,.helper-inline{color:var(--muted)}
.table-wrap{border:1px solid var(--line);border-radius:16px;background:var(--card)}
.table{min-width:100%;background:transparent}
.table thead th{
  font-size:12px;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--muted);
  background:var(--soft-surface);
  position:sticky;top:0;z-index:1;
}
.table th,.table td{padding:12px 12px;vertical-align:top}
.table tbody tr:hover{background:color-mix(in srgb, var(--soft-surface) 92%, var(--primary) 8%)}
input,select,textarea{
  border-radius:12px;
  min-height:42px;
  background:#fff;
}
textarea{min-height:92px}
button,.btn{border-radius:12px}
.btn-secondary{background:#eef2f7}
.badge{border:1px solid transparent}
.badge-admin{border-color:#d7e4ff}
.badge-dispatcher{border-color:#d5f0df}
.badge-viewer{border-color:#e5e7eb}
.details-card{padding:0}
.details-card summary{
  background:var(--summary-bg);
  border-bottom:1px solid transparent;
}
.theme-switcher select{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.form-group label,.compact-form label{color:var(--text)}
.compact-form .inline-check{background:var(--field-bg);border-color:var(--field-border)}
.details-card[open] summary{border-bottom-color:var(--line)}
.details-body{background:var(--card)}
.details-meta{font-size:12px}
.quick-actions,.section-actions,.table-actions{gap:10px}
.info-tile{background:var(--soft-surface)}
.toolbar-line,.table-head-inline{
  padding-bottom:6px;
  margin-bottom:8px;
  border-bottom:1px solid var(--line);
}
.theme-soft .table tbody tr:hover{background:#faf8ff}
.theme-soft .table thead th{background:#f7f4ff}
.theme-soft .table-wrap{background:#fff}
.theme-contrast .table thead th{background:#edf2f7}
.theme-contrast .table-wrap,.theme-contrast .card,.theme-contrast .chart-card,.theme-contrast .focus-table-card{box-shadow:none}
.theme-forest{--bg:#eef5ef;--card:#ffffff;--text:#193126;--muted:#5c7468;--line:#cfddd3;--primary:#2f7d55;--danger:#c24f3d;--success:#23764b;--warning:#a56b00;--soft-surface:#f2f7f3;--field-bg:#fbfdfb;--field-border:#c7d8cc;--field-focus:#95c5aa;--field-shadow:0 0 0 3px rgba(47,125,85,.12);--summary-bg:linear-gradient(180deg,#ffffff 0%,#f2f7f3 100%)}
.theme-forest .sidebar{background:#173126}
.theme-forest .nav a{color:#e5f2ea}
.theme-forest .nav a:hover,.theme-forest .nav a:focus{background:rgba(255,255,255,.08)}
.theme-forest .table tbody tr:hover{background:#f4faf5}
.theme-forest .table thead th{background:#edf5ef}
.theme-forest .btn-primary{background:var(--primary)}
.theme-forest .section-badge{background:#edf7f1;color:#2f7d55;border-color:#cfe4d5}
.theme-sand{--bg:#f7f1e8;--card:#fffdf9;--text:#3d2d22;--muted:#7a685a;--line:#e4d6c7;--primary:#b06d2c;--danger:#b84c3a;--success:#3e8a5c;--warning:#a96c12;--soft-surface:#fbf5ee;--field-bg:#fffdfa;--field-border:#dccab7;--field-focus:#e0b98c;--field-shadow:0 0 0 3px rgba(176,109,44,.12);--summary-bg:linear-gradient(180deg,#fffdf9 0%,#fbf5ee 100%)}
.theme-sand .sidebar{background:#4b3528}
.theme-sand .nav a{color:#f4eadf}
.theme-sand .nav a:hover,.theme-sand .nav a:focus{background:rgba(255,255,255,.08)}
.theme-sand .table tbody tr:hover{background:#fff8f0}
.theme-sand .table thead th{background:#f8efe4}
.theme-sand .btn-primary{background:var(--primary)}
.theme-sand .section-badge{background:#fff1e2;color:#9b5c1d;border-color:#efd2b3}
.theme-graphite{--bg:#eef2f7;--card:#ffffff;--text:#1a2433;--muted:#647286;--line:#d5ddea;--primary:#4e6fae;--danger:#c54b4b;--success:#2f7d78;--warning:#b57a14;--soft-surface:#f4f7fb;--field-bg:#fbfcfe;--field-border:#ccd6e3;--field-focus:#9bb0cf;--field-shadow:0 0 0 3px rgba(78,111,174,.12);--summary-bg:linear-gradient(180deg,#ffffff 0%,#f4f7fb 100%)}
.theme-graphite .sidebar{background:#1b2432}
.theme-graphite .nav a{color:#e6edf7}
.theme-graphite .nav a:hover,.theme-graphite .nav a:focus{background:rgba(255,255,255,.08)}
.theme-graphite .table tbody tr:hover{background:#f7f9fc}
.theme-graphite .table thead th{background:#eef3f9}
.theme-graphite .btn-primary{background:var(--primary)}
.theme-graphite .section-badge{background:#edf3fb;color:#47679f;border-color:#d4e0f2}
@media(max-width:900px){
  :root{--card-padding:16px;--card-radius:16px}
  .page-title{font-size:26px}
  .table-wrap{border-radius:14px}
  .table th,.table td{padding:10px 10px}
}

.header-search-form{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:nowrap}.header-search-form input{flex:1 1 340px;min-width:280px;max-width:420px}.header-search-form .btn{white-space:nowrap;min-height:42px;display:inline-flex;align-items:center}.header-search-form > *{margin:0}@media(max-width:900px){.header-search-form{width:100%;flex-wrap:wrap;justify-content:flex-start}.header-search-form input{flex:1 1 220px;max-width:none}}

.quickplanner-week-nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.table-head-inline-stack-mobile{align-items:flex-start}
@media (max-width: 900px){
  .table-head-inline-stack-mobile{flex-direction:column;align-items:flex-start}
  .quickplanner-week-nav{justify-content:flex-start}
}


/* Planning board uses edge-to-edge horizontal scrolling without visible inner scrollbar */
.planning-scroll-region{width:100%;max-width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}
.planning-scroll-region::-webkit-scrollbar{display:none}
.planning-board-card{display:inline-block;vertical-align:top;min-width:1500px;width:max-content;max-width:none}
.planning-table-shell{overflow:visible;border:1px solid var(--line);border-radius:16px;background:var(--card)}
.planning-board-card .table-wrap{overflow:visible;border:0;background:transparent}
.planning-table{min-width:1500px;width:max-content}
@media (max-width: 1200px){.planning-board-card{min-width:1400px}.planning-table{min-width:1400px}}


/* v2.4.10 planning fit-to-screen */
.planning-scroll-region{overflow:visible;padding-bottom:0}
.planning-board-card{display:block;vertical-align:top;min-width:0 !important;width:100% !important;max-width:100% !important}
.planning-table-shell{overflow:visible}
.planning-table{width:100% !important;min-width:0 !important;table-layout:fixed}
.planning-table th{vertical-align:top;min-width:0 !important;padding:10px 8px;font-size:13px}
.planning-table td{padding:8px 6px}
.planning-vehicle-cell{width:168px;min-width:168px;max-width:168px;vertical-align:top}
.planning-cell{vertical-align:top;background:#fbfcfe}
.planning-form .form-group{margin-bottom:6px}
.planning-form label{font-size:11px;line-height:1.2;margin-bottom:4px}
.planning-form input,.planning-form select,.planning-form textarea{padding:8px 9px;border-radius:10px;font-size:13px}
.planning-notes{min-height:56px}
.planning-save{width:100%;padding:10px 12px}
@media (max-width:1500px){
  .planning-vehicle-cell{width:150px;min-width:150px;max-width:150px}
  .planning-form input,.planning-form select,.planning-form textarea{font-size:12px;padding:7px 8px}
  .planning-notes{min-height:50px}
}

.table-compact th,.table-compact td{padding:10px 8px;font-size:14px;vertical-align:top}.table-compact .btn{min-height:34px;padding:7px 10px}.table-compact .helper{font-size:12px}.table-compact .status-pill,.table-compact .status-badge,.table-compact .status-chip{font-size:12px}

.quick-week-switch{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.quick-week-switch__meta{display:flex;flex-direction:column;gap:4px}
.quick-week-switch__meta strong{font-size:16px}
.quick-week-switch__meta span{color:var(--muted);font-size:13px}
.quick-week-switch__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width: 900px){
  .quick-week-switch{align-items:flex-start}
  .quick-week-switch__actions{justify-content:flex-start}
}


.nav-group{margin:6px 0;border-radius:12px;background:rgba(255,255,255,.04);overflow:hidden}
.nav-group summary{list-style:none;cursor:pointer;color:#d9e4f2;padding:10px 12px;font-weight:700;border-radius:10px}
.nav-group summary::-webkit-details-marker{display:none}
.nav-group summary::after{content:'▾';float:right;opacity:.8}
.nav-group:not([open]) summary::after{content:'▸'}
.nav-group summary:hover{background:#1b2735}
.nav-submenu{padding:0 6px 8px 6px;display:flex;flex-direction:column;gap:4px}
.nav-submenu a{margin-bottom:0;padding-left:18px;background:transparent}
.nav-submenu a:hover{background:#1b2735}
.session-panel{margin-top:14px;padding:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px;background:rgba(255,255,255,.04);border-radius:12px}
.session-row{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:#d9e4f2}
.session-row span{color:#b7c4d6}
.session-row strong{color:#fff;text-align:right}
@media(max-width:900px){.session-panel{margin-top:12px}}


/* v2.4.24 inactivity privacy shield */
.privacy-shield{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(15,23,32,.14);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9999}
.privacy-shield[hidden]{display:none!important}
.privacy-shield-card{max-width:520px;width:min(100%,520px);padding:22px 24px;border-radius:18px;background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.65);box-shadow:0 12px 36px rgba(15,23,32,.14);display:flex;flex-direction:column;gap:8px;text-align:center;color:#17202a}
.privacy-shield-card strong{font-size:20px;line-height:1.2}
.privacy-shield-card span{font-size:14px;line-height:1.5;color:#4b5563}
html.shield-active .app-shell{filter:blur(2px)}
html.shield-active .privacy-shield{pointer-events:auto}
@media(max-width:640px){.privacy-shield{padding:16px}.privacy-shield-card{padding:18px 16px;border-radius:16px}.privacy-shield-card strong{font-size:18px}}


.brand{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;font-weight:700;line-height:1.1;width:100%}.brand-logo{display:block;width:auto;max-width:calc(100% - 40px);max-height:64px;height:auto;object-fit:contain;background:rgba(255,255,255,.92);padding:8px 10px;border-radius:16px;margin:0 auto}.brand-name{display:block;word-break:break-word}.logo-upload-row{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap}.logo-preview-card{min-width:180px;max-width:320px;width:100%;padding:1rem;border:1px dashed rgba(128,128,128,.35);border-radius:16px;background:rgba(255,255,255,.02)}.logo-preview-card img{display:block;width:auto;max-width:calc(100% - 40px);max-height:90px;height:auto;object-fit:contain;background:rgba(255,255,255,.92);padding:8px 10px;border-radius:16px;margin:0 auto}.logo-preview-card .muted{margin-top:.5rem}.form-help{display:block;font-size:.82rem;opacity:.72;margin-top:.35rem}.inline-check.compact-danger{color:#b42318}.page-head-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-left:auto}.page-head-search{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.page-head-search input,.page-head-search select{min-width:220px}

.password-input-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
}

.form-hint {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(89, 125, 255, 0.08);
    color: var(--text-main, #1f2937);
    font-size: 0.92rem;
}

.text-link {
    align-self: center;
    color: var(--accent, #3451ff);
    text-decoration: none;
    font-weight: 600;
}

.text-link:hover {
    text-decoration: underline;
}

@media (max-width: 700px) {
    .password-input-row {
        grid-template-columns: 1fr;
    }
}

/* v2.4.36 password reset hardening */
.password-strength{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.password-strength-bar{height:8px;border-radius:999px;background:rgba(0,0,0,.08);overflow:hidden}
.password-strength-bar span{display:block;height:100%;width:0;border-radius:999px;transition:width .2s ease,background-color .2s ease}
.password-strength-bar span.is-empty{background:transparent}
.password-strength-bar span.is-weak{background:#d14b3f}
.password-strength-bar span.is-medium{background:#c58512}
.password-strength-bar span.is-good{background:#2d9d78}
.password-strength-bar span.is-strong{background:#3451ff}
.password-strength-text{font-size:.9rem;color:var(--muted)}



.privacy-unlock-form{margin-top:8px;display:flex;flex-direction:column;gap:10px}
.privacy-unlock-row{display:flex;gap:10px;align-items:center;justify-content:center}
.privacy-unlock-row input{max-width:180px;text-align:center;letter-spacing:.25em;font-size:18px}
.privacy-unlock-error{font-size:13px;color:#b42318}
@media(max-width:640px){.privacy-unlock-row{flex-direction:column}.privacy-unlock-row input{max-width:none;width:100%}}



/* v2.4.42 support ticket layout */
.grid-support-ticket{display:grid;grid-template-columns:minmax(320px,1.15fr) minmax(320px,.85fr);gap:16px;align-items:start}
.support-head-compact{align-items:flex-start}
.support-head-compact h2{margin-bottom:4px}
.support-meta-created{font-size:11px;line-height:1.35}
.support-ticket-meta-card{padding-bottom:14px}
.support-meta-groups{display:flex;flex-direction:column;gap:14px}
.support-meta-group{border:1px solid var(--line);border-radius:14px;background:var(--soft-surface);padding:10px 10px 8px}
.support-meta-group-title{font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.support-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.support-mini-grid-compact .support-mini-item{padding:9px 10px;border:1px solid var(--line);border-radius:12px;background:var(--card);display:flex;flex-direction:column;gap:3px;min-height:52px;justify-content:center}
.support-mini-item-wide{grid-column:1 / -1}
.support-mini-label{font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);line-height:1.2}
.support-mini-item strong,.support-mini-item .status-pill{font-size:12px;line-height:1.35}
.support-mini-item .status-pill{display:inline-flex;width:max-content}
.support-reply-card textarea{min-height:150px}
.support-chat-card{padding-bottom:12px}
.support-chat-stream{display:flex;flex-direction:column;gap:10px;padding-top:4px}
.support-chat-row{display:flex}
.support-chat-row-user{justify-content:flex-start}
.support-chat-row-staff{justify-content:flex-end}
.support-chat-bubble{max-width:min(78%,760px);padding:12px 14px;border-radius:18px;box-shadow:0 6px 18px rgba(16,24,40,.05);border:1px solid var(--line);position:relative}
.support-chat-bubble-user{background:#eef6ff;border-color:#cfe2ff;border-top-left-radius:6px}
.support-chat-bubble-staff{background:#ecfdf3;border-color:#b7ebc8;border-top-right-radius:6px}
.support-chat-meta{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:8px;font-size:11px;color:var(--muted)}
.support-chat-meta strong{font-size:12px;color:var(--text)}
.support-chat-text{font-size:13px;line-height:1.5;word-break:break-word}
@media(max-width:980px){.grid-support-ticket{grid-template-columns:1fr}.support-chat-bubble{max-width:100%}.support-mini-grid{grid-template-columns:1fr}}
.support-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.support-attachment-link{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.65);font-size:12px;color:var(--text);text-decoration:none}
.support-attachment-link small{color:var(--muted)}
.support-attachment-link:hover{border-color:var(--primary);text-decoration:none}

.support-attachment-link-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:6px}
.support-attachment-download{font-size:12px;font-weight:600;color:var(--accent,#3b82f6);text-decoration:none}
.support-attachment-download:hover{text-decoration:underline}

.support-attachments{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.support-attachment-item{display:flex;flex-direction:column;gap:8px}
.support-attachment-preview{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;max-width:520px}
.support-attachment-preview-image img{display:block;max-width:100%;height:auto}
.support-attachment-preview-pdf iframe{display:block;width:100%;height:360px;border:0;background:#fff}
.support-attachment-link-wrap{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
@media(max-width:980px){.support-attachment-preview{max-width:100%}.support-attachment-preview-pdf iframe{height:280px}}

.ticket-unread-badge{display:inline-flex;margin-top:6px;padding:3px 8px;border-radius:999px;background:#fff4e5;color:#9a5b00;border:1px solid #ffd08a;font-size:11px;font-weight:700}
.support-chat-row-event{justify-content:center}
.support-chat-bubble-event{background:#f4f5f7;border-color:#d7dbe2;color:#344054;border-radius:12px;max-width:min(68%,680px)}
.support-chat-bubble-note{background:#fff7ed;border-color:#fed7aa;border-top-right-radius:6px}


/* v2.4.46 support upload refinement */
.muted-upload-hint{font-size:11px;line-height:1.35;opacity:.78;margin-top:6px}
.file-input{display:block;width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--card);color:var(--text);font:inherit;line-height:1.35}
.file-input:hover{border-color:var(--primary)}
.file-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.16)}
.file-input::file-selector-button{margin-right:12px;padding:9px 14px;border:1px solid var(--primary);border-radius:10px;background:rgba(59,130,246,.08);color:var(--primary);font:inherit;font-weight:700;cursor:pointer}
.file-input:hover::file-selector-button{background:rgba(59,130,246,.14)}


/* v2.4.71 navigation workflow refresh */
.sidebar{display:flex;flex-direction:column;gap:18px}
.nav{display:flex;flex-direction:column;gap:8px}
.nav-section{margin:0;border-radius:14px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.05)}
.nav-section summary{padding:11px 12px;font-size:13px;font-weight:800;letter-spacing:.02em;text-transform:none}
.nav-section[open] summary{background:rgba(255,255,255,.06)}
.nav-submenu{padding:0 8px 10px 8px;gap:6px}
.nav-submenu a{position:relative;padding:10px 12px 10px 18px;border-radius:12px;font-weight:600}
.nav-submenu a.is-active{background:rgba(255,255,255,.14);color:#fff;font-weight:800;box-shadow:inset 3px 0 0 #8fb7ff}
.nav-submenu a.is-active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:#8fb7ff}
.session-panel{margin-top:auto;padding:14px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:10px;background:rgba(255,255,255,.05);border-radius:14px}
.session-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.session-row span{font-size:12px;font-weight:700;color:#b7c4d6;letter-spacing:.02em;text-transform:uppercase}
.session-row strong{font-size:14px;color:#fff;text-align:right}
.theme-switcher{margin-top:4px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px}
.theme-switcher label{font-size:12px;font-weight:700;color:#b7c4d6;letter-spacing:.03em;text-transform:uppercase}
.nav-logout{display:inline-flex;justify-content:center;align-items:center;width:100%;margin-top:2px}
@media(max-width:900px){
  .sidebar{gap:12px}
  .nav{flex-direction:column;overflow:visible;padding-bottom:0;gap:6px}
  .session-panel{margin-top:0}
  .nav-section{min-width:0}
  .nav-submenu a{padding-left:16px;white-space:normal}
}


/* v2.4.72 navigation refinement */
.brand-link{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;text-decoration:none;color:inherit;width:100%}
.brand-link:hover,.brand-link:focus{text-decoration:none;opacity:.98}
.nav-direct-link{display:block;color:#d9e4f2;padding:11px 12px;border-radius:12px;font-weight:800;text-decoration:none;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.05)}
.nav-direct-link:hover,.nav-direct-link:focus{background:rgba(255,255,255,.06);text-decoration:none}
.nav-section summary,.nav-direct-link{font-size:13px;letter-spacing:.02em}
.nav-submenu a,.nav-direct-link{position:relative}
.nav-submenu a.is-active,.nav-direct-link.is-active{background:transparent;box-shadow:none;color:#fff;font-weight:800}
.nav-submenu a.is-active::before,.nav-direct-link.is-active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:#8fb7ff}
.nav-logout-standalone{margin-top:2px;width:100%}
.session-panel{padding:12px 12px 13px;gap:8px}
.session-row{font-size:12px}
.session-row span{font-size:11px}
.session-row strong{font-size:12px;line-height:1.35}
.theme-switcher label{font-size:11px}
@media(max-width:900px){.brand-link{gap:.5rem}.nav-direct-link{padding:10px 12px}}

.nav-section[open] summary{background:transparent;color:#fff}


/* v2.4.73 sidebar navigation refinements */
.nav-section summary,.nav-direct-link{font-size:12px;line-height:1.2}
.nav-submenu a{font-size:12px;line-height:1.25;padding-top:9px;padding-bottom:9px}
.nav-direct-link{padding-top:10px;padding-bottom:10px}
.nav-logout-link{margin-top:2px}
.session-panel{padding:11px 12px 12px;gap:7px}
.session-row span{font-size:10px}
.session-row strong{font-size:11px;line-height:1.3}
.theme-switcher label{font-size:11px}
.theme-switcher select{min-height:38px;font-size:12px}
@media(max-width:900px){
  .nav-section summary,.nav-direct-link,.nav-submenu a{font-size:12px}
}


/* v2.4.74 handbook */
.handbook-top-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:16px}
.handbook-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.handbook-mini-item{padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:var(--soft-surface);display:flex;flex-direction:column;gap:4px}
.handbook-mini-item span{font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}
.handbook-mini-item strong{font-size:16px;line-height:1.3}
.handbook-mini-item-wide{grid-column:1 / -1}
.handbook-anchor-list{display:flex;flex-wrap:wrap;gap:10px}
.handbook-anchor-list a{display:inline-flex;align-items:center;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:var(--soft-surface);text-decoration:none;color:var(--text);font-size:13px;font-weight:700}
.handbook-anchor-list a:hover{border-color:var(--primary);text-decoration:none}
.handbook-section-card{scroll-margin-top:18px}
.handbook-section-head{margin-bottom:14px}
.handbook-module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.handbook-module-card{border:1px solid var(--line);border-radius:18px;background:var(--soft-surface);padding:16px 16px 14px;display:flex;flex-direction:column;gap:14px}
.handbook-module-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.handbook-module-head h3{margin:0;font-size:18px;line-height:1.2}
.handbook-module-purpose{margin:0;font-size:14px;line-height:1.6;color:var(--text)}
.handbook-module-block{display:flex;flex-direction:column;gap:8px}
.handbook-module-block strong{font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}
.handbook-list{margin:0;padding-left:18px;display:grid;gap:6px}
.handbook-list li{line-height:1.55}
.handbook-list-numbered{padding-left:20px}
.btn-small{padding:9px 12px;border-radius:10px;font-size:12px}
@media(max-width:980px){.handbook-top-grid,.handbook-module-grid{grid-template-columns:1fr}}
@media(max-width:700px){.handbook-mini-grid{grid-template-columns:1fr}.handbook-module-head{flex-direction:column;align-items:flex-start}}
