:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--vt-bg: #2f3437;--vt-bg-deep: #24282b;--vt-surface: #383e42;--vt-surface-raised: #42494e;--vt-surface-soft: #34393d;--vt-border: rgba(245, 247, 248, .13);--vt-border-strong: rgba(245, 247, 248, .2);--vt-text: #f5f7f8;--vt-muted: #a7b0b5;--vt-accent: #6e1e2a;--vt-accent-bright: #9e3345;--vt-success: #7da889;--vt-warning: #d6aa5b;--vt-error: #de6d78;--vt-shadow: 0 18px 42px rgba(0, 0, 0, .28)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#2f3437f2,#24282b),var(--vt-bg);color:var(--vt-text)}button,input,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}.session-page{display:grid;grid-template-columns:minmax(0,.85fr) minmax(360px,.6fr);gap:32px;min-height:100vh;padding:48px;align-items:center}.session-intro{display:flex;flex-direction:column;gap:34px;max-width:760px}.brand-block{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;width:42px;height:42px;place-items:center;border:1px solid rgba(245,247,248,.18);background:linear-gradient(145deg,var(--vt-accent),#3b2026);border-radius:8px}.brand-name{color:var(--vt-text);font-size:1.05rem;font-weight:750}.brand-block span,.topbar span,.session-state span,.section-copy,.intro-copy p,.page-heading p,.vehicle-card p,.metric-card small,.evidence-main span,.placeholder-panel p{color:var(--vt-muted)}.intro-copy{display:grid;gap:14px}.intro-copy h1{max-width:780px;font-size:clamp(2.4rem,6vw,5.4rem);line-height:.95;letter-spacing:0}.intro-copy p{max-width:680px;font-size:1.08rem;line-height:1.7}.eyebrow{color:var(--vt-muted);font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.session-card{display:grid;gap:24px;padding:26px;border:1px solid var(--vt-border);background:#383e42eb;border-radius:8px;box-shadow:var(--vt-shadow)}.section-heading{display:grid;gap:8px}.section-heading h1,.page-heading h1{font-size:2rem;line-height:1.08}.section-copy{line-height:1.55}.token-form{display:grid;gap:12px}label{color:var(--vt-text);font-size:.9rem;font-weight:700}textarea,input{width:100%;border:1px solid var(--vt-border);background:var(--vt-bg-deep);color:var(--vt-text);border-radius:8px;padding:12px 13px;outline:none}textarea:focus,input:focus{border-color:#9e3345cc;box-shadow:0 0 0 3px #6e1e2a47}.form-actions{display:flex;flex-wrap:wrap;gap:10px}.button,.icon-text-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:1px solid transparent;border-radius:8px;padding:0 14px;color:var(--vt-text);font-weight:750}.button:disabled,.icon-text-button:disabled{cursor:not-allowed;opacity:.48}.button-primary{background:var(--vt-accent);border-color:#f5f7f81f}.button-primary:hover{background:var(--vt-accent-bright)}.button-secondary{background:var(--vt-surface-raised);border-color:var(--vt-border)}.button-ghost{background:transparent;border-color:var(--vt-border)}.button-small{min-height:34px;padding:0 11px;font-size:.86rem}.button-wide{width:fit-content}.session-state{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--vt-border);background:var(--vt-bg-deep);border-radius:8px}.session-state p{font-weight:760}.app-frame{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;border-right:1px solid var(--vt-border);background:#24282bf5}.primary-nav{display:grid;gap:7px;margin-top:34px}.nav-link,.bottom-nav-link{display:flex;align-items:center;gap:10px;border-radius:8px;color:var(--vt-muted);font-weight:720}.nav-link{min-height:42px;padding:0 12px}.nav-link:hover,.nav-link.active,.bottom-nav-link.active{background:#6e1e2a5c;color:var(--vt-text)}.nav-link-context,.bottom-nav-context{cursor:default;opacity:.72}.nav-link-context:hover,.bottom-nav-context:hover{background:transparent;color:var(--vt-muted)}.main-shell{min-width:0}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;min-height:70px;padding:0 28px;border-bottom:1px solid var(--vt-border);background:#2f3437e6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar-title{font-weight:780}.session-chip{display:inline-flex;align-items:center;gap:7px;max-width:min(360px,46vw);margin-left:auto;padding:8px 10px;border:1px solid var(--vt-border);background:var(--vt-bg-deep);border-radius:999px;color:var(--vt-muted);font-size:.86rem}.session-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-button{display:none}.icon-button{width:40px;padding:0;background:var(--vt-surface);border-color:var(--vt-border)}.content-shell{width:min(1180px,100%);margin:0 auto;padding:34px 28px 74px}.page-stack{display:grid;gap:24px;min-width:0}.page-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}.page-heading>div{display:grid;gap:8px}.search-bar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;border:1px solid var(--vt-border);background:var(--vt-surface-soft);border-radius:8px}.search-bar input{border:0;background:transparent;padding:9px 4px}.vehicle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.vehicle-card,.metric-card,.event-card,.placeholder-panel,.empty-panel,.loading-panel{border:1px solid var(--vt-border);background:var(--vt-surface);border-radius:8px}.vehicle-card{display:grid;gap:14px;padding:18px}.vehicle-card:hover{border-color:var(--vt-border-strong);background:var(--vt-surface-raised)}.vehicle-card h2{font-size:1.22rem;line-height:1.2}.vehicle-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.plate-badge,.access-pill,.event-type{display:inline-flex;align-items:center;width:fit-content;min-height:28px;border-radius:6px;padding:0 9px;font-size:.76rem;font-weight:850}.plate-badge{background:var(--vt-text);color:var(--vt-bg-deep)}.access-pill,.event-type{border:1px solid rgba(245,247,248,.16);color:var(--vt-text);background:#6e1e2a61}.card-meta,.metadata-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:0}dt{color:var(--vt-muted);font-size:.72rem}dd{margin:0;color:var(--vt-text);font-weight:760}.empty-panel,.loading-panel,.placeholder-panel{padding:22px}.empty-panel,.placeholder-panel{display:flex;gap:14px;align-items:flex-start}.empty-panel{flex-direction:column;align-items:center;text-align:center}.empty-panel p,.placeholder-panel h2{font-weight:800}.empty-panel span,.placeholder-panel p{line-height:1.55}.detail-topline{display:flex;min-width:0}.summary-strip{display:grid;grid-template-columns:minmax(280px,1.4fr) repeat(3,minmax(170px,.7fr));gap:14px;max-width:100%;min-width:0}.vehicle-hero-card{display:flex;justify-content:space-between;gap:18px;padding:22px;border:1px solid rgba(158,51,69,.42);background:linear-gradient(145deg,#6e1e2ac7,#383e42f2);border-radius:8px;min-width:0}.vehicle-hero-card h1{margin:6px 0 14px;font-size:2rem;line-height:1.05;overflow-wrap:anywhere}.metric-card{display:flex;gap:12px;align-items:flex-start;padding:18px;min-width:0}.metric-card div{display:grid;gap:4px;min-width:0}.metric-card span{color:var(--vt-muted);font-size:.78rem}.metric-card strong{font-size:1.15rem;line-height:1.15;overflow-wrap:anywhere}.metric-card small{overflow-wrap:anywhere}.detail-tabs{display:inline-flex;width:fit-content;max-width:100%;padding:4px;border:1px solid var(--vt-border);background:var(--vt-bg-deep);border-radius:8px;overflow-x:auto;min-width:0}.detail-tabs button,.segment-button{min-height:34px;border:0;border-radius:6px;padding:0 12px;background:transparent;color:var(--vt-muted);font-weight:760;white-space:nowrap}.detail-tabs button[aria-pressed=true],.segment-button[aria-pressed=true]{background:var(--vt-surface-raised);color:var(--vt-text)}.timeline-section{display:grid;gap:18px}.toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.toolbar h2{margin-top:6px;font-size:1.55rem}.segmented{display:flex;max-width:100%;min-width:0;gap:4px;padding:4px;border:1px solid var(--vt-border);background:var(--vt-bg-deep);border-radius:8px;overflow-x:auto}.timeline-list{display:grid;gap:14px}.event-card{position:relative;display:grid;grid-template-columns:18px minmax(0,1fr);gap:14px;padding:18px}.event-marker{width:10px;height:10px;margin:8px 0 0 4px;border:2px solid var(--vt-accent-bright);background:var(--vt-bg-deep);border-radius:999px}.event-content{display:grid;gap:14px;min-width:0}.event-header{display:flex;justify-content:space-between;gap:14px}.event-header h3{margin-top:8px;font-size:1.15rem}.event-date,.event-description,.evidence-empty{color:var(--vt-muted)}.event-description{line-height:1.55}.evidence-list{display:grid;gap:10px}.evidence-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--vt-border);background:var(--vt-bg-deep);border-radius:8px}.evidence-main{display:flex;align-items:center;min-width:0;gap:10px}.evidence-main p,.evidence-main span{overflow-wrap:anywhere}.evidence-actions{display:flex;gap:8px}.icon-text-button{min-height:34px;padding:0 10px;border-color:var(--vt-border);background:var(--vt-surface);font-size:.86rem}.evidence-error{grid-column:1 / -1}.notice{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:flex-start;padding:14px;border-radius:8px}.notice-error{border:1px solid rgba(222,109,120,.45);background:#6e1e2a3d}.notice-title{font-weight:800}.notice-details{margin:8px 0 0;padding-left:18px;color:var(--vt-muted)}.notice-meta,.microcopy{margin-top:7px;color:var(--vt-muted);font-size:.82rem}.notice-actions{display:grid;justify-items:end;gap:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:20px;background:#0a0c0db8}.preview-dialog{display:grid;grid-template-rows:auto minmax(0,1fr);width:min(980px,100%);height:min(760px,86vh);border:1px solid var(--vt-border-strong);background:var(--vt-bg-deep);border-radius:8px;box-shadow:var(--vt-shadow)}.preview-header{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:16px;border-bottom:1px solid var(--vt-border)}.preview-body{min-height:0;padding:12px}.preview-image,.preview-frame{width:100%;height:100%;border:0;object-fit:contain;background:#111416;border-radius:6px}.bottom-nav{display:none}@media (max-width: 980px){.session-page{grid-template-columns:1fr;padding:28px}.app-frame{display:block;padding-bottom:62px}.sidebar{position:fixed;inset:70px auto 0 0;z-index:40;width:min(286px,88vw);transform:translate(-105%);transition:transform .18s ease}.sidebar-open{transform:translate(0)}.mobile-menu-button{display:inline-flex}.summary-strip{grid-template-columns:1fr 1fr}.vehicle-hero-card{grid-column:1 / -1}.toolbar{align-items:flex-start;flex-direction:column}.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:50;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border-top:1px solid var(--vt-border);background:#24282bf5}.bottom-nav-link{min-height:58px;justify-content:center;flex-direction:column;gap:4px;border-radius:0;font-size:.72rem}}@media (max-width: 680px){.session-page{padding:20px}.content-shell{padding:22px 16px 78px}.topbar{padding:0 14px}.session-chip{max-width:42vw}.search-bar,.evidence-item,.notice{grid-template-columns:1fr}.search-bar svg{display:none}.summary-strip,.card-meta,.metadata-grid{grid-template-columns:1fr}.detail-tabs,.segmented{width:100%}.event-header,.evidence-actions,.page-heading{align-items:flex-start;flex-direction:column}.notice-actions{justify-items:start}}
