/* =====================================================================
   Councilor Portal — Sangguniang Panlungsod ng Pagadian
   Brand-aligned with the LGU system (primary green #2c5530, accent blue
   #1976d2). Institutional, accessible (WCAG 2.2 AA), print-friendly.
   ===================================================================== */
:root{
  --sp-green:#2c5530; --sp-green-d:#1f3e23; --sp-green-2:#4a7c4a;
  --sp-blue:#1976d2; --sp-gold:#b8860b;
  /* Senior-citizen accessibility: pure-black body text, no grey (high contrast). */
  --ink:#000000; --muted:#000000; --line:#c9d2dc; --bg:#eef1f4; --card:#ffffff;
  --ok:#15662a; --ok-bg:#e6f4ea; --warn:#8a5600; --warn-bg:#fdf2dd;
  --danger:#c0392b; --danger-bg:#fbe9e7; --info:#155b9c; --info-bg:#e7f1fb;
  --radius:12px; --radius-sm:8px;
  --shadow:0 1px 2px rgba(16,32,24,.06),0 6px 18px rgba(16,32,24,.06);
  --shadow-sm:0 1px 2px rgba(16,32,24,.08);
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--sp-blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0;line-height:1.25;font-weight:700}

/* ---- Masthead ---- */
.masthead{background:linear-gradient(180deg,var(--sp-green) 0%,var(--sp-green-d) 100%);color:#fff;border-bottom:4px solid var(--sp-gold)}
.masthead-inner{max-width:1180px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:16px}
.masthead .seal{width:54px;height:54px;border-radius:50%;background:#fff;padding:3px;object-fit:contain;flex:none;box-shadow:var(--shadow-sm)}
.masthead .titles{flex:1;min-width:0}
.masthead .eyebrow{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#cfe0d2;font-weight:600}
.masthead h1{font-size:1.18rem;letter-spacing:.01em}
.masthead .sub{font-size:.82rem;color:#d8e6da}
.masthead .who{display:flex;align-items:center;gap:12px;font-size:.86rem}
.masthead .who .role-pill{background:rgba(255,255,255,.16);padding:3px 10px;border-radius:999px;font-size:.74rem;font-weight:600;text-transform:capitalize}
.btn-logout{color:#fff;border:1px solid rgba(255,255,255,.35);padding:6px 14px;border-radius:8px;font-size:.82rem;background:transparent;cursor:pointer}
.btn-logout:hover{background:rgba(255,255,255,.12);text-decoration:none}

/* ---- Layout ---- */
.wrap{max-width:1180px;margin:0 auto;padding:22px}
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin-bottom:18px}
.toolbar .picker{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--muted)}
.toolbar select{padding:8px 12px;border:1px solid var(--line);border-radius:8px;font-size:.9rem;background:#fff;min-width:260px}

/* ---- Profile header ---- */
.profile{display:flex;gap:18px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);margin-bottom:18px}
.avatar{position:relative;overflow:hidden;width:78px;height:78px;border-radius:50%;flex:none;display:grid;place-items:center;background:var(--sp-green);color:#fff;font-size:1.7rem;font-weight:700;object-fit:cover}
.profile .pname{font-size:1.4rem}
.profile .ppos{color:var(--sp-green-2);font-weight:600;margin-top:2px}
.profile .pmeta{color:var(--muted);font-size:.86rem;margin-top:6px;display:flex;flex-wrap:wrap;gap:6px 16px}

/* ---- KPI cards ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--sp-green);border-radius:var(--radius-sm);padding:15px 16px;box-shadow:var(--shadow-sm)}
.kpi.is-danger{border-left-color:var(--danger)}
.kpi.is-warn{border-left-color:var(--sp-gold)}
.kpi.is-blue{border-left-color:var(--sp-blue)}
.kpi .num{font-size:1.9rem;font-weight:800;letter-spacing:-.02em}
.kpi .lbl{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.kpi .hint{font-size:.74rem;color:var(--muted);margin-top:4px}

/* ---- Section cards ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:18px;overflow:hidden}
.card > h2{font-size:1.02rem;padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;background:#fafbfc}
.card > h2 .count{margin-left:auto;font-size:.78rem;color:var(--muted);font-weight:600}
.card .body{padding:6px 18px 16px}
.card > h2 .count-sub{font-size:.72rem;color:var(--muted);font-weight:500}
.section-note{color:var(--muted);font-size:.82rem;margin:8px 2px 12px}
.subcard{border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px 12px 8px;background:#fcfdfe}
.sub-h{font-size:.9rem;display:flex;align-items:center;gap:8px;padding:8px 2px;border-bottom:1px solid var(--line);margin-bottom:2px}
.sub-h .count{margin-left:auto;font-size:.78rem;color:var(--muted);font-weight:700}
.sub-h.ok-h{color:var(--ok)}
.sub-h.warn-h{color:var(--warn)}
.nowrap{white-space:nowrap;font-variant-numeric:tabular-nums}
/* Sponsored-bills index (numbered, printable) */
.billprint{font-size:14px;font-weight:700;white-space:nowrap}
.billlist{margin:6px 4px 4px;padding-left:30px}
.billlist li{padding:8px 4px;border-bottom:1px solid var(--line);font-size:14px;line-height:1.5;color:#000;
  display:flex;align-items:flex-start;gap:12px}
.billlist li:last-child{border-bottom:none}
.billlist li::marker{font-weight:800;color:#13294f}
.bill-link{flex:1;min-width:0;color:#000;text-decoration:none;cursor:pointer}
.bill-link:hover .billtitle{text-decoration:underline;font-weight:800;color:#0a2e63}
.bill-link:hover .billno{color:#0a2e63}
.billno{font-weight:800;color:#13294f;font-variant-numeric:tabular-nums;white-space:nowrap}
.billtitle{color:#000}
.bill-pdf{flex:none;align-self:center;white-space:nowrap;font-size:13px;font-weight:800;color:#fff;text-decoration:none;
  background:linear-gradient(180deg,#1d4ed8,#15307e);border-radius:8px;padding:5px 11px;box-shadow:0 2px 5px rgba(3,12,33,.25)}
.bill-pdf:hover{filter:brightness(1.12);text-decoration:none;color:#fff}
/* Clickable referral row -> opens the document */
.ref-link{color:#0a2e63;font-weight:700;text-decoration:none;cursor:pointer}
.ref-link:hover{text-decoration:underline}
.ref-go{color:#1d4ed8;font-weight:800}
/* Clickable KPI tiles -> jump to the matching tab/list */
.kpi-link{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.kpi-link:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(16,32,24,.18)}
.kpi-link:hover .lbl{text-decoration:underline}
.kpi-link:focus-visible{outline:2px solid var(--sp-blue);outline-offset:2px}
.subcard.kpi-flash{outline:3px solid var(--sp-gold);outline-offset:2px;animation:kpiFlash 1.7s ease}
@keyframes kpiFlash{0%,100%{background:#fcfdfe}25%{background:#fff6da}}
.wrap tbody tr:hover .ref-link{color:#0a2e63;text-decoration:underline}

/* ===== 3D tabbed panel (Bills / Referrals) — raised folder tabs ===== */
.tab3d{margin-bottom:18px}
.tab3d-bar{display:flex;gap:7px;padding:0 6px;position:relative;z-index:2}
.tab3d-btn{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-family:inherit;font-size:15px;font-weight:700;
  color:#445a72;background:linear-gradient(180deg,#eef2f7 0%,#d7e0ea 100%);
  border:1px solid var(--line);border-bottom:none;border-radius:13px 13px 0 0;padding:13px 22px 10px;
  transform:translateY(4px);box-shadow:inset 0 -7px 10px -8px rgba(16,32,24,.35);transition:transform .14s ease,background .14s ease,color .14s ease,box-shadow .14s ease}
.tab3d-btn:hover{background:linear-gradient(180deg,#f5f8fc 0%,#e3ebf4 100%);color:#13294f}
.tab3d-btn.is-active{color:var(--sp-green-d);background:#fff;transform:translateY(0);
  border-top:3px solid var(--sp-gold);padding-top:8px;box-shadow:0 -9px 20px rgba(16,32,24,.12)}
.tab3d-badge{font-size:13px;font-weight:800;color:#fff;background:var(--sp-green);border-radius:999px;padding:1px 10px;min-width:24px;text-align:center}
.tab3d-btn.is-active .tab3d-badge{background:var(--sp-gold)}
.tab3d-panel{margin:0 !important;border-radius:0 14px 14px 14px !important;box-shadow:0 12px 30px rgba(16,32,24,.12) !important}
.tab3d-panel[hidden]{display:none}
@media(max-width:560px){.tab3d-bar{flex-wrap:wrap;gap:4px}.tab3d-btn{font-size:13.5px;padding:10px 13px 8px}}

/* ---- Status chips ---- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.02em;white-space:nowrap}
.chip-acted,.chip-enacted{background:var(--ok-bg);color:var(--ok)}
.chip-overdue,.chip-disapproved{background:var(--danger-bg);color:var(--danger)}
.chip-pending,.chip-deferred{background:var(--warn-bg);color:var(--warn)}
.chip-filed,.chip-second{background:var(--info-bg);color:var(--info)}
.chip-role{background:#eef2f6;color:#445}
.chip-chair{background:var(--sp-green);color:#fff}
.chip-vice_chair{background:var(--sp-green-2);color:#fff}

/* ---- Tables / lists ---- */
table{width:100%;border-collapse:collapse;font-size:.88rem}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
th{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
tr:last-child td{border-bottom:none}
.measure-title{font-weight:600;color:var(--ink)}
.measure-sub{color:var(--muted);font-size:.78rem}
.num-cell{font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}
.row-overdue{background:#fff7f6}

/* ---- Empty states ---- */
.empty{padding:26px 18px;text-align:center;color:var(--muted)}
.empty .ico{font-size:1.8rem;opacity:.5}
.empty p{margin:8px 0 0;font-size:.9rem}

/* ---- Buttons / actions ---- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:8px;font-size:.9rem;font-weight:600;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--sp-green);color:#fff}
.btn-primary:hover{background:var(--sp-green-d);text-decoration:none}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--sp-green-2);text-decoration:none}

/* ---- Footer ---- */
.foot{max-width:1180px;margin:8px auto 30px;padding:0 22px;color:var(--muted);font-size:.78rem;text-align:center}
.note{background:var(--info-bg);border:1px solid #cfe0f3;color:#0f3d66;border-radius:8px;padding:10px 14px;font-size:.82rem;margin-bottom:16px}
.note-own{background:#eaf5ec;border-color:#bfe0c4;color:#1f3e23}

/* ---- Login ---- */
.login-shell{min-height:100vh;display:grid;place-items:center;padding:22px;background:linear-gradient(160deg,#1f3e23,#2c5530 60%,#3a6b3f)}
.login-card{background:#fff;border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.28);width:100%;max-width:400px;padding:30px 28px;text-align:center}
.login-card .seal{width:72px;height:72px;margin:0 auto 12px;display:block}
.login-card h1{font-size:1.15rem;color:var(--sp-green-d)}
.login-card .sub{color:var(--muted);font-size:.84rem;margin:4px 0 20px}
.login-card label{display:block;text-align:left;font-size:.8rem;font-weight:600;color:var(--muted);margin:12px 0 5px}
.login-card input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-size:.95rem}
.login-card input:focus{outline:2px solid var(--sp-green-2);border-color:var(--sp-green-2)}
.login-card .btn-primary{width:100%;justify-content:center;margin-top:20px;padding:12px}
.login-err{background:var(--danger-bg);color:var(--danger);border-radius:8px;padding:10px;font-size:.84rem;margin-bottom:6px}
.login-hint{margin-top:18px;font-size:.74rem;color:var(--muted);border-top:1px solid var(--line);padding-top:12px;text-align:left;line-height:1.7}

/* =====================================================================
   Councilor picker (login) — officials cards, click to reveal sign-in
   Royal-blue member cards + gold leadership badges, on a navy chamber
   backdrop (mirrors the official SP roster). Reveal panel shows the
   account credentials + a Sign in button.
   ===================================================================== */
:root{--oc-blue:#1d4ed8;--oc-blue-d:#15307e;--oc-navy:#0a1f44;--oc-orange:#ef8a1f;--oc-orange-d:#d4770f}
.picker-body{margin:0}
.picker-shell{min-height:100vh;padding:30px 22px 46px;
  background:radial-gradient(1200px 600px at 50% -10%,#143a86 0%,var(--oc-navy) 60%,#06122b 100%)}
.picker-head{max-width:1200px;margin:0 auto 22px;display:flex;gap:18px;align-items:center;color:#fff}
.picker-head .seal{width:68px;height:68px;border-radius:50%;background:#fff;padding:4px;flex:none;box-shadow:0 6px 18px rgba(0,0,0,.35)}
.picker-eyebrow{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#9bc0ff;font-weight:700}
.picker-head h1{font-size:1.55rem;margin:2px 0;letter-spacing:.01em}
.picker-sub{font-size:.9rem;color:#cdddf7;margin:0;max-width:720px}
.picker-err{max-width:1200px;margin:0 auto 16px}

/* Horizontal officials cards (cloned from the SP roster): blue header with a
   circular photo + name + leadership badge, then a white strip of orange
   committee chips. Click a card -> reveal overlay shows password + Sign in. */
.ocard-grid{max-width:1180px;margin:0 auto;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:18px;align-items:start}
.ocard{position:relative;border-radius:14px;overflow:hidden;background:#fff;
  border-top:4px solid var(--oc-orange);box-shadow:0 10px 24px rgba(3,12,33,.32);
  transition:transform .16s ease,box-shadow .16s ease}
.ocard:hover{transform:translateY(-4px);box-shadow:0 18px 38px rgba(3,12,33,.42)}
.ocard-face{display:block;width:100%;border:0;padding:0;cursor:pointer;background:none;
  font-family:inherit;color:#fff;text-align:left}
.ocard-head{display:flex;align-items:center;gap:15px;padding:16px 18px 15px;
  background:linear-gradient(135deg,var(--oc-blue) 0%,var(--oc-blue-d) 100%)}
.ocard-photo{position:relative;width:78px;height:78px;border-radius:50%;flex:none;overflow:hidden;
  background:linear-gradient(150deg,#cdd9ff,#7f9be6);border:3px solid #9bb8ee;box-shadow:0 0 0 3px rgba(255,255,255,.25),0 4px 10px rgba(0,0,0,.3)}
.ocard-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:1}
.ocard-ini{position:absolute;inset:0;z-index:0;display:grid;place-items:center;font-size:1.5rem;font-weight:800;color:#15307e}
.ocard-id{min-width:0;flex:1}
.ocard-name{display:block;font-family:Georgia,'Times New Roman',serif;font-size:1.22rem;font-weight:700;
  line-height:1.18;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.45);letter-spacing:.01em}
.ocard-pos{display:block;font-size:.86rem;font-weight:700;color:#f3c44d;margin:3px 0 9px;
  text-transform:uppercase;letter-spacing:.08em}
.ocard-badge{display:inline-block;font-size:.9rem;font-weight:800;letter-spacing:.01em;color:#fff;
  background:linear-gradient(180deg,var(--oc-orange),var(--oc-orange-d));padding:5px 14px;border-radius:999px;box-shadow:0 2px 5px rgba(0,0,0,.22)}
.ocard-chips{display:flex;flex-wrap:wrap;gap:7px;padding:12px 14px 13px;background:#fff}
.ochip{font-size:.84rem;font-weight:700;color:#b4530a;white-space:nowrap;background:#fff4e8;
  border:1.5px solid #f3b367;border-radius:8px;padding:4px 11px}
.ochip-more{color:#5b6b7b;background:#eef2f6;border-color:#d3dbe4}
.ocard-cue{display:block;text-align:center;color:#13233f;font-size:.86rem;font-weight:800;letter-spacing:.05em;
  background:linear-gradient(90deg,#f6cf63,#e7a73a);padding:9px 10px}
.ocard:hover .ocard-cue{background:linear-gradient(90deg,#ffd778,#efb24a)}
.ocard.is-open .ocard-cue{display:none}

/* reveal = overlay covering the card */
.ocard-reveal{position:absolute;inset:0;z-index:6;background:rgba(7,17,40,.975);
  display:flex;flex-direction:column;justify-content:center;gap:7px;padding:16px 20px;text-align:center}
.ocard-reveal[hidden]{display:none}  /* class display:flex would otherwise beat the hidden attr */
.cred-row{display:flex;align-items:center;justify-content:center;gap:10px}
.cred-k{font-size:.875rem;text-transform:uppercase;letter-spacing:.04em;color:#9bc0ff;font-weight:700;min-width:80px;text-align:right}
.cred-v{font-family:ui-monospace,Consolas,monospace;font-size:1rem;color:#fff;background:rgba(255,255,255,.12);
  border-radius:6px;padding:5px 12px;user-select:all;word-break:break-all}
.cred-pw{font-weight:800;color:#bbf7d0;background:rgba(34,197,94,.2)}
.ocard-signin{margin-top:9px}
.btn-block{width:100%;justify-content:center;padding:10px;font-size:.9rem}
.ocard-hide{display:block;margin:8px auto 0;background:none;border:0;color:#9bc0ff;font-size:.875rem;cursor:pointer;text-decoration:underline}

.staff-login{max-width:1180px;margin:22px auto 0;background:rgba(255,255,255,.96);border-radius:12px;
  padding:8px 16px;box-shadow:var(--shadow-sm)}
.staff-login summary{cursor:pointer;font-size:.86rem;font-weight:600;color:var(--oc-blue-d);padding:8px 2px;list-style:none}
.staff-login summary::-webkit-details-marker{display:none}
.staff-login summary::before{content:"▸ ";color:var(--oc-orange);font-weight:800}
.staff-login[open] summary::before{content:"▾ "}
.staff-form{padding:6px 2px 12px}
.staff-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.staff-row input{flex:1;min-width:160px;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:.92rem}
.staff-row input:focus{outline:2px solid var(--oc-blue);border-color:var(--oc-blue)}
.staff-row .btn-primary{padding:10px 22px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.picker-foot{max-width:1200px;margin:20px auto 0;text-align:center;color:#9bc0ff;font-size:.78rem}
@media (max-width:560px){
  .picker-head{flex-direction:column;text-align:center}
  .ocard-grid{grid-template-columns:1fr}
  .ocard-name{font-size:1rem}
}

/* ===== Senior-citizen readability — councilor dashboard: pure-black, >=14px =====
   No grey body text; nothing under 14px. (Login picker keeps its own colors.) */
.wrap{font-size:15px}
.wrap th,.wrap td,.wrap .kpi .lbl,.wrap .kpi .hint,.wrap .card>h2 .count,.wrap .card>h2 .count-sub,
.wrap .section-note,.wrap .sub-h .count,.wrap .measure-sub,.wrap .ppos,.wrap .pmeta,.wrap .pmeta span,
.wrap .chip,.wrap .count{font-size:14px}
.wrap .measure-title{font-size:15px;font-weight:700}
.wrap .kpi .lbl{font-weight:700}
.wrap .measure-sub,.wrap .section-note,.wrap th,.wrap .kpi .hint,.wrap .count,.wrap .count-sub,.wrap .ppos,.wrap .pmeta{color:#000}
.foot{font-size:14px;color:#000}

/* ===== Bold, clear hover affordance (senior-friendly) — dashboard ===== */
.wrap tr{transition:background .12s ease}
.wrap tbody tr:hover td{background:#e8f1fe}
.wrap tbody tr:hover .measure-title{font-weight:800;color:#0a2e63}
.wrap .measure-title{transition:color .12s ease,font-weight .12s ease}
.wrap .measure-title:hover{font-weight:800;text-decoration:underline;color:#0a2e63}
.wrap .billlist li{transition:background .12s ease}
.wrap .billlist li:hover{background:#e8f1fe;border-radius:6px}
.wrap .billlist li:hover .billtitle{font-weight:800;color:#000}
.wrap .billlist li:hover .billno{color:#0a2e63}
.wrap a:hover{font-weight:800;text-decoration:underline}
.wrap .kpi:hover .lbl,.wrap .kpi:hover .num{color:#0a2e63}

/* ---- Focus visibility (a11y) ---- */
a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--sp-blue);outline-offset:2px}

/* ---- Responsive ---- */
@media (max-width:820px){
  .grid-2{grid-template-columns:1fr}
  .masthead-inner{flex-wrap:wrap}
  .profile{flex-direction:column;text-align:center}
  .profile .pmeta{justify-content:center}
}

/* ---- Welcome hero (councilor login) ---- */
/* SONA-style grand member introduction (navy chamber + gold, serif name). */
.welcome{display:flex;flex-wrap:wrap;gap:22px;align-items:center;justify-content:space-between;
  background:linear-gradient(118deg,#091a3a 0%,#122a55 48%,#3a2c14 100%);color:#fff;border-radius:18px;
  padding:30px 32px;margin-bottom:22px;position:relative;overflow:hidden;border-bottom:3px solid var(--sp-gold);
  box-shadow:0 18px 44px rgba(6,16,40,.42),0 2px 6px rgba(0,0,0,.18)}
.welcome::after{content:"";position:absolute;right:-60px;top:-40px;width:320px;height:320px;
  background:radial-gradient(circle,rgba(230,180,90,.30),transparent 68%);pointer-events:none}
.welcome-main{position:relative;z-index:1}
.welcome-eyebrow{font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;color:#e3c389;font-weight:700;margin-bottom:10px}
.welcome-greet{font-size:1rem;color:#c9d6ee;font-style:italic;font-family:Georgia,serif}
.welcome-name{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-size:2.7rem;line-height:1.06;margin:4px 0 8px;
  background:linear-gradient(180deg,#f8df97,#d4a843 85%);-webkit-background-clip:text;background-clip:text;color:transparent}
.welcome-sub{font-size:1rem;color:#dfe7f5;letter-spacing:.02em}
.welcome-line{font-size:1.02rem;margin:16px 0 16px;color:#eef3fb;max-width:680px;line-height:1.6}
.welcome-line strong{color:#f6d98a}
.welcome-hot{color:#ff9e8f!important}
.welcome-actions{display:flex;flex-wrap:wrap;gap:11px}
.wbtn{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(180deg,#f6cf63,#e3a93a);color:#1a2336;padding:11px 18px;
  border-radius:11px;font-size:.94rem;font-weight:800;box-shadow:0 6px 16px rgba(0,0,0,.28);transition:transform .15s ease,box-shadow .15s ease}
.wbtn:hover{transform:translateY(-2px);text-decoration:none;box-shadow:0 10px 22px rgba(0,0,0,.34)}
.wbtn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(230,180,90,.55);box-shadow:none}
.wbtn-ghost:hover{background:rgba(255,255,255,.2)}
.welcome-search{position:relative;min-width:250px;flex:1;max-width:340px}
.welcome-search .ws-ico{position:absolute;left:13px;top:50%;transform:translateY(-50%);opacity:.55}
.welcome-search input{width:100%;padding:14px 14px 14px 38px;border:none;border-radius:11px;font-size:1rem;
  background:rgba(255,255,255,.97);color:var(--ink);box-shadow:0 5px 14px rgba(0,0,0,.24)}
.welcome-search input:focus{outline:2px solid var(--sp-gold)}

/* ---- 3D depth: lift cards/KPIs on hover ---- */
.kpi{transition:transform .16s ease,box-shadow .16s ease}
.kpi:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(16,32,24,.16)}
.card{transition:box-shadow .18s ease}
.card:hover{box-shadow:0 14px 32px rgba(16,32,24,.13)}
.profile{box-shadow:0 10px 28px rgba(16,32,24,.11)}
@media(max-width:820px){.welcome-name{font-size:1.55rem}.welcome-search{max-width:none}}

/* ---- Print (Accomplishment Report) ---- */
@media print{
  body{background:#fff}
  .masthead{background:#fff !important;color:#000;border-bottom:2px solid #000;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .masthead .eyebrow,.masthead .sub{color:#333}
  .no-print{display:none !important}
  .card,.kpi,.profile{box-shadow:none;border:1px solid #999;break-inside:avoid}
  .chip{border:1px solid #999}
  a{color:#000}
  .wrap{max-width:none;padding:0}
}

/* =====================================================================
   COMMAND CENTER — Councilor Portal dashboard (index.php only)
   Scoped to body.cp-app so login.php / report.php / measure.php /
   scorecard.php keep their existing styles untouched. Navy + gold extends
   the established welcome-hero / login-picker palette (brand continuity);
   content lives on WHITE panels to keep the senior-citizen AA contrast.
   ===================================================================== */
body.cp-app{
  --navy:#071B3A; --navy-2:#0B2D5C; --navy-3:#0e2247; --navy-line:#1c3a66;
  --gold:#F4B942; --gold-d:#e3a93a; --royal:#2563EB;
  --ink:#0F172A; --ink-soft:#334155; --panel:#ffffff; --panel-2:#f1f5fb;
  --side-ink:#e6eefb; --side-mut:#9fb3d6; --line:#e2e8f0;
  --ok:#15803d; --ok-bg:#dcfce7; --warn:#92600a; --warn-bg:#fef3c7;
  --danger:#b91c1c; --danger-bg:#fee2e2; --info:#1d4ed8; --info-bg:#dbeafe;
  margin:0;background:#06122b;color:var(--ink);
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
body.cp-app *{box-sizing:border-box}

/* ---- Shell ---- */
.cp-shell{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
.cp-main{min-width:0;display:flex;flex-direction:column;
  background:radial-gradient(1100px 520px at 78% -8%,#10306a 0%,#0a1f44 52%,#06122b 100%)}
/* Backdrop must never occupy a grid track (else it steals column 2 from .cp-main);
   it is a fixed overlay shown only when the mobile sidebar is open. */
.cp-backdrop{display:none;position:fixed;inset:0;z-index:55;background:rgba(4,10,28,.5)}

/* ---- Sidebar ---- */
.cp-sidebar{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;
  background:linear-gradient(180deg,#08213f 0%,#071a34 100%);border-right:1px solid var(--navy-line);
  display:flex;flex-direction:column;gap:4px;padding:18px 14px}
.cp-brand{display:flex;align-items:center;gap:11px;padding:4px 6px 14px;border-bottom:1px solid var(--navy-line);margin-bottom:8px}
.cp-brand .seal{width:42px;height:42px;border-radius:50%;background:#fff;padding:3px;object-fit:contain;flex:none;box-shadow:0 4px 12px rgba(0,0,0,.35)}
.cp-brand .bt{min-width:0}
.cp-brand .bt b{display:block;color:#fff;font-size:.82rem;line-height:1.2;letter-spacing:.01em}
.cp-brand .bt span{display:block;color:var(--gold);font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-top:2px}
.cp-navlabel{color:var(--side-mut);font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;padding:14px 10px 6px}
.cp-nav{display:flex;flex-direction:column;gap:2px}
.cp-nav a,.cp-nav button{display:flex;align-items:center;gap:12px;width:100%;text-align:left;cursor:pointer;
  color:var(--side-ink);background:transparent;border:0;border-radius:10px;padding:10px 12px;font:inherit;font-size:.9rem;font-weight:600;
  text-decoration:none;transition:background .14s ease,color .14s ease,box-shadow .14s ease;position:relative}
.cp-nav a .ic,.cp-nav button .ic{font-size:1.05rem;width:22px;text-align:center;flex:none;filter:saturate(.4) brightness(1.2)}
.cp-nav a:hover,.cp-nav button:hover{background:rgba(96,140,220,.14);color:#fff;text-decoration:none}
.cp-nav .is-active{background:linear-gradient(90deg,rgba(244,185,66,.20),rgba(244,185,66,.04));color:#fff;
  box-shadow:inset 3px 0 0 var(--gold)}
.cp-nav .is-active .ic{filter:none}
.cp-badge2{margin-left:auto;background:var(--gold);color:#3a2a00;font-size:.68rem;font-weight:800;border-radius:999px;padding:1px 8px;min-width:20px;text-align:center}
.cp-badge2.is-quiet{background:rgba(255,255,255,.16);color:#cfe0ff}
.cp-side-foot{margin-top:auto;padding-top:14px}
.cp-citycard{background:linear-gradient(135deg,#0f4d2b,#0a3a20);border:1px solid #1c6b3e;border-radius:14px;padding:14px;text-align:center;box-shadow:0 8px 22px rgba(0,0,0,.3)}
.cp-citycard b{display:block;color:#fff;font-size:.92rem;letter-spacing:.02em}
.cp-citycard span{display:block;color:#bfe7cd;font-size:.66rem;font-weight:700;letter-spacing:.05em;margin-top:4px}

/* ---- Topbar ---- */
.cp-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;
  padding:12px 22px;background:rgba(8,24,52,.86);backdrop-filter:blur(9px);border-bottom:1px solid var(--navy-line)}
.cp-burger{display:none;background:transparent;border:1px solid var(--navy-line);color:#fff;border-radius:9px;
  width:40px;height:40px;font-size:1.2rem;cursor:pointer;flex:none}
.cp-tophead{min-width:0;flex:none;color:#fff}
.cp-tophead .eb{font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.cp-tophead b{display:block;font-size:.96rem;line-height:1.15}
.cp-search{flex:1;max-width:560px;position:relative;margin:0 auto}
.cp-search .si{position:absolute;left:14px;top:50%;transform:translateY(-50%);opacity:.6;color:#0a1f44}
.cp-search input{width:100%;border:1px solid var(--navy-line);background:rgba(255,255,255,.96);color:var(--ink);
  border-radius:11px;padding:11px 14px 11px 40px;font-size:.92rem}
.cp-search input:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.cp-search kbd{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.66rem;color:#5a6b86;
  background:#eef2f9;border:1px solid #d6deeb;border-radius:6px;padding:2px 6px;font-family:inherit}
.cp-userwrap{display:flex;align-items:center;gap:14px;flex:none;margin-left:auto;color:#fff}
.cp-user{text-align:right;line-height:1.15}
.cp-user b{font-size:.86rem}
.cp-rolepill{display:inline-block;background:rgba(244,185,66,.18);color:var(--gold);border:1px solid rgba(244,185,66,.4);
  font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 9px;margin-top:3px}
.cp-bell{position:relative;background:transparent;border:1px solid var(--navy-line);color:#fff;border-radius:10px;width:40px;height:40px;font-size:1.1rem;cursor:pointer;flex:none}
.cp-bell .dot{position:absolute;top:-5px;right:-5px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:800;border-radius:999px;min-width:18px;height:18px;display:grid;place-items:center;border:2px solid #08213f}
.cp-logout{background:#fff;color:var(--navy-2);border-radius:10px;padding:9px 16px;font-size:.82rem;font-weight:700;text-decoration:none;flex:none;border:0;cursor:pointer}
.cp-logout:hover{background:var(--gold);color:#3a2a00;text-decoration:none}

/* ---- Content scroller ---- */
.cp-content{padding:22px;display:flex;flex-direction:column;gap:20px;max-width:1420px;width:100%;margin:0 auto}
.cp-note{background:rgba(244,185,66,.12);border:1px solid rgba(244,185,66,.4);color:#ffe9bf;border-radius:12px;padding:11px 16px;font-size:.85rem}
.cp-note a{color:var(--gold);font-weight:700}

/* ---- Hero ---- */
.cp-herorow{display:grid;grid-template-columns:1.65fr 1fr;gap:20px;align-items:stretch}
.cp-hero{position:relative;overflow:hidden;border-radius:20px;padding:26px 28px;color:#fff;
  background:linear-gradient(118deg,#0a1f44 0%,#12325f 52%,#3a2c14 118%);border:1px solid #244a82;
  box-shadow:0 22px 50px rgba(4,12,32,.5);display:flex;gap:24px;align-items:center}
.cp-hero::after{content:"";position:absolute;right:-70px;top:-60px;width:340px;height:340px;
  background:radial-gradient(circle,rgba(244,185,66,.26),transparent 68%);pointer-events:none}
.cp-photo{position:relative;width:128px;height:150px;border-radius:16px;flex:none;overflow:hidden;cursor:pointer;
  background:linear-gradient(150deg,#21407a,#142a52);border:2px solid rgba(244,185,66,.55);
  box-shadow:0 0 0 4px rgba(255,255,255,.07),0 12px 26px rgba(0,0,0,.4);display:grid;place-items:center;
  transition:transform .16s ease,box-shadow .16s ease}
.cp-photo:hover,.cp-photo:focus-visible{transform:translateY(-3px);box-shadow:0 0 0 4px rgba(244,185,66,.3),0 16px 34px rgba(0,0,0,.5);outline:none}
.cp-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:1}
.cp-photo .ini{font-size:2.6rem;font-weight:800;color:rgba(255,255,255,.85);font-family:Georgia,serif}
.cp-photo .cue{position:absolute;left:0;right:0;bottom:0;z-index:2;background:linear-gradient(180deg,transparent,rgba(4,10,28,.92));
  color:#fff;font-size:.6rem;font-weight:700;text-align:center;padding:16px 6px 6px;line-height:1.2;opacity:0;transition:opacity .16s ease}
.cp-photo:hover .cue,.cp-photo:focus-visible .cue{opacity:1}
.cp-hero-body{position:relative;z-index:1;min-width:0;flex:1}
.cp-chip-term{display:inline-block;background:rgba(37,99,235,.28);border:1px solid rgba(120,160,255,.5);color:#cfe0ff;
  font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;border-radius:999px;padding:3px 11px;margin-bottom:8px}
.cp-hero-name{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-size:2.15rem;line-height:1.05;margin:0;
  background:linear-gradient(180deg,#f8df97,#d4a843 86%);-webkit-background-clip:text;background-clip:text;color:transparent}
.cp-hero-pos{display:flex;align-items:center;gap:7px;color:#dbe7fb;font-weight:600;margin-top:6px;font-size:.94rem}
.cp-verif{color:#7fd1a0}
.cp-hero-greet{color:#c6d6f1;font-size:.9rem;margin:12px 0 2px}
.cp-hero-line{color:#eaf1fc;font-size:.96rem;line-height:1.6;margin:6px 0 0;max-width:620px}
.cp-hero-line b{color:#f6d98a}
.cp-hot{color:#ffb0a2!important;font-weight:800}
.cp-quickrow{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;align-items:center}
.cp-qcard{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:12px;padding:8px 13px}
.cp-qcard .qi{font-size:1.1rem}
.cp-qcard .qv{font-size:.92rem;font-weight:800;color:#fff;line-height:1.1}
.cp-qcard .ql{font-size:.62rem;color:#b7c8e6;text-transform:uppercase;letter-spacing:.06em}
.cp-cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(180deg,#f6cf63,#e3a93a);color:#1a2336;
  border:0;cursor:pointer;font:inherit;font-weight:800;font-size:.9rem;border-radius:12px;padding:11px 18px;
  box-shadow:0 8px 20px rgba(0,0,0,.32);transition:transform .15s ease,box-shadow .15s ease;text-decoration:none}
.cp-cta:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.4);text-decoration:none;color:#1a2336}

/* ---- Top committee roles panel ---- */
.cp-roles{background:linear-gradient(180deg,#0c2750,#0b2444);
  border:1px solid #244a82;border-radius:20px;padding:20px 22px;color:#fff;box-shadow:0 22px 50px rgba(4,12,32,.45);display:flex;flex-direction:column}
.cp-roles h3{font-size:.7rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 14px}
.cp-rolelist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;flex:1}
.cp-rolelist li{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;line-height:1.35;color:#e8f0fd}
.cp-rolelist .rb{width:9px;height:9px;border-radius:50%;margin-top:6px;flex:none;background:var(--gold)}
.cp-rolelist .rb.vice{background:#5b8def}
.cp-rolelist .rrole{display:block;font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#9fb6dc}
.cp-roles .cp-rolesmore{margin-top:16px;width:100%;justify-content:center;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(244,185,66,.45)}
.cp-roles .cp-rolesmore:hover{background:rgba(244,185,66,.2);color:#fff}
.cp-roles .cp-empty-d{color:#9fb6dc;font-size:.86rem;flex:1}

/* ---- Tabs ---- */
.cp-tabwrap{background:rgba(255,255,255,.04);border:1px solid var(--navy-line);border-radius:16px;padding:9px}
.cp-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:thin}
.cp-tab{flex:none;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:104px;cursor:pointer;
  background:transparent;border:1px solid transparent;border-radius:12px;padding:12px 14px;color:#bccbe6;font:inherit;font-weight:700;font-size:.8rem;
  transition:background .14s ease,color .14s ease,box-shadow .14s ease}
.cp-tab .ti{font-size:1.3rem}
.cp-tab:hover{background:rgba(120,160,220,.12);color:#fff}
.cp-tab.is-active{background:linear-gradient(180deg,#1f4fb0,#1a3f8c);color:#fff;box-shadow:0 8px 20px rgba(13,40,90,.6);border-color:#3b63b8}
.cp-tab.is-active .ti{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}

/* ---- Panels (white content) ---- */
.cp-panel{display:none;flex-direction:column;gap:18px}
.cp-panel.is-active{display:flex;animation:cpFade .22s ease}
/* On detail tabs, hide the always-on profile hero so the chosen section is the focus and
   isn't buried under a ~500px hero (made the sidebar feel "not clickable"). Overview keeps it. */
body.cp-app.cp-detail-view .cp-herorow{display:none}
@keyframes cpFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.cp-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px rgba(4,12,32,.22);overflow:hidden}
.cp-card > h2,.cp-cardhead{display:flex;align-items:center;gap:10px;font-size:1rem;color:var(--ink);padding:15px 18px;border-bottom:1px solid var(--line);background:var(--panel-2);margin:0}
.cp-card > h2 .sub{margin-left:auto;font-size:.78rem;color:var(--ink-soft);font-weight:600}
.cp-card .bd{padding:16px 18px}
.cp-secnote{color:var(--ink-soft);font-size:.84rem;margin:0 0 14px}

/* ---- Stat cards ---- */
.cp-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.cp-stat{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:0 10px 26px rgba(4,12,32,.2);
  display:flex;flex-direction:column;gap:3px;position:relative;transition:transform .14s ease,box-shadow .14s ease}
.cp-stat.is-link{cursor:pointer}
.cp-stat.is-link:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(4,12,32,.32)}
.cp-stat .si{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:1.15rem;margin-bottom:7px}
.cp-stat .sv{font-size:1.85rem;font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1}
.cp-stat .sl{font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.cp-stat .sh{font-size:.74rem;color:var(--ink-soft)}
.cp-i-blue{background:var(--info-bg);color:var(--info)} .cp-i-green{background:var(--ok-bg);color:var(--ok)}
.cp-i-gold{background:var(--warn-bg);color:var(--warn)} .cp-i-violet{background:#ede9fe;color:#6d28d9}
.cp-i-rose{background:var(--danger-bg);color:var(--danger)} .cp-i-cyan{background:#cffafe;color:#0e7490}

/* ---- Tables ---- */
.cp-table{width:100%;border-collapse:collapse;font-size:.88rem}
.cp-table th,.cp-table td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.cp-table th{font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:800;background:var(--panel-2);position:sticky;top:0}
.cp-table tbody tr{transition:background .12s ease}
.cp-table tbody tr:hover{background:#eff5ff}
.cp-table tr:last-child td{border-bottom:none}
.cp-tt{font-weight:700;color:var(--ink)}
.cp-tsub{color:var(--ink-soft);font-size:.78rem;margin-top:2px}
.cp-view{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:9px;background:var(--info-bg);color:var(--info);
  text-decoration:none;font-size:.95rem;border:1px solid #bcd3fb}
.cp-view:hover{background:var(--info);color:#fff;text-decoration:none}
.cp-tablebar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 12px}
.cp-tablebar .tf{flex:1;min-width:180px;position:relative}
.cp-tablebar input,.cp-tablebar select{border:1px solid var(--line);border-radius:10px;padding:9px 12px;font:inherit;font-size:.86rem;background:#fff;color:var(--ink)}
.cp-tablebar input{width:100%;padding-left:34px}
.cp-tablebar .tf .si{position:absolute;left:11px;top:50%;transform:translateY(-50%);opacity:.5}
.cp-showmore{display:block;margin:14px auto 2px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;
  padding:9px 18px;font:inherit;font-weight:700;font-size:.84rem;color:var(--info);cursor:pointer}
.cp-showmore:hover{background:#e7eefb}
.cp-row-hidden{display:none}

/* ---- Sub-grids / lists reused inside panels ---- */
.cp-grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cp-billlist{margin:4px 0 0;padding-left:26px}
.cp-billlist li{padding:9px 4px;border-bottom:1px solid var(--line);font-size:.9rem;line-height:1.5;display:flex;gap:12px;align-items:flex-start}
.cp-billlist li:last-child{border-bottom:none}
.cp-billlist li::marker{font-weight:800;color:var(--info)}
.cp-empty{padding:30px 18px;text-align:center;color:var(--ink-soft)}
.cp-empty .ic{font-size:2rem;opacity:.45}
.cp-empty p{margin:8px 0 0;font-size:.9rem}

/* ---- Chip overrides on white panels (reuse .chip from base) ---- */
body.cp-app .cp-panel .chip{font-size:.7rem}

/* ---- Photo profile modal ---- */
.cp-modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,10,28,.72);backdrop-filter:blur(4px)}
.cp-modal.is-open{display:flex;animation:cpFade .18s ease}
.cp-modal-card{background:#fff;border-radius:20px;max-width:780px;width:100%;max-height:90vh;overflow-y:auto;
  box-shadow:0 30px 80px rgba(0,0,0,.55);position:relative}
.cp-modal-hd{display:flex;gap:18px;align-items:center;padding:24px;color:#fff;
  background:linear-gradient(120deg,#0a1f44,#143364 60%,#3a2c14);border-radius:20px 20px 0 0}
.cp-modal-hd .ph{width:96px;height:112px;border-radius:14px;flex:none;overflow:hidden;background:#16203c;display:grid;place-items:center;
  border:2px solid rgba(244,185,66,.5);position:relative}
.cp-modal-hd .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.cp-modal-hd .ph .ini{font-size:2rem;font-weight:800;color:#fff;font-family:Georgia,serif}
.cp-modal-hd h2{font-family:Georgia,serif;font-style:italic;font-size:1.55rem;margin:0;color:#f8df97}
.cp-modal-hd .pos{color:#dbe7fb;font-weight:600;margin-top:3px}
.cp-modal-hd .meta{color:#aebfdd;font-size:.8rem;margin-top:6px}
.cp-modal-close{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.14);border:0;color:#fff;cursor:pointer;
  width:38px;height:38px;border-radius:50%;font-size:1.2rem;line-height:1}
.cp-modal-close:hover{background:rgba(255,255,255,.28)}
.cp-modal-bd{padding:22px 24px}
.cp-mstats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.cp-mstat{border:1px solid var(--line);border-radius:12px;padding:12px;text-align:center;background:var(--panel-2)}
.cp-mstat .n{font-size:1.4rem;font-weight:800;color:var(--ink)}
.cp-mstat .l{font-size:.62rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);font-weight:700;margin-top:2px}
.cp-msec{margin-top:16px}
.cp-msec h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--info);margin:0 0 8px;border-bottom:1px solid var(--line);padding-bottom:5px}
.cp-msec ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.cp-msec li{display:flex;gap:10px;align-items:center;font-size:.88rem;color:var(--ink)}
.cp-modal-ft{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;padding:16px 24px 24px;border-top:1px solid var(--line)}

/* ---- Big-portrait profile card (large photo · scrollable detail · name band) ---- */
.cp-modal-card.cp-pc{max-width:1040px;min-height:min(560px,90vh);padding:0;background:#0f172a;overflow:hidden;display:flex;flex-direction:column}
.cp-pc .cp-pcard{display:flex;flex-direction:column;flex:1;min-height:0}
.cp-pc .cp-pcard-top{display:flex;flex:1;min-height:0}
.cp-pc .cp-pcard-photo{position:relative;width:42%;flex:none;display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(135deg,#16317a 0%,#0a1f4f 55%,#2e2410 130%);box-shadow:inset -12px 0 34px rgba(0,0,0,.45)}
.cp-pc .cp-pcard-photo .ini{font-family:Georgia,serif;font-weight:800;font-size:4rem;color:rgba(255,255,255,.85)}
.cp-pc .cp-pcard-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.cp-pc .cp-pcard-info{flex:1;min-width:0;overflow-y:auto;background:#fff;padding:22px 24px}
.cp-pc .cp-pcard-info .cp-msec:first-of-type{margin-top:0}
.cp-pc .cp-pcard-badge{display:inline-block;font-size:.64rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--info);background:rgba(37,99,235,.1);border:1px solid #bcd3fb;border-radius:999px;padding:5px 12px;margin-bottom:14px}
.cp-pc .cp-pcard-foot{flex:none;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding:18px 26px;background:linear-gradient(120deg,#0a1f44,#143364 60%,#3a2c14);border-top:3px solid var(--gold)}
.cp-pc .cp-pcard-name h2{margin:0;font-family:Georgia,serif;font-style:italic;font-size:1.7rem;line-height:1.12;color:#f8df97}
.cp-pc .cp-pcard-name .pos{margin-top:4px;color:#dbe7fb;font-weight:600;font-size:.9rem}
.cp-pc .cp-pcard-actions{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:680px){
  .cp-modal-card.cp-pc{min-height:0;max-height:92vh;overflow-y:auto}
  .cp-pc .cp-pcard-top{flex-direction:column}
  .cp-pc .cp-pcard-photo{width:100%;height:280px}
  .cp-pc .cp-pcard-info{overflow:visible}
  .cp-pc .cp-pcard-name h2{font-size:1.4rem}
}

/* ---- Responsive ---- */
@media (max-width:1180px){
  .cp-herorow{grid-template-columns:1fr}
  .cp-stats{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1024px){
  .cp-shell{grid-template-columns:1fr}
  .cp-sidebar{position:fixed;top:0;left:0;z-index:60;width:264px;transform:translateX(-100%);transition:transform .22s ease}
  body.cp-app.nav-open .cp-sidebar{transform:none}
  body.cp-app.nav-open .cp-backdrop{display:block}
  .cp-burger{display:grid;place-items:center}
}
@media (max-width:720px){
  .cp-hero{flex-direction:column;text-align:center;align-items:center}
  .cp-quickrow{justify-content:center}
  .cp-stats{grid-template-columns:repeat(2,1fr)}
  .cp-grid2{grid-template-columns:1fr}
  .cp-tophead{display:none}
  .cp-mstats{grid-template-columns:repeat(2,1fr)}
  .cp-content{padding:16px}
}
@media (max-width:480px){
  .cp-hero-name{font-size:1.6rem}
  .cp-search kbd{display:none}
  .cp-user .uname-full{display:none}
}
@media (prefers-reduced-motion:reduce){
  body.cp-app *{animation:none!important;transition:none!important}
}

/* ---- Print: hide the app chrome (report.php remains the print artifact) ---- */
@media print{
  body.cp-app{background:#fff}
  .cp-sidebar,.cp-topbar,.cp-tabwrap,.cp-burger,.cp-modal,.no-print{display:none!important}
  .cp-shell{grid-template-columns:1fr}
  .cp-main{background:#fff}
  .cp-card,.cp-stat{box-shadow:none;border:1px solid #999}
  .cp-panel{display:flex!important}
}
