:root{--bg:#07111f;--panel:#0f1d2f;--panel2:#13243a;--text:#edf6ff;--muted:#9fb3c8;--line:#24405f;--primary:#00c2a8;--primary2:#1e88ff;--danger:#ff4d5e;--warn:#ffb020;--ok:#22c55e;--shadow:0 18px 50px rgba(0,0,0,.35)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,#12365e 0,#07111f 42%,#050b13 100%);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text)}a{color:#83d9ff}.hero{min-height:100vh;display:grid;place-items:center;padding:28px}.hero-card{width:min(1120px,100%);display:grid;grid-template-columns:1.35fr .8fr;gap:24px;align-items:stretch}.hero-panel,.boot-card,.card{background:linear-gradient(180deg,rgba(19,36,58,.94),rgba(12,24,40,.94));border:1px solid rgba(132,190,255,.14);box-shadow:var(--shadow);border-radius:26px}.hero-panel{padding:42px}.boot-card{width:min(470px,100%);padding:34px}.brand-row,.sidebar-top,.actions{display:flex;align-items:center;gap:12px}.brand-row span,.sidebar-subtitle{display:block;color:var(--muted);font-size:13px}.brand-mark{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#03111c;font-weight:900;display:grid;place-items:center;box-shadow:0 10px 26px rgba(0,194,168,.25)}.eyebrow{text-transform:uppercase;color:#77ffe9;letter-spacing:.12em;font-size:12px;margin-top:18px}h1{font-size:clamp(28px,4vw,54px);line-height:1.02;margin:.2em 0}h2{margin:0 0 14px;font-size:20px}p{color:var(--muted);line-height:1.6}.layout{min-height:100vh;display:grid;grid-template-columns:290px 1fr}.sidebar{background:rgba(7,17,31,.92);border-right:1px solid var(--line);padding:22px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh;max-height:100vh;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(0,194,168,.6) rgba(7,17,31,.92)}.sidebar-title{font-weight:800}.nav{display:grid;gap:8px}.nav button,.btn{border:0;border-radius:14px;padding:12px 15px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#03111c;font-weight:800;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.nav button{justify-content:flex-start;background:transparent;color:var(--muted);border:1px solid transparent}.nav button.active,.nav button:hover{background:rgba(0,194,168,.12);color:var(--text);border-color:rgba(0,194,168,.26)}.btn.secondary{background:#203957;color:var(--text)}.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}.btn.danger{background:var(--danger);color:white}.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}.sidebar-footer{margin-top:auto;display:grid;gap:8px;position:sticky;bottom:0;background:linear-gradient(180deg,rgba(7,17,31,.7),rgba(7,17,31,.98));padding-top:10px}.main{padding:26px;overflow:auto}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}.topbar h1{font-size:34px;margin:0}.grid{display:grid;gap:18px}.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.split{display:grid;grid-template-columns:1fr 1.2fr;gap:18px}.card{padding:20px}.stat{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:18px}.stat span,.stat-label{display:block;color:var(--muted);font-size:13px}.stat b,.stat-value{font-size:26px;font-weight:900;margin-top:4px}.form{display:grid;gap:12px}.form.inline{grid-template-columns:1fr 120px auto;align-items:end}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.input{width:100%;background:#071827;border:1px solid #2e5278;color:var(--text);border-radius:14px;padding:12px 13px;outline:none}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,194,168,.14)}.input.mini{padding:8px;border-radius:10px;font-size:13px;min-width:110px}.input.wide{min-width:240px}.checks{display:grid;gap:8px;max-height:280px;overflow:auto;padding:10px;border:1px solid var(--line);border-radius:14px}.check{display:flex;gap:8px;align-items:flex-start;color:var(--muted);font-size:13px}.notice{border-radius:14px;padding:12px 14px;margin:10px 0;background:#203957;color:var(--text);border:1px solid #31577f}.notice.error{background:rgba(255,77,94,.13);border-color:rgba(255,77,94,.45)}.notice.success{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.45)}.hidden{display:none}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;min-width:760px;background:rgba(7,17,31,.35)}th,td{padding:12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;font-size:13px}th{color:#b9d8ff;background:rgba(255,255,255,.05);font-size:12px;text-transform:uppercase;letter-spacing:.06em}tr:hover td{background:rgba(255,255,255,.025)}.badge{display:inline-flex;border:1px solid var(--line);background:#203957;border-radius:99px;padding:5px 9px;font-size:12px;color:var(--text)}.badge.success{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.5)}.badge.warning{background:rgba(255,176,32,.15);border-color:rgba(255,176,32,.5)}.badge.danger{background:rgba(255,77,94,.15);border-color:rgba(255,77,94,.5)}.empty{color:var(--muted);padding:18px;text-align:center}.kv{display:grid;grid-template-columns:150px 1fr;gap:8px}.kv div:nth-child(odd){color:var(--muted)}.max{max-width:600px}@media(max-width:980px){.layout{grid-template-columns:1fr}.sidebar{position:static;height:auto;max-height:none;overflow:visible}.hero-card,.split,.cols-4,.cols-5{grid-template-columns:1fr}.topbar{flex-direction:column}.form.inline,.form-grid{grid-template-columns:1fr}.main{padding:16px}}
.live-indicator{display:inline-flex;align-items:center;gap:8px;margin-top:10px;padding:8px 12px;border:1px solid rgba(34,197,94,.35);border-radius:999px;background:rgba(34,197,94,.10);color:#d9ffe6;font-size:13px;flex-wrap:wrap}.live-dot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(34,197,94,.75);animation:livePulse 1.4s infinite}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.75)}70%{box-shadow:0 0 0 9px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.toolbar{display:flex;gap:10px;align-items:center;margin:12px 0;flex-wrap:wrap}.toolbar .input{max-width:280px}.route-companies{min-height:54px;min-width:230px;resize:vertical}.routes-layout{grid-template-columns:.75fr 1.25fr}.field-label{display:block;color:var(--muted);font-size:12px;margin-bottom:5px}.muted{color:var(--muted)}.student-list{display:grid;gap:16px}.student-card{border:1px solid var(--line);border-radius:20px;padding:16px;background:rgba(7,17,31,.35)}.student-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:12px}.student-head span{color:var(--muted);font-size:13px}.photo-grid{display:grid;grid-template-columns:repeat(4,minmax(130px,1fr));gap:12px;margin:12px 0}.photo-thumb-link{display:grid;gap:7px;text-decoration:none;color:var(--text);font-size:12px}.photo-thumb{width:100%;height:120px;object-fit:cover;border-radius:14px;border:1px solid rgba(255,255,255,.16);background:#071827}.photo-missing{height:120px;border:1px dashed var(--line);border-radius:14px;color:var(--muted);display:grid;place-items:center;text-align:center;padding:8px}.student-kv{margin-top:10px}@media(max-width:980px){.routes-layout,.photo-grid{grid-template-columns:1fr}.student-head{flex-direction:column}}
.mini-pre{white-space:pre-wrap;font-family:inherit;margin:0;line-height:1.45;background:rgba(7,24,39,.72);border:1px solid #2e5278;border-radius:10px;padding:8px;max-width:360px;color:var(--text)}
textarea.input{min-height:110px;resize:vertical}
.action-icons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:16px 0}.icon-card{border:1px solid rgba(132,190,255,.18);border-radius:20px;background:linear-gradient(180deg,rgba(19,36,58,.95),rgba(7,24,39,.95));color:var(--text);padding:18px;text-align:left;cursor:pointer;box-shadow:0 10px 28px rgba(0,0,0,.18)}.icon-card:hover{border-color:var(--primary);transform:translateY(-1px)}.icon-card span{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;background:rgba(0,194,168,.13);font-size:24px;margin-bottom:10px}.icon-card b{display:block;font-size:17px}.icon-card small{display:block;color:var(--muted);margin-top:4px}.route-page{margin-top:16px}.movement-map{position:relative;min-height:310px;border-radius:22px;overflow:hidden;border:1px solid rgba(132,190,255,.16);background:linear-gradient(135deg,rgba(30,136,255,.16),rgba(0,194,168,.08)),repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.05) 1px,transparent 1px,transparent 36px),repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.05) 1px,transparent 1px,transparent 36px),#071827}.movement-map:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 25%,rgba(0,194,168,.18),transparent 22%),radial-gradient(circle at 80% 70%,rgba(30,136,255,.18),transparent 28%)}.map-empty{position:absolute;inset:0;display:grid;place-items:center;color:var(--muted);z-index:1}.map-marker{position:absolute;z-index:2;transform:translate(-50%,-50%);display:grid;justify-items:center;gap:3px;text-decoration:none;color:var(--text);min-width:94px}.map-marker span{width:18px;height:18px;border-radius:50%;background:var(--ok);border:3px solid #fff;box-shadow:0 0 0 8px rgba(34,197,94,.22),0 8px 20px rgba(0,0,0,.35);animation:markerPulse 1.5s infinite}.map-marker.warning span{background:var(--warn);box-shadow:0 0 0 8px rgba(255,176,32,.22),0 8px 20px rgba(0,0,0,.35)}.map-marker.danger span{background:var(--danger);box-shadow:0 0 0 8px rgba(255,77,94,.22),0 8px 20px rgba(0,0,0,.35)}.map-marker b,.map-marker em{background:rgba(7,17,31,.82);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:3px 8px;font-size:11px;font-style:normal;white-space:nowrap}.map-note{font-size:12px;margin:8px 0 0}@keyframes markerPulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.45),0 8px 20px rgba(0,0,0,.35)}70%{box-shadow:0 0 0 14px rgba(34,197,94,0),0 8px 20px rgba(0,0,0,.35)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0),0 8px 20px rgba(0,0,0,.35)}}@media(max-width:980px){.action-icons{grid-template-columns:1fr}.movement-map{min-height:240px}}

/* Nagar Jatra logo + contact page update */
.brand-logo{display:block;object-fit:contain}.home-logo-wrap{display:flex;align-items:center;justify-content:flex-start;margin:0 0 18px}.home-logo-wrap.compact{justify-content:center;margin-bottom:8px}.home-logo{width:min(520px,100%);max-height:360px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.28))}.login-logo{width:min(320px,100%);max-height:220px;object-fit:contain;margin:0 auto 14px;filter:drop-shadow(0 14px 26px rgba(0,0,0,.22))}.sidebar-logo{width:74px;height:74px;object-fit:contain;flex:0 0 74px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.22))}.contact-logo{width:min(440px,100%);max-height:300px;object-fit:contain;filter:drop-shadow(0 20px 40px rgba(0,0,0,.25))}.contact-card{width:min(980px,100%);background:linear-gradient(180deg,rgba(19,36,58,.94),rgba(12,24,40,.94));border:1px solid rgba(132,190,255,.14);box-shadow:var(--shadow);border-radius:26px;padding:34px}.contact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:22px 0}.stat small{display:block;color:var(--muted);font-weight:700;margin-top:6px;font-size:14px}@media(max-width:980px){.home-logo{max-height:260px}.contact-grid{grid-template-columns:1fr}.sidebar-logo{width:58px;height:58px;flex-basis:58px}}

/* Public website pages */
.public-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 24px;background:rgba(5,11,19,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
.public-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:900}.public-logo{width:56px;height:56px;object-fit:contain}.public-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.public-nav a{color:var(--muted);text-decoration:none;border:1px solid transparent;padding:9px 11px;border-radius:999px;font-size:13px;font-weight:700}.public-nav a:hover,.public-nav a.active{color:var(--text);background:rgba(0,194,168,.12);border-color:rgba(0,194,168,.25)}.public-nav .admin-link{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#03111c}.public-main{padding:28px;min-height:calc(100vh - 82px)}.public-hero{width:min(1180px,100%);margin:0 auto;display:grid;grid-template-columns:1.25fr .85fr;gap:24px;align-items:stretch}.public-hero-text,.public-section{background:linear-gradient(180deg,rgba(19,36,58,.94),rgba(12,24,40,.94));border:1px solid rgba(132,190,255,.14);box-shadow:var(--shadow);border-radius:26px;padding:34px}.public-card-stack{display:grid;gap:16px}.public-section{width:min(1120px,100%);margin:0 auto 24px}.public-section.narrow{width:min(860px,100%)}.public-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px}.info-card{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:18px}.info-card b{font-size:18px}.complaint-form{margin-top:18px}.complaint-list{display:grid;gap:16px}.complaint-card{border:1px solid var(--line);border-radius:20px;padding:16px;background:rgba(7,17,31,.35)}.photo-grid.two{grid-template-columns:repeat(2,minmax(160px,1fr))}@media(max-width:980px){.public-header{position:static;align-items:flex-start;flex-direction:column}.public-hero,.public-grid{grid-template-columns:1fr}.public-main{padding:16px}.public-nav{gap:6px}.public-nav a{font-size:12px;padding:8px 9px}}

/* Minimal attractive public website redesign */
.public-header.minimal{background:rgba(255,255,255,.94);color:#071827;border-bottom:1px solid rgba(15,23,42,.08);box-shadow:0 12px 28px rgba(15,23,42,.06)}
.public-header.minimal .public-brand{color:#071827}.public-header.minimal .public-nav a{color:#334155}.public-header.minimal .public-nav a:hover,.public-header.minimal .public-nav a.active{color:#033b5c;background:rgba(14,165,233,.08);border-color:rgba(14,165,233,.18)}
.lang-btn{border:1px solid rgba(14,165,233,.25);background:#eef8ff;color:#075985;font-weight:900;border-radius:999px;padding:9px 12px;cursor:pointer}.lang-btn:hover{background:#dff3ff}
.public-main.minimal-site{background:#f8fafc;color:#0f172a;padding:0}.minimal-site .eyebrow{color:#0284c7}.minimal-site h1,.minimal-site h2,.minimal-site h3{color:#071827}.minimal-site p{color:#475569;line-height:1.75}.minimal-site .btn.ghost{color:#075985;border-color:rgba(14,165,233,.24);background:white}.minimal-site .btn.secondary{background:#e0f2fe;color:#075985;border-color:#bae6fd}.minimal-site .btn{box-shadow:0 12px 28px rgba(14,165,233,.16)}
.hero-minimal{width:min(1180px,100%);margin:0 auto;padding:54px 24px 36px;display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}.hero-copy{padding:20px 0}.hero-copy h1{font-size:clamp(38px,6vw,74px);line-height:1.02;letter-spacing:-.055em;margin:14px 0 20px}.hero-copy p{font-size:18px;max-width:680px}.hero-photo{border-radius:34px;overflow:hidden;box-shadow:0 30px 80px rgba(15,23,42,.18);min-height:520px;background:#dbeafe}.real-img{display:block;width:100%;height:100%;min-height:280px;object-fit:cover}.hero-photo .real-img{min-height:520px}.home-logo-wrap{justify-content:flex-start}.home-logo{width:min(430px,100%);max-height:260px}.plain-section{width:min(1180px,100%);margin:0 auto;padding:54px 24px;display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}.plain-section.reverse{grid-template-columns:.9fr 1.1fr}.plain-section>.real-img,.plain-section>div>.real-img{border-radius:30px;box-shadow:0 22px 54px rgba(15,23,42,.14);min-height:360px}.success-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.success-strip span{background:white;border:1px solid #e2e8f0;border-radius:999px;padding:10px 14px;color:#075985;font-weight:800}.feature-lines{display:grid;gap:10px;margin-top:18px}.feature-lines p{margin:0;padding:14px 0;border-bottom:1px solid #e2e8f0}.feature-lines b{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;background:#e0f2fe;color:#0369a1;margin-right:10px}.blog-section{width:min(1180px,100%);margin:0 auto;padding:54px 24px 70px}.section-title{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:22px}.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.blog-grid article{background:white;border:1px solid #e2e8f0;border-radius:28px;overflow:hidden;box-shadow:0 16px 42px rgba(15,23,42,.07)}.blog-grid article .real-img{height:220px;min-height:220px}.blog-grid article h3{font-size:20px;margin:20px 20px 8px}.blog-grid article p{margin:0 20px 22px}.text-page{width:min(1060px,100%);margin:0 auto;padding:60px 24px}.text-page h1{font-size:clamp(34px,5vw,64px);letter-spacing:-.04em}.text-page>.real-img{border-radius:32px;box-shadow:0 24px 70px rgba(15,23,42,.14);margin-top:26px;max-height:460px}.product-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:28px}.product-list>div{background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:24px;box-shadow:0 14px 36px rgba(15,23,42,.06)}.product-list b{font-size:20px;color:#071827}.contact-clean .contact-logo{margin-bottom:16px}.contact-grid.clean{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:24px 0}.contact-grid.clean>div{background:white;border:1px solid #e2e8f0;border-radius:22px;padding:18px}.contact-grid.clean b{color:#075985}.public-footer{background:#071827;color:#dbeafe;padding:42px 24px 26px}.footer-grid{width:min(1180px,100%);margin:0 auto;display:grid;grid-template-columns:1.45fr .8fr .8fr 1fr;gap:28px}.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:12px}.footer-logo{width:82px;height:82px;object-fit:contain}.footer-brand b{display:block;font-size:22px;color:#fff}.footer-brand span{display:block;color:#93c5fd;font-size:13px}.public-footer p,.public-footer a{color:#bfdbfe}.public-footer h3{color:#fff;margin:0 0 12px}.public-footer a{display:block;text-decoration:none;margin:8px 0}.public-footer a:hover{color:#7dd3fc}.footer-login-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.footer-login{display:inline-flex!important;align-items:center;justify-content:center;background:#0ea5e9!important;color:white!important;border-radius:999px;padding:10px 14px;font-weight:900}.footer-login.secondary{background:#14b8a6!important}.social-icons{display:flex;gap:10px}.social-icons a{display:grid;place-items:center;width:36px;height:36px;background:#0f2945;border:1px solid rgba(255,255,255,.14);border-radius:50%;color:white!important;font-weight:900}.minimal-site .public-section,.minimal-site .public-hero-text,.minimal-site .info-card{background:white;color:#0f172a;border-color:#e2e8f0;box-shadow:0 18px 48px rgba(15,23,42,.07)}
@media(max-width:980px){.hero-minimal,.plain-section,.plain-section.reverse,.blog-grid,.product-list,.contact-grid.clean,.footer-grid{grid-template-columns:1fr}.hero-minimal{padding-top:28px}.hero-photo,.hero-photo .real-img{min-height:340px}.section-title{align-items:flex-start;flex-direction:column}.public-footer{padding-bottom:90px}.home-logo{max-height:220px}.public-header.minimal{position:static}}
/* Public site fixes: brand color, visual pages, blog detail */
.public-header.minimal .public-brand span{color:#0796c9;font-weight:1000;background:linear-gradient(135deg,#0796c9,#00a884);-webkit-background-clip:text;background-clip:text;color:transparent}
.public-header.minimal .public-brand{font-weight:1000}.footer-brand b{color:#7dd3fc}.visual-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin-top:30px}.visual-card{background:#fff;border:1px solid #e2e8f0;border-radius:28px;overflow:hidden;box-shadow:0 16px 42px rgba(15,23,42,.07)}.visual-card .real-img{height:260px;min-height:260px}.visual-card div{padding:22px}.visual-card h3{margin:0 0 8px;font-size:22px;color:#071827}.visual-card p{margin:0}.read-link{display:inline-flex;margin:0 20px 22px;color:#0284c7;font-weight:900;text-decoration:none}.read-link:hover{text-decoration:underline}.blog-list-page{margin-top:28px}.blog-detail .real-img{width:100%;max-height:440px;object-fit:cover;margin:22px 0;border-radius:30px}.blog-detail .lead{font-size:20px;color:#0369a1;font-weight:700}@media(max-width:980px){.visual-list{grid-template-columns:1fr}.visual-card .real-img{height:220px;min-height:220px}}
.map-fullscreen{position:fixed!important;inset:12px!important;z-index:9999!important;margin:0!important;display:flex!important;flex-direction:column!important;background:#07111f!important}.map-fullscreen .movement-map{flex:1!important;min-height:calc(100vh - 120px)!important}.map-fullscreen:after{content:'Press Full screen live map again or reload to exit';position:absolute;right:22px;top:18px;background:rgba(7,17,31,.82);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 12px;color:#dbeafe;font-size:12px;pointer-events:none}

/* Student barcode live camera scanner */
.barcode-scanner-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:9999;display:flex;align-items:center;justify-content:center;padding:18px}
.barcode-scanner-box{width:min(560px,100%);background:#fff;border-radius:18px;padding:18px;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.barcode-scanner-box h3{margin:0 0 6px;font-size:1.25rem}
.barcode-scanner-box p{margin:0 0 12px;color:#526070}
.barcode-scanner-box video{width:100%;max-height:60vh;background:#111;border-radius:14px;object-fit:cover}

/* Production image preview modal for admin/student ID photos */
.photo-open-btn{border:0;background:transparent;text-align:left;cursor:pointer;font:inherit;padding:0}.photo-open-btn small{color:var(--muted);font-size:11px}.photo-open-btn:hover .photo-thumb{outline:3px solid rgba(0,194,168,.35)}.photo-load-error .photo-thumb{display:none}.photo-load-error::before{content:'Image could not load';height:120px;border:1px dashed var(--danger);border-radius:14px;color:#fecaca;display:grid;place-items:center;text-align:center;padding:8px;background:rgba(255,77,94,.08)}.photo-modal{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:20px}.photo-modal.hidden{display:none}.photo-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(4px)}.photo-modal-panel{position:relative;width:min(1100px,96vw);height:min(820px,92vh);background:#07111f;border:1px solid rgba(255,255,255,.18);border-radius:22px;box-shadow:0 28px 90px rgba(0,0,0,.62);display:grid;grid-template-rows:auto 1fr;overflow:hidden}.photo-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);background:rgba(19,36,58,.98)}.photo-modal-body{display:grid;place-items:center;overflow:auto;background:#020617;padding:12px}.photo-modal-body img{max-width:100%;max-height:100%;object-fit:contain;border-radius:10px}.photo-modal-open{overflow:hidden}@media(max-width:700px){.photo-modal{padding:8px}.photo-modal-panel{width:100%;height:96vh;border-radius:16px}.photo-modal-head{align-items:flex-start;flex-direction:column}.photo-modal-head .actions{width:100%;justify-content:flex-end}}

/* Student registration dependent dropdowns */
.dependent-field.hidden{display:none}
.field-hint{display:block;color:var(--muted);font-size:12px;margin-top:5px;line-height:1.4}
.sidebar::-webkit-scrollbar{width:9px}
.sidebar::-webkit-scrollbar-track{background:rgba(7,17,31,.92)}
.sidebar::-webkit-scrollbar-thumb{background:rgba(0,194,168,.55);border-radius:999px}
.sidebar::-webkit-scrollbar-thumb:hover{background:rgba(30,136,255,.7)}

/* Business Analytics Board */
.analytics-filter{margin-bottom:18px}.analytics-stat-grid .stat small{display:block;color:var(--muted);font-size:12px;margin-top:6px}.stat.warning{border-color:rgba(255,176,32,.35);background:rgba(255,176,32,.08)}.analytics-layout{grid-template-columns:1fr 1fr}.analytics-chart{width:100%;height:230px;background:rgba(7,17,31,.35);border:1px solid var(--line);border-radius:18px}.analytics-bars{display:grid;gap:13px}.analytics-bar-row{display:grid;gap:7px}.analytics-bar-label{display:flex;justify-content:space-between;gap:10px;align-items:center}.analytics-bar-label span{color:var(--muted);font-size:12px}.analytics-bar-track{height:12px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.analytics-bar-track span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--primary2));border-radius:999px}.analytics-stat-grid{margin-bottom:0}@media(max-width:980px){.analytics-layout{grid-template-columns:1fr}.analytics-chart{height:200px}}

/* Bus company registry two-level view */
.link-btn{background:none;border:0;color:#83d9ff;font-weight:800;cursor:pointer;padding:0;text-align:left;font:inherit;text-decoration:underline;text-underline-offset:3px}
.link-btn:hover{color:#77ffe9}
.pill-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
