/* zine.css — design system ported verbatim from the approved mockup
   (.superpowers/brainstorm/81628-1780339951/content/zine-real-data.html)
   + prefers-reduced-motion reset per spec */

:root{--paper:#f4f1ea;--ink:#111210;--accent:#ff3b1d;--remote:#0a8f4f;--r2:#2563c9;--hybrid:#e8a200;--onsite:#1a1a1a;--muted:#6b665b;--line:#dcd7c9}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--paper);color:var(--ink);font-family:'Space Grotesk',system-ui,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}
.display{font-family:'Archivo Black',sans-serif;letter-spacing:-.03em;line-height:.9}
.wrap{max-width:880px;margin:0 auto;padding:0 28px}
.kicker{font-family:'Archivo';font-weight:800;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.tag{display:inline-block;font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:var(--paper);padding:4px 9px}
section{padding:58px 0;border-bottom:3px solid var(--ink)}
h2.head{font-size:clamp(28px,5vw,48px);margin:8px 0 12px;font-family:'Archivo Black';letter-spacing:-.02em;line-height:.98}
p.lede{font-size:18px;max-width:60ch;font-weight:500}
.pull{font-family:'Archivo';font-weight:800;font-size:clamp(18px,2.6vw,24px);line-height:1.25;border-left:6px solid var(--accent);padding-left:18px;margin:22px 0}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;border-bottom:3px solid var(--ink);position:sticky;top:0;background:var(--paper);z-index:5}
.topbar .brand{font-family:'Archivo Black';font-size:15px}
.topbar a{color:var(--ink);text-decoration:none;font-weight:600;font-size:13px;border-bottom:2px solid var(--accent)}
.hero{padding:64px 0 54px}
.hero h1{font-size:clamp(46px,9vw,104px)}
.hero .sub{font-size:19px;max-width:54ch;margin-top:20px;font-weight:500}
.stat-row{display:flex;flex-wrap:wrap;gap:26px;margin-top:30px;font-family:'Archivo'}
.stat-row b{font-family:'Archivo Black';font-size:21px;display:block}.stat-row span{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.segbar{display:flex;height:52px;border:3px solid var(--ink);overflow:hidden}
.segbar>div{display:flex;align-items:center;justify-content:center;font-family:'Archivo Black';font-size:13px}
.seglab{display:flex;justify-content:space-between;font-family:'Archivo';font-weight:700;font-size:12px;margin-top:8px;flex-wrap:wrap;gap:6px}
.hbar{display:grid;grid-template-columns:120px 1fr 92px;align-items:center;gap:12px;margin:8px 0;font-weight:600}
.hbar .track{height:24px;background:#e7e2d6}.hbar .fill{height:24px;background:var(--ink)}.hbar.hot .fill{background:var(--accent)}.hbar b{font-family:'Archivo Black';text-align:right}
svg{width:100%;height:auto}
.honest{background:#ece7da;border:3px dashed var(--ink)}
.note{font-size:13px;color:var(--muted)}
.foot{padding:50px 0 80px;text-align:center}
.browsebtn{display:inline-block;font-family:'Archivo Black';font-size:18px;color:var(--paper);background:var(--ink);padding:15px 28px;text-decoration:none;border:3px solid var(--ink)}

/* Geography two-column layout */
.geo-layout{display:flex;gap:24px;flex-wrap:wrap}
.geo-countries{flex:1;min-width:260px}
.remote-callout{flex:1;min-width:240px;border:3px solid var(--remote);padding:18px;align-self:flex-start}

/* Honest-box faint sector bars — muted styling */
.honest-bars-inner .hbar .fill{background:var(--muted);opacity:.5}
.honest-bars-inner .hbar b{color:var(--muted)}

/* ── Task 7: Motion — section entrance animation ─────────────────────────────
   SAFE RECIPE: initial hidden state is ONLY applied via JS-added .js-motion
   class. Without JS, or under reduced-motion, all content is fully visible. */
@keyframes rise-in{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}

/* JS sets .js-motion on <html> only when motion is not reduced */
.js-motion section,
.js-motion .hero,
.js-motion .foot{
  opacity:0;
  transform:translateY(24px);
}
.js-motion .in{
  animation:rise-in .6s ease forwards;
}

/* ── Task 7: Responsive — 375px pass ───────────────────────────────────────── */
@media (max-width:640px){
  /* Shrink hbar label/value columns to fit small screens */
  .hbar{grid-template-columns:88px 1fr 64px;gap:8px;font-size:13px}
  /* Stack geo layout */
  .geo-layout{flex-direction:column}
  .geo-countries,.remote-callout{min-width:0;width:100%}
  /* Hero headline clamp already set via clamp(); tighten sub text */
  .hero .sub{font-size:16px}
  /* Segmented bar labels wrap gracefully */
  .seglab{gap:4px}
  /* Honest box padding */
  .honest .wrap{padding:0 16px}
}

/* prefers-reduced-motion reset — per spec */
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* ── Explorer: extra tokens ───────────────────────────────────────────────── */
:root{
  --card:#fbfaf5;
  --accent2:#ffd000;
}

/* ── Explorer: screen-reader utility ──────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── Explorer: pagehead ────────────────────────────────────────────────────── */
.pagehead{padding:36px 28px 22px;border-bottom:3px solid var(--ink)}
.pagehead h1{font-size:clamp(34px,5vw,58px);margin:6px 0}
.pagehead .sub{font-weight:500;color:var(--muted);font-size:16px}

/* ── Explorer: toolbar ─────────────────────────────────────────────────────── */
.toolbar{display:flex;gap:10px;align-items:center;padding:18px 28px;flex-wrap:wrap;border-bottom:2px solid var(--line)}
.toggle{display:flex;border:3px solid var(--ink)}
.toggle button{font-family:'Archivo',sans-serif;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.06em;padding:9px 16px;background:var(--paper);border:none;cursor:pointer}
.toggle button.on{background:var(--ink);color:var(--paper)}
.toggle button:disabled{opacity:.4;cursor:not-allowed}
.search{flex:1;min-width:240px;display:flex;border:3px solid var(--ink);background:#fff}
.search input{flex:1;border:none;outline:none;padding:11px 14px;font-family:'Space Grotesk';font-size:15px;background:transparent}
.search .go{font-family:'Archivo Black';background:var(--accent);color:#fff;padding:0 18px;display:flex;align-items:center}

/* ── Explorer: layout grid ─────────────────────────────────────────────────── */
.layout{display:grid;grid-template-columns:230px 1fr;gap:0}
/* (mobile facet behavior is defined in the off-canvas-sheet block below) */

/* ── Explorer: facets sidebar ──────────────────────────────────────────────── */
.facets{border-right:3px solid var(--ink);padding:22px 20px}
.facet{margin-bottom:22px}
.facet h4{font-family:'Archivo',sans-serif;font-weight:800;font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;border-bottom:2px solid var(--ink);padding-bottom:5px}
.facet label{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;padding:3px 0;cursor:pointer}
.facet .cnt{font-family:'Archivo';font-weight:700;color:var(--muted);font-size:12px}
.facet label.sel{font-weight:700;color:var(--accent)}
.chip{display:inline-block;width:11px;height:11px;margin-right:7px;vertical-align:middle}

/* ── Explorer: results section ─────────────────────────────────────────────── */
.results{padding:0}
.resbar{display:flex;justify-content:space-between;align-items:center;padding:14px 28px;border-bottom:2px solid var(--line);font-weight:600}
.resbar .activef{display:flex;gap:7px;flex-wrap:wrap}
.pill{font-family:'Archivo';font-weight:700;font-size:12px;background:var(--ink);color:var(--paper);padding:3px 10px;border-radius:20px}
.pill .x{opacity:.6;margin-left:6px}

/* ── Explorer: table ───────────────────────────────────────────────────────── */
table{width:100%;border-collapse:collapse;font-size:14px}
thead th{font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.08em;text-transform:uppercase;text-align:left;padding:12px 28px;border-bottom:3px solid var(--ink);color:var(--muted)}
tbody td{padding:14px 28px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:hover{background:var(--card)}
.co{font-family:'Archivo';font-weight:800}
.ti{font-weight:600}
.meta{color:var(--muted);font-size:12.5px}
.rc{display:inline-flex;align-items:center;gap:6px;font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border:2px solid var(--ink)}
.rc .dot{width:9px;height:9px}
.apply{font-family:'Archivo Black';font-size:12px;border-bottom:3px solid var(--accent);text-decoration:none;white-space:nowrap}

/* ── Explorer: pagination ──────────────────────────────────────────────────── */
.pager{display:flex;justify-content:center;align-items:center;gap:8px;padding:30px;flex-wrap:wrap}
.pager button{font-family:'Archivo';font-weight:800;border:2px solid var(--ink);background:var(--paper);padding:8px 13px;cursor:pointer}
.pager button.on{background:var(--ink);color:var(--paper)}
.pager button:disabled{opacity:.35;cursor:not-allowed}
.pager button:not(:disabled):not(.on):hover{background:var(--card)}
.pager .ellipsis{font-family:'Archivo';font-weight:800;color:var(--muted);padding:0 2px}

/* ── Explorer: facet items (hidden checkbox + styled label) ─────────────────── */
.facet-item{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:13.5px;padding:3px 0;cursor:pointer}
.facet-item .facet-label{display:flex;align-items:center;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.facet-item.sel{font-weight:700;color:var(--accent)}
.facet-item:hover .facet-label{text-decoration:underline}
.facet-item input:focus-visible + .facet-label{outline:2px solid var(--accent);outline-offset:2px}
.show-more{margin-top:6px;font-family:'Archivo';font-weight:700;font-size:12px;background:none;border:none;color:var(--accent);cursor:pointer;padding:2px 0;border-bottom:2px solid var(--accent)}

/* ── Explorer: filter toggle (mobile only) ─────────────────────────────────── */
.filter-toggle{display:none;font-family:'Archivo',sans-serif;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.06em;padding:9px 16px;background:var(--paper);border:3px solid var(--ink);cursor:pointer}
.filter-toggle::before{content:"\2630  "}

/* ── Explorer: sortable headers ────────────────────────────────────────────── */
thead th[data-sort]{cursor:pointer;user-select:none}
thead th[data-sort]:hover{color:var(--ink)}
thead th[data-sort]:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}
thead th[aria-sort]{color:var(--ink)}
.sort-ind{font-size:12px}

/* ── Explorer: result-bar controls ─────────────────────────────────────────── */
.pill .x{opacity:.6;margin-left:6px;background:none;border:none;color:inherit;cursor:pointer;font-size:12px;padding:0;font-family:inherit;line-height:1}
.pill .x:hover{opacity:1}
.clear-all{font-family:'Archivo';font-weight:700;font-size:12px;background:none;border:2px solid var(--ink);color:var(--ink);padding:3px 10px;border-radius:20px;cursor:pointer}
.clear-all:hover{background:var(--ink);color:var(--paper)}

/* ── Explorer: empty state ─────────────────────────────────────────────────── */
td.empty{padding:48px 28px;text-align:center;color:var(--muted);font-weight:600}
.linkbtn{font-family:'Archivo Black';font-size:13px;background:none;border:none;color:var(--accent);cursor:pointer;border-bottom:3px solid var(--accent);padding:0}

/* ── Explorer: horizontal table scroll ─────────────────────────────────────── */
.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ── Explorer: mobile filter sheet (<780px) ────────────────────────────────── */
.facets-overlay{display:none}
@media(max-width:780px){
  .filter-toggle{display:inline-block}
  .layout{grid-template-columns:1fr}
  /* Facets become an off-canvas sheet, NOT display:none */
  .facets{display:block;position:fixed;top:0;left:0;bottom:0;width:min(300px,85vw);
    transform:translateX(-100%);transition:transform .25s ease;background:var(--paper);
    z-index:20;overflow-y:auto;border-right:3px solid var(--ink);box-shadow:4px 0 0 rgba(17,18,16,.08)}
  .facets.open{transform:translateX(0)}
  .facets-overlay{display:block;position:fixed;inset:0;background:rgba(17,18,16,.4);z-index:15;
    opacity:0;pointer-events:none;transition:opacity .25s ease}
  .facets-overlay.show{opacity:1;pointer-events:auto}
  thead th,tbody td{padding-left:16px;padding-right:16px}
}
@media(prefers-reduced-motion:reduce){
  .facets{transition:none}
  .facets-overlay{transition:none}
}
