/* ══════════════════════════════════════════════════════════════
   INRAE Transfert · EU Projects — Stylesheet
   ══════════════════════════════════════════════════════════════ */

:root {
  --it:         #1a4f8a;
  --it-mid:     #2563ab;
  --it-light:   #4a90d9;
  --it-pale:    #e8f0fb;
  --inrae:       #00847f;
  --inrae-mid:   #009a94;
  --inrae-light: #4dbdb8;
  --inrae-pale:  #e0f2f1;
  --both:        #275562;
  --both-mid:    #3a6e7e;
  --both-pale:   #e8eef0;
  --ink:        #1a1d24;
  --ink-mid:    #3a4050;
  --ink-light:  #6b7280;
  --ink-xlight: #9ca3af;
  --paper:      #f8f9fc;
  --white:      #ffffff;
  --rule:       #e2e8f0;
  --gold:       #92600a;
  --gold-pale:  #fdf3e3;
  --red:        #991b1b;
  --red-pale:   #fee2e2;
  --purple:     #6d28d9;
  --purple-pale:#ede9fe;
  --green:      #166534;
  --green-pale: #dcfce7;
  --r: 6px;
  --shadow:    0 1px 6px rgba(0,0,0,.07);
  --shadow-lg: 0 6px 24px rgba(0,0,0,.12);
  --sidebar-w: 240px;
  --header-h:  96px;
}

/* Active scope override — INRAE mode rebinds the IT vars to INRAE values */
html.mode-INRAE {
  --it:       var(--inrae);
  --it-mid:   var(--inrae-mid);
  --it-light: var(--inrae-light);
  --it-pale:  var(--inrae-pale);
}
html.mode-BOTH,
html.mode-ALL {
  --it:       var(--both);
  --it-mid:   var(--both-mid);
  --it-light: var(--both-mid);
  --it-pale:  var(--both-pale);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Lato',sans-serif;font-size:14px;background:var(--paper);color:var(--ink);line-height:1.5}
a{color:var(--it-mid);text-decoration:none}
button{font-family:'Lato',sans-serif;cursor:pointer}

/* ── HEADER ── */
.hdr{background:var(--it);color:#fff;position:sticky;top:0;z-index:200;box-shadow:0 2px 14px rgba(0,0,0,.25)}
.hdr-top{display:flex;align-items:center;gap:14px;padding:0 18px;min-height:50px}
.hdr-logo{font-family:'Spectral',serif;font-size:1.05rem;font-weight:600;white-space:nowrap;flex-shrink:0}
.hdr-logo em{font-style:italic;opacity:.6;font-weight:400;font-size:.95rem}
.hdr-search{flex:1;max-width:360px;display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:5px 13px}
.hdr-search input{background:none;border:none;outline:none;color:#fff;font-size:.83rem;width:100%;font-family:'Lato',sans-serif}
.hdr-search input::placeholder{color:rgba(255,255,255,.42)}
.hdr-kpis{margin-left:auto;display:flex;gap:16px}
.kpi{text-align:right}
.kpi-val{font-family:'Spectral',serif;font-size:1.3rem;line-height:1;display:block}
.kpi-lbl{font-size:.6rem;opacity:.6;text-transform:uppercase;letter-spacing:.07em}
.tab-bar{display:flex;gap:1px;padding:0 18px;background:var(--it);border-top:1px solid rgba(255,255,255,.1)}
.tab-btn{padding:7px 15px;border:none;background:transparent;color:rgba(255,255,255,.6);font-size:.78rem;font-weight:700;border-bottom:3px solid transparent;transition:all .15s;white-space:nowrap;letter-spacing:.02em}
.tab-btn:hover{color:#fff}
.tab-btn.on{color:#fff;border-bottom-color:#fff}
.tab-btn.tab-btn-discrete{font-family:'Fira Code',monospace;font-size:.62rem;font-weight:400;color:rgba(255,255,255,.45);text-transform:lowercase;letter-spacing:.04em;padding:0 10px;border-bottom:none;transition:color .15s}
.tab-btn.tab-btn-discrete:hover{color:rgba(255,255,255,.9);border-bottom:none}
.tab-btn.tab-btn-discrete.on{color:#fff;border-bottom:none}
.tab-btn.tab-btn-discrete + .tab-btn.tab-btn-discrete{border-left:1px solid rgba(255,255,255,.18)}

/* ── LAYOUT ── */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:calc(100vh - var(--header-h))}

/* ── SIDEBAR ── */
.sidebar{background:var(--white);border-right:1px solid var(--rule);position:sticky;top:var(--header-h);height:calc(100vh - var(--header-h));overflow-y:auto;padding:12px 11px}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:var(--rule);border-radius:2px}
.fb{margin-bottom:12px}
.ft{font-family:'Fira Code',monospace;font-size:.59rem;font-weight:500;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-light);margin-bottom:5px;display:block}
.fr{border:none;border-top:1px solid var(--rule);margin:11px 0}
.fsel{width:100%;padding:6px 24px 6px 8px;border:1.5px solid var(--rule);border-radius:var(--r);font-family:'Lato',sans-serif;font-size:.8rem;color:var(--ink);background:var(--paper) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7280'/%3E%3C/svg%3E") no-repeat right 8px center;outline:none;appearance:none}
.fsel:focus{border-color:var(--it-mid)}
.cl{display:flex;flex-direction:column;gap:2px}
.ci{display:flex;align-items:center;gap:6px;padding:4px 5px;border-radius:4px;font-size:.79rem;transition:background .1s}
.ci:hover{background:var(--it-pale)}
.ci input[type=checkbox]{accent-color:var(--it);width:12px;height:12px;flex-shrink:0;cursor:pointer}
.cc{margin-left:auto;font-family:'Fira Code',monospace;font-size:.59rem;color:var(--ink-xlight);background:var(--paper);border:1px solid var(--rule);border-radius:7px;padding:0 5px}
.btn-reset{width:100%;padding:6px;background:none;border:1.5px solid var(--rule);border-radius:var(--r);font-family:'Fira Code',monospace;font-size:.61rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-light);transition:all .15s}
.btn-reset:hover{border-color:var(--it);color:var(--it)}

/* ── MAIN ── */
.main{padding:14px 16px;min-width:0}
.tab-panel{display:none}
.tab-panel.on{display:block}
.rbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.rcount{font-family:'Fira Code',monospace;font-size:.71rem;color:var(--ink-light)}
.rcount strong{color:var(--it)}
.filter-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 8px 3px 9px;border-radius:12px;background:var(--it-pale);border:1px solid rgba(37,99,171,.25);font-size:.7rem;color:var(--it);font-family:'Lato',sans-serif;white-space:nowrap}
.filter-pill .pill-x{cursor:pointer;font-size:.75rem;opacity:.6;transition:opacity .1s;line-height:1;margin-left:1px}
.filter-pill .pill-x:hover{opacity:1}
.filter-pill.pill-domain{background:#e8f5ec;border-color:rgba(22,101,52,.2);color:#166534}
.filter-pill.pill-region{background:#fdf3e3;border-color:rgba(146,96,10,.2);color:#92600a}
.vbtns{display:flex;gap:3px}
.vbtn{padding:4px 9px;border:1.5px solid var(--rule);background:var(--white);border-radius:var(--r);font-size:.75rem;color:var(--ink-light);transition:all .15s}
.vbtn.on{background:var(--it);border-color:var(--it);color:#fff}

/* ── TAGS ── */
.tag{font-family:'Fira Code',monospace;font-size:.59rem;padding:2px 6px;border-radius:10px;border:1px solid;white-space:nowrap;line-height:1.7}
.tg-he        {color:#1e5631;border-color:#a8d8b9;background:#e8f5ec}
.tg-h2020     {color:#1a4f8a;border-color:#93c5fd;background:#e8f0fb}
.tg-fp7       {color:#5b2d8e;border-color:#c4b5fd;background:#f5f3ff}
.tg-SIGNED    {color:var(--green);border-color:#86efac;background:var(--green-pale)}
.tg-CLOSED    {color:#78350f;border-color:#fcd34d;background:#fef9c3}
.tg-TERMINATED{color:var(--red);border-color:#fca5a5;background:var(--red-pale)}
.tg-coordinator     {color:var(--gold);border-color:#fcd34d;background:var(--gold-pale)}
.tg-participant     {color:var(--it);border-color:#93c5fd;background:var(--it-pale)}
.tg-associatedPartner{color:var(--purple);border-color:#c4b5fd;background:var(--purple-pale)}
.tg-thirdParty      {color:var(--ink-light);border-color:var(--rule);background:var(--paper)}
.tg-scheme{color:var(--ink-mid);border-color:var(--rule);background:var(--paper)}
/* Entity badges (always blue for IT, always teal for INRAE) */
.tag.tag-entity{border-style:dashed}
.tag-it    {color:#1a4f8a;border-color:#93c5fd;background:#e8f0fb}
.tag-inrae {color:#00847f;border-color:#4dbdb8;background:#e0f2f1}
/* Card budget chips (3 slots: Total / IT / INRAE) */
.card-budgets{display:flex;gap:8px;font-family:'Fira Code',monospace;font-size:.65rem;font-weight:500;flex-wrap:wrap}
.cb{white-space:nowrap}
.cb-total{color:var(--ink-light)}
.cb-it{color:#1a4f8a}
.cb-inrae{color:#00847f}

/* ── CARDS ── */
#grid{display:grid;gap:8px;grid-template-columns:1fr}
#grid.cols2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);cursor:pointer;overflow:hidden;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.card-top{padding:10px 12px 8px;border-bottom:1px solid var(--rule);display:flex;gap:9px;align-items:flex-start}
.card-acro{font-family:'Fira Code',monospace;font-size:.66rem;font-weight:500;background:var(--it);color:#fff;padding:3px 7px;border-radius:3px;white-space:nowrap;flex-shrink:0;margin-top:1px}
.card-title{font-size:.85rem;font-weight:700;line-height:1.35}
.card-body{padding:7px 12px;flex:1}
.card-kw{font-size:.74rem;color:var(--ink-mid);font-style:italic;margin-bottom:6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-tags{display:flex;flex-wrap:wrap;gap:3px}
.card-foot{padding:5px 12px;border-top:1px solid var(--rule);background:var(--paper);display:flex;align-items:center;justify-content:space-between;gap:5px;flex-wrap:wrap}
.card-dates{font-family:'Fira Code',monospace;font-size:.61rem;color:var(--ink-light)}
.card-budget{font-family:'Fira Code',monospace;font-size:.65rem;color:var(--it);font-weight:500}
.card-flags{font-size:.8rem;letter-spacing:-.04em}
.card-link{font-family:'Fira Code',monospace;font-size:.59rem;color:var(--it-mid);border:1px solid var(--rule);padding:2px 6px;border-radius:3px}
.card-link:hover{background:var(--it-pale)}

/* ── CHART CONTAINERS ── */
.section-title{font-family:'Fira Code',monospace;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light);margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid var(--rule)}
.stat-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.stat-card{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:10px 14px;flex:1;min-width:120px}
.stat-val{font-family:'Spectral',serif;font-size:1.6rem;color:var(--it);line-height:1}
.stat-lbl{font-size:.65rem;color:var(--ink-light);margin-top:3px;text-transform:uppercase;letter-spacing:.04em}
.stat-sub{font-size:.72rem;color:var(--ink-mid);margin-top:2px}
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.chart-box{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:12px}
.chart-box.full{grid-column:span 2}
.chart-box.third{grid-column:span 1}
.chart-title{font-family:'Fira Code',monospace;font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-light);margin-bottom:8px}
.chart-box canvas{max-height:220px !important}
.chart-box canvas#chart-l2-top25,.chart-box canvas#chart-domains{max-height:none !important}
.chart-box.tall canvas{max-height:280px !important}
.chart-box.short canvas{max-height:160px !important}

/* ── DISCIPLINES TAB ── */
.disc-main{display:grid;grid-template-columns:1fr 200px;gap:12px;margin-bottom:0}
.acc-wrap{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);overflow:hidden}
.acc-all-row{display:flex;align-items:center;padding:8px 10px;border-bottom:2px solid var(--rule);cursor:pointer;background:var(--paper);transition:background .1s}
.acc-all-row:hover{background:var(--it-pale)}
.acc-all-label{font-size:.8rem;font-weight:700;color:var(--it);font-family:'Lato',sans-serif}
.acc-body{max-height:440px;overflow-y:auto}
.acc-body::-webkit-scrollbar{width:3px}
.acc-body::-webkit-scrollbar-thumb{background:var(--rule);border-radius:2px}
.acc-row{display:flex;align-items:center;transition:background .1s;border-bottom:1px solid var(--rule);min-height:32px}
.acc-row:hover{background:var(--it-pale)}
.acc-row.acc-sel{background:#e4f0e8}
.acc-btn{flex-shrink:0;padding:2px 6px;border-radius:4px;border:1px solid var(--rule);font-family:'Fira Code',monospace;font-size:.58rem;cursor:pointer;transition:all .15s;background:var(--paper);color:var(--ink-xlight);white-space:nowrap;margin:0 2px;user-select:none}
.acc-btn-open{border-color:var(--it-light);color:var(--it-light)}
.acc-btn-open:hover,.acc-btn-open.on{background:var(--it);color:#fff;border-color:var(--it)}
.acc-btn-sel{border-color:#6d28d9;color:#6d28d9;opacity:.7}
.acc-btn-sel:hover,.acc-btn-sel.on{background:#6d28d9;color:#fff;border-color:#6d28d9;opacity:1}
.acc-btn-spacer{flex-shrink:0;width:38px;margin:0 2px}
.acc-label{flex:1;padding:4px 6px;font-size:.78rem;line-height:1.3;color:var(--ink-mid)}
.acc-row.acc-sel .acc-label{font-weight:600;color:var(--green)}
.acc-badge{flex-shrink:0;margin-right:7px;font-family:'Fira Code',monospace;font-size:.57rem;background:var(--paper);border:1px solid var(--rule);border-radius:7px;padding:0 5px;color:var(--ink-xlight);white-space:nowrap}
.acc-children{display:none}
.acc-children.open{display:block}
.acc-row.acc-d1{padding-left:0px}
.acc-row.acc-d2{padding-left:14px}
.acc-row.acc-d3{padding-left:26px}
.acc-row.acc-d4{padding-left:38px}
.acc-row.acc-d5{padding-left:50px}

/* Selection panel */
.sel-wrap{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:11px;position:sticky;top:var(--header-h)}
.sel-title{font-family:'Fira Code',monospace;font-size:.59rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light);margin-bottom:9px;padding-bottom:5px;border-bottom:1px solid var(--rule)}
.switch-row{display:flex;gap:0;margin-bottom:10px;background:var(--paper);border:1.5px solid var(--rule);border-radius:20px;padding:3px}
.sw-btn{flex:1;padding:4px 6px;border:none;border-radius:16px;background:transparent;font-size:.71rem;font-weight:700;cursor:pointer;transition:all .15s;color:var(--ink-light);font-family:'Lato',sans-serif}
.sw-btn.on{background:var(--it);color:#fff}
.sel-list{display:flex;flex-direction:column;gap:5px;min-height:50px}
.sel-empty{font-size:.71rem;color:var(--ink-xlight);font-style:italic;text-align:center;padding:12px 0;line-height:1.5}
.sel-item{display:flex;align-items:flex-start;gap:5px;padding:6px 8px;border-radius:var(--r);border:1px solid}
.sel-item-body{flex:1;min-width:0}
.sel-item-name{font-size:.73rem;font-weight:600;line-height:1.3;word-break:break-word}
.sel-item-path{font-size:.61rem;color:var(--ink-xlight);margin-top:2px;line-height:1.3;word-break:break-word}
.sel-item-x{cursor:pointer;font-size:.82rem;opacity:.5;flex-shrink:0;margin-top:1px;transition:opacity .1s;line-height:1}
.sel-item-x:hover{opacity:1}
.sel-results{margin-top:10px;display:flex;flex-direction:column;gap:5px}
.sel-result-btn{display:flex;align-items:center;justify-content:space-between;padding:7px 9px;border-radius:var(--r);border:1.5px solid var(--rule);background:var(--paper);cursor:pointer;transition:all .15s;font-size:.74rem;color:var(--ink-mid);text-align:left;font-family:'Lato',sans-serif;width:100%}
.sel-result-btn:hover{border-color:var(--it);background:var(--it-pale);color:var(--it)}
.sel-result-btn .rn{font-family:'Fira Code',monospace;font-size:.82rem;font-weight:700;color:var(--it)}
.sel-result-btn .rarr{font-size:.68rem;opacity:.5}
.sel-result-btn:hover .rarr{opacity:1}
.sel-op-label{font-family:'Fira Code',monospace;font-size:.58rem;color:var(--ink-xlight);text-align:center;margin-top:3px}

/* ── PARTNERS ── */
.partner-search{display:flex;gap:7px;margin-bottom:8px;flex-wrap:wrap}
.partner-search input,.partner-search select{padding:5px 8px;border:1.5px solid var(--rule);border-radius:var(--r);font-size:.79rem;outline:none;font-family:'Lato',sans-serif}
.partner-search input:focus,.partner-search select:focus{border-color:var(--it-mid)}
.partner-search input{flex:1;min-width:140px}
.ptable{width:100%;border-collapse:collapse;font-size:.75rem}
.ptable th{text-align:left;padding:4px 7px;font-family:'Fira Code',monospace;font-size:.59rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-light);border-bottom:2px solid var(--rule);white-space:nowrap}
.ptable td{padding:4px 7px;border-bottom:1px solid var(--rule);vertical-align:top;color:var(--ink-mid)}
.ptable tr:last-child td{border-bottom:none}
.ptable tr:hover td{background:var(--paper)}
.pager{display:flex;gap:3px;margin-top:7px;align-items:center;font-size:.74rem;flex-wrap:wrap}
.pager button{padding:3px 7px;border:1px solid var(--rule);background:var(--white);border-radius:3px;font-size:.72rem}
.pager button:hover{background:var(--it-pale)}
.pager button.on{background:var(--it);color:#fff;border-color:var(--it)}

/* ── GEO ── */
.geo-grid{display:grid;gap:12px}
/* #chart-countries sizing handled by Chart.js */
#chart-region-time{max-height:220px !important}
.region-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.region-card{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:10px}
.region-name{font-weight:700;font-size:.82rem;margin-bottom:5px}
.rbar-wrap{background:var(--paper);border-radius:3px;height:5px;margin-bottom:3px}
.rbar-fill{background:var(--it-light);border-radius:3px;height:5px;transition:width .4s}
.rstat{font-family:'Fira Code',monospace;font-size:.62rem;color:var(--ink-light)}

/* ── GANTT ── */
.gantt-controls{display:flex;gap:7px;margin-bottom:9px;align-items:center;flex-wrap:wrap}
.gantt-controls select{padding:5px 22px 5px 7px;border:1.5px solid var(--rule);border-radius:var(--r);font-size:.78rem;outline:none;background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7280'/%3E%3C/svg%3E") no-repeat right 7px center;appearance:none}
.gantt-wrap{overflow-x:auto;background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:10px;max-height:70vh;overflow-y:auto}
.gantt-legend{display:flex;gap:14px;align-items:center;padding:2px 2px 8px;font-size:.75rem;color:var(--ink-mid);flex-wrap:wrap}
.gantt-legend .gl-closed{color:var(--ink-light)}
.gl-dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}
.gantt-head{display:flex;margin-bottom:5px;border-bottom:1px solid var(--rule);padding-bottom:5px;position:sticky;top:0;background:var(--white);z-index:1}
.g-label-col{width:180px;flex-shrink:0;font-family:'Fira Code',monospace;font-size:.57rem;color:var(--ink-light);text-transform:uppercase;letter-spacing:.06em}
.g-months{flex:1;display:flex}
.g-tick{flex:1;font-family:'Fira Code',monospace;font-size:.56rem;color:var(--ink-xlight);text-align:center;border-left:1px dotted var(--rule)}
.g-row{display:flex;align-items:center;margin-bottom:2px;min-height:20px}
.g-row:hover .g-bar{filter:brightness(.9)}
.g-name{width:180px;flex-shrink:0;font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:7px;cursor:pointer;color:var(--ink-mid)}
.g-name:hover{color:var(--it)}
.g-track{flex:1;position:relative;height:13px}
.g-bar{position:absolute;height:100%;border-radius:3px;cursor:pointer;transition:filter .15s;background:var(--it)}
.g-today{position:absolute;top:0;bottom:0;width:1.5px;background:var(--red);opacity:.45;pointer-events:none}

/* ── EMPTY ── */
.empty{text-align:center;padding:40px 20px;color:var(--ink-light);grid-column:1/-1}
.empty .big{font-family:'Spectral',serif;font-size:2.8rem;opacity:.13;display:block;margin-bottom:6px}

/* ── MODAL ── */
.overlay{display:none;position:fixed;inset:0;background:rgba(10,20,40,.48);z-index:300;align-items:flex-start;justify-content:center;padding:26px 14px;overflow-y:auto}
.overlay.open{display:flex}
.modal{background:var(--white);border-radius:8px;max-width:860px;width:100%;box-shadow:var(--shadow-lg);animation:fadeUp .2s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.mhd{padding:14px 18px 11px;border-bottom:1px solid var(--rule);display:flex;gap:11px;align-items:flex-start}
.macro{font-family:'Spectral',serif;font-style:italic;font-size:1.4rem;color:var(--it);flex-shrink:0;line-height:1.2}
.mtw{flex:1}
.mtitle{font-size:.93rem;font-weight:700;line-height:1.4;margin-bottom:5px}
.mtags{display:flex;flex-wrap:wrap;gap:3px}
.mclose{margin-left:auto;background:none;border:none;font-size:1.2rem;color:var(--ink-light);flex-shrink:0;padding:2px;transition:color .1s}
.mclose:hover{color:var(--ink)}
.mbody{padding:14px 18px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.msec{grid-column:span 1}
.msec.full{grid-column:span 2}
.msec-title{font-family:'Fira Code',monospace;font-size:.59rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-light);margin-bottom:6px;padding-bottom:3px;border-bottom:1px solid var(--rule)}
dl.kv{font-size:.79rem}
dl.kv dt{color:var(--ink-light);font-size:.69rem;margin-top:4px}
dl.kv dd{color:var(--ink)}
.mptable{width:100%;border-collapse:collapse;font-size:.73rem}
.mptable th{text-align:left;padding:4px 6px;font-family:'Fira Code',monospace;font-size:.58rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-light);border-bottom:1px solid var(--rule)}
.mptable td{padding:4px 6px;border-bottom:1px solid var(--rule);vertical-align:top;color:var(--ink-mid)}
.mptable tr:last-child td{border-bottom:none}
.mptable tr.is-it td{background:var(--it-pale);color:var(--it);font-weight:700}
.mptable tr:not(.is-it):hover td{background:var(--paper)}
.mfoot{padding:10px 18px;border-top:1px solid var(--rule);display:flex;justify-content:flex-end}
.btn-primary{display:inline-block;padding:7px 15px;background:var(--it);color:#fff;border-radius:var(--r);font-size:.8rem;font-weight:700;transition:background .15s}
.btn-primary:hover{background:var(--it-mid)}

/* ── ABOUT PAGE (in-flow tab content, no longer modal) ── */
.about-page{background:var(--white);border:1px solid var(--rule);border-radius:8px;width:100%;margin:8px 0 32px;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.about-hdr{padding:18px 24px 14px;border-bottom:2px solid var(--it);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:var(--white);border-radius:8px 8px 0 0}
.about-hdr-title{font-family:'Spectral',serif;font-size:1.15rem;font-weight:600;color:var(--it);line-height:1.2}
.about-hdr-sub{font-family:'Fira Code',monospace;font-size:.64rem;color:var(--ink-light);margin-top:4px}
.about-body{padding:24px 26px;display:flex;flex-direction:column;gap:28px}
.about-sec-title{font-family:'Fira Code',monospace;font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-light);padding-bottom:6px;border-bottom:1px solid var(--rule);margin-bottom:14px}
.about-text{font-size:.84rem;line-height:1.7;color:var(--ink-mid);margin-bottom:8px}
.about-text:last-child{margin-bottom:0}
.about-list{list-style:none;display:flex;flex-direction:column;gap:7px;font-size:.83rem;color:var(--ink-mid)}
.about-list li{padding-left:14px;position:relative;line-height:1.5}
.about-list li::before{content:'·';position:absolute;left:0;color:var(--it);font-weight:700}
.about-list strong{color:var(--ink)}
.about-note{margin-top:12px;padding:9px 13px;background:var(--gold-pale);border-left:3px solid var(--gold);border-radius:0 var(--r) var(--r) 0;font-size:.78rem;color:var(--gold);line-height:1.55}
.about-tab-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.about-tab-card{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r);padding:12px 13px}
.about-tab-icon{font-size:1.25rem;margin-bottom:5px}
.about-tab-name{font-family:'Fira Code',monospace;font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--it);margin-bottom:5px;font-weight:500}
.about-tab-tip{font-size:.77rem;line-height:1.55;color:var(--ink-mid)}
.about-dl{font-size:.83rem}
.about-dl dt{font-weight:700;color:var(--ink);margin-top:14px;margin-bottom:3px}
.about-dl dt:first-child{margin-top:0}
.about-dl dd{color:var(--ink-mid);line-height:1.65;padding-left:12px;border-left:2px solid var(--rule);margin-left:0}
.about-dl dd code{font-family:'Fira Code',monospace;font-size:.78rem;background:var(--paper);border:1px solid var(--rule);border-radius:3px;padding:0 4px;color:var(--it)}
.about-footer{padding:12px 24px;border-top:1px solid var(--rule);font-family:'Fira Code',monospace;font-size:.64rem;color:var(--ink-light);display:flex;align-items:center;gap:7px;flex-wrap:wrap;border-radius:0 0 8px 8px}
.about-footer a{color:var(--it-mid)}

/* ── STATS TAB ── */
.av-bandeau{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:14px 18px;margin-bottom:16px}
.av-title{font-family:'Spectral',serif;font-size:1.05rem;font-weight:600;color:var(--ink);margin:0 0 8px;letter-spacing:.01em}
.av-intro{font-size:.86rem;line-height:1.65;color:var(--ink-mid);margin:0}
.av-intro strong{color:var(--ink);font-weight:600}
.av-intro-meta{display:block;margin-top:6px;font-family:'Fira Code',monospace;font-size:.66rem;color:var(--ink-xlight)}
.av-section{margin-bottom:18px}
.av-section-title{font-family:'Spectral',serif;font-size:.95rem;font-weight:600;color:var(--ink);margin:0 0 9px;padding-bottom:5px;border-bottom:1px solid var(--rule)}
.av-section-meta{font-family:'Fira Code',monospace;font-size:.65rem;color:var(--ink-xlight);font-weight:400;letter-spacing:.04em}
.av-note{font-size:.72rem;color:var(--ink-light);margin-top:7px;line-height:1.55}
.av-note code{font-family:'Fira Code',monospace;font-size:.86em;background:var(--paper);border:1px solid var(--rule);border-radius:3px;padding:0 4px}
.av-note-callout{background:#f4f7fb;border-left:3px solid #1a4f8a;color:var(--ink-mid);padding:7px 11px;font-size:.76rem;border-radius:0 var(--r) var(--r) 0;margin:0 0 10px}
.av-note-callout strong{color:var(--ink);font-weight:600}
.av-table{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--rule);border-radius:var(--r);overflow:hidden;font-size:.78rem}
.av-table thead th{background:var(--paper);font-family:'Fira Code',monospace;font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-light);padding:6px 9px;text-align:left;border-bottom:1.5px solid var(--rule)}
.av-table tbody tr:nth-child(even) td{background:#fbfaf6}
.av-table tbody tr:hover td{background:var(--it-pale)}
.av-table td{padding:6px 9px;border-bottom:1px solid var(--rule);vertical-align:middle}
.av-table tr:last-child td{border-bottom:none}
.av-lbl{color:var(--ink-mid)}
.av-num{font-family:'Fira Code',monospace;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;color:var(--ink)}
.av-coverage-table thead th:nth-child(n+2),
.av-coverage-table tbody td:nth-child(n+2){text-align:right}
.av-coverage-table thead th:last-child,
.av-coverage-table tbody td:last-child{text-align:left;min-width:180px}
.av-progress{position:relative;display:inline-block;width:160px;height:18px;background:#eef2f7;border:1px solid #d8dde6;border-radius:3px;overflow:hidden;vertical-align:middle}
.av-progress-bar{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,rgba(26,79,138,0.78),rgba(37,99,171,0.78));transition:width .3s}
.av-progress-text{position:relative;display:flex;align-items:center;justify-content:center;height:100%;font-family:'Fira Code',monospace;font-size:.7rem;color:#0c243d;font-weight:600;letter-spacing:.02em}
.av-sig-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle;background:#9ca3af}
.av-sig-strong{color:#15803d;font-weight:600}
.av-sig-mid{color:#a16207;font-weight:600}
.av-sig-no{color:var(--ink-light)}
.av-boxplots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.av-bp-cell{background:var(--white);border:1px solid var(--rule);border-radius:var(--r);padding:6px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.av-boxplot{width:100%;max-width:240px;height:auto;display:block}
.av-bp-title{font-family:'Spectral',serif;font-size:11px;fill:var(--ink);font-weight:600}
.av-bp-grid{stroke:#e2e8f0;stroke-width:.7;stroke-dasharray:2 2}
.av-bp-tick{font-family:'Fira Code',monospace;font-size:8.5px;fill:var(--ink-light)}
.av-bp-xlabel{font-family:'Fira Code',monospace;font-size:9.5px;font-weight:500}
.av-bp-n{font-family:'Fira Code',monospace;font-size:8.5px;fill:var(--ink-light)}
.av-bp-unit{font-family:'Fira Code',monospace;font-size:8px;fill:var(--ink-xlight);text-transform:uppercase;letter-spacing:.06em}
.av-bp-sig{font-family:'Fira Code',monospace;font-size:.66rem;color:var(--ink-light);letter-spacing:.02em}

/* ── RESPONSIVE ── */
@media(max-width:800px){
  .disc-main{grid-template-columns:1fr}
  .sel-wrap{position:static}
  .app{grid-template-columns:1fr}
  .sidebar{position:static;height:auto}
  .mbody,.chart-grid,.disc-grid{grid-template-columns:1fr}
  .chart-box.full,.disc-grid .full,.msec.full{grid-column:span 1}
  #grid.cols2,.region-grid{grid-template-columns:1fr}
  .about-tab-grid{grid-template-columns:repeat(2,1fr)}
  .about-body{padding:16px}
  .av-boxplots{grid-template-columns:1fr}
}
