/* ==================================================================
   CISP National Evaluation Toolkit - design system
   CISP brand palette: deep teal + turquoise with navy ink on cool neutrals.
   (Colours sampled from the CISP / ASPIRE framework deck.)
   ================================================================== */
:root {
  --teal-900:#04172d; --teal-800:#0a4a47; --teal-700:#0e6f6b; --teal-600:#13908b;
  --teal-500:#19a39d; --teal-300:#49d6d1; --teal-100:#dbf1f0; --teal-50:#eef8f8;
  --coral-600:#c81f23; --coral-500:#ea262a; --coral-400:#f15a5d; --coral-100:#fbe0e0;
  --ink-900:#0f2433; --ink-700:#33454f; --ink-500:#5a6a78; --ink-400:#8a98a4;
  --sand-50:#f5f9fa; --sand-100:#e9eef1; --line:#d8e0e6; --line-soft:#e7edf0;
  --white:#ffffff; --gold:#dca62a;
  --ok:#1f8f6b; --ok-bg:#e2f3ec; --warn:#a9791f; --warn-bg:#fbf1da; --bad:#c81f23; --bad-bg:#fbe2e2;
  --radius:14px; --radius-sm:9px; --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(21,34,38,.06), 0 1px 3px rgba(21,34,38,.05);
  --shadow:0 6px 24px rgba(21,34,38,.09); --shadow-lg:0 20px 50px rgba(21,34,38,.16);
  --maxw:1140px; --maxw-narrow:760px;
  --font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-serif:"Spectral",Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-sans);color:var(--ink-900);
  background:var(--sand-50);line-height:1.6;font-size:16.5px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--teal-700);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-serif);color:var(--ink-900);line-height:1.18;font-weight:600;margin:0 0 .5em}
h1{font-size:clamp(2rem,4vw,3rem);letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem);letter-spacing:-.005em}
h3{font-size:1.28rem}
h4{font-size:1.06rem;font-family:var(--font-sans);font-weight:700}
p{margin:0 0 1rem}
.lead{font-size:1.18rem;color:var(--ink-700)}
.muted{color:var(--ink-500)}
.small{font-size:.9rem}
.tiny{font-size:.8rem}
hr{border:none;border-top:1px solid var(--line);margin:2rem 0}
code{background:var(--sand-100);padding:.1em .4em;border-radius:5px;font-size:.92em}

/* layout ----------------------------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 22px}
.section{padding:64px 0}
.section-sm{padding:38px 0}
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:880px){.g2,.g3,.g4{grid-template-columns:1fr}}
@media(max-width:880px){.g3.keep2,.g4.keep2{grid-template-columns:repeat(2,1fr)}}
.row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.between{justify-content:space-between}
.center{text-align:center}
.stack>*+*{margin-top:14px}
.spacer{flex:1}

/* header / nav ----------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,249,245,.92);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;height:84px}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--font-serif);
  font-weight:700;font-size:1.04rem;color:var(--ink-900)}
.brand:hover{text-decoration:none}
.brand .brand-logo{height:68px;width:auto;display:block}
.site-footer .brand-logo{height:62px}
@media(max-width:560px){.brand .brand-logo{height:54px}}
.brand .brand-sub{font-family:var(--font-sans);font-weight:600;font-size:.82rem;color:var(--ink-500);
  padding-left:12px;border-left:1px solid var(--line);letter-spacing:.01em}
.brand-logo-white{filter:brightness(0) invert(1)}
.brand .logo-mark{width:34px;height:34px;border-radius:9px;background:var(--teal-600);
  color:#fff;display:grid;place-items:center;font-size:1rem;font-weight:700;font-family:var(--font-sans)}
.nav-links{display:flex;gap:4px;align-items:center;margin-left:auto;flex-wrap:wrap}
.nav-links>a{color:var(--ink-700);padding:8px 11px;border-radius:8px;font-size:.93rem;font-weight:500}
.nav-links>a:hover{background:var(--teal-50);color:var(--teal-800);text-decoration:none}
.nav-links>a.active{color:var(--teal-800);background:var(--teal-50)}
.nav-dd{position:relative}
.nav-dd-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;
  font-family:var(--font-sans);color:var(--ink-700);padding:8px 11px;border-radius:8px;font-size:.93rem;font-weight:500}
.nav-dd-btn:hover,.nav-dd-btn.active{background:var(--teal-50);color:var(--teal-800)}
.nav-dd-btn .caret{font-size:.7rem;opacity:.7;transition:transform .15s}
.nav-dd:hover .caret,.nav-dd.open .caret{transform:rotate(180deg)}
.nav-dd-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:212px;background:#fff;
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:7px;display:none;z-index:60}
/* transparent bridge so the cursor can cross the gap from button to menu without losing :hover */
.nav-dd-menu::before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px}
.nav-dd::after{content:"";position:absolute;left:0;right:0;top:100%;height:10px;pointer-events:none}
.nav-dd:hover::after{pointer-events:auto}
.nav-dd:hover .nav-dd-menu,.nav-dd.open .nav-dd-menu{display:block}
.nav-dd-menu a{display:block;color:var(--ink-700);padding:9px 12px;border-radius:8px;font-size:.92rem;font-weight:500}
.nav-dd-menu a:hover{background:var(--teal-50);color:var(--teal-800);text-decoration:none}
.nav-dd-menu a.active{background:var(--teal-50);color:var(--teal-800)}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);
  border-radius:9px;padding:8px 10px;cursor:pointer}
@media(max-width:1024px){
  .nav-toggle{display:block}
  .nav-links{display:none;position:absolute;top:84px;left:0;right:0;background:var(--sand-50);
    flex-direction:column;align-items:stretch;padding:10px 16px 18px;border-bottom:1px solid var(--line);gap:2px}
  .nav-links.open{display:flex}
  .nav-links>a{padding:11px 12px}
  .brand .brand-sub{display:none}
  .nav-dd{width:100%}
  .nav-dd-btn{width:100%;justify-content:space-between;padding:11px 12px}
  .nav-dd-menu{position:static;display:block;box-shadow:none;border:none;padding:0 0 6px 12px;min-width:0}
  #account{margin:10px 0 0 0!important;flex-wrap:wrap}
}

/* account menu ----------------------------------------------------- */
.account-dd .account-btn{gap:8px;padding:5px 10px 5px 6px;border:1px solid var(--line);background:#fff}
.account-dd .account-btn:hover{border-color:var(--teal-300);background:var(--teal-50)}
.account-avatar{width:30px;height:30px;border-radius:50%;background:var(--teal-600);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:.86rem;font-family:var(--font-sans)}
.account-name{font-weight:600;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-dd .nav-dd-menu{left:auto;right:0;min-width:212px}
.account-menu .account-head{padding:8px 12px 10px;border-bottom:1px solid var(--line-soft);margin-bottom:5px}
.account-menu .account-signout{color:var(--coral-600)}
@media(max-width:1024px){
  .account-dd{width:100%}
  .account-dd .account-btn{width:100%;justify-content:flex-start}
  .account-name{max-width:none}
  .account-dd .nav-dd-menu{right:auto}
}

/* buttons ---------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;
  font-family:var(--font-sans);font-weight:600;font-size:.96rem;cursor:pointer;
  padding:11px 20px;border-radius:10px;border:1px solid transparent;transition:.15s;text-decoration:none;line-height:1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--teal-600);color:#fff}
.btn-primary:hover{background:var(--teal-700);color:#fff}
.btn-coral{background:var(--coral-500);color:#fff}
.btn-coral:hover{background:var(--coral-600);color:#fff}
.btn-ghost{background:transparent;color:var(--teal-800);border-color:var(--teal-300)}
.btn-ghost:hover{background:var(--teal-50)}
.btn-light{background:#fff;color:var(--ink-900);border-color:var(--line)}
.btn-light:hover{border-color:var(--teal-300);background:var(--teal-50)}
.btn-sm{padding:7px 13px;font-size:.86rem;border-radius:8px}
.btn-block{width:100%}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none}

/* cards ------------------------------------------------------------ */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm)}
.card-hover{transition:.18s}
.card-hover:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--teal-300)}
a.card{color:inherit;display:block}
a.card:hover{text-decoration:none}
.card-pad-lg{padding:32px}

/* badges / pills --------------------------------------------------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;
  letter-spacing:.03em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.badge-teal{background:var(--teal-100);color:var(--teal-800)}
.badge-coral{background:var(--coral-100);color:var(--coral-600)}
.badge-sand{background:var(--sand-100);color:var(--ink-700)}
.badge-gold{background:#faf0d3;color:#8a6a16}
.badge-program{background:#e8eef6;color:#2f5586}
.badge-participant{background:var(--teal-100);color:var(--teal-800)}
.pill{display:inline-block;font-size:.82rem;padding:4px 11px;border-radius:999px;
  background:var(--sand-100);color:var(--ink-700);border:1px solid var(--line)}
.tier{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;padding:3px 9px;border-radius:6px}
.tier-1{background:var(--teal-100);color:var(--teal-800)}
.tier-2{background:#e8eef6;color:#2f5586}
.tier-3{background:var(--coral-100);color:var(--coral-600)}
.burden{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:700;padding:3px 9px;border-radius:6px;white-space:nowrap}
.burden::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.65}
.burden.vl{background:var(--teal-50);color:var(--teal-700)}
.burden.lo{background:var(--teal-100);color:var(--teal-800)}
.burden.mo{background:#faf0d3;color:#8a6a16}
.burden.hi{background:var(--coral-100);color:var(--coral-600)}
.mt{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:6px;white-space:nowrap;text-transform:uppercase;letter-spacing:.02em}
.mt-validated{background:#e8eef6;color:#2f5586}
.mt-simple{background:var(--teal-50);color:var(--teal-700)}
.mt-qual{background:#f3ecf8;color:#6b3fa0}
.status{font-size:.76rem;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:capitalize}
.status.pending{background:var(--warn-bg);color:var(--warn)}
.status.approved{background:var(--ok-bg);color:var(--ok)}
.status.rejected{background:var(--bad-bg);color:var(--bad)}

/* principle callout ------------------------------------------------ */
.principle{margin:22px 0 4px;padding:15px 20px;background:#fff;border:1px solid var(--teal-100);
  border-left:4px solid var(--teal-500);border-radius:0 12px 12px 0;box-shadow:var(--shadow-sm)}
.principle .hp-tag{display:inline-block;font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;color:var(--teal-700);margin-bottom:6px}
.principle p{margin:0;font-size:1rem;color:var(--ink-700)}
.principle p+p{margin-top:8px}

/* co-design callout ------------------------------------------------ */
.codesign{background:#fbf4ec;border:1px solid #ecd9bf;border-left:4px solid var(--gold);
  border-radius:0 12px 12px 0;padding:14px 18px;margin:16px 0}
.codesign .cd-tag{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:#9a6b14;margin-bottom:5px}
.codesign .cd-tag::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold)}
.codesign p{margin:0;font-size:.95rem;color:var(--ink-700)}
.codesign p+p{margin-top:6px}
.codesign a{font-weight:600}

/* hero ------------------------------------------------------------- */
.hero{background:
   radial-gradient(1200px 500px at 88% -10%,var(--teal-100),transparent 60%),
   radial-gradient(900px 500px at 0% 110%,var(--teal-50),transparent 55%),
   var(--sand-50);
  border-bottom:1px solid var(--line)}
.hero-inner{padding:78px 0 70px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--teal-700);margin-bottom:16px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--coral-500)}

/* forms ------------------------------------------------------------ */
label{display:block;font-weight:600;font-size:.92rem;margin:0 0 6px;color:var(--ink-900)}
.hint{font-weight:400;color:var(--ink-500);font-size:.85rem;margin:-2px 0 7px}
input[type=text],input[type=email],input[type=password],input[type=url],input[type=number],
input[type=date],select,textarea{
  width:100%;font-family:inherit;font-size:.97rem;color:var(--ink-900);background:#fff;
  border:1px solid var(--line);border-radius:9px;padding:10px 12px;transition:.12s}
textarea{min-height:92px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal-500);
  box-shadow:0 0 0 3px var(--teal-100)}
.field{margin-bottom:18px}
.check{display:flex;gap:9px;align-items:flex-start;font-weight:400;margin:0;padding:7px 10px;
  border:1px solid var(--line);border-radius:9px;background:#fff;cursor:pointer;font-size:.92rem}
.check:hover{border-color:var(--teal-300);background:var(--teal-50)}
.check input{margin-top:3px;width:auto}
.check.sel{border-color:var(--teal-500);background:var(--teal-50)}
.checkgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}
@media(max-width:680px){.checkgrid{grid-template-columns:1fr}}

/* alerts ----------------------------------------------------------- */
.alert{border-radius:10px;padding:13px 16px;font-size:.93rem;margin:0 0 16px;border:1px solid}
.alert-ok{background:var(--ok-bg);border-color:#bfe2cd;color:#1f6e41}
.alert-bad{background:var(--bad-bg);border-color:#eec4ba;color:#9c3a25}
.alert-info{background:var(--teal-50);border-color:var(--teal-100);color:var(--teal-800)}
.alert-warn{background:var(--warn-bg);border-color:#ecd6a4;color:#8a6512}

/* tables ----------------------------------------------------------- */
.table{width:100%;border-collapse:collapse;font-size:.93rem;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.table th,.table td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line-soft);vertical-align:top}
.table th{background:var(--sand-100);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-700)}
.table tr:last-child td{border-bottom:none}
.table-wrap{overflow-x:auto}

/* misc ------------------------------------------------------------- */
.kicker{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--coral-600)}
.divider-label{display:flex;align-items:center;gap:14px;color:var(--ink-400);
  font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;margin:8px 0}
.divider-label::before,.divider-label::after{content:"";flex:1;height:1px;background:var(--line)}
.note{background:var(--sand-100);border-left:3px solid var(--teal-500);border-radius:0 9px 9px 0;padding:14px 18px;font-size:.93rem}
.cite{font-size:.84rem;color:var(--ink-500);line-height:1.5}
.tag-list{display:flex;flex-wrap:wrap;gap:7px}
.icon{width:1.05em;height:1.05em;vertical-align:-.15em;stroke-width:2;display:inline-block}
.loading{display:inline-block;width:18px;height:18px;border:2.5px solid var(--teal-100);
  border-top-color:var(--teal-600);border-radius:50%;animation:spin .7s linear infinite;vertical-align:-3px}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:linear-gradient(90deg,var(--sand-100),#fff,var(--sand-100));
  background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:8px;height:14px}
@keyframes shimmer{to{background-position:-200% 0}}
.hide{display:none!important}

/* partners --------------------------------------------------------- */
.partner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin:14px 0 8px}
.partner-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;
  border:1px solid var(--line);border-radius:12px;padding:18px 14px;background:#fff}
.partner-logo{height:54px;width:100%;display:flex;align-items:center;justify-content:center}
.partner-logo img{max-height:54px;width:auto;object-fit:contain}
.partner-logo-ph{height:54px;width:54px;border-radius:10px;background:var(--teal-50);border:1px dashed var(--teal-300);
  display:grid;place-items:center;color:var(--teal-700);font-weight:700;font-family:var(--font-serif);font-size:1.1rem}
.partner-card .pname{font-size:.86rem;font-weight:600;color:var(--ink-700);line-height:1.35}
.partner-strip{display:flex;flex-wrap:wrap;gap:12px 26px;align-items:center;justify-content:center;margin-top:14px}
.partner-strip .pname{font-size:.9rem;font-weight:600;color:var(--ink-500)}

/* feature icon */
.fic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--teal-100);color:var(--teal-700);margin-bottom:14px}
.fic.coral{background:var(--coral-100);color:var(--coral-600)}
.fic.sand{background:var(--sand-100);color:var(--ink-700)}

/* footer ----------------------------------------------------------- */
.site-footer{background:var(--teal-900);color:#cfe3e3;margin-top:60px;padding:52px 0 28px;font-size:.92rem}
.site-footer h5{color:#fff;font-family:var(--font-sans);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}
.site-footer a{color:#9fc6c7;display:block;padding:3px 0}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-bottom{border-top:1px solid rgba(255,255,255,.13);margin-top:34px;padding-top:20px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8fb3b4;font-size:.84rem}

/* map -------------------------------------------------------------- */
#map{height:560px;border-radius:var(--radius);border:1px solid var(--line);z-index:1}
.leaflet-popup-content{font-family:var(--font-sans);font-size:.9rem}
.map-layout{display:grid;grid-template-columns:340px 1fr;gap:22px}
@media(max-width:920px){.map-layout{grid-template-columns:1fr}}
.site-list{max-height:560px;overflow:auto;padding-right:4px}
.site-item{border:1px solid var(--line);border-radius:10px;padding:13px 15px;margin-bottom:10px;background:#fff;cursor:pointer;transition:.12s}
.site-item:hover{border-color:var(--teal-300);background:var(--teal-50)}

/* step progress */
.steps{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.step{flex:1;min-width:120px;border-top:3px solid var(--line);padding-top:9px;font-size:.83rem;color:var(--ink-400);font-weight:600}
.step.active{border-color:var(--teal-600);color:var(--teal-800)}
.step.done{border-color:var(--teal-300);color:var(--teal-600)}
.step b{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--coral-600)}

/* avatar */
.avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;background:var(--teal-100);border:2px solid #fff;box-shadow:var(--shadow-sm)}
.avatar-lg{width:96px;height:96px}
.worker{display:flex;gap:15px;align-items:flex-start;padding:16px;border:1px solid var(--line);border-radius:12px;background:#fff}

/* selected-tools tray */
.tray{position:sticky;top:84px}
.builder-layout{display:grid;grid-template-columns:1fr 330px;gap:26px;align-items:start}
@media(max-width:980px){.builder-layout{grid-template-columns:1fr}}
.sel-row{display:flex;justify-content:space-between;gap:8px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line-soft);font-size:.9rem}
.sel-row:last-child{border-bottom:none}

/* timepoint chips (Evaluation Tool Builder) */
.tp-chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}
.tp-chip{font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:6px;border:1px solid var(--line);
  background:#fff;color:var(--ink-400);cursor:pointer;user-select:none;transition:.12s}
.tp-chip:hover{border-color:var(--teal-300)}
.tp-chip.on{background:var(--teal-600);color:#fff;border-color:var(--teal-600)}

/* journey picker selection bar */
.sel-bar{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);
  box-shadow:0 -6px 24px rgba(21,34,38,.10);z-index:70;padding:12px 0}
.sel-bar-inner{display:flex;justify-content:space-between;align-items:center;gap:14px}
.sel-bar #sel-count{font-weight:600}
.domain-pick{display:flex;gap:12px;align-items:flex-start;cursor:pointer;margin:0;font-weight:400;padding:0}
.domain-pick input{margin-top:6px;width:auto;flex:none}
.domain-card.picked{box-shadow:0 0 0 2px var(--teal-500);border-color:var(--teal-500)}
.ind-pick{display:flex;gap:10px;align-items:flex-start;cursor:pointer;margin:0;font-weight:400;padding:9px 0;border-bottom:1px solid var(--line-soft)}
.ind-pick input{margin-top:4px;width:auto;flex:none}

/* domain accent bar */
.domain-card{border-left:5px solid var(--teal-500)}
.domain-card.program{border-left-color:#3a6aa8}
.domain-card.participant{border-left-color:var(--teal-500)}

/* feedback widget -------------------------------------------------- */
.fb-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;
  background:var(--coral-500);color:#fff;border:none;padding:16px 9px;border-radius:10px 0 0 10px;
  cursor:pointer;font-family:var(--font-sans);font-weight:700;font-size:.82rem;letter-spacing:.05em;
  z-index:80;box-shadow:-2px 2px 12px rgba(15,36,51,.18)}
.fb-tab:hover{background:var(--coral-600)}
.fb-overlay{position:fixed;inset:0;background:rgba(15,36,51,.45);opacity:0;pointer-events:none;transition:.2s;z-index:90}
.fb-overlay.open{opacity:1;pointer-events:auto}
.fb-modal{position:fixed;right:18px;bottom:18px;width:min(380px,calc(100vw - 36px));background:#fff;
  border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);padding:20px;z-index:95;
  transform:translateY(16px);opacity:0;pointer-events:none;transition:.2s;max-height:85vh;overflow:auto}
.fb-modal.open{transform:none;opacity:1;pointer-events:auto}
.fb-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink-400);line-height:1;padding:0 4px}
.fb-close:hover{color:var(--ink-900)}
.fb-modal .field{margin-bottom:12px}
@media(max-width:520px){.fb-tab{top:auto;bottom:90px;transform:none}}

/* numbers & stories panel ------------------------------------------ */
.ns-panel{background:var(--teal-50);border:1px solid var(--teal-100);border-radius:12px;padding:14px 16px;margin:6px 0 4px}
.ns-row{display:grid;grid-template-columns:128px 1fr;gap:12px;align-items:start;padding:7px 0;border-top:1px solid var(--teal-100)}
.ns-row:first-of-type{border-top:none}
.ns-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:4px 8px;border-radius:6px;text-align:center;white-space:nowrap}
.ns-num{background:#e8eef6;color:#2f5586}
.ns-val{background:#fff;color:var(--teal-800);border:1px solid var(--teal-300)}
.ns-story{background:#f3ecf8;color:#6b3fa0}
@media(max-width:560px){.ns-row{grid-template-columns:1fr;gap:4px}}

/* compare-measures modal ------------------------------------------- */
.cmp-overlay{position:fixed;inset:0;background:rgba(15,36,51,.5);opacity:0;pointer-events:none;transition:.2s;z-index:90}
.cmp-overlay.open{opacity:1;pointer-events:auto}
.cmp-modal{position:fixed;inset:5% 4%;background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);
  padding:22px;z-index:95;opacity:0;pointer-events:none;transform:translateY(12px);transition:.2s;
  overflow:auto;display:flex;flex-direction:column}
.cmp-modal.open{opacity:1;pointer-events:auto;transform:none}
.cmp-picker{display:flex;flex-wrap:wrap;margin-bottom:12px}
.cmp-cols{display:flex;gap:16px;overflow-x:auto;align-items:stretch;flex:1}
.cmp-col{min-width:262px;max-width:330px;flex:1 0 262px;border:1px solid var(--line);border-radius:12px;
  padding:14px;background:var(--sand-50)}
@media(max-width:640px){.cmp-modal{inset:2% 2%;padding:16px}.cmp-col{min-width:220px;flex-basis:220px}}

/* coverage chart --------------------------------------------------- */
.cov-row{display:grid;grid-template-columns:200px 1fr 54px;gap:12px;align-items:center;padding:6px 0}
.cov-bar{height:14px;border-radius:7px;background:var(--sand-100);overflow:hidden}
.cov-fill{height:100%;border-radius:7px;background:var(--teal-500)}
.cov-fill.none{background:var(--coral-400)}
.cov-fill.partial{background:var(--gold)}
@media(max-width:620px){.cov-row{grid-template-columns:130px 1fr 44px}}
