/* NiceUCL — Aadhaar / UCL ECMP themed stylesheet */
:root{
    --saffron:#ff9933;
    --saffron-dark:#e07a14;
    --green:#138808;
    --green-dark:#0c5d05;
    --navy:#0b1f5c;
    --navy-dark:#071444;
    --gold:#c9a227;
    --ink:#1f2435;
    --muted:#5b6478;
    --bg:#f5f7fb;
    --card:#ffffff;
    --line:#e6e9f2;
    --shadow:0 6px 18px rgba(12,30,80,.08);
    --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.55}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--saffron-dark)}
.wrap{max-width:1180px;margin:0 auto;padding:0 18px}

/* Topbar */
.topbar{background:linear-gradient(180deg,#fff,#fff);border-bottom:3px solid transparent;border-image:linear-gradient(90deg,var(--saffron) 0,var(--saffron) 33%,#fff 33%,#fff 66%,var(--green) 66%,var(--green) 100%) 1;box-shadow:var(--shadow);position:sticky;top:0;z-index:50}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 18px}
.brand-link{display:flex;gap:12px;align-items:center;color:var(--navy);text-decoration:none}
.brand-emblem{font-size:30px}
.brand-logo{height:46px;width:auto;display:block;max-width:230px}
.brand-text-fallback{display:none}
.brand-text strong{font-size:20px;display:block;letter-spacing:.3px;color:var(--navy)}
.brand-text small{color:var(--muted);font-size:12px}
@media (max-width:600px){
    .brand-logo{height:36px;max-width:170px}
}
.navlinks{display:flex;align-items:center;gap:14px}
.navlinks a{font-weight:500;color:var(--navy)}

/* Buttons */
.btn{display:inline-block;padding:9px 18px;border-radius:8px;border:1px solid transparent;cursor:pointer;font-weight:600;font-size:14px;transition:transform .05s ease, box-shadow .15s ease, background .2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(11,31,92,.18)}
.btn-primary{background:linear-gradient(135deg,var(--saffron),var(--saffron-dark));color:#fff}
.btn-success{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff}
.btn-navy{background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:#fff}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--navy)}
.btn-ghost:hover{background:#f0f3fa}
.btn-block{width:100%}
.btn.sm{padding:5px 10px;font-size:12px}

/* Main */
.main{padding:26px 18px 60px;min-height:55vh}

/* Hero */
.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:center;background:linear-gradient(135deg,#ffffff 0%,#fffaf0 50%,#f1faea 100%);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;inset:auto -40px -40px auto;width:240px;height:240px;background:radial-gradient(circle at center,rgba(255,153,51,.18),transparent 70%);border-radius:50%}
.hero h1{margin:0 0 12px;font-size:38px;line-height:1.15;color:var(--navy)}
.hero h1 span{background:linear-gradient(135deg,var(--saffron) 0%,var(--green) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:var(--muted);font-size:16px;margin:0 0 18px;max-width:560px}
.hero .cta-row{display:flex;gap:10px;flex-wrap:wrap}
.hero .badge-row{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:12px;color:var(--navy);font-weight:500}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}
.hero-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow);position:relative}
.hero-card .ribbon{position:absolute;top:-12px;right:18px;background:linear-gradient(90deg,var(--saffron),var(--green));color:#fff;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.3px}
.aadhaar-mock{border:1px dashed #c9d2e8;border-radius:10px;padding:14px;background:linear-gradient(180deg,#fff,#f7f9ff)}
.aadhaar-mock .row{display:flex;justify-content:space-between;margin-bottom:8px}
.aadhaar-mock label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.aadhaar-mock .val{font-weight:600;color:var(--navy)}
.aadhaar-number{letter-spacing:6px;font-size:22px;font-weight:700;color:var(--navy);text-align:center;margin:10px 0;padding:8px;background:#fff7e6;border-radius:8px}

/* Sections */
.section-title{margin:34px 0 14px;font-size:22px;color:var(--navy);border-left:4px solid var(--saffron);padding-left:10px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:transform .15s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(11,31,92,.12)}
.card .ico{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--saffron),var(--green));color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:12px}
.card h3{margin:0 0 6px;color:var(--navy);font-size:17px}
.card p{margin:0;color:var(--muted);font-size:14px}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:14px}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;text-align:center}
.stat .num{font-size:30px;font-weight:700;color:var(--navy)}
.stat .lbl{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.5px}

/* Auth */
.auth-shell{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin:10px auto;max-width:1000px}
.auth-side{background:linear-gradient(135deg,var(--navy) 0%,#13297a 100%);color:#fff;padding:34px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-side:before{content:"";position:absolute;inset:auto -60px -60px auto;width:260px;height:260px;background:radial-gradient(circle,rgba(255,153,51,.45),transparent 65%);border-radius:50%}
.auth-side h2{margin:0 0 8px;font-size:26px}
.auth-side p{color:#cfd6f0;margin:0 0 14px}
.auth-side .stripe{display:flex;height:8px;border-radius:4px;overflow:hidden;margin-top:12px}
.auth-side .stripe span{flex:1}
.auth-side .stripe .s1{background:var(--saffron)}
.auth-side .stripe .s2{background:#fff}
.auth-side .stripe .s3{background:var(--green)}
.auth-body{padding:34px}
.auth-body h1{margin:0 0 6px;color:var(--navy);font-size:24px}
.auth-body .hint{color:var(--muted);margin:0 0 18px;font-size:14px}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;color:var(--navy);font-weight:500;margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;transition:border-color .15s ease, box-shadow .15s ease}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--saffron);box-shadow:0 0 0 3px rgba(255,153,51,.18)}
.field .help{font-size:12px;color:var(--muted);margin-top:4px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.role-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.role-cards label{cursor:pointer;border:2px solid var(--line);border-radius:10px;padding:12px;text-align:center;background:#fff;transition:.15s ease}
.role-cards input{display:none}
.role-cards input:checked + .role-content{color:var(--navy)}
.role-cards label:has(input:checked){border-color:var(--saffron);background:#fff7e6;box-shadow:0 4px 10px rgba(255,153,51,.18)}
.role-cards .role-content strong{display:block;font-size:15px}
.role-cards .role-content small{color:var(--muted);font-size:12px}

/* Alerts */
.alert{padding:11px 14px;border-radius:10px;margin-bottom:14px;font-size:14px;border:1px solid transparent}
.alert.ok{background:#e7f7e8;border-color:#bce5bd;color:#0c5d05}
.alert.warn{background:#fff7e0;border-color:#f4dc8f;color:#8a6500}
.alert.err{background:#fbe7e7;border-color:#f0b9b9;color:#9a1d1d}
.alert ul{margin:6px 0 0 18px;padding:0}

/* Tables */
.table-shell{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.table-tools{display:flex;justify-content:space-between;align-items:center;padding:14px;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:10px}
.table-tools form{display:flex;gap:8px;flex-wrap:wrap}
table{width:100%;border-collapse:collapse}
th,td{padding:11px 13px;text-align:left;font-size:14px;border-bottom:1px solid var(--line)}
th{background:#f7f9fd;color:var(--navy);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.4px}
tr:last-child td{border-bottom:none}
.pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.pill.admin{background:#e8edff;color:#1a3eb0}
.pill.partner{background:#e7f7e8;color:#0c5d05}
.pill.retailer{background:#fff3e0;color:#a05500}
.pill.active{background:#e7f7e8;color:#0c5d05}
.pill.blocked{background:#fbe7e7;color:#9a1d1d}
.pagi{padding:12px;display:flex;justify-content:center}

/* Dashboard */
.dash-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;margin-top:6px}
.profile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.profile h2{margin:0 0 14px;color:var(--navy)}
.kv{display:grid;grid-template-columns:160px 1fr;gap:8px 14px;font-size:14px}
.kv dt{color:var(--muted)}
.kv dd{margin:0;color:var(--navy);font-weight:500}

/* Responsive */
@media (max-width: 900px){
    .hero{grid-template-columns:1fr}
    .auth-shell{grid-template-columns:1fr}
    .auth-side{display:none}
    .grid-3{grid-template-columns:1fr}
    .grid-2{grid-template-columns:1fr}
    .dash-grid{grid-template-columns:1fr}
    .hero h1{font-size:28px}
}

/* Sidebar layout (authenticated) */
.layout{display:grid;grid-template-columns:260px 1fr;gap:0;min-height:calc(100vh - 130px)}
.layout-main{padding:22px 26px;max-width:100%;overflow-x:hidden}
.sidebar{background:linear-gradient(180deg,#0b1f5c 0%,#13297a 100%);color:#fff;padding:18px 12px 22px;min-height:100%}

/* Profile card */
.side-user{display:flex;gap:10px;align-items:flex-start;padding:0 4px 14px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:12px}
.side-user .avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--saffron),var(--green));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex-shrink:0}
.side-user strong{font-size:14px;display:block;line-height:1.2}
.side-user small{color:#cfd6f0;font-size:11px;display:block;margin-top:3px}

/* Wallet card (clickable) */
.side-wallet{display:block;text-decoration:none;background:linear-gradient(135deg,rgba(255,153,51,.18),rgba(19,136,8,.18));border:1px solid rgba(255,153,51,.3);border-radius:10px;padding:12px 14px;margin-bottom:14px;color:#fff;transition:.18s}
.side-wallet:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(0,0,0,.25);border-color:rgba(255,153,51,.55);color:#fff}
.side-wallet.wallet-active{background:linear-gradient(135deg,var(--saffron),var(--green));border-color:transparent}
.side-wallet small{color:#ffd6a8;text-transform:uppercase;letter-spacing:.6px;font-size:10px;display:block}
.side-wallet .amt{font-size:22px;font-weight:700;color:#fff;margin-top:2px;line-height:1.1}
.side-wallet-cta{display:inline-block;background:rgba(255,255,255,.18);color:#fff;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;margin-top:6px}

/* Navigation */
.side-nav{display:flex;flex-direction:column;gap:1px}
.side-nav a, .side-logout{
    display:flex;align-items:center;gap:9px;
    padding:9px 12px;border-radius:7px;
    color:#cfd6f0;text-decoration:none;font-size:13.5px;font-weight:500;
    background:transparent;border:none;text-align:left;cursor:pointer;width:100%;font-family:inherit;
    transition:.15s;
}
.side-nav a .ico{flex-shrink:0;width:20px;text-align:center;font-size:14px}
.side-nav a .lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-nav a .chg{font-size:10px;font-weight:600;background:rgba(255,255,255,.12);padding:2px 7px;border-radius:999px;color:#fff;flex-shrink:0}
.side-nav a:hover, .side-logout:hover{background:rgba(255,255,255,.1);color:#fff}
.side-nav a:hover .chg{background:rgba(255,255,255,.22)}
.side-nav a.active{background:linear-gradient(90deg,rgba(255,153,51,.22),rgba(19,136,8,.18));color:#fff;border-left:3px solid var(--saffron);padding-left:9px;font-weight:600}
.side-nav a.active .chg{background:linear-gradient(135deg,var(--saffron),var(--green))}

/* Sub-item (List under each service) */
.side-nav a.side-sub{
    padding:6px 12px 6px 36px;font-size:12px;font-weight:500;color:#a8b4d0;margin-bottom:3px;
    position:relative;
}
.side-nav a.side-sub:before{
    content:"";position:absolute;left:22px;top:0;bottom:50%;width:8px;
    border-left:1px dashed rgba(255,255,255,.22);border-bottom:1px dashed rgba(255,255,255,.22);border-bottom-left-radius:4px;
}
.side-nav a.side-sub .ico{font-size:11px;width:14px}
.side-nav a.side-sub:hover{background:rgba(255,255,255,.06);color:#fff;padding-left:36px}
.side-nav a.side-sub.active{background:rgba(255,255,255,.12);color:#fff;border-left:none;padding-left:36px;font-weight:600}
.side-nav a.side-sub.active:before{border-color:rgba(255,153,51,.6)}

/* Disabled (OFF) service */
.side-nav a.side-off{opacity:.45;text-decoration:line-through}
.side-nav a.side-off .chg{background:rgba(255,80,80,.3);color:#ffb0b0}

/* Section group label */
.side-group{font-size:10px;color:#8b95b5;text-transform:uppercase;letter-spacing:.8px;margin:14px 4px 5px;padding:0 8px;font-weight:600}

/* Logout */
.side-logout-form{margin-top:8px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}
.side-logout{color:#ffb0b0}
.side-logout:hover{background:rgba(255,80,80,.15);color:#fff}

/* Page head / form */
.page-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.page-head h1{margin:0;color:var(--navy);font-size:24px}
.form-card{padding:0;overflow:hidden}
.form-card > *{padding-left:28px;padding-right:28px}
.form-card > .form-section{padding-left:28px;padding-right:28px}
.form-section{margin:0;padding:14px 28px;font-size:16px;color:#fff;background:linear-gradient(135deg,var(--navy) 0%,#13297a 100%);display:flex;align-items:center;gap:10px;border-left:5px solid var(--saffron);position:relative}
.form-section:before{content:attr(data-step);background:var(--saffron);color:#fff;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.form-section.green{border-left-color:var(--green);background:linear-gradient(135deg,#0c5d05 0%,#138808 100%)}
.form-section.green:before{background:var(--green)}
.form-section.orange{border-left-color:var(--saffron);background:linear-gradient(135deg,#a55400 0%,#ff9933 100%)}
.form-card > .form-section{margin:0}
.form-card .form-body{padding:18px 28px 4px;background:#fff}
.form-card .form-body.alt{background:#fafbff}
.form-card .submit-row{padding:18px 28px;border-top:1px solid var(--line);background:#f7f9fd;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.radio-row{display:flex;gap:18px;flex-wrap:wrap;padding:8px 0}
.radio-row label{font-weight:400;cursor:pointer;padding:8px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;transition:.15s}
.radio-row label:has(input:checked){border-color:var(--saffron);background:#fff7e6;font-weight:600;color:var(--navy)}
.required{color:#d33;font-weight:700;margin-left:2px}
.field label{font-size:13px;color:var(--navy);font-weight:600}

/* Tabs */
.tab-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;border-bottom:2px solid var(--line);padding-bottom:0}
.tab{padding:10px 16px;text-decoration:none;color:var(--muted);font-weight:500;border-bottom:3px solid transparent;margin-bottom:-2px;display:inline-flex;align-items:center;gap:8px}
.tab:hover{color:var(--navy)}
.tab.active{color:var(--navy);border-bottom-color:var(--saffron)}
.tab .cnt{background:var(--line);color:var(--navy);padding:1px 8px;border-radius:999px;font-size:12px;font-weight:600}
.tab.active .cnt{background:linear-gradient(135deg,var(--saffron),var(--green));color:#fff}

/* Biometric scanner panel */
.bio-shell{background:linear-gradient(135deg,#0a1633 0%,#0b1f5c 100%);border-radius:14px;padding:18px;margin:6px 0 4px;color:#e6f7ff;box-shadow:0 6px 18px rgba(11,31,92,.25)}
.bio-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:14px}
.bio-head strong{color:#fff;font-size:15px;display:block}
.bio-head small{color:#8ab4d8;display:block;margin-top:2px;font-size:12px}
.bio-counter{background:rgba(34,230,255,.12);border:1px solid rgba(34,230,255,.3);border-radius:10px;padding:8px 14px;text-align:center;color:#22e6ff;font-weight:700;font-size:18px;line-height:1}
.bio-counter small{display:block;font-size:10px;color:#8ab4d8;margin-top:2px;font-weight:500}
.bio-grid{display:grid;grid-template-columns:1fr 280px;gap:16px}
@media (max-width:1024px){.bio-grid{grid-template-columns:1fr}}

.finger-row{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
@media (max-width:900px){.finger-row{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.finger-row{grid-template-columns:repeat(2,1fr)}}

.scanner{display:flex;flex-direction:column;gap:6px}
.scanner-card{position:relative;background:#020815;border:1px solid rgba(34,230,255,.35);border-radius:10px;aspect-ratio:3/4;overflow:hidden;box-shadow:inset 0 0 14px rgba(34,230,255,.08)}
.scan-num{position:absolute;top:5px;left:5px;width:20px;height:20px;background:rgba(34,230,255,.15);border:1px solid rgba(34,230,255,.45);border-radius:50%;color:#22e6ff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;z-index:3}
.fp-img.fp-idle{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;transition:opacity .3s ease, filter .3s ease}
.fp-img.fp-done{position:absolute;inset:0;margin:auto;width:55%;height:55%;object-fit:contain;opacity:0;transition:opacity .3s ease, transform .4s ease;filter:drop-shadow(0 0 8px #3ddc97);z-index:2}
.scan-status{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.65);color:#8ab4d8;font-size:11px;text-align:center;padding:3px 4px;letter-spacing:.3px;backdrop-filter:blur(4px);z-index:2}

.scanner-card.scanning .fp-idle{filter:brightness(1.3) saturate(1.4)}
.scanner-card.scanning{animation:scanRing 1.3s ease-in-out}
@keyframes scanRing{
    0%,100%{box-shadow:inset 0 0 14px rgba(34,230,255,.08),0 0 0 0 rgba(34,230,255,.7)}
    50%{box-shadow:inset 0 0 14px rgba(34,230,255,.08),0 0 0 8px rgba(34,230,255,0)}
}
.scanner-card.captured{border-color:#3ddc97;box-shadow:0 0 16px rgba(61,220,151,.5),inset 0 0 22px rgba(61,220,151,.22)}
.scanner-card.captured .fp-idle{opacity:.16;filter:grayscale(1) hue-rotate(90deg) brightness(.8)}
.scanner-card.captured .fp-done{opacity:1;animation:capturePop .55s cubic-bezier(.34,1.56,.64,1)}
.scanner-card.captured .scan-status{background:rgba(8,80,40,.9);color:#a6f0c5;font-weight:600}
@keyframes capturePop{0%{transform:scale(.4) rotate(-15deg);opacity:0}60%{transform:scale(1.15) rotate(5deg);opacity:1}100%{transform:scale(1) rotate(0);opacity:1}}

.scanner-btn{font-size:11px;padding:6px 8px}
.scanner-label{font-size:10px;color:#8ab4d8;text-align:center;line-height:1.3}

.bio-preview{background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px}
.bio-preview h4{margin:0;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px}
.preview-screen{background:#061026;border:1px solid rgba(34,230,255,.2);border-radius:8px;min-height:170px;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:14px;position:relative;overflow:hidden}
.preview-empty p{color:#5e7a99;font-size:12px;margin:8px 0 0}
.preview-fp{width:90px;height:120px;filter:drop-shadow(0 0 10px #3ddc97);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}
.preview-meta{margin-top:8px;color:#cfe7ff;font-size:12px;line-height:1.6}
.preview-meta strong{display:block;color:#22e6ff;font-size:13px;margin-bottom:4px}
.preview-meta b{color:#3ddc97}
.preview-log{list-style:none;padding:0;margin:0;max-height:120px;overflow-y:auto;font-size:12px;color:#cfe7ff}
.preview-log li{padding:5px 0;border-bottom:1px dashed rgba(255,255,255,.08);display:flex;align-items:center;gap:6px}
.preview-log .dot.ok{display:inline-block;width:7px;height:7px;border-radius:50%;background:#3ddc97;box-shadow:0 0 6px #3ddc97}
.preview-log em{color:#3ddc97;font-style:normal;font-weight:600}

/* Doc tiles */
.doc-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.doc-tile{display:block;text-align:center;padding:18px 10px;border:1px solid var(--line);border-radius:10px;text-decoration:none;color:var(--navy);font-weight:600;background:#fff;transition:.15s ease}
.doc-tile:hover{background:#fff7e6;border-color:var(--saffron);transform:translateY(-2px)}
@media (max-width:600px){.doc-row{grid-template-columns:1fr}}

/* Driver cards */
.card.driver{display:flex;flex-direction:column}
.card.driver ul.meta{list-style:none;padding:0;margin:8px 0 12px;font-size:13px}
.card.driver ul.meta li{padding:3px 0;color:var(--muted)}
.card.driver ul.meta strong{color:var(--navy)}

/* Mobile sidebar collapse */
@media (max-width:900px){
    .layout{grid-template-columns:1fr}
    .sidebar{position:sticky;top:0;display:flex;flex-direction:row;overflow-x:auto;min-height:auto;padding:10px;gap:6px;z-index:30}
    .side-user, .side-wallet, .side-group, .side-logout-form{display:none}
    .side-nav{flex-direction:row;flex-wrap:nowrap;gap:6px}
    .side-nav a, .side-logout{white-space:nowrap;padding:6px 10px;font-size:12px}
    .side-nav a .chg{display:none}
    .side-nav a.side-sub{padding:6px 10px;font-size:11px}
    .side-nav a.side-sub:before{display:none}
    .side-nav form{display:inline}
    .layout-main{padding:14px}
}

/* Footer */
.footer{background:linear-gradient(180deg,#0b1f5c,#071444);color:#cfd6f0;margin-top:60px;padding:28px 0 18px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px}
.footer a{color:#cfd6f0;display:block;margin:4px 0;font-size:14px}
.footer a:hover{color:var(--saffron)}
.footer .copy{font-size:12px;color:#8b95b5}
@media (max-width: 700px){.footer-inner{grid-template-columns:1fr}}
