*{box-sizing:border-box}
:root{--bg:#eef4ff;--card:#ffffff;--text:#111827;--muted:#64748b;--line:#d9e2f2;--brand:#3469b7;--brand-dark:#2e5fa7;--brand-light:#5f8dd2;--danger:#dc2626;--success:#166534;--shadow:0 14px 34px rgba(29,48,87,.12)}
html,body{margin:0;padding:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}
body{min-height:100vh}
body.sidebar-open,body.modal-open{overflow:hidden}
a{color:inherit}
img,video{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.app-shell{display:flex;min-height:100vh;position:relative}
.app-shell.with-sidebar{background:linear-gradient(90deg,var(--brand) 0 290px,var(--bg) 290px 100%)}
.sidebar{width:290px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;padding:26px 22px calc(34px + env(safe-area-inset-bottom));display:block;box-shadow:inset -1px 0 0 rgba(255,255,255,.12);height:100dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.sidebar{position:relative}
.sidebar-mobile-logo-slot{display:none}.sidebar-mobile-logo{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 8px 24px rgba(15,23,42,.18))}
.sidebar-inner{display:flex;flex-direction:column;min-height:100%;gap:18px}.brand{font-size:22px;font-weight:400;letter-spacing:.2px;margin-bottom:0}
.user-card{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:20px;background:rgba(255,255,255,.12);margin-bottom:18px;backdrop-filter:blur(6px)}
.user-card strong{font-size:17px}.user-card span{font-size:13px;color:#dbeafe;text-transform:capitalize}
.nav-links{display:flex;flex-direction:column;gap:18px;min-width:0}
.nav-section{display:flex;flex-direction:column;gap:8px}
.nav-section-title{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#f8fafc;padding:0 8px 6px;border-bottom:1px solid rgba(255,255,255,.28)}
.nav-links a,.logout-link{text-decoration:none;color:#eef6ff;padding:12px 14px;border-radius:16px;transition:.2s;background:rgba(255,255,255,.05);border:1px solid transparent;word-break:break-word}
.nav-links a:hover,.logout-link:hover,.nav-links a:focus-visible,.logout-link:focus-visible,.nav-links a.active{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.24);outline:none}
.logout-link{display:block;text-align:center;font-weight:700;background:rgba(255,255,255,.14);backdrop-filter:blur(6px);box-shadow:0 12px 28px rgba(8,15,35,.18)}
.mobile-nav-toggle,.sidebar-overlay{display:none}
.sidebar::-webkit-scrollbar{width:10px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.28);border-radius:999px}
.main-content{flex:1;padding:28px;min-width:0}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;gap:16px;flex-wrap:wrap}.page-head h1{margin:0 0 8px;font-size:30px;color:#12233f}.page-head p{margin:0;color:#51627e;line-height:1.6;max-width:900px}
.card{background:var(--card);border-radius:24px;padding:22px;box-shadow:var(--shadow);min-width:0;border:1px solid rgba(52,105,183,.08)}
.main-content .card + .card{margin-top:18px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}.card-head h2{margin:0;font-size:20px;color:#173159}
.hero-card{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:22px}.stats-grid-mini{margin-top:-4px}
.stat-card{background:var(--card);border-radius:22px;padding:22px;box-shadow:var(--shadow);border:1px solid rgba(52,105,183,.08);min-width:0}.stat-card span{display:block;color:var(--muted);font-size:14px;margin-bottom:10px}.stat-card strong{font-size:32px;color:#12233f;line-height:1.1}
.inline-link{font-size:18px;color:var(--brand-dark);text-decoration:none}
.grid-two{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}
.stack-form{display:flex;flex-direction:column;gap:12px}.stack-form label{font-weight:700;color:#334155;font-size:14px}
.stack-form input,.stack-form select,.stack-form textarea{width:100%;border:1px solid #c9d7eb;border-radius:16px;padding:14px 16px;font-size:15px;background:#fff;color:#0f172a;outline:none;min-width:0}.stack-form input:focus,.stack-form select:focus,.stack-form textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(52,105,183,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:16px;padding:14px 18px;font-weight:800;cursor:pointer;text-decoration:none;white-space:normal;text-align:center;line-height:1.3}.btn.primary{background:var(--brand);color:#fff}.btn.dark{background:#173159;color:#fff}.btn.muted{background:#e6edf8;color:#173159}.btn.danger{background:var(--danger);color:#fff}.btn.big{min-height:58px;font-size:16px}.btn.huge{min-height:64px;padding:18px 26px;font-size:18px}.btn.compact{padding:10px 14px;border-radius:12px;font-size:13px}.full-btn{width:100%}
.button-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.top-gap{margin-top:18px}.top-card-gap{margin-top:18px}
.table-wrap{overflow:auto;border:1px solid #dce6f4;border-radius:18px;max-width:100%}.table-wrap.max-h{max-height:560px}table{width:100%;min-width:720px;border-collapse:collapse;background:#fff}th,td{padding:14px;border-bottom:1px solid #e6edf8;text-align:left;font-size:14px;color:#0f172a;vertical-align:top;word-break:break-word}th{background:#f7faff;position:sticky;top:0;z-index:1}
.status-pill{display:inline-flex;padding:6px 12px;border-radius:999px;font-weight:700;text-transform:capitalize}.status-pill.active{background:#dcfce7;color:#166534}.status-pill.completed{background:#e2e8f0;color:#334155}
.mini-list{display:flex;flex-direction:column;gap:12px;min-width:0}.mini-item{display:flex;justify-content:space-between;gap:12px;background:#f7faff;padding:14px 16px;border-radius:16px;color:#0f172a;min-width:0}.mini-item span{color:var(--muted);font-size:13px}.stacked-item{flex-direction:column;align-items:flex-start}.stacked-item span{font-size:13px}.large-list{max-height:480px;overflow:auto}
.alert{padding:16px 18px;border-radius:18px;margin-bottom:18px;font-weight:700}.alert.success{background:#dcfce7;color:#166534}.alert.error{background:#fee2e2;color:#991b1b}
.login-wrap{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:30px}.login-card{width:min(100%,540px);background:#fff;padding:32px;border-radius:30px;box-shadow:0 30px 70px rgba(15,23,42,.15)}
html.login-page,body.login-page{height:100%;min-height:100%;overflow:hidden;overscroll-behavior:none}
.login-page{position:fixed;inset:0;width:100%;height:var(--app-height,100dvh);height:var(--app-height,100vh);min-height:var(--app-height,100dvh);overflow:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:auto;touch-action:manipulation}
.login-page .app-shell{position:fixed;inset:0;min-height:var(--app-height,100dvh);height:var(--app-height,100dvh);overflow:hidden}
.login-page .main-content{display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;height:100%}
.login-page .login-wrap{width:100%;min-height:var(--app-height,100dvh);height:var(--app-height,100dvh);padding:18px 16px;overflow:hidden;align-items:center;justify-content:center}
.login-page .login-card{margin:0;width:min(100%,520px);max-height:calc(var(--app-height,100dvh) - 32px)}
.title-block h1{margin:12px 0 8px;font-size:34px;color:#0f172a}.title-block p{margin:0 0 22px;color:#475569;line-height:1.6}.badge{display:inline-flex;padding:8px 14px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:800}.badge-line{display:inline-flex;padding:10px 16px;border-radius:999px;background:#ddeafd;color:#2454a6;font-weight:800;margin-bottom:16px}
.test-box{margin-top:18px;background:#f8fafc;border-radius:18px;padding:16px;color:#334155;display:grid;gap:6px}
.center-card{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.qr-box{width:264px;min-height:264px;border-radius:24px;background:#fff;display:flex;align-items:center;justify-content:center;margin:18px auto 0;padding:12px;box-shadow:inset 0 0 0 1px #e2e8f0}.qr-box-large{width:min(100%,380px);min-height:380px;padding:18px;background:#f8fbff}.qr-box img{max-width:100%;height:auto}
.qr-meta{margin-top:14px;color:#475569}.countdown{margin-top:14px;font-size:18px;font-weight:800;color:#2454a6}.qr-focus-card{gap:10px}.qr-color-panel{width:100%;max-width:420px;background:#f7faff;border:1px solid #d9e5f7;border-radius:18px;padding:14px 16px;margin-top:8px;text-align:left}.qr-color-row{display:flex;align-items:center;gap:12px}.qr-color-row input{width:58px;height:42px;padding:4px;border-radius:12px}.qr-modal[hidden]{display:none !important}.qr-modal{position:fixed;inset:0;z-index:10000}.qr-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.28)}.qr-modal-screen{position:relative;z-index:1;min-height:100dvh;min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 18px 34px;text-align:center}.qr-modal-close{position:fixed;right:18px;top:18px;width:58px;height:58px;border-radius:999px;border:0;background:rgba(15,23,42,.88);color:#fff;font-size:38px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 16px 34px rgba(15,23,42,.28);cursor:pointer;z-index:2}.qr-modal-head{width:min(100%,560px);margin:0 auto 14px}.qr-modal-head h2{font-size:clamp(28px,5vw,42px);margin:8px 0 6px;color:#0f172a}.qr-modal-head p{margin:0;color:#334155;font-size:18px;font-weight:600}.qr-modal-meta{font-size:18px;font-weight:700;color:#1e293b}.qr-modal-box{margin-top:18px;margin-bottom:0;background:rgba(255,255,255,.96);box-shadow:0 18px 60px rgba(15,23,42,.16)}.qr-modal-countdown{font-size:26px;color:#0f172a;margin-top:18px}.qr-modal .badge-line{background:rgba(255,255,255,.66);color:#0f172a}
.personnel-grid,.review-grid,.driver-grid,.admin-grid,.audio-grid{align-items:start}.grid-form,.trip-start-form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}.form-full{grid-column:1/-1}
.top-note{color:#51627e;line-height:1.6}
.vehicle-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}.vehicle-card.single-column{grid-template-columns:1fr}.vehicle-card>div{background:#f7faff;padding:16px;border-radius:18px;display:flex;flex-direction:column;gap:8px;min-width:0}.label-chip{display:inline-flex;align-self:flex-start;padding:7px 12px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:800;font-size:12px}
.soft-line{border:0;border-top:1px solid #e2e8f0;margin:8px 0}
.review-listing{display:grid;gap:18px}.review-card{display:grid;gap:16px}.review-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap}.review-head h2{margin:0 0 8px;font-size:20px}.review-head p{margin:0 0 6px;color:#475569}.rating-badge{padding:12px 16px;border-radius:16px;background:#fff7ed;color:#c2410c;font-weight:800;white-space:nowrap}.review-text{line-height:1.7;color:#1f2937;background:#f8fafc;border-radius:18px;padding:16px}.review-media{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.media-link img,.video-wrap video,.media-thumb img,.media-thumb video{width:100%;height:260px;object-fit:cover;border-radius:18px;border:1px solid #e2e8f0;background:#000}.video-wrap small{display:block;margin-top:8px;color:#475569}.media-thumb{position:relative;border:0;padding:0;background:transparent;cursor:pointer}.media-chip{position:absolute;right:12px;bottom:12px;background:rgba(15,23,42,.82);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}
.quick-links-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.quick-link-card{display:flex;flex-direction:column;gap:8px;padding:18px;border-radius:18px;background:#f8fafc;text-decoration:none;color:#0f172a;border:1px solid #e2e8f0;min-width:0}.quick-link-card span{color:#64748b;font-size:14px}
.filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.compact-form{gap:10px}.soft-panel{background:#f8fafc;box-shadow:none;border:1px solid #e2e8f0}.manager-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:start}
.media-modal[hidden]{display:none !important}
.media-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:18px}.media-modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.82)}.media-modal-content{position:relative;z-index:1;width:min(100%,960px);background:#0f172a;border-radius:28px;padding:22px;box-shadow:0 24px 70px rgba(0,0,0,.35)}.media-modal-content img,.media-modal-content video{width:100%;max-height:75vh;object-fit:contain;border-radius:18px;background:#000}.modal-close{position:absolute;right:18px;top:18px;width:42px;height:42px;border-radius:999px;border:0;background:#fff;color:#0f172a;font-size:28px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.live-badge{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:999px;background:#dcfce7;color:#166534;font-weight:800}.live-trip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.live-trip-card{padding:18px;border-radius:22px;background:#f8fafc;border:1px solid #e2e8f0;min-width:0}.live-trip-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.live-trip-route{font-weight:700;color:#0f172a;margin:10px 0}.live-trip-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.live-trip-metrics div{padding:12px;border-radius:16px;background:#fff;border:1px solid #e2e8f0}.live-trip-metrics span{display:block;color:#64748b;font-size:12px;margin-bottom:4px}.live-trip-metrics strong{font-size:18px}.compact-reviews{gap:12px}.compact-review-row{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:16px;background:#f8fafc;border-radius:18px}.review-manager-card .review-media{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.scanner-stats{grid-template-columns:repeat(4,minmax(0,1fr))}.audio-card audio{width:100%}.audio-preview-box{display:flex;flex-direction:column;gap:12px;padding:16px;border-radius:18px;background:#f8fafc;border:1px solid #e2e8f0}.inline-check{display:flex;align-items:center;gap:10px;font-weight:700;color:#334155}.inline-check input{width:auto}
.reader-box{width:100%;min-height:320px;border:2px dashed #c8d7ee;border-radius:24px;overflow:hidden;background:#0f172a}.reader-box-large{min-height:560px;border-style:solid;border-color:#d6e1f3;background:#0b1220}.reader-box section{border-radius:24px;overflow:hidden}
.scan-result{margin-top:16px;padding:16px;border-radius:18px;font-weight:800}.scan-result.idle{background:#e8eef8;color:#334155}.scan-result.success{background:#dcfce7;color:#166534}.scan-result.error{background:#fee2e2;color:#991b1b}
.manual-box{margin-top:20px;display:flex;flex-direction:column;gap:10px}.manual-box label{font-weight:700}.subtle-box{background:#f7faff;border:1px solid #d9e6f8;border-radius:18px;padding:14px 16px}.subtle-box summary{cursor:pointer;font-weight:800;color:#173159;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px}.subtle-box summary::-webkit-details-marker{display:none}.subtle-box[open] summary{margin-bottom:14px}.review-summary-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.review-count-badge{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#ddeafd;color:#214889;font-weight:800}.empty-state{padding:20px;border-radius:18px;background:#f7faff;border:1px dashed #c8d8f2;color:#51627e}
.scanner-page-head{margin-bottom:16px}.scanner-focus-card{display:grid;gap:16px}.scanner-route-strip{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:12px;align-items:center}.scanner-route-box{background:#f7faff;border:1px solid #dbe4f4;border-radius:20px;padding:18px 20px;min-width:0}.scanner-route-box span{display:block;color:var(--muted);font-size:13px;margin-bottom:6px}.scanner-route-box strong{font-size:24px;color:#153260;word-break:break-word}.scanner-arrow{display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;color:var(--brand-dark);background:transparent;border:0;padding:0}.scanner-bottom-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.scanner-seat-box{background:#f7faff;border:1px solid #dbe4f4;border-radius:20px;padding:16px 18px;display:flex;flex-direction:column;gap:6px}.scanner-seat-box span{color:var(--muted);font-size:13px}.scanner-seat-box strong{font-size:34px;color:#153260}.scanner-seat-box small{color:#51627e}
.info-box{padding:14px 16px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0;color:#334155;line-height:1.7}.info-box code{background:#eef2ff;border-radius:8px;padding:2px 6px}.muted-text{color:#64748b}

@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-two,.grid-form,.trip-start-form,.vehicle-card,.review-media,.manager-grid,.quick-links-grid,.live-trip-grid,.filter-grid{grid-template-columns:1fr}.scanner-route-strip{grid-template-columns:1fr}.scanner-arrow{transform:rotate(90deg);justify-self:center}.live-trip-metrics{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:980px){.app-shell.with-sidebar{background:var(--bg)}.mobile-nav-toggle{display:inline-flex;position:fixed;left:14px;top:14px;z-index:1002;width:48px;height:48px;border-radius:14px;border:0;background:var(--brand);color:#fff;font-size:24px;align-items:center;justify-content:center;box-shadow:var(--shadow)}.sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.45);opacity:0;pointer-events:none;transition:.2s;z-index:1000}.sidebar-overlay.is-open{opacity:1;pointer-events:auto}.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);transition:.22s ease;z-index:1001;max-width:88vw;width:min(88vw,320px);padding-top:86px;padding-bottom:28px;overflow-y:auto}.sidebar.is-open{transform:translateX(0)}.sidebar-mobile-logo-slot{display:flex;align-items:center;justify-content:center;position:absolute;top:14px;left:76px;right:22px;height:56px;padding:8px 12px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(8px)}.sidebar-mobile-logo{width:100%;height:100%}.sidebar .brand-logo{display:none}.sidebar .brand-block{padding-top:4px}.main-content{width:100%;padding:78px 18px 18px}.page-head h1{font-size:24px}.reader-box-large{min-height:420px}.scanner-bottom-bar{align-items:stretch}.scanner-seat-box,.scanner-bottom-bar .button-row{width:100%}}
@media (max-width:720px){.stats-grid,.scanner-stats{grid-template-columns:1fr}.hero-card,.review-head,.compact-review-row,.page-head{flex-direction:column;align-items:flex-start}.table-wrap{border-radius:16px}.card{padding:18px;border-radius:22px}.button-row{width:100%}.button-row .btn,.button-row a{flex:1 1 auto}.scanner-route-box strong{font-size:20px}.scanner-seat-box strong{font-size:30px}.qr-box-large{min-height:320px;width:min(100%,330px)}.reader-box-large{min-height:360px}.qr-color-row{align-items:flex-start;flex-direction:column}.qr-modal-screen{padding:76px 16px 30px}.qr-modal-close{right:14px;top:14px;width:52px;height:52px;font-size:34px}.qr-modal-head h2{font-size:34px}.qr-modal-head p,.qr-modal-meta{font-size:16px}.qr-modal-countdown{font-size:22px}}

/* Personnel page refinements */
.top-actions{justify-content:flex-end}.compact-top-gap{margin-top:20px}.personnel-stats-grid{margin-bottom:20px}.quick-menu-card{height:100%}.quick-menu-grid{display:grid;grid-template-columns:1fr;gap:12px}.quick-menu-item{display:block;text-decoration:none;background:#f7faff;border:1px solid #d9e5f7;border-radius:18px;padding:16px 18px;color:#173159;transition:.2s}.quick-menu-item strong{display:block;font-size:16px;margin-bottom:4px}.quick-menu-item span{display:block;color:#475569;line-height:1.45}.quick-menu-item:hover,.quick-menu-item:focus-visible{transform:translateY(-1px);box-shadow:0 10px 24px rgba(36,84,166,.08);outline:none}.danger-soft{background:#fff5f5;border-color:#ffd0d0;color:#8f1d1d}.stack-list{display:flex;flex-direction:column;gap:12px}.summary-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 16px;background:#f8fbff;border:1px solid #deebfb;border-radius:18px}.summary-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.mini-meta{font-size:13px;color:#64748b}.empty-note{padding:18px;border:1px dashed #d5e3f7;border-radius:18px;color:#475569;background:#f8fbff}.qr-refresh-btn{margin-top:18px;min-width:min(100%,340px)}.large-table-wrap table td:last-child{min-width:220px;white-space:normal}.personnel-grid .card{height:100%}@media (max-width:720px){.top-actions{width:100%;justify-content:stretch}.top-actions .btn,.top-actions a{flex:1 1 100%}.summary-row{flex-direction:column}.summary-side{align-items:flex-start;width:100%}.large-table-wrap table td:last-child{min-width:180px}}


/* Driver scanner modal */
.scanner-management-grid{align-items:start}
.scanner-summary-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.scanner-summary-list .mini-item{height:100%}
.scanner-modal[hidden]{display:none !important}
.scanner-modal{position:fixed;inset:0;z-index:9998}
.scanner-modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(3px)}
.scanner-modal-dialog{position:relative;z-index:1;min-height:100dvh;width:100%;display:flex;flex-direction:column;justify-content:space-between;gap:18px;padding:22px;background:linear-gradient(180deg,#eef4ff 0%,#dbe8ff 100%)}
.scanner-modal-top{padding:8px 72px 0 8px}
.scanner-trip-line{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;font-size:clamp(24px,3vw,40px);font-weight:900;color:#10213e;text-align:center}
.scanner-trip-line span{color:var(--brand-dark);font-size:1.05em}
.scanner-trip-subline{text-align:center;color:#385277;font-weight:700;margin-top:10px;font-size:14px}
.scanner-modal-reader{flex:1;min-height:52vh;max-width:min(100%,920px);margin:0 auto;width:100%;border-width:3px;box-shadow:0 24px 70px rgba(16,33,62,.16)}
.scanner-modal-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.scanner-seat-box-modal{background:#fff;border-color:#cddcf5;box-shadow:0 16px 40px rgba(26,54,104,.12)}
.scanner-modal-actions{justify-content:flex-end}
.scanner-modal-close{position:absolute;right:18px;top:18px;width:58px;height:58px;border-radius:999px;border:0;background:#fff;color:#0f172a;font-size:40px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 16px 40px rgba(15,23,42,.18)}

/* Panel lists side-by-side */
.mini-list.large-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-content:start}
.review-listing.compact-reviews{grid-template-columns:repeat(2,minmax(0,1fr))}
.stack-list.review-summary-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.summary-row{height:100%}

@media (max-width:1200px){
  .scanner-summary-list{grid-template-columns:1fr}
  .mini-list.large-list,.review-listing.compact-reviews,.stack-list.review-summary-list{grid-template-columns:1fr}
}
@media (max-width:720px){
  .scanner-modal-dialog{padding:16px 16px 20px}
  .scanner-modal-top{padding-right:60px}
  .scanner-trip-line{font-size:24px;gap:10px}
  .scanner-modal-reader{min-height:44vh}
  .scanner-modal-bottom{align-items:stretch}
  .scanner-seat-box-modal,.scanner-modal-actions{width:100%}
  .scanner-modal-actions .btn{flex:1 1 auto}
  .scanner-modal-close{right:12px;top:12px;width:52px;height:52px;font-size:34px}
}

/* 2026-04-11 refinements */
html,body{overflow-x:hidden;max-width:100%}
.sidebar{overflow-x:hidden}
.nav-links a,.logout-link{display:block}
.nav-section-logout{margin-top:auto;padding-top:6px}
.qr-modal,.scanner-modal{overflow:hidden}
.qr-modal-screen,.scanner-modal-dialog{max-height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.qr-modal-screen{padding-bottom:110px}
.qr-box,.reader-box,.qr-modal-box,.scanner-modal-reader{max-width:100%}
.qr-refresh-btn{position:fixed;left:50%;bottom:max(16px,calc(env(safe-area-inset-bottom) + 12px));transform:translateX(-50%);z-index:3;width:min(calc(100% - 32px),360px);margin-top:0}

.review-accordion{padding:0;overflow:hidden}
.review-accordion + .review-accordion{margin-top:18px}
.review-accordion-summary{list-style:none;cursor:pointer;padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.review-accordion-summary::-webkit-details-marker{display:none}
.review-accordion-summary:hover{background:#f8fbff}
.review-accordion-summary-main{display:flex;flex-direction:column;gap:6px;min-width:0}
.review-accordion-summary-main h2,.review-accordion-summary-main h3{margin:0;font-size:20px;color:#173159}
.review-accordion-summary-main p{margin:0;color:#51627e;line-height:1.5;word-break:break-word}
.review-accordion-summary-side{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0}
.review-accordion-toggle{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#e8f0fd;color:#214889;font-weight:800;font-size:13px;white-space:nowrap}
.review-accordion[open] .review-accordion-toggle{background:#173159;color:#fff}
.review-accordion-body{padding:0 22px 22px}
.review-accordion-body > .review-text:first-child{margin-top:0}
.review-accordion-body .manager-grid,.review-accordion-body .button-row{margin-top:18px}
.review-status-text{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:700;font-size:13px}
.review-status-text.pending{background:#fff7ed;color:#c2410c}
.review-status-text.muted{background:#f1f5f9;color:#475569}
.review-summary-link{display:flex;text-decoration:none;color:inherit}
.review-summary-link .summary-row{width:100%}
.compact-review-row-link{display:block;text-decoration:none;color:inherit}
.compact-review-row-link .compact-review-row{height:100%;transition:.2s}
.compact-review-row-link:hover .compact-review-row,.review-summary-link:hover .summary-row{transform:translateY(-1px);box-shadow:0 12px 26px rgba(36,84,166,.08)}
.personnel-info-card .info-box + .info-box{margin-top:12px}
.review-detail-stack{display:flex;flex-direction:column;gap:14px}
.review-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.review-detail-item{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #deebfb}
.review-detail-item span{display:block;color:#64748b;font-size:13px;margin-bottom:4px}
.review-detail-item strong{display:block;color:#173159;word-break:break-word}

@media (max-width:720px){
  .qr-modal-screen{padding:76px 14px 104px}
  .qr-box-large{width:min(100%,280px);min-height:280px}
  .reader-box-large{min-height:320px}
  .scanner-modal-reader{min-height:38vh;max-height:44vh}
  .review-accordion-summary{padding:18px}
  .review-accordion-summary,.review-accordion-summary-side{align-items:flex-start}
  .review-accordion-summary{flex-direction:column}
  .review-accordion-summary-side{width:100%}
  .review-accordion-toggle{width:100%}
  .review-accordion-body{padding:0 18px 18px}
  .review-detail-grid{grid-template-columns:1fr}
}

/* 2026-04-11 detail, live and report improvements */
.login-logo{display:block;width:min(100%,220px);height:auto;margin:0 auto 16px}
.live-trip-link,.live-mini-link,.detail-link-row{text-decoration:none;color:inherit}
.live-trip-link:hover,.live-trip-link:focus-visible,.live-mini-link:hover,.detail-link-row:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(36,84,166,.10);outline:none}
.detail-hero{background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%)}
.detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.detail-title-row h2{margin:0;color:#173159;font-size:28px}
.detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.detail-box{background:#f8fbff;border:1px solid #dceafb;border-radius:20px;padding:16px 18px}
.detail-box span{display:block;color:#64748b;font-size:13px;margin-bottom:6px}
.detail-box strong{display:block;color:#173159;word-break:break-word}
.detail-stack-list{display:flex;flex-direction:column;gap:12px}
.detail-list-row{display:block;background:#f8fbff;border:1px solid #deebfb;border-radius:18px;padding:14px 16px;color:#173159}
.detail-list-row strong{display:block;margin-bottom:4px}
.detail-list-row span{display:block;color:#52637e;line-height:1.5;white-space:pre-line}
.report-group-list{display:flex;flex-direction:column;gap:18px}
.report-group-card .report-group-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.report-group-card h2{margin:4px 0 6px;font-size:24px}
.report-group-card h2 a{text-decoration:none;color:#173159}
.report-group-card p{margin:0;color:#52637e}
.report-group-actions{display:flex;gap:10px;flex-wrap:wrap}
.report-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.button-row-wrap{flex-wrap:wrap}
@media (max-width:980px){.detail-grid,.report-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:720px){.detail-title-row h2{font-size:22px}.detail-grid,.report-summary-grid{grid-template-columns:1fr}.report-group-card .report-group-head,.report-group-actions{width:100%}.report-group-actions .btn{flex:1 1 auto}}


/* 2026-04-11 management modals and professional cards */
.management-shell{display:flex;flex-direction:column;gap:18px}
.management-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.management-toolbar .button-row{margin:0}
.management-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.management-section{display:flex;flex-direction:column;gap:14px}
.management-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.management-section-head h2{margin:0;color:#173159;font-size:24px}
.management-section-head p{margin:4px 0 0;color:#5b6b84}
.management-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.management-card{background:#fff;border:1px solid #dbe7f8;border-radius:24px;padding:18px;box-shadow:0 12px 28px rgba(32,67,129,.08);display:flex;flex-direction:column;gap:14px;min-width:0}
.management-card:hover{box-shadow:0 16px 36px rgba(32,67,129,.11)}
.management-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.management-card-head h3{margin:0;color:#173159;font-size:20px;line-height:1.25}
.management-card-head p{margin:6px 0 0;color:#607089;line-height:1.5}
.management-card-body{display:flex;flex-direction:column;gap:12px}
.management-card-meta{display:flex;flex-wrap:wrap;gap:8px}
.management-card-actions{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap}
.management-card-actions > *{margin:0}
.management-card-actions form{display:inline-flex}
.meta-chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#eef4ff;color:#214889;font-weight:700;font-size:13px;max-width:100%;text-align:center}
.meta-chip.soft{background:#f8fbff;color:#52637e;border:1px solid #dbe7f8}
.meta-chip.success{background:#ecfdf3;color:#166534}
.meta-chip.warning{background:#fff7ed;color:#c2410c}
.meta-chip.danger{background:#fff1f2;color:#be123c}
.info-stack{display:flex;flex-direction:column;gap:10px}
.info-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:18px;background:#f8fbff;border:1px solid #e0ebfa}
.info-row span{display:block;color:#66768f;font-size:13px}
.info-row strong{display:block;color:#173159;text-align:right;word-break:break-word}
.empty-state-card{padding:26px;border:1px dashed #c9daf4;border-radius:24px;background:#f8fbff;color:#586982;text-align:center}
.app-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}
.app-modal[hidden]{display:none !important}
.app-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.62);backdrop-filter:blur(4px)}
.app-modal-dialog{position:relative;z-index:1;width:min(100%,860px);max-height:min(92dvh,960px);background:#fff;border-radius:28px;box-shadow:0 28px 80px rgba(15,23,42,.28);display:flex;flex-direction:column;overflow:hidden}
.app-modal-dialog.narrow{width:min(100%,620px)}
.app-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px 18px;border-bottom:1px solid #e3ebf8}
.app-modal-header h2{margin:0;color:#173159;font-size:24px}
.app-modal-header p{margin:6px 0 0;color:#607089;line-height:1.5}
.app-modal-close{border:0;background:#edf3fe;color:#173159;width:46px;height:46px;border-radius:999px;font-size:28px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.app-modal-content{padding:22px 24px 24px;overflow:auto}
.modal-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.modal-form-grid .full{grid-column:1 / -1}
.form-section-title{margin:4px 0 0;color:#173159;font-size:18px}
.form-help{margin:0;color:#607089;line-height:1.5}
.stack-form .button-row.modal-actions{margin-top:18px}
.management-inline-note{padding:16px 18px;border-radius:20px;background:#f8fbff;border:1px solid #dde8f9;color:#52637e;line-height:1.6}
.input-surface{background:#fff}
.route-stop-grid{display:grid;grid-template-columns:2fr 1.3fr;gap:18px}
.card-link-title{text-decoration:none;color:#173159}
.card-link-title:hover{text-decoration:underline}
@media (max-width:1180px){.management-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.management-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.route-stop-grid{grid-template-columns:1fr}}
@media (max-width:720px){.management-toolbar,.management-section-head,.management-card-head,.info-row{flex-direction:column}.management-card-grid,.management-stat-grid,.modal-form-grid{grid-template-columns:1fr}.app-modal{padding:12px}.app-modal-dialog{width:100%;max-height:94dvh;border-radius:24px}.app-modal-header,.app-modal-content{padding-left:18px;padding-right:18px}.management-card-actions{flex-direction:column}.management-card-actions form,.management-card-actions .btn{width:100%}.management-card-actions .btn,.management-card-actions button{justify-content:center}.info-row strong{text-align:left}}

/* 2026-04-11 dashboard simplification */
.compact-dashboard-head{margin-bottom:18px}
.dashboard-focus-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);gap:18px;align-items:start}
.focus-main-card{min-height:100%}
.dashboard-side-card{height:100%}
.quick-link-side-card{display:flex;flex-direction:column;gap:16px}
.quick-action-stack{display:flex;flex-direction:column;gap:12px}
.quick-link-card.large{padding:18px 20px;border-radius:20px;background:#f8fbff;border:1px solid #deebfb;box-shadow:none}
.quick-link-card.large strong{font-size:17px;color:#173159}
.quick-link-card.large span{line-height:1.55}
.quick-link-card.large:hover,.quick-link-card.large:focus-visible{transform:translateY(-1px);box-shadow:0 12px 28px rgba(36,84,166,.08);outline:none}
.panel-mini-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.panel-mini-stat{background:#f7faff;border:1px solid #d9e5f7;border-radius:18px;padding:14px 16px}
.panel-mini-stat span{display:block;color:#64748b;font-size:13px;margin-bottom:6px}
.panel-mini-stat strong{display:block;color:#173159;font-size:20px;word-break:break-word}
.info-box{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #deebfb;color:#334155;line-height:1.55}
.dashboard-start-form .info-box{grid-column:1/-1}
.full-width-mobile form{margin:0}

@media (max-width:1200px){
  .dashboard-focus-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .panel-mini-stats{grid-template-columns:1fr}
  .compact-dashboard-head h1{font-size:28px}
}

/* 2026-04-11 report rows visual upgrade */
.report-row-board{border:1px solid #dce7f8;border-radius:22px;overflow:hidden;background:#f8fbff}
.report-row-board-head,.report-row-board-row{display:grid;grid-template-columns:minmax(170px,1.3fr) minmax(120px,.8fr) minmax(100px,.7fr) minmax(180px,1.3fr) minmax(150px,1fr) minmax(190px,1.3fr);gap:0}
.report-row-board-head{background:#edf4ff;border-bottom:1px solid #dce7f8}
.report-row-board-head > div{padding:14px 16px;font-size:13px;font-weight:800;letter-spacing:.02em;color:#2a4b83}
.report-row-board-body{display:flex;flex-direction:column}
.report-row-board-row{background:#fff;border-bottom:1px solid #e6eefb;color:#173159;text-decoration:none}
.report-row-board-row:last-child{border-bottom:0}
.report-row-board-link{display:grid}
.report-row-board-link:hover,.report-row-board-link:focus-visible{background:#f7fbff;outline:none}
.report-board-cell{padding:15px 16px;display:flex;flex-direction:column;gap:4px;justify-content:center;min-width:0}
.report-board-cell + .report-board-cell{border-left:1px solid #edf2fb}
.report-board-cell span{display:none;color:#64748b;font-size:12px;font-weight:700;letter-spacing:.02em}
.report-board-cell strong{display:block;color:#173159;font-size:15px;line-height:1.4;word-break:break-word}
.report-board-cell small{display:block;color:#607089;font-size:12px;line-height:1.5}
@media (max-width:1100px){.report-row-board-head,.report-row-board-row{grid-template-columns:minmax(160px,1.2fr) minmax(110px,.75fr) minmax(90px,.65fr) minmax(170px,1.1fr) minmax(140px,.95fr) minmax(170px,1.1fr)}}
@media (max-width:860px){.report-row-board{background:transparent;border:0;overflow:visible}.report-row-board-head{display:none}.report-row-board-body{gap:12px}.report-row-board-row,.report-row-board-link{grid-template-columns:repeat(2,minmax(0,1fr));gap:0;background:#fff;border:1px solid #dce7f8;border-radius:20px;box-shadow:0 10px 26px rgba(36,84,166,.08)}.report-board-cell{padding:14px;border-left:0}.report-board-cell:nth-child(odd){border-right:1px solid #edf2fb}.report-board-cell:nth-child(n+3){border-top:1px solid #edf2fb}.report-board-cell span{display:block}.report-board-cell strong{font-size:14px}}
@media (max-width:520px){.report-row-board-row,.report-row-board-link{grid-template-columns:1fr}.report-board-cell{padding:14px 15px}.report-board-cell:nth-child(odd){border-right:0}.report-board-cell + .report-board-cell{border-top:1px solid #edf2fb}}


.status-pill.cancelled{background:#fee2e2;color:#b91c1c}
.padded-empty-note{padding:18px}
.inline-link-strong{font-weight:800;color:#1d4ed8;text-decoration:none}
.inline-link-strong:hover,.inline-link-strong:focus-visible{text-decoration:underline}
.report-inline-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:20px;background:#f7fbff;border:1px solid #dce7f8}
.compact-inline-actions{justify-content:flex-end}
.trip-lock-box{width:100%;max-width:520px;background:linear-gradient(180deg,#eef6ff 0%,#dce9ff 100%);border:1px solid #c7dafc;border-radius:24px;padding:22px 20px;display:flex;flex-direction:column;gap:10px;text-align:center;box-shadow:0 12px 32px rgba(36,84,166,.10)}
.trip-lock-box strong{font-size:24px;color:#163d7a;letter-spacing:.02em}
.trip-lock-box span{font-size:18px;font-weight:700;color:#173159}
.trip-lock-box small{font-size:14px;color:#475569}
.qr-blocked-state{display:flex;align-items:center;justify-content:center;padding:24px}
.qr-block-message{width:min(100%,420px);display:flex;flex-direction:column;gap:12px;padding:24px;border-radius:24px;background:linear-gradient(180deg,#eef6ff 0%,#dce9ff 100%);border:1px solid #c7dafc;box-shadow:0 12px 32px rgba(36,84,166,.10)}
.qr-block-message strong{font-size:26px;color:#163d7a}
.qr-block-message span{font-size:17px;line-height:1.6;color:#173159;font-weight:700}
.modern-login-wrap{padding:32px 18px;min-height:100vh;background:radial-gradient(circle at top,#dbeafe 0%,#eef4ff 32%,#f8fbff 100%)}
.modern-login-card{width:min(100%,760px);padding:44px 42px;border-radius:34px;box-shadow:0 32px 80px rgba(36,84,166,.14);border:1px solid #e1ebfb}
.centered-login-block{text-align:center;gap:10px;margin-bottom:14px}
.large-login-logo{width:min(100%,260px);margin:0 auto 10px}
.login-heading{margin:0;color:#153e75;font-size:clamp(28px,4vw,40px)}
.login-form-grid{max-width:100%;gap:18px}
.login-form-grid label{font-weight:800;color:#153e75;margin-bottom:8px;display:block}
.login-form-grid input{height:58px;font-size:18px;border-radius:18px;border:1px solid #d3e0f6;background:#fff}
.login-form-grid .btn{min-height:58px;font-size:18px}
@media (max-width:980px){.report-inline-banner{flex-direction:column;align-items:flex-start}.compact-inline-actions{width:100%}.compact-inline-actions .btn,.compact-inline-actions form{width:100%}.compact-inline-actions form button{width:100%}.modern-login-card{padding:34px 22px;border-radius:28px}.large-login-logo{width:min(100%,220px)}}
@media (max-width:720px){.trip-lock-box strong{font-size:22px}.trip-lock-box span{font-size:17px}.qr-block-message strong{font-size:22px}.qr-block-message span{font-size:16px}.login-heading{font-size:30px}.login-form-grid input{font-size:17px;height:56px}.modern-login-wrap{padding:22px 14px}}

/* 2026-04-11 personnel list, branding and account improvements */
.brand-block{display:flex;align-items:center;gap:12px;font-weight:800;line-height:1.25}
.brand-logo{width:46px;height:46px;object-fit:contain;border-radius:14px;background:rgba(255,255,255,.14);padding:6px;flex-shrink:0}
.sidebar .brand-block{align-items:center;gap:14px;padding:8px 0 2px}
.sidebar .brand-block span{font-size:clamp(18px,1.25vw,24px);font-weight:800;line-height:1.2;word-break:break-word}
.personnel-search-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%}
.personnel-search-form input{min-width:min(240px,100%);flex:1 1 220px;height:48px;border-radius:16px;border:1px solid #d6e3f7;background:#fff;padding:0 14px}
.personnel-board .report-row-board-head,.personnel-board .report-row-board-row{grid-template-columns:minmax(180px,1.25fr) minmax(95px,.65fr) minmax(150px,.95fr) minmax(150px,.95fr) minmax(110px,.75fr) minmax(170px,1fr)}
.compact-inline-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.branding-preview-card{display:flex;align-items:center;gap:16px;padding:18px;border-radius:22px;background:#f8fbff;border:1px solid #dce8fa}
.branding-preview-card strong{display:block;color:#173159;font-size:18px;margin-bottom:4px}
.branding-preview-card p{margin:0;color:#607089;line-height:1.5}
.settings-logo-preview{width:92px;height:92px;object-fit:contain;border-radius:22px;background:#fff;border:1px solid #dce8fa;padding:10px;box-shadow:0 10px 24px rgba(36,84,166,.08)}
.checkbox-inline{display:inline-flex;align-items:center;gap:10px;color:#173159;font-weight:600}
.settings-grid{align-items:start}
.account-grid,.personnel-detail-grid{align-items:start}
.account-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:980px){.branding-preview-card{align-items:flex-start}.personnel-board .report-row-board-head,.personnel-board .report-row-board-row{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:720px){.brand-block{font-size:18px}.brand-logo{width:42px;height:42px;border-radius:12px}.sidebar-mobile-logo-slot{left:72px;right:18px;height:54px}.sidebar .brand-block span{font-size:17px}.personnel-search-form{width:100%}.personnel-search-form input,.personnel-search-form .btn{width:100%}.branding-preview-card{flex-direction:column;text-align:center}.settings-logo-preview{width:84px;height:84px}.account-detail-grid{grid-template-columns:1fr}}

.stack-form input[type=color]{padding:8px 10px;height:56px;max-width:180px;cursor:pointer}


/* 2026-04-11 personnel profile photo and cleaner QR card */
.personnel-qr-clean-card{gap:18px;padding-top:28px}
.personnel-qr-identity{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.personnel-qr-identity h2{margin:0;font-size:clamp(28px,4vw,44px);color:#0f172a}
.personnel-qr-identity p{margin:0;color:#334155;font-size:18px;font-weight:600}
.personnel-photo-wrap{width:92px;height:92px;border-radius:999px;background:linear-gradient(180deg,#dbeafe 0%,#bfdbfe 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;border:4px solid rgba(255,255,255,.88);box-shadow:0 16px 34px rgba(15,23,42,.12);color:#1d4ed8;font-weight:900;font-size:30px}
.personnel-photo-wrap.large{width:120px;height:120px;font-size:38px}
.personnel-photo-wrap.modal-photo{width:104px;height:104px;margin:0 auto 12px;font-size:34px}
.personnel-photo-wrap img,.profile-photo-large img,.detail-photo-inline img{width:100%;height:100%;object-fit:cover}
.qr-inline-controls{width:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,320px);gap:14px;align-items:stretch}
.qr-inline-color-card{background:#f7faff;border:1px solid #d9e5f7;border-radius:22px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;min-height:84px}
.qr-inline-color-card label{font-weight:800;color:#173159}
.qr-inline-color-card input{width:64px;height:48px;padding:4px;border-radius:14px;border:1px solid #c9d7eb;background:#fff;flex:0 0 auto}
.qr-inline-open-btn{width:100%;min-height:84px}
.qr-inline-note{width:100%;font-size:15px;color:#51627e;line-height:1.55;text-align:left}
.compact-lock-box{width:100%;max-width:520px;text-align:left}
.personnel-qr-modal-head{text-align:center}
.profile-photo-settings{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.profile-photo-large{width:124px;height:124px;border-radius:999px;background:linear-gradient(180deg,#dbeafe 0%,#bfdbfe 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#1d4ed8;font-weight:900;font-size:38px;box-shadow:0 16px 34px rgba(15,23,42,.12)}
.profile-photo-copy{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}
.profile-photo-copy strong{font-size:22px;color:#173159}
.profile-photo-copy p{margin:0;color:#51627e;line-height:1.6}
.checkbox-inline{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;color:#334155;font-weight:700}
.checkbox-inline input{width:18px;height:18px}
.detail-box-photo{display:flex;flex-direction:column;gap:10px}
.detail-photo-inline{width:80px;height:80px;border-radius:999px;background:linear-gradient(180deg,#dbeafe 0%,#bfdbfe 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#1d4ed8;font-weight:900;font-size:24px}
@media (max-width:720px){
  .qr-inline-controls{grid-template-columns:1fr}
  .qr-inline-color-card{min-height:auto;padding:14px 16px}
  .personnel-photo-wrap.large{width:104px;height:104px;font-size:32px}
  .profile-photo-settings{flex-direction:column;align-items:flex-start}
}

.live-announcement-admin-grid {
    align-items: start;
}

.live-recorder-box {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid rgba(59, 130, 246, 0.12);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.75);
}

.live-recorder-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.announcement-audio-preview {
    width: 100%;
}

.live-target-mode-stack {
    display: grid;
    gap: 10px;
}

.radio-card,
.trip-check-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff;
}

.radio-card input,
.trip-check-card input {
    margin: 0;
}

.live-trip-selection-box {
    display: grid;
    gap: 12px;
}

.live-trip-check-grid {
    display: grid;
    gap: 10px;
}

.trip-check-card span {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.trip-check-card small,
.live-announcement-history-row small {
    color: #64748b;
}

.live-announcement-history-row {
    align-items: flex-start;
}

.live-announcement-history-row audio {
    width: 100%;
    margin-top: 8px;
}

.driver-live-announcement {
    position: fixed;
    left: 16px;
    right: 16px;
    bottom: 16px;
    z-index: 1200;
}

.driver-live-announcement-card {
    max-width: 620px;
    margin: 0 auto;
    background: #0f172a;
    color: #fff;
    border-radius: 24px;
    box-shadow: 0 22px 50px rgba(15, 23, 42, 0.35);
    padding: 18px 18px 16px;
}

.driver-live-announcement-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(96, 165, 250, 0.18);
    color: #bfdbfe;
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 10px;
}

.driver-live-announcement-card h3 {
    margin: 0 0 8px;
    font-size: 24px;
    color: #fff;
}

.driver-live-announcement-card p {
    margin: 0 0 10px;
    color: rgba(255, 255, 255, 0.82);
}

.driver-live-announcement-card .top-note {
    color: rgba(255, 255, 255, 0.8);
    margin-top: 10px;
}

.driver-live-announcement-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

@media (max-width: 768px) {
    .live-recorder-actions,
    .driver-live-announcement-actions {
        flex-direction: column;
    }

    .driver-live-announcement {
        left: 12px;
        right: 12px;
        bottom: 12px;
    }

    .driver-live-announcement-card h3 {
        font-size: 20px;
    }
}

.personnel-qr-modal-head{padding-top:4px}
.qr-modal-meta,.qr-modal-countdown{max-width:min(100%,560px);text-align:center;line-height:1.3;padding-left:8px;padding-right:8px}

@media (max-width: 640px){
  .qr-modal-screen{justify-content:flex-start;padding-top:88px;padding-bottom:24px}
  .qr-modal-head{margin-bottom:8px}
  .personnel-qr-modal-head .badge-line{margin-bottom:10px}
  .qr-modal-head h2{font-size:26px;line-height:1.08;margin:4px 0 2px}
  .qr-modal-head p{font-size:14px}
  .qr-modal-meta{font-size:14px;margin-top:0}
  .qr-modal-box{margin-top:0}
  .qr-modal-countdown{font-size:18px;margin-top:8px;margin-bottom:4px}
}

@media (max-width: 480px){
  .qr-box-large{width:min(100%,248px);min-height:248px;padding:12px}
  .qr-modal-screen{padding-left:12px;padding-right:12px}
}

.inline-audio-setting{display:grid;gap:12px;padding:14px 16px;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#fff}.inline-audio-setting audio{width:100%}

/* 2026-04-11 QR modal fit and no-scroll layout */
.qr-modal{overflow:hidden}
.qr-modal-screen{
  --qr-render-size: 300px;
  min-height:100dvh;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:center;
  padding:18px 18px max(20px, env(safe-area-inset-bottom));
  overflow:hidden !important;
  overscroll-behavior:contain;
  gap:8px;
}
.qr-modal-head{
  width:min(100%,520px);
  margin:0 auto;
  padding-top:max(6px, env(safe-area-inset-top));
  flex:0 0 auto;
}
.personnel-qr-modal-head .badge-line{margin-bottom:8px}
.qr-modal-head h2{
  font-size:clamp(22px,4vw,30px);
  line-height:1.08;
  margin:0 0 4px;
}
.qr-modal-head p{font-size:15px;margin:0}
.qr-modal-body{
  width:min(100%,520px);
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  padding-top:4px;
}
.qr-modal-meta,
.qr-modal-countdown,
.qr-refresh-btn{width:min(100%,420px)}
.qr-modal-meta{
  margin-top:0;
  font-size:15px;
  font-weight:700;
}
.qr-modal-box.qr-box-large{
  width:min(100%, calc(var(--qr-render-size) + 28px));
  min-height:calc(var(--qr-render-size) + 28px);
  padding:12px;
  margin:0;
  border-radius:26px;
}
.qr-modal-box img{
  width:var(--qr-render-size) !important;
  max-width:100% !important;
  height:auto !important;
}
.qr-modal-countdown{
  margin-top:0;
  margin-bottom:0;
  font-size:22px;
  font-weight:900;
}
.qr-refresh-btn{
  position:static;
  left:auto;
  bottom:auto;
  transform:none;
  z-index:auto;
  display:inline-flex;
  justify-content:center;
  margin-top:2px;
  min-height:58px;
}
@media (max-width:640px){
  .qr-modal-screen{padding:14px 12px max(18px, env(safe-area-inset-bottom));gap:8px}
  .personnel-qr-modal-head .badge-line{margin-bottom:8px}
  .qr-modal-head h2{font-size:24px;margin:0 0 2px}
  .qr-modal-head p{font-size:14px}
  .qr-modal-meta{font-size:14px}
  .qr-modal-countdown{font-size:18px}
  .qr-refresh-btn{min-height:54px;font-size:16px}
}

/* 2026-04-11 live announcement delete actions */
.card-head-split{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.inline-danger-form{margin:0}
.live-announcement-history-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.live-announcement-history-top > div{min-width:0;flex:1 1 260px}
@media (max-width:720px){
  .card-head-split,.live-announcement-history-top{align-items:stretch}
  .inline-danger-form,.inline-danger-form .btn{width:100%}
}

@media (max-width:640px){.login-page .login-wrap{padding:14px}.login-page .login-card{padding:24px 20px;border-radius:24px}.login-page .title-block h1{font-size:30px}.login-page .large-login-logo{max-width:150px}.login-page .stack-form input,.login-page .stack-form select,.login-page .stack-form textarea{padding:13px 14px}}


.vehicle-audio-settings-form {
    gap: 18px;
}

.vehicle-audio-setting {
    padding: 16px 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 18px;
    background: rgba(248, 250, 252, 0.96);
}

.vehicle-audio-setting-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    margin-top: 10px;
}

.vehicle-audio-setting-row strong {
    min-width: 54px;
    text-align: right;
    font-size: 1rem;
}

.vehicle-audio-setting input[type="range"] {
    width: 100%;
}

/* 2026-04-12 report sheet tables */
.report-sheet-wrap{border:1px solid #22324a;border-radius:12px;background:#fff;overflow:hidden}
.report-sheet-title{padding:14px 18px;border-bottom:2px solid #22324a;text-align:center;font-weight:800;font-size:18px;letter-spacing:.03em;color:#101828;background:#fff}
.report-sheet-table-wrap{overflow:auto;background:#fff}
.report-sheet-table{width:100%;min-width:860px;border-collapse:collapse;background:#fff}
.report-sheet-table th,.report-sheet-table td{border:1px solid #22324a;padding:11px 10px;font-size:13px;line-height:1.45;text-align:center;vertical-align:middle;color:#101828}
.report-sheet-table th{background:#f8fafc;font-weight:800;position:static}
.report-sheet-table td.text-left-cell,.report-sheet-table th.text-left-cell{text-align:left}
.report-sheet-table small{display:block;font-size:11px;color:#475467;line-height:1.4;margin-top:3px}
.report-sheet-actions{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.sheet-link{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border:1px solid #22324a;border-radius:8px;background:#fff;color:#101828;text-decoration:none;font-size:12px;font-weight:700;line-height:1.2}
.sheet-link:hover,.sheet-link:focus-visible{text-decoration:none;background:#f3f4f6;outline:none}
.sheet-link.muted{background:#eef2ff}
.sheet-link.danger{background:#fff1f2;color:#b42318;cursor:pointer}
.report-sheet-actions form{margin:0}
.report-sheet-actions .sheet-link{min-width:56px}
.compact-sheet-table{min-width:640px}
@media (max-width:860px){.report-sheet-title{font-size:15px;padding:12px 14px}.report-sheet-table{min-width:700px}.report-sheet-table th,.report-sheet-table td{padding:10px 8px;font-size:12px}.report-sheet-actions{flex-direction:column}.report-sheet-actions .sheet-link,.report-sheet-actions form{width:100%}.report-sheet-actions form .sheet-link{width:100%}}
