/* BIEMS — Bangladesh Integrated Education Management System
   Live Production Console · Ministry of Education · DSHE */
:root{
  --bd-green:#006A4E;
  --bd-green-dark:#004D38;
  --bd-green-light:#E8F3EF;
  --bd-red:#F42A41;
  --bd-red-dark:#C8132A;
  --ink:#10221B;
  --ink-2:#3A4A44;
  --ink-3:#6B7B75;
  --line:#E2E8E5;
  --line-2:#D2DAD6;
  --paper:#F6F8F7;
  --white:#FFFFFF;
  --card:#FFFFFF;
  --amber:#E8A317;
  --blue:#1F5FA8;
  --shadow:0 1px 2px rgba(16,34,27,.04), 0 4px 16px rgba(16,34,27,.06);
  --shadow-lg:0 10px 30px rgba(16,34,27,.18);
}

/* ===== Apple-style Dark mode ============================
   Pure black canvas, near-black elevated surfaces, hairline separators,
   near-white primary type, Apple's gray secondary, blurred glass nav.
   Reference palette: #000 base · #1d1d1f surface · #2c2c2e elevated ·
   rgba(255,255,255,0.08) hairlines · #f5f5f7 primary · #86868b secondary.
   ========================================================= */
html[data-theme="dark"]{
  --bd-green:#30D158;
  --bd-green-dark:#28BD4D;
  --bd-green-light:rgba(48,209,88,.14);
  --bd-red:#FF453A;
  --bd-red-dark:#FF6961;
  --amber:#FFD60A;
  --blue:#0A84FF;
  --ink:#F5F5F7;
  --ink-2:#A1A1A6;
  --ink-3:#86868B;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.16);
  --paper:#000000;
  --white:#000000;
  --card:#1D1D1F;
  --shadow:0 1px 2px rgba(0,0,0,.6), 0 4px 16px rgba(0,0,0,.5);
  --shadow-lg:0 12px 40px rgba(0,0,0,.7);
  color-scheme:dark;
}
html[data-theme="dark"] body{
  background:var(--paper);color:var(--ink);
  font-family:'SF Pro Text','Inter','Hind Siliguri',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}

/* Surfaces: pure black canvas with subtle elevated surfaces */
html[data-theme="dark"] .sidebar,
html[data-theme="dark"] .masthead{
  background:rgba(0,0,0,.72);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  backdrop-filter:saturate(180%) blur(20px);
  border-color:var(--line);
}
html[data-theme="dark"] .masthead{border-bottom:1px solid var(--line)}
html[data-theme="dark"] .sidebar{border-right:1px solid var(--line)}
html[data-theme="dark"] .gov-bar{background:#000;border-bottom-color:var(--bd-red);color:rgba(255,255,255,.7)}
html[data-theme="dark"] .gov-bar .bn,
html[data-theme="dark"] .gov-bar .clock{color:#fff}

html[data-theme="dark"] .card,
html[data-theme="dark"] .kpi,
html[data-theme="dark"] .mod,
html[data-theme="dark"] .modal,
html[data-theme="dark"] .toast,
html[data-theme="dark"] .dropdown,
html[data-theme="dark"] .fieldset{
  background:var(--card);
  color:var(--ink);
  border-color:var(--line);
  box-shadow:none;
}
html[data-theme="dark"] .card:hover,
html[data-theme="dark"] .mod:hover{border-color:var(--line-2)}

/* Buttons: outlined / subtle fills like Apple */
html[data-theme="dark"] .btn,
html[data-theme="dark"] .icon-btn,
html[data-theme="dark"] .user-chip,
html[data-theme="dark"] .search{
  background:rgba(255,255,255,.06);
  color:var(--ink);
  border-color:var(--line);
}
html[data-theme="dark"] .btn:hover,
html[data-theme="dark"] .icon-btn:hover,
html[data-theme="dark"] .user-chip:hover{
  background:rgba(255,255,255,.12);
  border-color:var(--line-2);
}
html[data-theme="dark"] .btn.primary{background:var(--bd-green);color:#000;border-color:var(--bd-green);font-weight:600}
html[data-theme="dark"] .btn.primary:hover{background:var(--bd-green-dark);border-color:var(--bd-green-dark)}
html[data-theme="dark"] .btn.red{background:var(--bd-red);color:#fff;border-color:var(--bd-red)}
html[data-theme="dark"] .btn.red:hover{background:var(--bd-red-dark)}

/* Inputs */
html[data-theme="dark"] .fld input,
html[data-theme="dark"] .fld select,
html[data-theme="dark"] .fld textarea{
  background:rgba(255,255,255,.04);
  color:var(--ink);
  border-color:var(--line);
}
html[data-theme="dark"] .fld input:focus,
html[data-theme="dark"] .fld select:focus,
html[data-theme="dark"] .fld textarea:focus{
  border-color:var(--bd-green);
  background:rgba(255,255,255,.06);
  box-shadow:0 0 0 3px rgba(48,209,88,.14);
}
html[data-theme="dark"] .search input{background:transparent;color:var(--ink)}
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{color:var(--ink-3)}

/* Tables: borderless rows, hairline separators, no row-zebra */
html[data-theme="dark"] table.dt th{background:transparent;color:var(--ink-3);border-bottom-color:var(--line)}
html[data-theme="dark"] table.dt td{border-bottom-color:var(--line);color:var(--ink)}
html[data-theme="dark"] table.dt tr:hover td{background:rgba(255,255,255,.03)}
html[data-theme="dark"] table.dt tr{background:transparent}

/* Sidebar hover/active — Apple-style subtle fill */
html[data-theme="dark"] .side-link{color:var(--ink)}
html[data-theme="dark"] .side-link:hover{background:rgba(255,255,255,.06)}
html[data-theme="dark"] .side-link.active{
  background:rgba(48,209,88,.10);
  color:var(--bd-green);
  border-left-color:var(--bd-green);
}
html[data-theme="dark"] .side-link.active .ic{color:var(--bd-green)}
html[data-theme="dark"] .side-section{color:var(--ink-3)}

/* Tags: low-saturation, refined */
html[data-theme="dark"] .tag.green{background:rgba(48,209,88,.16);color:#9FE6B2}
html[data-theme="dark"] .tag.red{background:rgba(255,69,58,.18);color:#FFB1AC}
html[data-theme="dark"] .tag.amber{background:rgba(255,214,10,.14);color:#FFE066}
html[data-theme="dark"] .tag.blue{background:rgba(10,132,255,.18);color:#7CB8FF}
html[data-theme="dark"] .tag.gray{background:rgba(255,255,255,.08);color:var(--ink-2)}

/* Bars / dots use accents */
html[data-theme="dark"] .bar{background:rgba(255,255,255,.10)}
html[data-theme="dark"] .bar > span{background:var(--bd-green)}
html[data-theme="dark"] .bar.red > span{background:var(--bd-red)}
html[data-theme="dark"] .bar.amber > span{background:var(--amber)}

/* Alerts */
html[data-theme="dark"] .alert{background:rgba(255,214,10,.08);border-color:rgba(255,214,10,.24);color:#FFE066}
html[data-theme="dark"] .alert.info{background:rgba(10,132,255,.10);border-color:rgba(10,132,255,.32);color:#7CB8FF}
html[data-theme="dark"] .alert.success{background:rgba(48,209,88,.10);border-color:rgba(48,209,88,.32);color:#9FE6B2}
html[data-theme="dark"] .alert.error{background:rgba(255,69,58,.10);border-color:rgba(255,69,58,.32);color:#FFB1AC}

/* Avatar — Apple uses a more refined gradient */
html[data-theme="dark"] .avatar{background:linear-gradient(135deg,#3a3a3c,#1d1d1f);color:#f5f5f7;border:1px solid var(--line)}

/* Misc Apple touches */
html[data-theme="dark"] .phase{background:var(--card);border-color:var(--line)}
html[data-theme="dark"] .phase.complete{background:rgba(48,209,88,.06);border-color:rgba(48,209,88,.30)}
html[data-theme="dark"] .phase.active{background:rgba(255,69,58,.06);border-color:rgba(255,69,58,.45);box-shadow:0 0 0 1px rgba(255,69,58,.45) inset}
html[data-theme="dark"] .phase.upcoming{background:rgba(255,255,255,.02);border-style:dashed;border-color:var(--line-2)}

/* Modules cards */
html[data-theme="dark"] .mod .code{background:rgba(48,209,88,.14);color:var(--bd-green)}

/* Pipeline cards */
html[data-theme="dark"] .pipeline .stage{background:var(--card);border-color:var(--line)}
html[data-theme="dark"] .pipeline .stage.complete{background:rgba(48,209,88,.06);border-color:rgba(48,209,88,.32)}
html[data-theme="dark"] .pipeline .stage.active{background:rgba(255,69,58,.06);border-color:rgba(255,69,58,.50);box-shadow:0 0 0 1px rgba(255,69,58,.50) inset}

/* Calendar */
html[data-theme="dark"] .cal .cd{background:var(--card);border-color:var(--line)}
html[data-theme="dark"] .cal .cd.today{border-color:var(--bd-red);box-shadow:0 0 0 1px var(--bd-red) inset}

/* AI summary card — refined dark gradient */
html[data-theme="dark"] .ai-summary{background:linear-gradient(135deg,#1d1d1f 0%,#2c2c2e 100%);border-left-color:var(--bd-red);color:var(--ink)}
html[data-theme="dark"] .ai-summary li strong{color:#FFB1AC}

/* Hero — keep accent, but border darker */
html[data-theme="dark"] .hero{background:linear-gradient(135deg,#0a3024 0%,#0d4a37 100%)}

/* Verification page — keep dark even if dark mode triggered */
html[data-theme="dark"] body.verify-body{background:#000}
html[data-theme="dark"] .verify-card{background:var(--card);color:var(--ink)}
html[data-theme="dark"] .verify-result{background:rgba(48,209,88,.10);border-left-color:var(--bd-green);color:var(--ink)}

/* Login */
html[data-theme="dark"] body.login-body{background:linear-gradient(135deg,#000 0%,#1d1d1f 60%,#000 100%)}
html[data-theme="dark"] .login-card{background:transparent;box-shadow:none}
html[data-theme="dark"] .login-pitch{background:linear-gradient(160deg,#000,#1d1d1f);border:1px solid var(--line);border-right:0;border-radius:10px 0 0 10px}
html[data-theme="dark"] .login-form{background:var(--card);border:1px solid var(--line);border-left:0;border-radius:0 10px 10px 0}
html[data-theme="dark"] .login-roles button{background:rgba(255,255,255,.06);border-color:var(--line);color:var(--ink-2)}
html[data-theme="dark"] .login-roles button.active{background:var(--bd-green);color:#000;border-color:var(--bd-green)}

/* Ticker */
html[data-theme="dark"] .ticker{background:#000;border-bottom-color:var(--line);color:var(--ink-3)}
html[data-theme="dark"] .ticker .tk-item{border-right-color:rgba(255,255,255,.08)}

/* K-bar */
html[data-theme="dark"] .kbar{background:#1d1d1f;border:1px solid var(--line)}
html[data-theme="dark"] .kbar-input{border-bottom-color:var(--line)}
html[data-theme="dark"] .kbar-section,
html[data-theme="dark"] .kbar-foot{background:rgba(255,255,255,.04);color:var(--ink-3)}
html[data-theme="dark"] .kbar-item{border-bottom-color:var(--line)}
html[data-theme="dark"] .kbar-item:hover,
html[data-theme="dark"] .kbar-item.active{background:rgba(48,209,88,.12)}
html[data-theme="dark"] .kbar-item .kb-ico{background:rgba(48,209,88,.14);color:var(--bd-green)}
html[data-theme="dark"] .kbar-input .kbar-hint,
html[data-theme="dark"] .kbar-foot kbd{background:rgba(255,255,255,.06);border-color:var(--line);color:var(--ink-2)}

/* Detail hero */
html[data-theme="dark"] .detail-hero{background:var(--card);border-color:var(--line)}

/* Footer */
html[data-theme="dark"] footer.gov-foot{background:#000;color:var(--ink-3);border-top:1px solid var(--line)}
html[data-theme="dark"] footer.gov-foot strong{color:var(--ink)}

/* Scrollbar — subtle on dark */
html[data-theme="dark"] ::-webkit-scrollbar{width:10px;height:10px}
html[data-theme="dark"] ::-webkit-scrollbar-track{background:transparent}
html[data-theme="dark"] ::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:6px;border:2px solid #000}
html[data-theme="dark"] ::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.28)}

/* Focus ring — Apple style */
html[data-theme="dark"] *:focus-visible{outline:2px solid var(--bd-green);outline-offset:2px}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Inter','Hind Siliguri','Noto Sans Bengali',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--paper);font-size:14px;line-height:1.5}
a{color:var(--bd-green);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit}

/* ===== Government Header ===== */
.gov-bar{background:var(--bd-green-dark);color:#cfe5dc;font-size:12px;padding:6px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--bd-red)}
.gov-bar .bn{font-family:'Hind Siliguri','Noto Sans Bengali',sans-serif;font-weight:600;color:#fff}
.gov-bar .right{display:flex;gap:18px;align-items:center}
.gov-bar a{color:#cfe5dc}
.gov-bar .clock{font-variant-numeric:tabular-nums;font-weight:600;color:#fff}

.masthead{background:#fff;border-bottom:1px solid var(--line);padding:12px 24px;display:flex;align-items:center;gap:16px}
.crest{width:50px;height:50px;flex-shrink:0;background-image:url('../assets/BD.png');background-size:contain;background-repeat:no-repeat;background-position:center}
.login-pitch .crest{background-image:url('../assets/BD.png');filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}
.masthead h1{margin:0;font-size:17px;letter-spacing:.1px}
.masthead .sub{font-size:12px;color:var(--ink-3);margin-top:2px}
.masthead .right{margin-left:auto;display:flex;align-items:center;gap:12px}

/* ===== Notification + User chip ===== */
.icon-btn{position:relative;width:36px;height:36px;border-radius:6px;border:1px solid var(--line);background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:16px;color:var(--ink-2)}
.icon-btn:hover{background:var(--bd-green-light);border-color:var(--bd-green)}
.icon-btn .badge{position:absolute;top:-4px;right:-4px;background:var(--bd-red);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:1px 5px;min-width:16px;text-align:center;border:1.5px solid #fff}

.user-chip{display:flex;align-items:center;gap:10px;padding:5px 12px 5px 5px;border:1px solid var(--line);border-radius:30px;background:#fff;cursor:pointer}
.user-chip:hover{border-color:var(--bd-green);background:var(--bd-green-light)}
.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--bd-green),var(--bd-green-dark));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;flex-shrink:0}
.user-chip .who{font-size:12px;line-height:1.2}
.user-chip .who strong{display:block;color:var(--ink);font-size:13px}
.user-chip .who span{color:var(--ink-3)}

.dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:var(--shadow-lg);min-width:340px;z-index:50;display:none;overflow:hidden}
.dropdown.open{display:block}
.dropdown .dh{padding:12px 14px;border-bottom:1px solid var(--line);background:#FAFBFA;font-size:12px;color:var(--ink-3);font-weight:600;display:flex;justify-content:space-between;align-items:center}
.dropdown .dh a{font-weight:600}
.dropdown .di{padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px;display:flex;gap:10px;align-items:flex-start}
.dropdown .di:last-child{border-bottom:0}
.dropdown .di:hover{background:#FAFCFB}
.dropdown .di .ic{width:24px;height:24px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.dropdown .di .ic.r{background:#FDE6E9;color:var(--bd-red-dark)}
.dropdown .di .ic.a{background:#FFF4DC;color:#8a5d00}
.dropdown .di .ic.g{background:var(--bd-green-light);color:var(--bd-green-dark)}
.dropdown .di .ic.b{background:#E7EFFA;color:var(--blue)}
.dropdown .di .meta{color:var(--ink-3);font-size:11px;margin-top:2px}

.menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;border-bottom:1px solid var(--line);cursor:pointer;color:var(--ink)}
.menu-item:hover{background:var(--bd-green-light);text-decoration:none}
.menu-item:last-child{border-bottom:0}

.pos-rel{position:relative}

/* ===== Layout ===== */
.shell{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 86px)}
.sidebar{background:#fff;border-right:1px solid var(--line);padding:6px 0 20px;position:sticky;top:0;align-self:start;max-height:100vh;overflow-y:auto}
.side-section{font-size:11px;font-weight:700;color:var(--ink-3);letter-spacing:.8px;padding:14px 18px 6px;text-transform:uppercase}
.side-link{display:flex;align-items:center;gap:10px;padding:7px 18px;color:var(--ink);font-weight:500;border-left:3px solid transparent;font-size:13px}
.side-link:hover{background:var(--bd-green-light);text-decoration:none}
.side-link.active{background:var(--bd-green-light);border-left-color:var(--bd-green);color:var(--bd-green-dark);font-weight:600}
.side-link .ic{
  width:20px;height:20px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-3);
  font-family:'Material Symbols Outlined';
  font-size:20px;font-weight:400;font-style:normal;line-height:1;
  text-transform:none;letter-spacing:normal;white-space:nowrap;
  direction:ltr;-webkit-font-feature-settings:'liga';font-feature-settings:'liga';
  -webkit-font-smoothing:antialiased;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 20;
}
.side-link.active .ic{color:var(--bd-green);font-variation-settings:'FILL' 1,'wght' 500,'GRAD' 0,'opsz' 20}
.side-link .pill{margin-left:auto;font-size:10px;background:var(--bd-red);color:#fff;padding:1px 6px;border-radius:8px;font-weight:700}
.side-link .pill.green{background:var(--bd-green)}
.side-foot{font-size:11px;color:var(--ink-3);padding:18px;border-top:1px solid var(--line);margin-top:14px;line-height:1.6}
.side-foot .env{display:inline-block;padding:1px 6px;background:var(--bd-green-light);color:var(--bd-green-dark);border-radius:3px;font-weight:700;font-size:10px;letter-spacing:.4px;margin-right:4px}

.main{padding:20px 28px 60px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px;border-bottom:1px solid var(--line);padding-bottom:14px}
.page-head h2{margin:0;font-size:21px;letter-spacing:-.2px}
.crumbs{font-size:12px;color:var(--ink-3);margin-bottom:4px}
.crumbs a{color:var(--ink-3)}
.page-head .actions{display:flex;gap:8px;align-items:center}

.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:5px;font-weight:600;font-size:13px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;text-decoration:none}
.btn:hover{background:var(--bd-green-light);border-color:var(--bd-green);text-decoration:none}
.btn.primary{background:var(--bd-green);color:#fff;border-color:var(--bd-green)}
.btn.primary:hover{background:var(--bd-green-dark);border-color:var(--bd-green-dark)}
.btn.red{background:var(--bd-red);color:#fff;border-color:var(--bd-red)}
.btn.red:hover{background:var(--bd-red-dark)}
.btn.ghost{border:1px dashed var(--line-2);color:var(--ink-2)}
.btn.sm{padding:4px 9px;font-size:12px}

/* ===== KPI Cards ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:6px;padding:14px 16px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--bd-green)}
.kpi.red::before{background:var(--bd-red)}
.kpi.amber::before{background:var(--amber)}
.kpi.blue::before{background:var(--blue)}
.kpi .label{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.5px}
.kpi .value{font-size:25px;font-weight:700;margin-top:6px;color:var(--ink);letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.kpi .delta{font-size:11px;margin-top:4px;color:var(--ink-3)}
.kpi .delta .up{color:#117a3d;font-weight:600}
.kpi .delta .down{color:var(--bd-red-dark);font-weight:600}

/* ===== Cards ===== */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:1.4fr 1fr}
.grid-2e{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:16px}
.card h3{margin:0 0 4px;font-size:14px;letter-spacing:.1px}
.card .desc{font-size:12px;color:var(--ink-3);margin-bottom:14px}
.card .chart-box{height:260px;position:relative}

.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:14px}
.tabs button{background:transparent;border:0;border-bottom:2px solid transparent;padding:10px 16px;font-size:13px;font-weight:600;color:var(--ink-3);cursor:pointer}
.tabs button.active{color:var(--bd-green-dark);border-bottom-color:var(--bd-green)}
.tabs button:hover{color:var(--ink)}

/* ===== Tables ===== */
table.dt{width:100%;border-collapse:collapse;font-size:13px}
table.dt th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);font-weight:700;padding:10px 10px;border-bottom:1px solid var(--line);background:#FAFBFA}
table.dt td{padding:10px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
table.dt tr:hover td{background:#FAFCFB}
table.dt .id{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;color:var(--ink-2)}
table.dt td .row-actions{display:flex;gap:4px;visibility:hidden}
table.dt tr:hover .row-actions{visibility:visible}

/* ===== Tags ===== */
.tag{display:inline-block;padding:3px 8px;border-radius:3px;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}
.tag.green{background:var(--bd-green-light);color:var(--bd-green-dark)}
.tag.red{background:#FDE6E9;color:var(--bd-red-dark)}
.tag.amber{background:#FFF4DC;color:#8a5d00}
.tag.blue{background:#E7EFFA;color:var(--blue)}
.tag.gray{background:#EEF2F0;color:var(--ink-2)}

.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot.green{background:#2BA463}
.dot.red{background:var(--bd-red)}
.dot.amber{background:var(--amber)}
.dot.blue{background:var(--blue)}
.dot.gray{background:#9aa8a2}

.bar{height:6px;background:#EEF2F0;border-radius:3px;overflow:hidden;margin-top:4px}
.bar > span{display:block;height:100%;background:var(--bd-green)}
.bar.red > span{background:var(--bd-red)}
.bar.amber > span{background:var(--amber)}

.alert{padding:11px 14px;border-radius:6px;background:#FFF7E0;border:1px solid #F2DDA0;color:#7a5800;font-size:13px;display:flex;gap:10px;align-items:flex-start;margin-bottom:14px}
.alert.info{background:#E7EFFA;border-color:#BCD2EF;color:#1a3f70}
.alert.success{background:#E8F3EF;border-color:#B7D8C8;color:#0F4731}
.alert.error{background:#FDE6E9;border-color:#F3B5BE;color:#7a0c1c}

.search{display:flex;gap:8px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:5px;padding:6px 10px;width:260px}
.search input{border:0;outline:0;flex:1;font-size:13px;background:transparent}

.legend{display:flex;gap:14px;font-size:12px;color:var(--ink-3);margin-top:10px;flex-wrap:wrap}

/* ===== Modules grid (home/overview) ===== */
.modules{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.mod{background:#fff;border:1px solid var(--line);border-radius:6px;padding:16px;position:relative;transition:all .15s;color:var(--ink);display:block}
.mod:hover{border-color:var(--bd-green);box-shadow:var(--shadow);text-decoration:none}
.mod .num{position:absolute;top:14px;right:14px;font-size:11px;color:var(--ink-3);font-weight:700}
.mod .code{display:inline-block;font-size:11px;font-weight:700;color:var(--bd-green-dark);background:var(--bd-green-light);padding:2px 6px;border-radius:3px;margin-bottom:8px;letter-spacing:.4px}
.mod h4{margin:0 0 6px;font-size:14px;color:var(--ink)}
.mod p{margin:0;font-size:12px;color:var(--ink-3);line-height:1.55}

/* ===== Hero ===== */
.hero{background:linear-gradient(120deg,var(--bd-green-dark) 0%,var(--bd-green) 65%,#0d8a64 100%);color:#fff;padding:34px 32px;border-radius:8px;position:relative;overflow:hidden;margin-bottom:22px}
.hero::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;background:var(--bd-red);opacity:.18;border-radius:50%}
.hero::after{content:"";position:absolute;right:60px;bottom:-120px;width:220px;height:220px;background:#fff;opacity:.06;border-radius:50%}
.hero .bn{font-family:'Hind Siliguri','Noto Sans Bengali',sans-serif;font-size:14px;opacity:.85;margin-bottom:6px}
.hero h1{font-size:30px;margin:0 0 8px;letter-spacing:-.3px;font-weight:700;position:relative;z-index:1}
.hero .lede{font-size:15px;max-width:780px;opacity:.92;position:relative;z-index:1;line-height:1.55}
.hero .doc-meta{display:flex;gap:24px;margin-top:20px;font-size:12px;opacity:.85;position:relative;z-index:1;flex-wrap:wrap}
.hero .doc-meta div span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.6px;opacity:.7;margin-bottom:2px}

/* ===== Phase Timeline ===== */
.phases{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:10px}
.phase{padding:14px 16px;border:1px solid var(--line);border-radius:6px;background:#fff;position:relative;display:flex;flex-direction:column;min-height:200px}
.phase.complete{border-color:#B7D8C8;background:#F4FAF7}
.phase.active{border-color:#F3B5BE;background:#FFF6F7;box-shadow:0 0 0 1px var(--bd-red) inset}
.phase.upcoming{border-style:dashed;background:#FAFBFA}
.phase .ph-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.phase .ph{font-size:10px;color:var(--ink-3);font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.phase h5{margin:2px 0 8px;font-size:14px;letter-spacing:-.1px}
.phase .ph-bar{height:5px;background:#EEF2F0;border-radius:3px;overflow:hidden;margin-bottom:10px}
.phase .ph-bar > span{display:block;height:100%;background:var(--bd-green)}
.phase.active .ph-bar > span{background:var(--bd-red)}
.phase .ph-pct{font-size:10px;color:var(--ink-3);font-weight:700;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.phase ul.dlv{list-style:none;padding:0;margin:0;font-size:12px;color:var(--ink-2);flex:1}
.phase ul.dlv li{padding:3px 0 3px 14px;position:relative;line-height:1.45}
.phase ul.dlv li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--bd-green)}
.phase.active ul.dlv li::before{background:var(--bd-red)}
.phase.upcoming ul.dlv li::before{background:var(--line-2)}

/* ===== FORMS ===== */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.form-grid .full{grid-column:1/-1}
.form-grid .third{grid-column:span 1}
.fld{display:flex;flex-direction:column;gap:4px}
.fld label{font-size:12px;font-weight:600;color:var(--ink-2)}
.fld label .req{color:var(--bd-red);margin-left:2px}
.fld label .hint{font-weight:400;color:var(--ink-3);font-size:11px;margin-left:6px}
.fld input,.fld select,.fld textarea{font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:5px;background:#fff;font-size:13px;color:var(--ink);outline:0;transition:border-color .15s}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--bd-green);box-shadow:0 0 0 3px rgba(0,106,78,.10)}
.fld textarea{resize:vertical;min-height:88px}
.fld .help{font-size:11px;color:var(--ink-3);margin-top:2px}
.fld .err{font-size:11px;color:var(--bd-red-dark);margin-top:2px;display:none}
.fld.invalid input,.fld.invalid select,.fld.invalid textarea{border-color:var(--bd-red)}
.fld.invalid .err{display:block}
.fld-row{display:flex;gap:8px;align-items:center}
.checkbox{display:flex;gap:8px;align-items:flex-start;font-size:13px;cursor:pointer}
.checkbox input{width:auto;margin-top:2px}
.fieldset{border:1px solid var(--line);border-radius:6px;padding:14px 16px;margin-bottom:14px;background:#FAFBFA}
.fieldset legend{font-size:11px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.6px;padding:0 6px}

.form-foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}

/* Wizard / stepper */
.stepper{display:flex;gap:0;margin-bottom:20px;background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.step{flex:1;padding:14px 16px;display:flex;align-items:center;gap:10px;position:relative;border-right:1px solid var(--line);font-size:12px;color:var(--ink-3)}
.step:last-child{border-right:0}
.step .n{width:24px;height:24px;border-radius:50%;background:#EEF2F0;color:var(--ink-3);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.step.done .n{background:var(--bd-green);color:#fff}
.step.active{background:var(--bd-green-light);color:var(--bd-green-dark);font-weight:700}
.step.active .n{background:var(--bd-green);color:#fff}
.step .lbl strong{display:block;color:var(--ink);font-size:12px}

/* ===== Modal ===== */
.modal-back{position:fixed;inset:0;background:rgba(16,34,27,.45);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}
.modal-back.open{display:flex}
.modal{background:#fff;border-radius:8px;box-shadow:var(--shadow-lg);max-width:560px;width:100%;max-height:90vh;overflow:auto}
.modal .mh{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal .mh h3{margin:0;font-size:15px}
.modal .mh .x{background:transparent;border:0;cursor:pointer;font-size:22px;line-height:1;color:var(--ink-3)}
.modal .mb{padding:18px 20px}
.modal .mf{padding:14px 20px;border-top:1px solid var(--line);background:#FAFBFA;display:flex;justify-content:flex-end;gap:8px}

/* ===== Toast ===== */
.toast-wrap{position:fixed;top:80px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:#fff;border:1px solid var(--line);border-left:4px solid var(--bd-green);box-shadow:var(--shadow-lg);padding:12px 16px;border-radius:6px;font-size:13px;min-width:280px;max-width:380px;pointer-events:auto;animation:slideIn .25s ease}
.toast.error{border-left-color:var(--bd-red)}
.toast.warn{border-left-color:var(--amber)}
.toast .tt{font-weight:700;font-size:13px;margin-bottom:2px}
.toast .tm{color:var(--ink-2);font-size:12px}
@keyframes slideIn{ from{transform:translateX(20px);opacity:0} to{transform:none;opacity:1} }

/* ===== Login ===== */
body.login-body{background:linear-gradient(135deg,#003A2A 0%,var(--bd-green-dark) 50%,#0d4d3a 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}
body.login-body::before{content:"";position:absolute;right:-200px;top:-200px;width:600px;height:600px;background:var(--bd-red);opacity:.12;border-radius:50%}
body.login-body::after{content:"";position:absolute;left:-100px;bottom:-180px;width:500px;height:500px;background:#fff;opacity:.04;border-radius:50%}
.login-card{background:#fff;border-radius:10px;width:100%;max-width:920px;display:grid;grid-template-columns:1.1fr 1fr;box-shadow:var(--shadow-lg);overflow:hidden;position:relative;z-index:1}
.login-pitch{background:linear-gradient(160deg,var(--bd-green-dark),var(--bd-green));color:#fff;padding:40px 36px;position:relative;overflow:hidden}
.login-pitch::after{content:"";position:absolute;right:-60px;bottom:-60px;width:240px;height:240px;background:var(--bd-red);opacity:.16;border-radius:50%}
.login-pitch .bn{font-family:'Hind Siliguri',sans-serif;opacity:.85;font-size:13px;margin-bottom:6px}
.login-pitch h1{font-size:28px;margin:0 0 12px;letter-spacing:-.3px}
.login-pitch p{font-size:13px;line-height:1.6;opacity:.92;margin:0 0 20px}
.login-pitch .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px;position:relative;z-index:1}
.login-pitch .stat strong{display:block;font-size:22px;font-weight:700}
.login-pitch .stat span{font-size:11px;opacity:.8;text-transform:uppercase;letter-spacing:.5px}
.login-form{padding:40px 36px}
.login-form h2{margin:0 0 4px;font-size:20px}
.login-form .sub{color:var(--ink-3);font-size:13px;margin-bottom:24px}
.login-roles{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.login-roles button{font-size:11px;padding:5px 9px;border:1px solid var(--line);border-radius:30px;background:#fff;cursor:pointer;color:var(--ink-2)}
.login-roles button.active{background:var(--bd-green);color:#fff;border-color:var(--bd-green)}

/* ===== Profile pane ===== */
.profile-head{display:flex;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px;margin-bottom:18px}
.profile-head .ava-lg{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--bd-green),var(--bd-green-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;flex-shrink:0}
.profile-head h2{margin:0;font-size:20px}
.profile-head .meta{color:var(--ink-3);font-size:13px;margin-top:2px}

/* ===== Misc ===== */
footer.gov-foot{background:var(--bd-green-dark);color:#cfe5dc;padding:16px 28px;font-size:12px;display:flex;justify-content:space-between;align-items:center}
footer.gov-foot strong{color:#fff}

/* ============================================================
   RESPONSIVE — mobile-first refinements
   Breakpoints: 1100 (small desktop) · 900 (tablet/drawer) · 680 (small tablet) · 480 (phone) · 380 (small phone)
   ============================================================ */

/* Hamburger only shows when the drawer is in play */
.hamburger{display:none}
.nav-scrim{display:none;position:fixed;inset:0;background:rgba(16,34,27,.45);z-index:80;backdrop-filter:blur(2px)}
.nav-scrim.open{display:block}

@media (max-width:1200px){
  .grid-2,.grid-2e{grid-template-columns:1fr 1fr}
}

/* === Tablet & below — sidebar becomes off-canvas drawer === */
@media (max-width:900px){
  .shell{grid-template-columns:1fr}
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;
    width:280px;max-width:85vw;
    z-index:90;background:#fff;
    transform:translateX(-100%);
    transition:transform .25s ease;
    box-shadow:var(--shadow-lg);
    overflow-y:auto;
    max-height:none;
    border-right:1px solid var(--line)
  }
  .sidebar.open{transform:none}
  .hamburger{display:inline-flex}

  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .grid-3,.grid-4,.modules,.phases{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .stepper .step .lbl{display:none}
  .stepper .step{justify-content:center}
}

/* === Compact top bar + tighter cards/forms at <= 760 === */
@media (max-width:760px){
  .gov-bar{padding:6px 12px;font-size:11px;flex-wrap:wrap;gap:4px}
  .gov-bar .right{gap:8px}
  .gov-bar .bn{font-size:11px}

  .masthead{padding:10px 12px;gap:10px}
  .masthead h1{font-size:14px;line-height:1.25}
  .masthead .sub{font-size:11px}
  .crest{width:38px;height:38px}
  .masthead .right{gap:6px}
  .hide-sm{display:none !important}

  .main{padding:14px 12px 36px}
  .page-head{flex-direction:column;align-items:stretch;gap:10px}
  .page-head h2{font-size:18px}
  .page-head .actions{width:100%;flex-wrap:wrap;gap:6px}
  .page-head .actions .btn{flex:1 1 auto}
  .search{width:100%;min-width:0}

  .card{padding:14px}
  .card h3{font-size:13px}
  .card .desc{font-size:11.5px;margin-bottom:10px}

  /* Wide non-table content (the Gantt) still scrolls horizontally */
  .gantt{min-width:900px}
  .card:has(.gantt){overflow-x:auto;-webkit-overflow-scrolling:touch}

  .hero{padding:22px 18px}
  .hero h1{font-size:22px;line-height:1.25}
  .hero .lede{font-size:13px}
  .hero .doc-meta{gap:14px}

  .modules{grid-template-columns:repeat(2,1fr)}
  .phase{min-height:auto}
  .modal-back{padding:0;align-items:flex-end}
  .modal{max-height:92vh;border-radius:10px 10px 0 0}
  .modal .mf{flex-wrap:wrap;gap:6px}
  .modal .mf .btn{flex:1 1 auto}

  .toast-wrap{top:auto;bottom:14px;right:14px;left:14px}
  .toast{min-width:0;max-width:none}

  .form-foot{flex-direction:column;gap:10px;align-items:stretch}
  .form-foot .btn{width:100%;justify-content:center}

  .profile-head{flex-direction:column;text-align:center;gap:10px}
  .profile-head .ava-lg{margin:0 auto}
}

/* === Phone <= 680 — tables RESTRUCTURE into labelled card-rows === */
@media (max-width:680px){
  /* Each row becomes its own bordered card; header row hidden, data-label drives the column label */
  table.dt{display:block;min-width:0;border-collapse:separate}
  table.dt thead{display:none}
  table.dt tbody,
  table.dt tr,
  table.dt td{display:block;width:100%}
  table.dt tr{
    background:#FAFBFA;
    border:1px solid var(--line);
    border-radius:6px;
    padding:10px 12px;
    margin-bottom:8px;
  }
  table.dt tr:hover td{background:transparent}
  table.dt td{
    display:grid;
    grid-template-columns:108px 1fr;
    gap:10px;
    align-items:center;
    padding:5px 0;
    border:none;
    text-align:left;
    white-space:normal;
    word-break:break-word;
    font-size:13px;
    line-height:1.45;
  }
  table.dt td::before{
    content:attr(data-label);
    font-weight:700;
    color:var(--ink-3);
    font-size:10px;
    text-transform:uppercase;
    letter-spacing:.5px;
  }
  /* Cells without label (e.g. spacer columns) drop the label slot */
  table.dt td:not([data-label])::before{display:none}
  table.dt td:not([data-label]){grid-template-columns:1fr}

  /* Action cells with multiple buttons stay flex */
  table.dt td .row-actions,
  table.dt td > div[style*="display:flex"]{justify-content:flex-start}

  /* Tighter card grids on phone — keep 2-col where items are small (boards, modules) */
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .modules{grid-template-columns:repeat(2,1fr)}

  /* Chart cards shouldn't grow with the longer label column */
  .chart-box{height:220px !important}
}

/* === Phone === */
@media (max-width:480px){
  .gov-bar .bn,
  .gov-bar > div:first-child > span:not(.bn){font-size:10px}
  .masthead h1{font-size:13px}
  .masthead .sub{font-size:10px}
  .user-chip .who{display:none}
  .user-chip{padding:4px}

  .kpi{padding:10px 12px}
  .kpi .value{font-size:20px}
  .kpi .label{font-size:10px}
  .kpi .delta{font-size:10px}

  .grid-3,.grid-4,.modules,.phases{grid-template-columns:1fr}

  .dropdown{position:fixed;left:8px;right:8px;top:64px;min-width:0;max-width:none;width:auto}

  footer.gov-foot{flex-direction:column;gap:6px;text-align:center;padding:14px 16px;font-size:11px}

  .phases{grid-template-columns:1fr}
  .step .n{width:22px;height:22px;font-size:11px}
  .stepper .step{padding:10px 6px}

  /* Login adapts */
  body.login-body{padding:12px;align-items:flex-start;padding-top:20px}
  .login-card{grid-template-columns:1fr;max-width:480px}
  .login-pitch{padding:24px 20px}
  .login-pitch h1{font-size:22px}
  .login-pitch .stats{grid-template-columns:1fr 1fr;gap:10px}
  .login-pitch .stat strong{font-size:18px}
  .login-form{padding:22px 20px}
  .login-form h2{font-size:18px}
}

/* === Small phone === */
@media (max-width:420px){
  .kpi-grid{grid-template-columns:1fr}
  .grid-4,.modules{grid-template-columns:1fr}
  .page-head .actions .btn{font-size:12px;padding:6px 10px}
  table.dt td{grid-template-columns:92px 1fr;gap:8px}
  .card{padding:12px}
}

/* Help touch targets */
@media (hover:none){
  .btn,.icon-btn,.side-link{min-height:36px}
  .btn.sm{min-height:30px}
}

/* ============================================================
   FEATURE BLOCKS — ticker · search · tour · calendar · map · workflow · print · etc.
   ============================================================ */

/* ===== Activity ticker (under top bar) ===== */
.ticker{background:#0c1e18;color:#cfe5dc;font-size:12px;padding:6px 0;overflow:hidden;border-bottom:1px solid #0a1612;position:relative}
.ticker .tk-label{position:absolute;left:0;top:0;bottom:0;background:var(--bd-red);color:#fff;padding:0 12px;display:flex;align-items:center;font-weight:700;font-size:10px;letter-spacing:.6px;text-transform:uppercase;z-index:2}
.ticker .tk-track{display:inline-block;white-space:nowrap;padding-left:90px;animation:tkmove 65s linear infinite}
.ticker .tk-item{display:inline-block;padding:0 24px;border-right:1px solid #1a2e27}
.ticker .tk-item .dot{margin-right:6px}
@keyframes tkmove{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker:hover .tk-track{animation-play-state:paused}

/* ===== Search command palette (⌘K) ===== */
.kbar-back{position:fixed;inset:0;background:rgba(16,34,27,.55);display:none;align-items:flex-start;justify-content:center;z-index:120;padding-top:10vh;padding-left:14px;padding-right:14px}
.kbar-back.open{display:flex;animation:fadeIn .15s ease}
.kbar{background:#fff;border-radius:10px;box-shadow:var(--shadow-lg);width:100%;max-width:620px;overflow:hidden}
html[data-theme="dark"] .kbar{background:var(--card)}
.kbar-input{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.kbar-input input{flex:1;border:0;outline:0;font:inherit;font-size:16px;background:transparent;color:var(--ink)}
.kbar-input .kbar-hint{font-size:11px;color:var(--ink-3);background:var(--paper);padding:2px 6px;border-radius:3px;border:1px solid var(--line)}
.kbar-list{max-height:50vh;overflow:auto}
.kbar-section{font-size:10px;text-transform:uppercase;color:var(--ink-3);font-weight:700;letter-spacing:.5px;padding:10px 16px 4px;background:var(--paper)}
.kbar-item{display:flex;gap:10px;padding:10px 16px;align-items:center;cursor:pointer;border-bottom:1px solid var(--line)}
.kbar-item:hover,.kbar-item.active{background:var(--bd-green-light)}
.kbar-item .kb-ico{width:28px;height:28px;border-radius:6px;background:var(--bd-green-light);color:var(--bd-green-dark);display:inline-flex;align-items:center;justify-content:center;font-family:'Material Symbols Outlined';font-size:18px;flex-shrink:0}
.kbar-item .kb-body{flex:1;min-width:0}
.kbar-item .kb-body strong{display:block;font-size:13px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kbar-item .kb-body span{font-size:11px;color:var(--ink-3)}
.kbar-foot{padding:8px 16px;border-top:1px solid var(--line);font-size:11px;color:var(--ink-3);background:var(--paper);display:flex;gap:14px}
.kbar-foot kbd{background:#fff;border:1px solid var(--line);border-radius:3px;padding:1px 5px;font-size:10px;font-family:inherit}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ===== Onboarding tour ===== */
.tour-overlay{position:fixed;inset:0;background:rgba(16,34,27,.65);z-index:140;display:none;align-items:center;justify-content:center;padding:24px}
.tour-overlay.open{display:flex;animation:fadeIn .2s ease}
.tour-card{background:#fff;border-radius:10px;padding:24px 26px;max-width:460px;box-shadow:var(--shadow-lg)}
html[data-theme="dark"] .tour-card{background:var(--card)}
.tour-card h3{margin:0 0 6px;font-size:18px}
.tour-card p{margin:0 0 18px;color:var(--ink-2);font-size:13.5px;line-height:1.55}
.tour-dots{display:flex;gap:4px;margin-bottom:16px}
.tour-dots span{width:18px;height:4px;background:var(--line);border-radius:2px}
.tour-dots span.on{background:var(--bd-green)}
.tour-foot{display:flex;justify-content:space-between;gap:8px}

/* ===== Calendar grid ===== */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;background:transparent}
.cal .ch{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--ink-3);text-align:center;padding:6px 4px;letter-spacing:.5px}
.cal .cd{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:8px;min-height:90px;font-size:11px;position:relative}
.cal .cd.other{opacity:.4}
.cal .cd.today{border-color:var(--bd-red);box-shadow:0 0 0 1px var(--bd-red) inset}
.cal .cd .dn{font-weight:700;font-size:13px;color:var(--ink);margin-bottom:4px}
.cal .ev{display:block;font-size:10px;line-height:1.25;padding:2px 4px;border-radius:3px;margin-bottom:2px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal .ev.exam{background:var(--bd-red)}
.cal .ev.finance{background:var(--bd-green)}
.cal .ev.training{background:var(--blue)}
.cal .ev.holiday{background:var(--amber);color:#3d2700}
.cal .ev.meeting{background:#6B7B75}
.cal .ev.deadline{background:var(--bd-red-dark)}

/* ===== Map ===== */
#bdMap{height:520px;border-radius:6px;border:1px solid var(--line);position:relative;z-index:1}
.legend-chip{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;background:var(--card);border:1px solid var(--line);border-radius:30px;font-size:11px;color:var(--ink-2)}

/* ===== MPO Workflow pipeline ===== */
.pipeline{display:flex;gap:10px;align-items:stretch;overflow-x:auto;padding-bottom:6px}
.pipeline .stage{flex:1;min-width:180px;background:var(--card);border:1px solid var(--line);border-radius:6px;padding:12px 14px;position:relative}
.pipeline .stage.complete{border-color:#B7D8C8;background:#F4FAF7}
.pipeline .stage.active{border-color:var(--bd-red);box-shadow:0 0 0 1px var(--bd-red) inset}
.pipeline .stage.upcoming{border-style:dashed;opacity:.7}
.pipeline .stage .st-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);font-weight:700}
.pipeline .stage h5{margin:0 0 4px;font-size:13px}
.pipeline .stage p{margin:0;font-size:11.5px;color:var(--ink-2);line-height:1.4}
html[data-theme="dark"] .pipeline .stage.complete{background:#0F2A20;border-color:#1F5A40}

/* ===== AI summary card on dashboard ===== */
.ai-summary{background:linear-gradient(135deg,#0c2820 0%,#13483A 100%);color:#fff;border-radius:8px;padding:16px 20px;margin-bottom:18px;border-left:4px solid var(--bd-red);position:relative;overflow:hidden}
.ai-summary::before{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;background:rgba(255,255,255,.04);border-radius:50%}
.ai-summary .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;position:relative}
.ai-summary .head h3{margin:0;font-size:13px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;opacity:.9}
.ai-summary .head .when{font-size:11px;opacity:.7}
.ai-summary ul{margin:0;padding:0 0 0 18px;font-size:13.5px;line-height:1.75;position:relative}
.ai-summary li{margin-bottom:2px}
.ai-summary li strong{color:#ffd9dd}

/* ===== Notification preferences page ===== */
.pref-row{display:grid;grid-template-columns:1fr 80px 80px 80px;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.pref-row:last-child{border-bottom:0}
.pref-row label{font-size:13px}
.pref-row .ck{display:flex;justify-content:center}

/* ===== Detail page hero ===== */
.detail-hero{background:#fff;border:1px solid var(--line);border-radius:8px;padding:20px;display:flex;gap:20px;align-items:flex-start;margin-bottom:18px}
html[data-theme="dark"] .detail-hero{background:var(--card)}
.detail-hero .ava{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--bd-green),var(--bd-green-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:28px;flex-shrink:0}
.detail-hero h2{margin:0;font-size:22px}
.detail-hero .meta{color:var(--ink-3);font-size:13px;margin-top:4px;line-height:1.6}
.detail-hero .tags{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.detail-hero .right-col{margin-left:auto;text-align:right;font-size:12px;color:var(--ink-3)}
@media (max-width:680px){
  .detail-hero{flex-direction:column;text-align:center}
  .detail-hero .right-col{margin-left:0;text-align:center}
  .pref-row{grid-template-columns:1fr;gap:6px}
  .pref-row .ck{justify-content:flex-start}
}

/* ===== Tooltips for theme/lang toggle ===== */
.icon-btn.lang{font-size:11px;font-weight:700;letter-spacing:.4px}

/* ===== Verification (public) page ===== */
body.verify-body{background:linear-gradient(135deg,#003A2A,var(--bd-green-dark));min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.verify-card{background:#fff;border-radius:10px;max-width:520px;width:100%;padding:30px 30px 26px;box-shadow:var(--shadow-lg)}
.verify-card h1{margin:0 0 4px;font-size:22px}
.verify-card .lede{color:var(--ink-3);font-size:13px;margin-bottom:20px}
.verify-result{margin-top:18px;padding:16px;background:var(--bd-green-light);border-radius:6px;border-left:4px solid var(--bd-green)}
.verify-result h3{margin:0 0 8px;font-size:14px}
.verify-result .row{display:grid;grid-template-columns:130px 1fr;gap:6px;font-size:13px;padding:3px 0}
.qr-block{display:flex;align-items:center;gap:14px;margin-top:14px}
.qr-block svg{flex-shrink:0}

/* ===== Print stylesheet ===== */
@media print{
  .gov-bar,.masthead,.sidebar,footer.gov-foot,.ticker,.actions,.toast-wrap,.dropdown,.icon-btn,.user-chip,.nav-scrim,.hamburger,.kbar-back{display:none !important}
  .shell{display:block}
  .main{padding:0}
  .card{border:1px solid #ccc;box-shadow:none;break-inside:avoid;page-break-inside:avoid}
  body{background:#fff;color:#000;font-size:11px}
  .ai-summary{background:#f7f7f7 !important;color:#000 !important;border-left-color:#000}
  .hero{background:#f0f0f0 !important;color:#000 !important}
  .tag{border:1px solid #999;background:#fff !important;color:#000 !important}
  table.dt th{background:#f0f0f0 !important;color:#000 !important}
}

/* ============================================================
   PIXEL-LEVEL RESPONSIVE — every common device width covered
   320 → 360 → 375 → 414 → 480 → 568 → 768 → 1024 → 1280
   ============================================================ */

/* Universal safety — prevent horizontal scrolls on mobile only.
   (overflow:hidden on html at desktop would break sticky sidebar.) */
img,svg,video,canvas,iframe{max-width:100%;height:auto}
*{min-width:0}
@media (max-width:900px){
  html,body{max-width:100vw;overflow-x:hidden}
}

/* Smarter wrapping for fluid scaling */
.kpi .value{word-break:break-word}
.crumbs{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.detail-hero h2{word-break:break-word;line-height:1.2}

/* === iPad landscape (1024) and below === */
@media (max-width:1024px){
  .main{padding:18px 20px 48px}
  .hero{padding:28px 24px}
  .hero h1{font-size:26px}
  .login-card{max-width:760px}
  .pipeline .stage{min-width:160px}
}

/* === iPad portrait (768) === */
@media (max-width:820px){
  #bdMap{height:380px}
  .ai-summary{padding:14px 16px}
  .ai-summary .head h3{font-size:12px}
  .ai-summary ul{font-size:13px}
  .login-pitch{padding:30px 26px}
}

/* === Visibility helpers (the `hide-md` class is used in markup) === */
@media (max-width:900px){
  .hide-md{display:none !important}
}

/* === Tighten top bar between phone-and-tablet (~ 620px) ===
   At this range the user-chip text wraps and the BD region chip crowds. */
@media (max-width:620px){
  .user-chip .who{display:none}
  .user-chip{padding:4px}
  .masthead{gap:8px}
  .masthead .right{gap:6px;flex-wrap:wrap;justify-content:flex-end}
  .masthead .sub{font-size:11px}
  /* Prevent any leftover top-bar tags from wrapping their own text */
  .masthead .tag{white-space:nowrap}
  /* Stack side-by-side card grids so charts/tables get full width */
  .grid-2,.grid-2e{grid-template-columns:1fr}
  /* Page-head actions stack & each fills the row */
  .page-head .actions{flex-direction:column;width:100%;gap:6px}
  .page-head .actions > *{width:100%}
  .page-head .actions .btn,
  .page-head .actions select.btn{justify-content:center}
}

/* === Larger phones / smallest tablets (568) === */
@media (max-width:568px){
  /* Smaller hero */
  .hero{padding:22px 18px;border-radius:6px}
  .hero h1{font-size:20px;letter-spacing:-.2px}
  .hero .bn{font-size:12px}
  .hero .lede{font-size:13px}
  .hero .doc-meta{gap:10px;font-size:11px}
  .hero .doc-meta div span{font-size:9px}

  /* Page head */
  .page-head{padding-bottom:10px;gap:8px}
  .page-head h2{font-size:17px}

  /* Pipeline → vertical stack on phone */
  .pipeline{flex-direction:column}
  .pipeline .stage{min-width:0;width:100%}

  /* Stepper: hide labels (keep numbers); 5 dots in a row at 320 is fine */
  .stepper .step{padding:9px 4px}
  .stepper .step .lbl{display:none}
  .stepper .step .n{width:24px;height:24px}

  /* AI summary card scales with viewport */
  .ai-summary{padding:14px 16px;border-radius:6px}
  .ai-summary .head{flex-direction:column;align-items:flex-start;gap:2px}
  .ai-summary ul{padding-left:18px;font-size:12.5px;line-height:1.65}

  /* Charts shorter */
  .chart-box{height:200px !important}

  /* Map */
  #bdMap{height:320px}

  /* Top bar tighter */
  .icon-btn{width:34px;height:34px;font-size:14px}
  .icon-btn.lang{font-size:10px}
  .icon-btn .badge{font-size:9px;padding:1px 4px;min-width:14px}

  /* KPI lighter */
  .kpi{padding:9px 11px}
  .kpi .value{font-size:18px}

  /* Detail hero stacks */
  .detail-hero{padding:14px;gap:12px}
  .detail-hero h2{font-size:18px}
  .detail-hero .meta{font-size:12px}
  .detail-hero .ava{width:60px;height:60px;font-size:22px}

  /* Calendar — convert from 7-col grid to a list view */
  .cal{display:block;gap:0}
  .cal .ch{display:none}
  .cal .cd{
    min-height:0;display:flex;align-items:center;gap:10px;padding:10px 12px;
    border-radius:6px;margin-bottom:6px;font-size:12px;
  }
  .cal .cd.other{display:none}
  .cal .cd .dn{
    flex-shrink:0;width:38px;height:38px;border-radius:50%;
    background:var(--bd-green-light);color:var(--bd-green-dark);
    display:inline-flex;align-items:center;justify-content:center;
    font-weight:700;margin-bottom:0;font-size:14px;
  }
  .cal .cd.today .dn{background:var(--bd-red);color:#fff}
  .cal .cd:has(.ev){background:var(--card)}
  .cal .cd:not(:has(.ev)){background:transparent;opacity:.5;padding:6px 12px}
  .cal .cd:not(:has(.ev)) .dn{background:transparent;color:var(--ink-3);width:auto;height:auto;font-size:12px;font-weight:500}
  .cal .ev{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;margin-right:4px;margin-bottom:0}

  /* MPO Pipeline — already vertical above, ensure spacing */
  .pipeline{padding-bottom:0;gap:6px}

  /* Form footer buttons stack already; just tighten */
  .form-foot{margin-top:14px;padding-top:10px}

  /* Tour card */
  .tour-overlay{padding:16px}
  .tour-card{padding:18px 18px;border-radius:8px}
  .tour-card h3{font-size:16px}
  .tour-card p{font-size:13px;margin-bottom:14px}
}

/* === Standard iPhone (414) === */
@media (max-width:414px){
  .gov-bar{font-size:10.5px;padding:5px 10px}
  .masthead{padding:8px 10px;gap:8px}
  .masthead h1{font-size:13px}
  .masthead .sub{font-size:10.5px}
  .crest{width:34px;height:34px}

  .main{padding:12px 10px 32px}
  .card{padding:12px;border-radius:6px}

  /* Forms */
  .form-grid{gap:10px}
  .fld input,.fld select,.fld textarea{padding:8px 10px;font-size:13px}

  /* Modules */
  .mod{padding:12px}
  .mod h4{font-size:13px}
  .mod p{font-size:11.5px}

  /* Reduce all card chrome */
  .card h3{font-size:12.5px}
  .card .desc{font-size:11px;margin-bottom:8px}
}

/* === iPhone SE / smallest (375 and below) === */
@media (max-width:375px){
  .gov-bar{flex-wrap:wrap;font-size:10px}
  .gov-bar .right{gap:6px}
  .masthead h1{font-size:12.5px}

  /* KPI: 2-col still survives at 375; force smaller text */
  .kpi-grid{gap:8px}
  .kpi .value{font-size:16px}
  .kpi .label{font-size:9.5px}
  .kpi .delta{font-size:9.5px}

  /* Tables stacked already; make label column tighter */
  table.dt td{grid-template-columns:88px 1fr;gap:6px;font-size:12.5px}
  table.dt td::before{font-size:9px}

  /* Hero */
  .hero{padding:18px 14px}
  .hero h1{font-size:17px}

  /* Login */
  .login-form,.login-pitch{padding:20px 16px}
  .login-form h2{font-size:17px}
  .login-pitch h1{font-size:18px}
  .login-pitch .stats{gap:8px}
  .login-pitch .stat strong{font-size:16px}
  .login-pitch .stat span{font-size:9px}
  .login-roles{gap:4px}
  .login-roles button{font-size:10px;padding:4px 7px}

  /* Verify card */
  .verify-card{padding:22px 18px;border-radius:8px}
  .verify-card h1{font-size:18px}
  .verify-card .lede{font-size:12px}
  .qr-block{flex-direction:column;align-items:flex-start;gap:10px}
  .qr-block svg{width:80px;height:80px}

  /* Stepper — even tinier */
  .stepper{margin-bottom:14px}
  .stepper .step{padding:8px 3px}
  .stepper .step .n{width:22px;height:22px;font-size:11px}

  /* Detail hero */
  .detail-hero{padding:12px}
  .detail-hero h2{font-size:16px}
  .detail-hero .meta{font-size:11.5px}
  .detail-hero .ava{width:52px;height:52px;font-size:18px}
  .detail-hero .right-col{font-size:11px}

  /* AI summary tight */
  .ai-summary ul{padding-left:16px;font-size:12px}

  /* Tour */
  .tour-card{padding:16px 14px}
  .tour-foot{flex-direction:column;gap:6px}
  .tour-foot .btn{width:100%;justify-content:center}

  /* Map */
  #bdMap{height:260px}

  /* Calendar list — already optimised */
  .cal .cd .dn{width:32px;height:32px;font-size:12px}
}

/* === Tiny phone (320) === */
@media (max-width:320px){
  body{font-size:13px}
  .masthead h1{font-size:11.5px}
  .masthead .sub{display:none}
  .main{padding:10px 8px 28px}
  .card{padding:10px;border-radius:5px}
  .kpi .value{font-size:14.5px}
  .hero h1{font-size:15px}
  .crest{width:30px;height:30px}
  .icon-btn{width:30px;height:30px}
  table.dt td{grid-template-columns:80px 1fr;gap:6px;font-size:12px}
  .gov-bar .clock{display:none}
}

/* === Landscape phones (max-height 480) === */
@media (max-height:480px) and (orientation:landscape){
  body.login-body{align-items:flex-start;padding-top:12px;padding-bottom:12px}
  .login-pitch h1{font-size:20px;margin-bottom:8px}
  .login-pitch p{font-size:12px;margin-bottom:10px}
  .login-pitch .stats{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
  .tour-overlay{align-items:flex-start;padding-top:16px}
}

/* === Touch device — bigger tap targets (Apple guideline 44pt) === */
@media (hover:none) and (pointer:coarse){
  .btn,.icon-btn,.side-link,.menu-item,.tag,.tour-foot button{min-height:42px}
  .btn.sm{min-height:34px}
  table.dt tr{cursor:pointer}
  .side-link{padding:10px 18px}
  /* Bigger checkboxes for fingers */
  input[type="checkbox"]{width:18px;height:18px}
}

/* === High DPI / Retina === */
@media (-webkit-min-device-pixel-ratio:2),(min-resolution:2dppx){
  .crest{image-rendering:-webkit-optimize-contrast}
}

/* === Reduce motion === */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .ticker .tk-track{animation:none}
}

/* === Print extras === */
@media print{
  .ai-summary,.ticker,.hero{display:none !important}
}
