/* ──────────────────────────────────────────────────────────────────────────
   Conscious UX Studio — shared component primitives
   Three card primitives + a unified tag/chip/star/tooltip system.

   Available primitives:
     .c-card-film   — 16:9 or 9:16 thumb, hover-plays, title overlay, clickable
     .c-card-essay  — image + headline + lede + cta, click-through (editorial)
     .c-card-meta   — icon + label + small body, no thumb (lab tiles, contacts)

     .c-stars       — star rating (5-star, supports fractional fill)
     .c-tag         — pill tag, with .c-tag--genre / --mood / --ai / --coll
     .c-chip        — slimmer chip (active filter, byline, status badge)
     .c-tooltip     — instant CSS tooltip on data-tip="..." host

   Naming uses `c-` prefix so existing classes (.card, .tag, .featured-card, etc.)
   continue to work and these can be adopted gradually.
   ────────────────────────────────────────────────────────────────────────── */

/* ── Card: film ───────────────────────────────────────────────────────── */
.c-card-film{
  position:relative;
  display:block;
  aspect-ratio:16/9;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--bg2);
  border:1px solid var(--rule);
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  isolation:isolate;
  transition:border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.c-card-film[data-orientation="portrait"]{ aspect-ratio:9/16 }
.c-card-film:hover{
  border-color:var(--accent);
  transform:translateY(-2px);
  box-shadow:0 18px 40px -16px rgba(0,0,0,.55);
}
.c-card-film:focus-visible{
  outline:2px solid var(--accent2) !important;
  outline-offset:3px;
}
.c-card-film > img,
.c-card-film > video{
  width:100%;height:100%;object-fit:cover;display:block;
}
.c-card-film::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.72) 100%);
  pointer-events:none;
}
.c-card-film .c-card-title{
  position:absolute;bottom:14px;left:14px;right:14px;z-index:2;
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1rem,1.5vw,1.2rem);
  line-height:1.2;color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.7);
}
.c-card-film .c-card-meta-line{
  position:absolute;top:12px;left:12px;z-index:2;
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.78);
  text-shadow:0 1px 6px rgba(0,0,0,.7);
}

/* ── Card: essay ─────────────────────────────────────────────────────── */
.c-card-essay{
  display:flex;flex-direction:column;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:rgba(255,255,255,.02);
  border:1px solid var(--rule);
  text-decoration:none;color:inherit;
  transition:border-color .2s ease, background .2s ease, transform .2s ease;
}
[data-theme="light"] .c-card-essay{ background:var(--bg2); }
.c-card-essay:hover{
  border-color:var(--accent);
  background:rgba(136,179,158,.04);
  transform:translateY(-2px);
}
[data-theme="light"] .c-card-essay:hover{ background:var(--bg3); }
.c-card-essay:focus-visible{ outline:2px solid var(--accent2) !important; outline-offset:3px; }
.c-card-essay > img{ width:100%;aspect-ratio:16/9;object-fit:cover;display:block; }
.c-card-essay .c-card-body{
  padding:22px;display:flex;flex-direction:column;gap:10px;
}
.c-card-essay .c-eyebrow{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);font-weight:300;
}
.c-card-essay .c-card-headline{
  font-family:var(--serif);font-size:1.25rem;font-weight:400;
  line-height:1.2;letter-spacing:-.005em;color:var(--text);margin:0;
}
.c-card-essay .c-card-lede{
  font-family:var(--sans);font-weight:300;font-size:14px;line-height:1.6;
  color:var(--text2);margin:0;
}
.c-card-essay .c-card-cta{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent);margin-top:6px;
}

/* ── Card: meta (icon + label + body) ─────────────────────────────────── */
.c-card-meta{
  padding:24px;
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.02);
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .2s ease, background .2s ease;
}
[data-theme="light"] .c-card-meta{ background:var(--bg2); }
.c-card-meta:hover{ border-color:var(--accent); }
.c-card-meta .c-card-icon{
  color:var(--accent);width:24px;height:24px;
}
.c-card-meta .c-card-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);font-weight:400;
}
.c-card-meta .c-card-headline{
  font-family:var(--serif);font-size:1.05rem;font-weight:400;
  line-height:1.25;color:var(--text);margin:0;
}
.c-card-meta .c-card-body-text{
  font-family:var(--sans);font-weight:300;font-size:13px;line-height:1.6;
  color:var(--text2);margin:0;
}

/* ── Star rating — unified ─────────────────────────────────────────────
   Two modes:
     .c-stars[data-role="display"]  → read-only, fractional fill via --fill
     .c-stars[data-role="input"]    → interactive radiogroup, hover highlights
   Use --rating (0–5) or --fill (0–1) to control display fill. */
.c-stars{
  --rating:0;
  --fill:calc(var(--rating) / 5);
  display:inline-flex;align-items:center;gap:2px;
  font-size:14px;line-height:1;
  position:relative;
}
.c-stars[data-role="display"]{
  background:linear-gradient(90deg,
    var(--star) 0 calc(var(--fill) * 100%),
    var(--text3) calc(var(--fill) * 100%) 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  font-family:var(--mono);
  letter-spacing:1px;
}
.c-stars[data-role="display"]::before{
  content:'★★★★★';
}
/* Input mode — interactive radiogroup. Cumulative fill via .lit class.
   Hover preview is pure CSS via :has() — no JS hover handlers needed.
   Scale via font-size on the container: button is 1.3em, svg is 1em. */
.c-stars[data-role="input"]{
  font-size:16px;
  gap:4px;
}
.c-stars[data-role="input"] button{
  background:none;border:none;padding:0;cursor:pointer;
  color:var(--text3);
  width:1.3em;height:1.3em;
  display:inline-flex;align-items:center;justify-content:center;
  transition:color .15s, transform .1s;
}
.c-stars[data-role="input"] button svg{
  width:1em;height:1em;
  fill:none;stroke:currentColor;stroke-width:1.5;
  transition:fill .1s,stroke .1s;
}
.c-stars[data-role="input"] button.lit{ color:var(--star); }
.c-stars[data-role="input"] button.lit svg{ fill:var(--star);stroke:var(--star); }
.c-stars[data-role="input"] button:focus-visible{ outline:2px solid var(--star);outline-offset:2px; }

/* Hover preview: fill 1..K when hovering K, dim rest. */
.c-stars[data-role="input"]:has(button:hover) button{ color:var(--text3); }
.c-stars[data-role="input"]:has(button:hover) button svg{ fill:none;stroke:currentColor; }
.c-stars[data-role="input"] button:hover,
.c-stars[data-role="input"] button:has(~ button:hover){ color:var(--star);transform:scale(1.12); }
.c-stars[data-role="input"] button:hover svg,
.c-stars[data-role="input"] button:has(~ button:hover) svg{ fill:var(--star);stroke:var(--star); }

/* ── Tag / chip / pill ─────────────────────────────────────────────────
   .c-tag: rectangular tag chip (genre/mood/etc on a film card)
   .c-chip: rounded pill (active filter, status badge, byline label) */
.c-tag{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--sans);font-weight:400;
  font-size:10px;letter-spacing:.02em;
  padding:2px 7px;border-radius:3px;
  line-height:1.4;
  white-space:nowrap;
}
.c-tag--genre  { background:#1e2a3a; color:#6baed6; }
.c-tag--mood   { background:#2a1e3a; color:#b39ddb; }
.c-tag--ai     { background:#1e3a2a; color:#81c784; }
.c-tag--coll   { background:#3a2a1e; color:#ffb74d; }
[data-theme="light"] .c-tag--genre { background:#dde7f2; color:#2a4a6e; }
[data-theme="light"] .c-tag--mood  { background:#e6dfee; color:#4a3268; }
[data-theme="light"] .c-tag--ai    { background:#dceadf; color:#2d5a3a; }
[data-theme="light"] .c-tag--coll  { background:#efe2cf; color:#7a5320; }

.c-chip{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;font-weight:400;
  padding:3px 10px;border-radius:999px;
  border:1px solid var(--accent);
  color:var(--accent);
  background:rgba(136,179,158,.08);
}
[data-theme="light"] .c-chip{
  background:rgba(45,90,71,.08);
  color:var(--accent);
}
.c-chip button{
  background:none;border:none;padding:0;cursor:pointer;
  color:inherit;font:inherit;line-height:1;
}

/* ── Tooltip — body-portal, escapes any overflow:hidden ancestor ──────
   Usage: <button data-tip="Toggle theme">…</button>
   The pseudo-element approach gets clipped by `overflow:hidden` cards and
   sidebars, leaving partial fragments like "APSE SID". The actual tooltip
   element is created in document.body by the JS in _theme.html.
   Position hints: data-tip-pos="top|bottom|left|right" (default: bottom). */
.cs-tip{
  position:absolute;top:0;left:0;
  background:rgba(10,10,10,.92);color:#f0ede8;
  font-family:var(--sans);font-weight:400;font-size:11px;letter-spacing:.02em;
  padding:5px 9px;border-radius:3px;
  white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .12s ease;
  z-index:99999;
  will-change:transform,opacity;
}
.cs-tip.cs-tip--visible{ opacity:1; }
[data-theme="light"] .cs-tip{ color:#fff; }
@media (prefers-reduced-motion: reduce){
  .cs-tip{ transition:none; }
}

/* ── Focus ring for circular icon buttons ─────────────────────────────
   The global :focus-visible rule produces a slightly-rounded square offset,
   which sits awkwardly on perfectly-round buttons. This override gives them
   a matching circular ring. Apply via class .c-icon-btn or to known IDs. */
.c-icon-btn:focus-visible,
#theme-toggle:focus-visible,
.hero-ctrl:focus-visible,
.featured-mute:focus-visible,
.card-heart:focus-visible{
  outline:none !important;
  box-shadow:0 0 0 2px var(--accent), 0 0 0 4px rgba(136,179,158,.25) !important;
  border-radius:50% !important;
}

/* ── Card hover affordance — slightly louder than default ────────────
   Cards in the gallery were too subtle on hover. Add a soft accent bloom
   so "this is clickable" reads at a glance. */
.card:hover{
  border-color:var(--accent) !important;
}

/* ── Visually-hidden helper (used in addition to .sr-only) ─────────── */
.c-sr-only{
  position:absolute !important;
  width:1px !important;height:1px !important;
  padding:0 !important;margin:-1px !important;
  overflow:hidden !important;clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;border:0 !important;
}

/* ── Chrome primitives — extracted from per-template inline styles ─────
   Previously these blocks were duplicated near-verbatim across 8+ templates
   (welcome, about, study, contact, manifesto, blog, blog_post, book, voices,
   timeline, ailab). Defined here once; loaded after page inline styles so
   page-local overrides still win if needed. */

/* Skip link — keyboard-only "skip to content" affordance */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:8px 14px;z-index:200;font-size:13px;font-weight:600;border-radius:0 0 6px 0}
.skip-link:focus{left:0}

/* Top bar — fixed header common to all pages */
#topbar,
header#topbar,
nav#topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 100%);transition:background .3s,backdrop-filter .3s}
#topbar.scrolled,
header#topbar.scrolled,
nav#topbar.scrolled{background:rgba(10,10,10,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule)}
#logo,
header#topbar #logo,
nav#topbar .logo{font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:.22em;color:var(--text);text-transform:uppercase}
#topbar-nav{display:flex;gap:28px;align-items:center}
.nav-link{font-family:var(--sans);font-weight:400;color:rgba(240,237,232,.82);font-size:11px;letter-spacing:.12em;text-transform:uppercase;transition:color .2s;padding:4px 0;text-decoration:none;text-shadow:0 1px 6px rgba(0,0,0,.5)}
.nav-link:hover,.nav-link.active{color:rgba(240,237,232,1)}
.nav-link.active{border-bottom:1px solid var(--sage);padding-bottom:2px}

[data-theme="light"] .nav-link{text-shadow:none !important}
[data-theme="light"] #topbar-nav .nav-link,
[data-theme="light"] nav#topbar .nav-link{text-shadow:none !important}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-family:var(--sans);text-decoration:none;transition:background .2s,border-color .2s,color .2s,transform .15s}
.btn:focus-visible{outline:2px solid var(--sage);outline-offset:3px}
.btn-primary{background:transparent;border:1px solid rgba(240,237,232,.35);border-radius:2px;color:#f0ede8;padding:13px 26px;font-weight:400;font-size:10px;letter-spacing:.15em;text-transform:uppercase}
.btn-primary:hover{background:rgba(240,237,232,.07);border-color:rgba(240,237,232,.65)}
.btn-secondary{background:transparent;border:none;border-bottom:1px solid rgba(240,237,232,.2);border-radius:0;color:rgba(240,237,232,.55);padding:6px 0;font-weight:300;font-size:10px;letter-spacing:.12em;text-transform:uppercase}
.btn-secondary:hover{color:rgba(240,237,232,1);border-bottom-color:rgba(240,237,232,.6)}
.btn-arrow{margin-left:8px;display:inline-block}

/* Footer — three-column grid with brand / explore / connect */
footer{padding:56px clamp(24px,5vw,80px) 32px;border-top:1px solid var(--rule)}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;align-items:start}
.footer-brand{display:flex;flex-direction:column;gap:6px}
.footer-brand .logo-text{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--text)}
.footer-brand p{font-size:12px;color:var(--text3);max-width:420px;line-height:1.6}
.footer-h{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text3);margin-bottom:14px;font-weight:600}
.footer-list{display:flex;flex-direction:column;gap:9px}
.footer-list a{font-size:12px;color:var(--text2);transition:color .2s;display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.footer-list a:hover{color:var(--accent)}
@media(max-width:900px){.footer-inner{grid-template-columns:1fr 1fr;gap:32px 24px}.footer-brand{grid-column:1/-1}}
@media(max-width:640px){.footer-inner{grid-template-columns:1fr}}

/* ── Read Next ───────────────────────────────────────────────────────────
   End-of-page cross-link for long-form pages. Eyebrow + title + one-line
   hook + arrow link. Visual register matches the editorial pages' own
   eyebrow pattern so it lands as a natural closing beat rather than a
   marketing CTA. */
.read-next{
  margin:80px auto 96px;
  max-width:720px;
  padding:48px 0 0;
  border-top:1px solid var(--rule);
}
.read-next-eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--accent);
  display:flex;
  align-items:center;
  gap:14px;
  margin:0 0 24px;
}
.read-next-eyebrow::before{
  content:'';
  width:28px;
  height:1px;
  background:var(--accent);
  flex:0 0 28px;
  opacity:.85;
}
.read-next h2{
  font-family:var(--display);
  font-size:clamp(1.85rem,3.4vw,2.5rem);
  font-weight:400;
  line-height:1.12;
  letter-spacing:-.01em;
  text-transform:none;
  color:var(--text);
  margin:0 0 14px;
  display:block;
}
/* Defend against page-level h2::before pseudo-elements (manifesto adds
   a leading sage hairline to every h2 in <main>). */
.read-next h2::before{content:none;display:none}
.read-next-hook{
  font-family:var(--sans);
  font-size:17px;
  font-weight:300;
  line-height:1.55;
  color:var(--text2);
  max-width:540px;
  margin:0 0 28px;
}
.read-next-link{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:0 0 6px;
  border-bottom:1px solid var(--accent);
  transition:gap .2s ease, color .15s, border-color .15s;
}
.read-next-link:hover,
.read-next-link:focus-visible{
  gap:14px;
  color:var(--accent2);
  border-bottom-color:var(--accent2);
}
@media (max-width:720px){
  .read-next{margin:56px 22px 72px;padding:36px 0 0}
  .read-next h2{margin-bottom:12px}
  .read-next-hook{font-size:16px;margin-bottom:22px}
}
[data-theme="light"] .read-next-eyebrow,
[data-theme="light"] .read-next-link{color:var(--accent)}
[data-theme="light"] .read-next-eyebrow::before{background:var(--accent)}
[data-theme="light"] .read-next-link{border-bottom-color:var(--accent)}
[data-theme="light"] .read-next-link:hover,
[data-theme="light"] .read-next-link:focus-visible{
  color:var(--accent2);
  border-bottom-color:var(--accent2);
}
