/* ============================================================
   web.css — static site component layer (no framework)
   Reproduces the design-system primitives (header, footer,
   masthead, eyebrow, statement, prose, buttons, tags, timeline,
   cards…) as plain CSS classes built on the existing tokens.
   Load AFTER styles.css (which provides the tokens).

   Progressive-enhancement contract:
   - All content is fully visible with NO JavaScript.
   - Reveal animations only engage when <html class="js"> is set
     (enhance.js adds it). With JS off, nothing is ever hidden.
   ============================================================ */

/* ---- Layout shell ---- */
.wrap { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(3.5rem, 7vw, 6rem); }
.section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }
.band-dark { background: var(--ink-900); color: var(--text-inverse); }
.band-light { background: var(--surface-canvas); color: var(--text-primary); }
.hairline-top { border-top: 1px solid var(--hairline); }

/* ============================================================
   Progressive-enhancement reveals
   Visible by default; only hidden once JS marks <html class="js">.
   ============================================================ */
.reveal { opacity: 1; transform: none; }
html.js .reveal {
  opacity: 0; transform: translateY(16px);
  transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
  will-change: opacity, transform;
}
html.js .reveal.is-in { opacity: 1; transform: none; }
html.js .reveal:nth-child(2) { transition-delay: 0.06s; }
html.js .reveal:nth-child(3) { transition-delay: 0.12s; }
html.js .reveal:nth-child(4) { transition-delay: 0.18s; }
@media (prefers-reduced-motion: reduce) {
  html.js .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ============================================================
   Header — dark sticky bar with logo lockup + nav + CTA
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  background: var(--ink-900); color: var(--text-inverse);
  border-bottom: 1px solid var(--hairline-on-dark);
}
.site-header__inner {
  max-width: var(--container); margin: 0 auto;
  padding: 1.1rem var(--gutter);
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
}

/* AA logo lockup */
.aa-lockup { display: inline-flex; align-items: center; gap: 0.85rem; text-decoration: none; }
.aa-lockup__mark { height: 36px; display: block; flex: none; }
.aa-lockup-meta { display: inline-flex; align-items: stretch; gap: 0.85rem; }
/* name stacked above role (not side-by-side) — matches the original lockup */
.aa-lockup-meta > span:last-child { display: flex; flex-direction: column; justify-content: center; line-height: 1.05; }
.aa-lockup__rule { width: 1px; background: rgba(255,255,255,0.18); }
.aa-lockup__name {
  font-family: var(--font-grotesque); font-weight: 600; font-size: 1.125rem;
  letter-spacing: -0.02em; color: var(--text-inverse); white-space: nowrap; line-height: 1.05;
}
.aa-lockup__role {
  margin-top: 0.32rem; font-family: var(--font-grotesque); font-size: 0.5rem; font-weight: 600;
  letter-spacing: 0.28em; text-transform: uppercase; color: rgba(243,242,238,0.55); white-space: nowrap;
}

/* Nav */
.site-nav { display: flex; align-items: center; gap: 1.9rem; flex-wrap: wrap; }
.site-nav a {
  position: relative; font-family: var(--font-grotesque); font-size: 0.9375rem;
  color: var(--text-inverse-muted); text-decoration: none; padding-block: 0.25rem;
  transition: color var(--dur-fast) var(--ease-out);
}
.site-nav a:hover { color: var(--text-inverse); }
.site-nav a[aria-current="page"] { color: var(--text-inverse); font-weight: 500; }
.site-nav a::after {
  content: ""; position: absolute; left: 0; bottom: -4px; height: 1px; width: 0;
  background: var(--gold-metallic); transition: width var(--dur-base) var(--ease-out);
}
.site-nav a[aria-current="page"]::after, .site-nav a:hover::after { width: 100%; }
/* right-hand group: nav links + CTA as siblings, so the CTA never
   inherits .site-nav link styling (underline / muted colour) */
.site-header__right { display: flex; align-items: center; gap: 1.9rem; flex-wrap: wrap; }
/* exact header CTA from the bundle: compact, 0.875rem, weight 500 */
.site-header__cta { white-space: nowrap; padding: 0.6rem 1.15rem; font-size: 0.875rem; font-weight: 500; }
.site-nav .btn::after { content: none; }

/* mobile: nav + CTA wrap full-width under the lockup; usable with no JS */
@media (max-width: 720px) {
  .site-header__inner { flex-wrap: wrap; gap: 0.75rem; }
  .site-header__right { width: 100%; gap: 0.9rem 1.4rem; }
  .site-nav { gap: 1.1rem 1.4rem; }
}
@media (max-width: 560px) { .aa-lockup-meta { display: none !important; } }

/* ============================================================
   Masthead — dark editorial opening band
   ============================================================ */
.masthead { position: relative; overflow: hidden; background: var(--ink-900); color: var(--text-inverse); }
.masthead__bg {
  position: absolute; inset: 0; opacity: 0.6; pointer-events: none;
  background-size: cover; background-position: top right; background-repeat: no-repeat;
  filter: invert(1); /* dark dispersion PNG → light dust on the dark band */
  -webkit-mask-image: radial-gradient(125% 125% at 88% 0%, #000 22%, transparent 68%);
  mask-image: radial-gradient(125% 125% at 88% 0%, #000 22%, transparent 68%);
}
.masthead__inner { position: relative; max-width: var(--container); margin: 0 auto; padding: clamp(3.5rem,8vw,6.5rem) var(--gutter) clamp(3rem,6vw,5rem); }
.masthead__title { margin: 1.5rem 0 0; font-family: var(--font-grotesque); font-size: var(--text-6xl); font-weight: 600; line-height: 1.0; letter-spacing: -0.03em; max-width: 16ch; color: var(--text-inverse); }
.masthead__lead { margin-top: 1.6rem; max-width: 54ch; font-size: var(--text-lg); line-height: 1.55; color: var(--text-inverse-muted); }

/* ============================================================
   Typographic primitives
   ============================================================ */
/* exact Eyebrow: gold index (optional) + always-present gold dash + label */
.eyebrow { display: inline-flex; align-items: center; gap: 0.85rem; font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-secondary); }
.eyebrow::before { content: ""; flex: none; width: 1.75rem; height: 1px; background: var(--gold-metallic); opacity: 0.9; }
.eyebrow--on-dark { color: var(--text-inverse-muted); }
.eyebrow__index { order: -1; color: var(--gold); font-variant-numeric: tabular-nums; } /* sits before the dash */
.eyebrow--on-dark .eyebrow__index { color: var(--gold-soft); }

/* exact sizes/weight from the bundle's Statement primitive */
.statement { font-family: var(--font-serif); font-weight: 500; line-height: 1.08; letter-spacing: -0.015em; color: var(--text-primary); text-wrap: balance; }
.statement--on-dark { color: var(--text-inverse); }
.statement em, .statement i { font-style: italic; }
.statement.s-sm { font-size: clamp(1.5rem, 1.3vw + 1.15rem, 2rem); }
.statement.s-md { font-size: clamp(1.875rem, 2.2vw + 1.3rem, 2.75rem); }
.statement.s-lg { font-size: clamp(2.25rem, 3.6vw + 1.4rem, 3.75rem); }
.statement.s-xl { font-size: clamp(2.75rem, 5.2vw + 1.4rem, 5rem); }
.statement.s-2xl { font-size: clamp(3.25rem, 7vw + 1.5rem, 6rem); }

.prose { max-width: 62ch; font-family: var(--font-grotesque); font-size: var(--text-lg); line-height: 1.62; color: var(--text-secondary); }
.prose p { margin: 0 0 1.15em; }
.prose p:last-child { margin-bottom: 0; }
.prose strong { color: var(--text-primary); font-weight: 600; }

.pullquote { margin: clamp(2.25rem,5vw,3.5rem) 0; max-width: min(680px,100%); }
.pullquote .divider { margin-bottom: 1.5rem; }

/* Eyebrow→title rhythm helper */
.lede { margin-top: 1.4rem; }

/* ============================================================
   Buttons
   ============================================================ */
/* exact Button: md default, gold = border-only, hover bg, arrow shifts */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6em;
  font-family: var(--font-grotesque); font-weight: 500; letter-spacing: -0.005em; line-height: 1;
  font-size: 0.9375rem; padding: 0.72rem 1.35rem;
  border: 1px solid transparent; border-radius: 0; cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.btn--sm { padding: 0.5rem 0.95rem; font-size: 0.8125rem; }
.btn--lg { padding: 0.95rem 1.85rem; font-size: 1.0625rem; }
.btn--solid { background: var(--ink-900); color: var(--text-inverse); border-color: var(--ink-900); }
.btn--solid:hover { background: var(--ink-700); border-color: var(--ink-700); }
.btn--outline { background: transparent; color: var(--text-primary); border-color: var(--hairline-strong); }
.btn--outline:hover { background: rgba(18,17,16,0.04); border-color: var(--ink-900); }
.btn--gold { border-color: var(--hairline-gold); }
.btn--gold:hover { border-color: var(--gold); background: rgba(18,17,16,0.04); }
.btn--full { width: 100%; }
.btn__arrow { display: inline-block; transition: transform var(--dur-fast) var(--ease-out); }
.btn:hover .btn__arrow { transform: translateX(3px); }
/* on-dark bands (hero / point-of-view / Sumut) */
.btn--on-dark.btn--solid { background: var(--surface-bright); color: var(--ink-900); border-color: var(--surface-bright); }
.btn--on-dark.btn--solid:hover { background: var(--ink-050); border-color: var(--ink-050); }
.btn--on-dark.btn--outline { color: var(--text-inverse); border-color: var(--hairline-on-dark); }
.btn--on-dark.btn--outline:hover { background: rgba(255,255,255,0.06); border-color: var(--text-inverse); }
.btn--on-dark.btn--gold { color: var(--text-inverse); border-color: var(--hairline-gold); }
.btn--on-dark.btn--gold:hover { border-color: var(--gold-soft); background: rgba(255,255,255,0.06); }

/* ============================================================
   Tags / labels
   ============================================================ */
.tag {
  display: inline-flex; align-items: center; font-family: var(--font-grotesque); font-size: 0.7rem;
  font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; line-height: 1;
  padding: 0.34rem 0.7rem; border: 1px solid var(--hairline-strong); color: var(--text-primary);
  white-space: nowrap;
}
.tag--on-dark { border-color: var(--hairline-on-dark); color: var(--text-inverse); }
.tag--gold { border-color: var(--hairline-gold); color: var(--gold); }
.tag--gold.tag--on-dark { color: var(--gold); }

/* ============================================================
   Dividers / rules
   ============================================================ */
.divider { border: 0; height: 1px; background: var(--hairline); margin: 0; }
.divider--gold { background: var(--gold-metallic); opacity: 0.9; }
.divider--on-dark { background: var(--hairline-on-dark); }

/* gold-marked highlight line */
.highlight { display: flex; gap: 0.85rem; align-items: baseline; padding: 0.5rem 0; }
.highlight::before { content: ""; flex: none; margin-top: 0.55em; width: 1.6rem; height: 1px; background: var(--gold-metallic); }
.highlight > span { font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.5; font-weight: 500; color: var(--text-primary); }

/* ============================================================
   Résumé timeline
   ============================================================ */
.timeline { margin: 0; padding: 0; list-style: none; }
.tl-row { display: grid; grid-template-columns: minmax(140px,180px) 1fr; gap: clamp(1.5rem,4vw,3.5rem); }
.tl-year { font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); padding-top: 0.35rem; }
.tl-body { position: relative; padding-left: clamp(1.25rem,3vw,2.25rem); padding-bottom: clamp(2.5rem,4vw,3.5rem); border-left: 1px solid var(--hairline); }
.tl-row:last-child .tl-body { padding-bottom: 0; }
.tl-body::before { content: ""; position: absolute; left: -4.5px; top: 0.6rem; width: 8px; height: 8px; background: var(--ink-900); border-radius: 50%; }
.tl-co { margin: 0; font-family: var(--font-grotesque); font-size: var(--text-3xl); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; }
.tl-role { margin-top: 0.45rem; font-family: var(--font-grotesque); font-size: var(--text-lg); color: var(--text-secondary); }
.tl-ctx { margin-top: 0.35rem; font-family: var(--font-serif); font-style: italic; font-size: var(--text-md); color: var(--text-muted); }
.tl-desc { margin: 1.1rem 0 0; max-width: 60ch; font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.6; color: var(--text-secondary); }
.tl-highlights { margin-top: 1.1rem; border-top: 1px solid var(--hairline); padding-top: 0.6rem; }
.featured-work {
  display: inline-flex; align-items: center; gap: 0.6em; margin-top: 1.1rem; padding: 0.7rem 1rem;
  border: 1px solid var(--hairline-gold); text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out);
}
.featured-work:hover { background: rgba(201,162,75,0.06); }
.featured-work__label { font-family: var(--font-grotesque); font-size: 0.7rem; font-weight: 500; letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--gold); }
.featured-work__title { font-family: var(--font-serif); font-style: italic; font-size: var(--text-md); color: var(--text-primary); }
.featured-work__arrow { color: var(--gold); transition: transform var(--dur-base) var(--ease-out); }
.featured-work:hover .featured-work__arrow { transform: translateX(3px); }
@media (max-width: 720px) { .tl-row { grid-template-columns: 1fr; } .tl-year { margin-bottom: 0.4rem; } }

/* employer chip row (fixes the run-together "MICROSOFTMBN…" — distinct, spaced items) */
.cred-tags { display: flex; flex-wrap: wrap; gap: 0.6rem; margin: 1.8rem 0 0; padding: 0; list-style: none; }

/* exact CredentialRow: "Previously | Twitter | Amazon | Microsoft" */
.cred-row { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 1.4rem; }
.cred-row__label { font-family: var(--font-grotesque); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-inverse-muted); }
.cred-row__items { display: flex; flex-wrap: wrap; align-items: center; gap: 1.4rem; list-style: none; margin: 0; padding: 0; }
.cred-row__items li { display: flex; align-items: center; gap: 1.4rem; font-family: var(--font-grotesque); font-size: 0.95rem; font-weight: 600; letter-spacing: -0.005em; color: var(--text-inverse); }
.cred-row__items li::before { content: ""; flex: none; width: 1px; height: 0.9rem; background: var(--hairline-on-dark); }

/* ============================================================
   Cards (What I do) + Writing list rows
   ============================================================ */
/* exact Card: padding, 1.5px top-border that goes gold + lifts on hover, arrow */
.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 1.25rem; }
.card { position: relative; display: flex; flex-direction: column; gap: 1rem; padding: 2rem 1.9rem 2.1rem;
  background: var(--surface-bright); border: 1px solid var(--hairline); border-top: 1.5px solid var(--hairline-strong);
  color: var(--text-primary); text-decoration: none;
  transition: transform var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.card[href]:hover { transform: translateY(-3px); border-top-color: var(--gold); }
.card__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.card__index { font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.1em; color: var(--gold); font-variant-numeric: tabular-nums; }
.card__title { margin: 0; font-family: var(--font-grotesque); font-size: 1.25rem; font-weight: 600; line-height: 1.25; letter-spacing: -0.01em; }
.card__body { margin: 0; font-family: var(--font-grotesque); font-size: 1rem; line-height: 1.55; color: var(--text-secondary); }
.card__footer { margin-top: auto; padding-top: 1.25rem; display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-primary); transition: color var(--dur-fast) var(--ease-out); }
.card[href]:hover .card__footer { color: var(--gold); }
.card__footer span { transition: transform var(--dur-fast) var(--ease-out); }
.card[href]:hover .card__footer span { transform: translateX(3px); }

.post-row { display: grid; grid-template-columns: minmax(120px,160px) 1fr auto; gap: 1.5rem; align-items: baseline; padding: 1.6rem 0; border-top: 1px solid var(--hairline); text-decoration: none; color: inherit; }
.post-row__meta { font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
.post-row__title { margin: 0; font-family: var(--font-grotesque); font-size: var(--text-2xl); font-weight: 600; letter-spacing: -0.02em; line-height: 1.1; }
.post-row__excerpt { margin: 0.7rem 0 0; max-width: 58ch; font-size: var(--text-md); line-height: 1.55; color: var(--text-secondary); }
.post-row__arrow { font-size: 1.4rem; color: var(--text-muted); }
@media (max-width: 600px) { .post-row { grid-template-columns: 1fr; gap: 0.35rem; } }

/* ============================================================
   Footer — dark band
   ============================================================ */
/* exact SiteFooter: big name, serif-italic tagline, gold-soft column titles,
   a gold-metallic hairline, then the legal row. */
.site-footer { background: var(--ink-900); color: var(--text-inverse); }
.site-footer__inner { max-width: var(--container); margin: 0 auto; padding: clamp(3.5rem,7vw,6rem) var(--gutter) 2rem; }
.site-footer__top { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 3rem; padding-bottom: clamp(3rem,6vw,5rem); }
.site-footer__brand { max-width: 30ch; }
.site-footer__name { font-family: var(--font-grotesque); font-weight: 600; font-size: clamp(1.75rem,3vw,2.5rem); letter-spacing: -0.02em; line-height: 1.05; color: var(--text-inverse); }
.site-footer__tagline { margin: 1rem 0 0; font-family: var(--font-serif); font-style: italic; font-size: 1.125rem; line-height: 1.35; color: var(--text-inverse-muted); }
.site-footer__cols { display: flex; gap: clamp(2.5rem,6vw,5rem); flex-wrap: wrap; }
.site-footer__col { display: flex; flex-direction: column; gap: 0.9rem; }
.site-footer__coltitle { font-family: var(--font-grotesque); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-soft); }
.site-footer__col a { font-family: var(--font-grotesque); font-size: 1rem; color: var(--text-inverse); text-decoration: none; opacity: 0.85; }
.site-footer__col a:hover { opacity: 1; }
.site-footer__rule { height: 1px; background: var(--gold-metallic); opacity: 0.8; }
.site-footer__legal { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem; padding-top: 1.6rem; font-family: var(--font-grotesque); font-size: 0.8125rem; color: var(--text-inverse-muted); }

/* utilities */
.cta-row { margin-top: 2rem; display: flex; gap: 0.9rem; flex-wrap: wrap; align-items: center; }
.stack-gap { display: flex; flex-direction: column; }

/* ============================================================
   Homepage-only sections (hero · track record · point of view · contact)
   ============================================================ */

/* Hero — the dark editorial opening */
.hero { position: relative; overflow: hidden; background: var(--ink-900); color: var(--text-inverse); }
.hero__bg { position: absolute; inset: 0; opacity: 0.85; pointer-events: none;
  background-size: cover; background-position: top right; background-repeat: no-repeat; filter: invert(1);
  -webkit-mask-image: radial-gradient(125% 125% at 88% 0%, #000 22%, transparent 68%);
  mask-image: radial-gradient(125% 125% at 88% 0%, #000 22%, transparent 68%); }
.hero__inner { position: relative; max-width: var(--container); margin: 0 auto;
  padding: clamp(4.5rem,11vw,9rem) var(--gutter) clamp(3.5rem,7vw,6rem); }
.hero__title { margin: 1.6rem 0 0; font-family: var(--font-grotesque); font-size: var(--text-6xl);
  font-weight: 600; line-height: 0.98; letter-spacing: -0.03em; max-width: 16ch; color: var(--text-inverse); }
.hero__lead { margin-top: 1.6rem; max-width: 44ch; font-size: var(--text-lg); line-height: 1.5; color: var(--text-inverse-muted); }
.hero__cred { margin-top: 3rem; padding-top: 1.6rem; border-top: 1px solid var(--hairline-on-dark); }

/* Track record rows */
.tr-row { display: grid; grid-template-columns: clamp(140px,16vw,200px) 1fr auto; gap: 1.5rem; align-items: baseline; padding: 1.4rem 0; }
.tr-co { font-family: var(--font-grotesque); font-weight: 600; font-size: var(--text-xl); letter-spacing: -0.01em; }
.tr-role { font-family: var(--font-grotesque); font-size: var(--text-lg); color: var(--text-secondary); }
.tr-yr { font-family: var(--font-grotesque); font-size: 0.8125rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); white-space: nowrap; }

/* Point of view — dark band with eclipse art */
.pov-grid { display: grid; grid-template-columns: minmax(0,1.5fr) minmax(0,1fr); gap: clamp(2rem,6vw,5rem); align-items: center; }
.pov__lead { margin-top: 1.8rem; max-width: 54ch; font-size: var(--text-lg); line-height: 1.55; color: var(--text-inverse-muted); }
.pov__lead--bright { margin-top: 1.2rem; color: var(--text-inverse); }
.pov__art { display: flex; justify-content: center; }
.pov__art-inner { width: min(360px,70vw); aspect-ratio: 1/1; background-size: contain; background-repeat: no-repeat; background-position: center; filter: invert(1); opacity: 0.92; }

/* Contact form (Formspree — works with and without JS) */
.contact-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: clamp(2.5rem,6vw,5rem); }
.form { display: flex; flex-direction: column; gap: 1.6rem; }
.field { display: flex; flex-direction: column; gap: 0.5rem; width: 100%; }
.field > span { font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); transition: color var(--dur-fast) var(--ease-out); }
.field:focus-within > span { color: var(--gold); }
.field input, .field textarea { appearance: none; -webkit-appearance: none; background: transparent; border: 0;
  border-bottom: 1px solid var(--hairline-strong); border-radius: 0; padding: 0.55rem 0;
  font-family: var(--font-grotesque); font-size: 1.0625rem; color: var(--text-primary); outline: none; width: 100%;
  transition: border-color var(--dur-fast) var(--ease-out); }
.field textarea { line-height: 1.5; resize: vertical; }
.field input:focus, .field textarea:focus { border-bottom-color: var(--gold); }
.contact-tags { margin-top: 1.8rem; display: flex; gap: 0.6rem; flex-wrap: wrap; }
.form-status { margin-top: 0.8rem; font-family: var(--font-grotesque); font-size: 0.9375rem; color: var(--text-muted); }

/* ============================================================
   Projects index rows + Writing index (featured + list)
   ============================================================ */
.proj-list { border-bottom: 1px solid var(--hairline); }
.proj-row { display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: start;
  border-top: 1px solid var(--hairline); padding: clamp(2rem,4vw,3rem) 0; text-decoration: none; color: inherit; }
.proj-row__head { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.proj-row__name { margin: 0; font-family: var(--font-grotesque); font-size: var(--text-3xl); font-weight: 600;
  letter-spacing: -0.02em; line-height: 1.04; color: var(--text-primary); transition: color var(--dur-fast) var(--ease-out); }
.proj-row:hover .proj-row__name { color: var(--gold-deep); }
.proj-row__what { margin: 1rem 0 0; max-width: 60ch; font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.6; color: var(--text-secondary); }
.proj-row__meta { margin-top: 1.1rem; font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.proj-row__arrow { font-size: 1.75rem; line-height: 1; padding-top: 0.4rem; color: var(--text-muted); transition: color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); }
.proj-row:hover .proj-row__arrow { color: var(--gold); transform: translateX(4px); }
@media (max-width: 720px) { .proj-row { grid-template-columns: 1fr; gap: 0.5rem; } }

.wr-feat { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,0.8fr); gap: clamp(2rem,5vw,4rem); align-items: center; padding-bottom: clamp(2.5rem,5vw,4rem); text-decoration: none; color: inherit; }
.wr-feat__meta { display: flex; gap: 0.7rem; align-items: center; margin-bottom: 1.2rem; }
.wr-feat__date { font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
.wr-feat__excerpt { margin: 0; font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.6; color: var(--text-secondary); }
@media (max-width: 760px) { .wr-feat { grid-template-columns: 1fr; } }
.post-row__title { transition: color var(--dur-fast) var(--ease-out); }
.post-row:hover .post-row__title { color: var(--gold-deep); }
.post-row:hover .post-row__arrow { color: var(--gold); }

/* ============================================================
   Back link · Ramadan stats band · press list
   ============================================================ */
.backlink { display: inline-flex; align-items: center; gap: 0.5em; font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none; color: var(--text-inverse-muted); transition: color var(--dur-fast) var(--ease-out); }
.backlink:hover { color: var(--gold); }
.backlink__arrow { transition: transform var(--dur-base) var(--ease-out); }
.backlink:hover .backlink__arrow { transform: translateX(-3px); }

.stat-band { background: var(--ink-900); color: var(--text-inverse); border-top: 1px solid var(--hairline-on-dark); }
.stat-band__inner { max-width: var(--container); margin: 0 auto; padding: clamp(2.5rem,5vw,4rem) var(--gutter); }
.stat-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; }
.stat { border-top: 1px solid var(--hairline-gold); padding-top: 1rem; }
.stat__n { font-family: var(--font-grotesque); font-size: var(--text-4xl); font-weight: 600; letter-spacing: -0.02em; line-height: 1; color: var(--gold-bright); }
.stat__l { margin-top: 0.6rem; font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-inverse-muted); }
@media (max-width: 760px) { .stat-grid { grid-template-columns: repeat(2,1fr); } }

.press-row { display: grid; grid-template-columns: minmax(140px,200px) 1fr auto; gap: 1.5rem; align-items: baseline; padding: 1.2rem 0; border-top: 1px solid var(--hairline); text-decoration: none; color: inherit; }
.press-row__pub { font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); transition: color var(--dur-fast) var(--ease-out); }
.press-row:hover .press-row__pub { color: var(--gold); }
.press-row__title { font-family: var(--font-serif); font-style: italic; font-size: var(--text-lg); color: var(--text-primary); }
.press-row__arrow { color: var(--text-muted); transition: transform var(--dur-base) var(--ease-out); }
.press-row:hover .press-row__arrow { transform: translate(2px,-2px); }
@media (max-width: 700px) { .press-row { grid-template-columns: 1fr; gap: 0.3rem; } }

/* Article meta (tag · date · read · back link) under an essay title */
.article-meta { margin-top: 1.4rem; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.article-meta__date { font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-inverse-muted); }

/* ============================================================
   Sumut mini-site: sticky nav (+ hybrid back link), policy sections & tables
   ============================================================ */
.sumut-nav { position: sticky; top: 0; z-index: var(--z-sticky); background: var(--ink-900); border-bottom: 1px solid var(--hairline-on-dark); }
.sumut-nav__inner { max-width: var(--container); margin: 0 auto; padding: 0.95rem var(--gutter); display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.sumut-nav__left { display: flex; align-items: baseline; gap: 0.95rem; min-width: 0; }
.sumut-back { font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.02em; color: var(--text-inverse-muted); text-decoration: none; white-space: nowrap; display: inline-flex; align-items: center; gap: 0.35em; }
.sumut-back:hover { color: var(--text-inverse); }
.sumut-nav__brand { font-family: var(--font-grotesque); font-size: 1.0625rem; font-weight: 600; letter-spacing: -0.02em; text-decoration: none; color: var(--text-inverse); }
.sumut-nav__brand[aria-current="page"] { color: var(--gold-soft); }
.sumut-nav__menu { display: flex; align-items: center; gap: 1.7rem; }
.sumut-nav__menu a { position: relative; font-family: var(--font-grotesque); font-size: 0.9375rem; font-weight: 400; text-decoration: none; color: var(--text-inverse-muted); }
.sumut-nav__menu a[aria-current="page"] { color: var(--text-inverse); font-weight: 500; }
.sumut-nav__menu a::after { content: ""; position: absolute; left: 0; bottom: -4px; height: 1px; width: 0; background: var(--gold-metallic); transition: width var(--dur-base) var(--ease-out); }
.sumut-nav__menu a[aria-current="page"]::after, .sumut-nav__menu a:hover::after { width: 100%; }

.policy { max-width: min(800px, 100%); }
.policy-section { margin-top: clamp(2.5rem,5vw,3.5rem); padding-top: clamp(1.75rem,3.5vw,2.5rem); border-top: 1px solid var(--hairline); }
.policy-section__head { display: flex; align-items: baseline; gap: 1rem; }
.policy-section__n { font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 600; letter-spacing: 0.12em; color: var(--gold); font-variant-numeric: tabular-nums; }
.policy-section__title { margin: 0; font-family: var(--font-grotesque); font-size: var(--text-xl); font-weight: 600; letter-spacing: -0.01em; line-height: 1.2; }
.policy-section__body { margin-top: 1.25rem; }
.policy-link { color: var(--gold-deep); text-decoration: none; border-bottom: 1px solid var(--hairline-gold); }

.pv-tbl-wrap { overflow-x: auto; margin: 1.6rem 0 0.4rem; }
.pv-tbl { width: 100%; min-width: min(34rem,100%); border-collapse: collapse; font-family: var(--font-grotesque); }
.pv-tbl th { text-align: left; padding: 0 1.25rem 0.7rem 0; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); border-bottom: 1px solid var(--hairline-strong); white-space: nowrap; }
.pv-tbl td { padding: 0.8rem 1.25rem 0.8rem 0; font-size: var(--text-md); line-height: 1.45; color: var(--text-secondary); border-bottom: 1px solid var(--hairline); vertical-align: top; }
.pv-tbl td:first-child { color: var(--text-primary); font-weight: 500; }
@media (max-width: 640px) { .pv-tbl { font-size: 0.9375rem; } }

/* Sumut case-study page */
.sumut-kicker { margin-top: 1.7rem; }
.sumut-id { display: flex; align-items: center; gap: 1.3rem; flex-wrap: wrap; }
.sumut-icon { width: 82px; height: 82px; border-radius: 19px; display: block; flex: none; box-shadow: 0 10px 28px -12px rgba(0,0,0,0.75); }
.sumut-id__col { display: flex; flex-direction: column; gap: 0.85rem; }
.sumut-arabic { font-family: var(--font-grotesque); font-size: var(--text-md); color: var(--text-inverse-muted); }
.sumut-arabic .ar { font-size: 1.25em; color: var(--text-inverse); }
.sumut-badge { display: inline-block; line-height: 0; }
.sumut-badge img { display: block; height: 46px; width: auto; }
.sumut-meaning { margin-top: 1.5rem; max-width: 54ch; font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.55; color: var(--text-inverse-muted); }
.sumut-meaning .ar { color: var(--text-inverse); }

.pr-grid { display: grid; grid-template-columns: minmax(0,1.4fr) minmax(0,1fr); gap: clamp(2rem,6vw,5rem); align-items: start; }
@media (max-width: 760px) { .pr-grid { grid-template-columns: 1fr; } }
.glance { border-left: 1px solid var(--hairline); padding-left: clamp(1.25rem,3vw,2.25rem); }
.glance__title { font-family: var(--font-grotesque); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.glance dl { margin: 1.1rem 0 0; display: grid; grid-template-columns: 1fr; gap: 0.9rem; }
.glance dl > div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px solid var(--hairline); padding-bottom: 0.7rem; }
.glance dt { font-family: var(--font-grotesque); font-size: var(--text-md); color: var(--text-muted); }
.glance dd { margin: 0; font-family: var(--font-grotesque); font-size: var(--text-md); font-weight: 500; color: var(--text-primary); }
.glance__links { display: flex; flex-direction: column; gap: 0.7rem; margin-top: 1.5rem; }
.glance__links a { display: inline-flex; align-items: center; gap: 0.4em; font-family: var(--font-grotesque); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.04em; color: var(--text-secondary); text-decoration: none; }
.glance__links a span { color: var(--gold); }

.feature-grid { margin-top: 2.6rem; display: grid; grid-template-columns: repeat(auto-fit,minmax(270px,1fr)); gap: 1.6rem 2.5rem; }
.feature { border-top: 1px solid var(--hairline-strong); padding-top: 1.1rem; }
.feature__t { font-family: var(--font-grotesque); font-size: var(--text-lg); font-weight: 600; letter-spacing: -0.01em; }
.feature__c { margin: 0.6rem 0 0; font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.55; color: var(--text-secondary); }
.principle-grid { margin-top: 2rem; display: grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 1.25rem; }
.principle { border-top: 1px solid var(--hairline-strong); padding-top: 1.1rem; }
.principle__t { font-family: var(--font-grotesque); font-size: var(--text-xl); font-weight: 600; letter-spacing: -0.01em; }
.principle__c { margin: 0.6rem 0 0; font-family: var(--font-grotesque); font-size: var(--text-md); line-height: 1.55; color: var(--text-secondary); }
