:root{
  --navy:#0a2e5c;
  --navy-d:#06203f;
  --blue:#13498a;
  --blue-l:#2c6bbd;
  --saffron:#ff9933;
  --saffron-d:#e87d18;
  --green:#138808;
  --gold:#c9a227;
  --ink:#1b2330;
  --muted:#5a6573;
  --line:#dde3ec;
  --bg:#f4f6fa;
  --card:#ffffff;
  --soft:#eef3fa;
  --shadow:0 1px 2px rgba(10,46,92,.06),0 8px 24px rgba(10,46,92,.08);
  --shadow-lg:0 12px 40px rgba(10,46,92,.16);
  --serif:'Spectral',Georgia,serif;
  --sans:'Mukta',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.fs{font-family:var(--serif)}

/* ============ TOP UTILITY BAR ============ */
.topbar{background:var(--navy-d);color:#cdd9ec;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:14px;flex-wrap:wrap}
.topbar a{color:#cdd9ec;opacity:.9}
.topbar a:hover{opacity:1;color:#fff}
.topbar .left,.topbar .right{display:flex;gap:16px;align-items:center}
.fontctl{display:flex;gap:6px;align-items:center}
.fontctl button{background:rgba(255,255,255,.1);color:#fff;border:0;width:24px;height:22px;border-radius:4px;cursor:pointer;font-family:var(--sans);font-weight:600}
.fontctl button:hover{background:var(--saffron);color:var(--navy-d)}
.tricolor{height:4px;background:linear-gradient(90deg,var(--saffron) 0 33.3%,#fff 33.3% 66.6%,var(--green) 66.6% 100%)}

/* ============ MASTHEAD ============ */
.masthead{background:#fff;border-bottom:1px solid var(--line)}
.masthead .wrap{display:flex;align-items:center;gap:18px;padding:16px 22px}
.emblem{width:64px;height:64px;flex:0 0 64px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#1a5bbf,var(--navy));display:grid;place-items:center;color:#fff;box-shadow:var(--shadow)}
.emblem svg{width:38px;height:38px}
.mast-txt{flex:1;min-width:0}
.mast-txt .gov{font-size:12.5px;letter-spacing:.5px;color:var(--saffron-d);font-weight:700;text-transform:uppercase}
.mast-txt h1{font-family:var(--serif);font-weight:800;font-size:26px;line-height:1.15;color:var(--navy);letter-spacing:-.3px}
.mast-txt .sub{font-size:14px;color:var(--muted);font-weight:500}
.mast-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.naac{font-size:11px;color:var(--muted);text-align:right}
.opac-pill{display:inline-flex;align-items:center;gap:8px;background:var(--saffron);color:var(--navy-d);font-weight:700;padding:9px 16px;border-radius:999px;font-size:13.5px;box-shadow:0 4px 14px rgba(255,153,51,.45);position:relative}
.opac-pill::after{content:"";position:absolute;inset:0;border-radius:999px;border:2px solid var(--saffron);animation:ring 2.2s infinite}
@keyframes ring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.35);opacity:0}}
.opac-pill:hover{background:var(--saffron-d);color:#fff}

/* ============ NAV ============ */
nav.mainnav{background:var(--navy);position:sticky;top:0;z-index:50;box-shadow:0 2px 10px rgba(6,32,63,.35)}
.navlist{display:flex;align-items:stretch;flex-wrap:wrap}
.navlist>li{position:relative}
.navlist>li>a{display:flex;align-items:center;gap:6px;color:#e7eef9;padding:14px 17px;font-weight:600;font-size:14.5px;cursor:pointer;border-bottom:3px solid transparent;transition:.18s}
.navlist>li>a:hover,.navlist>li.active>a{background:var(--blue);color:#fff;border-bottom-color:var(--saffron)}
.caret{font-size:10px;opacity:.8}
.dropdown{position:absolute;top:100%;left:0;min-width:230px;background:#fff;box-shadow:var(--shadow-lg);border-top:3px solid var(--saffron);border-radius:0 0 8px 8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;z-index:60}
.navlist>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:11px 18px;color:var(--ink);font-size:14px;font-weight:500;border-bottom:1px solid #f0f3f8}
.dropdown a:last-child{border-bottom:0}
.dropdown a:hover{background:var(--soft);color:var(--blue);padding-left:24px}
.navtoggle{display:none}
.hamburger{display:none;background:none;border:0;color:#fff;font-size:24px;cursor:pointer;padding:12px 16px;margin-left:auto}

/* ============ MARQUEE ============ */
.ticker{background:#fff3e2;border-bottom:1px solid #f3d9b3;display:flex;align-items:center;overflow:hidden}
.ticker .lbl{background:var(--saffron-d);color:#fff;font-weight:700;font-size:13px;padding:8px 16px;white-space:nowrap;display:flex;align-items:center;gap:6px}
.ticker .track{overflow:hidden;flex:1}
.ticker .move{display:inline-block;white-space:nowrap;padding-left:100%;animation:scroll 26s linear infinite;font-size:14px;color:#7a4a10;font-weight:500}
.ticker:hover .move{animation-play-state:paused}
.ticker .move a{margin-right:54px}
.ticker .move .new{background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;margin-right:6px}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

/* ============ PAGE SYSTEM ============ */
.page{display:none;animation:fade .4s ease}
.page.show{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ============ HERO ============ */
.hero{position:relative;background:linear-gradient(120deg,var(--navy) 0%,var(--blue) 60%,#1a5bbf 100%);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 85% 20%,rgba(255,153,51,.22),transparent 45%),
  radial-gradient(circle at 10% 90%,rgba(19,136,8,.18),transparent 40%);}
.hero::after{content:"";position:absolute;inset:0;opacity:.06;background-image:repeating-linear-gradient(45deg,#fff 0 1px,transparent 1px 22px)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding:54px 22px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:6px 14px;border-radius:999px;font-size:12.5px;font-weight:600;letter-spacing:.4px;margin-bottom:18px}
.hero h2{font-family:var(--serif);font-size:42px;line-height:1.12;font-weight:800;letter-spacing:-.5px}
.hero h2 span{color:var(--saffron)}
.hero p.lede{margin:16px 0 26px;font-size:17px;color:#d7e3f5;max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;padding:13px 24px;border-radius:8px;cursor:pointer;border:0;transition:.2s}
.btn-saffron{background:var(--saffron);color:var(--navy-d)}
.btn-saffron:hover{background:#fff;transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:#fff;color:var(--navy);transform:translateY(-2px)}
.opac-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:26px;backdrop-filter:blur(6px)}
.opac-card h3{font-family:var(--serif);font-size:20px;margin-bottom:6px}
.opac-card .scan{display:flex;gap:14px;align-items:center;margin-top:16px}
.opac-search{display:flex;margin-top:14px;background:#fff;border-radius:8px;overflow:hidden}
.opac-search input{flex:1;border:0;padding:12px 14px;font-family:var(--sans);font-size:14px;color:var(--ink)}
.opac-search input:focus{outline:none}
.opac-search button{background:var(--saffron);border:0;color:var(--navy-d);font-weight:700;padding:0 18px;cursor:pointer}
.opac-search button:hover{background:var(--saffron-d);color:#fff}
.book-stack{display:flex;gap:6px;margin-top:18px}
.book-stack span{display:block;flex:1;height:54px;border-radius:3px;animation:rise 1.4s ease infinite alternate}
.book-stack span:nth-child(1){background:var(--saffron);animation-delay:0s}
.book-stack span:nth-child(2){background:#fff;animation-delay:.15s}
.book-stack span:nth-child(3){background:var(--green);animation-delay:.3s}
.book-stack span:nth-child(4){background:#9fc3f0;animation-delay:.45s}
.book-stack span:nth-child(5){background:var(--saffron);animation-delay:.6s}
@keyframes rise{to{transform:translateY(-8px)}}

/* ============ SECTIONS ============ */
section.block{padding:54px 0}
.sec-head{text-align:center;margin-bottom:38px}
.sec-head .kick{color:var(--saffron-d);font-weight:700;font-size:13px;letter-spacing:1.5px;text-transform:uppercase}
.sec-head h3{font-family:var(--serif);font-size:30px;font-weight:800;color:var(--navy);margin-top:6px}
.sec-head .rule{width:64px;height:3px;background:var(--saffron);margin:14px auto 0;border-radius:2px}
.sec-head p{color:var(--muted);max-width:620px;margin:12px auto 0}

/* messages */
.msg-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.msg-card{background:var(--card);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--line);display:flex;flex-direction:column}
.msg-top{display:flex;gap:16px;align-items:center;padding:22px;background:linear-gradient(120deg,var(--soft),#fff);border-bottom:1px solid var(--line)}
.avatar{width:74px;height:74px;flex:0 0 74px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:26px;font-weight:700;box-shadow:0 6px 16px rgba(10,46,92,.3)}
.msg-top h4{font-family:var(--serif);font-size:19px;color:var(--navy)}
.msg-top .role{color:var(--saffron-d);font-weight:600;font-size:13.5px}
.msg-body{padding:22px;color:#414c5c;font-size:15px;flex:1}
.msg-body .quote{font-family:var(--serif);font-style:italic;color:var(--blue);font-size:16px}

/* stats */
.stats{background:linear-gradient(120deg,var(--navy),var(--blue));color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .num{font-family:var(--serif);font-size:40px;font-weight:800;color:var(--saffron)}
.stat .lab{font-size:14px;color:#cdd9ec;margin-top:4px;letter-spacing:.3px}

/* services */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.scard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:var(--shadow);transition:.22s;cursor:pointer}
.scard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--saffron)}
.scard .ico{width:54px;height:54px;border-radius:12px;background:var(--soft);display:grid;place-items:center;color:var(--blue);margin-bottom:14px}
.scard:hover .ico{background:var(--saffron);color:#fff}
.scard .ico svg{width:28px;height:28px}
.scard h4{font-family:var(--serif);font-size:18px;color:var(--navy);margin-bottom:6px}
.scard p{color:var(--muted);font-size:14px}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:160px;gap:14px}
.gitem{border-radius:12px;overflow:hidden;position:relative;box-shadow:var(--shadow)}
.gitem.tall{grid-row:span 2}
.gitem.wide{grid-column:span 2}
.gitem .ph{width:100%;height:100%}
.gitem .cap{position:absolute;left:0;right:0;bottom:0;padding:18px 14px 12px;background:linear-gradient(transparent,rgba(6,32,63,.85));color:#fff;font-weight:600;font-size:14px;transform:translateY(8px);opacity:.92;transition:.25s}
.gitem:hover .cap{transform:translateY(0);opacity:1}

/* quicklinks strip */
.qlinks{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.qlink{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-left:4px solid var(--saffron);border-radius:10px;padding:16px 18px;font-weight:600;color:var(--navy);box-shadow:var(--shadow);transition:.2s;cursor:pointer}
.qlink:hover{border-left-color:var(--green);transform:translateX(4px)}
.qlink .qi{color:var(--blue)}

/* generic content page */
.pagehero{background:linear-gradient(120deg,var(--navy),var(--blue));color:#fff;padding:42px 0}
.pagehero .crumbs{font-size:13px;color:#cdd9ec;margin-bottom:8px}
.pagehero .crumbs span{color:var(--saffron)}
.pagehero h2{font-family:var(--serif);font-size:34px;font-weight:800}
.pagewrap{padding:46px 0}
.two-col{display:grid;grid-template-columns:1fr 300px;gap:34px;align-items:start}
.sidebar{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);position:sticky;top:80px}
.sidebar .sh{background:var(--navy);color:#fff;padding:14px 18px;font-family:var(--serif);font-weight:700;font-size:16px}
.sidebar a{display:block;padding:12px 18px;border-bottom:1px solid #f0f3f8;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer}
.sidebar a:hover,.sidebar a.on{background:var(--soft);color:var(--blue);border-left:3px solid var(--saffron);padding-left:21px}
.prose h3{font-family:var(--serif);color:var(--navy);font-size:23px;margin:26px 0 12px}
.prose h3:first-child{margin-top:0}
.prose h4{font-family:var(--serif);color:var(--blue);font-size:18px;margin:20px 0 8px}
.prose p{margin-bottom:14px;color:#3c4654}
.prose ul{margin:0 0 16px 20px;color:#3c4654}
.prose li{margin-bottom:7px}
table.gtab{width:100%;border-collapse:collapse;margin:10px 0 22px;font-size:14.5px;background:#fff;border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
table.gtab th{background:var(--navy);color:#fff;text-align:left;padding:12px 16px;font-weight:600}
table.gtab td{padding:11px 16px;border-bottom:1px solid var(--line);color:#3c4654}
table.gtab tr:nth-child(even) td{background:#f8fafd}
.staff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.staff{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;text-align:center;box-shadow:var(--shadow)}
.staff .av{width:72px;height:72px;border-radius:50%;margin:0 auto 12px;background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:24px;font-weight:700}
.staff h5{font-family:var(--serif);font-size:16px;color:var(--navy)}
.staff .r{color:var(--saffron-d);font-size:13px;font-weight:600}
.staff .c{color:var(--muted);font-size:12.5px;margin-top:4px}

/* resource cards */
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.res{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column;gap:8px}
.res:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.res .tag{align-self:flex-start;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 9px;border-radius:5px;background:var(--soft);color:var(--blue)}
.res h4{font-family:var(--serif);font-size:18px;color:var(--navy)}
.res p{font-size:13.5px;color:var(--muted);flex:1}
.res .go{align-self:flex-start;color:var(--saffron-d);font-weight:700;font-size:13.5px;margin-top:4px}

/* tabs */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;border-bottom:2px solid var(--line)}
.tab{padding:11px 20px;font-weight:600;cursor:pointer;color:var(--muted);border-bottom:3px solid transparent;margin-bottom:-2px}
.tab.on{color:var(--navy);border-bottom-color:var(--saffron)}
.tabpane{display:none}
.tabpane.on{display:block;animation:fade .3s}

/* question bank filter */
.qb-filter{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:end;margin-bottom:24px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.field select,.field input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-family:var(--sans);font-size:14px;background:#fff;color:var(--ink)}
.field select:focus,.field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(19,73,138,.12)}
.qp-list{display:flex;flex-direction:column;gap:10px}
.qp{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 18px;box-shadow:var(--shadow)}
.qp .pdfico{width:42px;height:42px;flex:0 0 42px;border-radius:8px;background:#fdecec;color:#d12b2b;display:grid;place-items:center;font-weight:800;font-size:12px}
.qp .meta{flex:1}
.qp .meta h5{font-size:15px;color:var(--navy);font-weight:600}
.qp .meta .sub{font-size:12.5px;color:var(--muted)}
.qp .dl{background:var(--blue);color:#fff;font-weight:600;font-size:13px;padding:8px 14px;border-radius:7px;cursor:pointer}
.qp .dl:hover{background:var(--navy)}
.pill-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.mini{font-size:11px;font-weight:600;padding:2px 8px;border-radius:5px;background:var(--soft);color:var(--blue)}

/* admin */
.admin-shell{display:grid;grid-template-columns:230px 1fr;min-height:560px;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.admin-side{background:var(--navy);color:#cdd9ec;padding:18px 0}
.admin-side .me{padding:0 20px 18px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:14px}
.admin-side .me .nm{color:#fff;font-family:var(--serif);font-weight:700;font-size:16px}
.admin-side .me .rl{font-size:12px;color:var(--saffron)}
.admin-side a{display:flex;gap:10px;align-items:center;padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;border-left:3px solid transparent}
.admin-side a:hover,.admin-side a.on{background:var(--blue);color:#fff;border-left-color:var(--saffron)}
.admin-main{padding:28px}
.admin-main h3{font-family:var(--serif);color:var(--navy);font-size:22px;margin-bottom:4px}
.admin-main .desc{color:var(--muted);font-size:14px;margin-bottom:22px}
.adminpane{display:none}
.adminpane.on{display:block;animation:fade .3s}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.form-grid .full{grid-column:1/-1}
.uploadbox{border:2px dashed var(--line);border-radius:10px;padding:26px;text-align:center;color:var(--muted);cursor:pointer;transition:.2s;background:#fafcff}
.uploadbox:hover{border-color:var(--blue);background:var(--soft);color:var(--blue)}
.btn-primary{background:var(--blue);color:#fff;font-weight:700;padding:12px 24px;border:0;border-radius:8px;cursor:pointer;font-family:var(--sans);font-size:14.5px}
.btn-primary:hover{background:var(--navy)}
textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:var(--sans);font-size:14px;resize:vertical;min-height:90px}
textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(19,73,138,.12)}
.kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.kbox{background:var(--soft);border-radius:10px;padding:16px;border-left:4px solid var(--saffron)}
.kbox .n{font-family:var(--serif);font-size:28px;font-weight:800;color:var(--navy)}
.kbox .l{font-size:12.5px;color:var(--muted)}
.toast{position:fixed;bottom:26px;right:26px;background:var(--green);color:#fff;padding:14px 22px;border-radius:10px;font-weight:600;box-shadow:var(--shadow-lg);transform:translateY(120px);opacity:0;transition:.35s;z-index:200}
.toast.show{transform:translateY(0);opacity:1}
.adtab{width:100%;border-collapse:collapse;font-size:14px;margin-top:8px}
.adtab th{background:var(--soft);text-align:left;padding:10px 14px;color:var(--navy);font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
.adtab td{padding:11px 14px;border-bottom:1px solid var(--line);color:#3c4654}
.adtab .x{color:#d12b2b;cursor:pointer;font-weight:700}
.login-note{background:#fff8ec;border:1px solid #f3d9b3;border-radius:10px;padding:14px 18px;font-size:13.5px;color:#7a4a10;margin-bottom:22px}

/* footer */
footer{background:var(--navy-d);color:#aebfd6;padding:48px 0 0;margin-top:30px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px}
footer h5{color:#fff;font-family:var(--serif);font-size:17px;margin-bottom:16px}
footer a{display:block;color:#aebfd6;font-size:14px;padding:5px 0;cursor:pointer}
footer a:hover{color:var(--saffron);padding-left:5px}
footer p{font-size:14px;line-height:1.7}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding:18px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px}
.visitors{display:inline-flex;gap:4px;align-items:center}
.visitors b{background:rgba(255,255,255,.08);padding:2px 7px;border-radius:4px;font-family:var(--serif);color:#fff}

/* responsive */
@media(max-width:960px){
  .hero .wrap{grid-template-columns:1fr;padding:38px 22px}
  .hero h2{font-size:32px}
  .msg-grid,.card-grid,.res-grid,.staff-grid,.qb-filter,.form-grid,.stats-grid,.kpi,.qlinks{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
  .sidebar{position:static}
  .admin-shell{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .mast-right{display:none}
  .hamburger{display:block}
  .navlist{display:none;flex-direction:column;width:100%}
  nav.mainnav.open .navlist{display:flex}
  .navlist>li>a{border-bottom:1px solid rgba(255,255,255,.08)}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border-radius:0;background:rgba(255,255,255,.05)}
  .dropdown a{color:#cdd9ec}
  .msg-grid,.card-grid,.res-grid,.staff-grid,.qb-filter,.form-grid,.stats-grid,.kpi,.qlinks,.gallery,.fgrid{grid-template-columns:1fr}
  .topbar .left{display:none}
}

/* ============ MEMBER LOGIN HOVER CARD ============ */
.memberli>a{color:#bfe0ff!important}
.memcard{min-width:300px;left:auto;right:0;padding:0}
.memcard-in{padding:22px}
.memcard-ico{width:46px;height:46px;border-radius:12px;background:var(--soft);color:var(--blue);display:grid;place-items:center;font-size:22px;margin-bottom:12px}
.memcard-in h4{font-family:var(--serif);color:var(--navy);font-size:18px;margin-bottom:6px}
.memcard-in p{color:var(--muted);font-size:13.5px;margin-bottom:14px;line-height:1.5}
.memcard-btn{display:block;text-align:center;background:var(--saffron);color:var(--navy-d)!important;font-weight:700;padding:11px;border-radius:8px;font-size:14px;transition:.18s}
.memcard-btn:hover{background:var(--saffron-d);color:#fff!important;padding-left:11px!important}
.memcard-foot{margin-top:12px;font-size:13px;color:var(--muted);text-align:center}
.memcard-foot a{color:var(--blue);cursor:pointer;font-weight:600;display:inline!important;padding:0!important}

/* ============ WEATHER STRIP ============ */
.wbar{background:linear-gradient(120deg,#0c6b3f,#138808);color:#fff}
.wbar-in{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;flex-wrap:wrap;gap:12px}
.wbar-left{display:flex;align-items:center;gap:14px}
.wbar-ico{font-size:38px;line-height:1}
.wbar-temp{font-family:var(--serif);font-size:24px;font-weight:700;display:flex;align-items:baseline;gap:4px}
.wbar-deg{font-size:16px;opacity:.85}
.wbar-desc{font-family:var(--sans);font-size:15px;font-weight:500;opacity:.92;margin-left:6px}
.wbar-place{font-size:13px;opacity:.85}
.wbar-meta{display:flex;gap:22px;font-size:14px;flex-wrap:wrap}
.wbar-meta b{font-weight:700}

/* ============ NEW ARRIVALS ============ */
.arrivals{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.bookcard{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:.22s}
.bookcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.bookcover{height:150px;display:grid;place-items:center;color:rgba(255,255,255,.9);font-size:34px;position:relative}
.bookcover .ribbon{position:absolute;top:8px;left:-1px;background:var(--saffron);color:var(--navy-d);font-size:10px;font-weight:800;padding:2px 9px;border-radius:0 4px 4px 0;letter-spacing:.3px}
.bookcover img{width:100%;height:100%;object-fit:cover}
.bookmeta{padding:12px 13px}
.bookmeta h5{font-family:var(--serif);font-size:14.5px;color:var(--navy);line-height:1.25;margin-bottom:4px}
.bookmeta .au{font-size:12.5px;color:var(--muted)}
.bookmeta .cat{display:inline-block;margin-top:7px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--blue);background:var(--soft);padding:2px 8px;border-radius:5px}
.bookmeta .acc{font-size:11px;color:var(--muted);margin-top:6px}

/* ============ BEST LIBRARY USERS ============ */
.bestusers{background:linear-gradient(120deg,var(--navy-d),var(--navy) 60%,var(--blue))}
.bu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bucard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:24px;text-align:center;backdrop-filter:blur(6px);transition:.22s;position:relative;overflow:hidden}
.bucard::before{content:"\2605";position:absolute;top:14px;right:16px;color:var(--gold);font-size:18px;opacity:.8}
.bucard:hover{transform:translateY(-5px);border-color:var(--gold)}
.bu-photo{width:96px;height:96px;border-radius:50%;margin:0 auto 14px;border:3px solid var(--gold);background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:34px;font-weight:700;overflow:hidden}
.bu-photo img{width:100%;height:100%;object-fit:cover}
.bucard h4{font-family:var(--serif);color:#fff;font-size:19px}
.bucard .bu-branch{color:var(--gold);font-weight:600;font-size:13.5px;margin-top:2px}
.bucard .bu-detail{color:#cdd9ec;font-size:13.5px;margin-top:10px;line-height:1.5}
.bucard .bu-period{display:inline-block;margin-top:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--navy-d);background:var(--gold);padding:3px 12px;border-radius:999px}

/* ============ MEMBERSHIP FORM ============ */
.applyform{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:var(--shadow)}
.applyform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.applyform .row .full{grid-column:1/-1}
.applyform label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.applyform input,.applyform select,.applyform textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:var(--sans);font-size:14px;color:var(--ink)}
.applyform input:focus,.applyform select:focus,.applyform textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(19,73,138,.12)}
.applyform .req{color:#d12b2b}
.applyok{background:#dff5d8;border:1px solid #a9dca0;color:#0c6b3f;border-radius:10px;padding:16px 18px;font-weight:600;display:none}

@media(max-width:960px){
  .arrivals{grid-template-columns:repeat(3,1fr)}
  .bu-grid{grid-template-columns:1fr 1fr}
  .applyform .row{grid-template-columns:1fr}
  .memcard{right:auto;left:0}
}
@media(max-width:680px){
  .arrivals{grid-template-columns:1fr 1fr}
  .bu-grid{grid-template-columns:1fr}
  .wbar-in{flex-direction:column;align-items:flex-start}
}
