/* =========================================================================
   ELLE INTERNATIONAL — Foundation Design System
   Palette: deep plum/berry + warm neutrals + gold accent
   Type: Spectral (display serif) + Hanken Grotesk (UI/body)
   ========================================================================= */

:root{
  /* warm neutrals */
  --bg:        #FBF7F3;   /* warm ivory */
  --bg-sand:   #F3EAE1;   /* warm sand   */
  --bg-blush:  #EFDDE0;   /* soft blush  */
  --paper:     #FFFFFF;

  /* plum / berry */
  --ink:       #25141B;   /* deep aubergine-black (text) */
  --plum:      #6B2A43;   /* primary */
  --plum-deep: #3E1626;   /* darkest brand */
  --berry:     #9E3B5C;   /* brighter accent */
  --rose:      #C77E92;   /* muted rose */
  --blush-ink: #8A5566;   /* muted text on light */

  /* accent */
  --gold:      #B8863C;   /* awards / highlight */
  --gold-soft: #E6CFA3;

  /* lines & shadow */
  --line:      rgba(37,20,27,0.12);
  --line-soft: rgba(37,20,27,0.07);
  --shadow-sm: 0 1px 2px rgba(37,20,27,.06), 0 2px 8px rgba(37,20,27,.05);
  --shadow-md: 0 8px 30px rgba(62,22,38,.10), 0 2px 8px rgba(62,22,38,.06);
  --shadow-lg: 0 24px 60px rgba(62,22,38,.16);

  /* type */
  --serif: "Spectral", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, sans-serif;

  --container: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans);
  font-size:18px; line-height:1.62; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; font-family:var(--serif); font-weight:500; line-height:1.06; letter-spacing:-.01em; }
p{ margin:0 0 1em; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- type scale ---------- */
.display{ font-size:clamp(2.7rem, 6.6vw, 5.6rem); line-height:1.0; letter-spacing:-.022em; }
.h1{ font-size:clamp(2.2rem, 4.6vw, 3.6rem); }
.h2{ font-size:clamp(1.8rem, 3.4vw, 2.7rem); }
.h3{ font-size:clamp(1.35rem, 2.2vw, 1.7rem); }
.h4{ font-size:1.2rem; }
.lead{ font-size:clamp(1.15rem, 1.7vw, 1.4rem); line-height:1.5; color:var(--blush-ink); }
.serif{ font-family:var(--serif); }
.italic{ font-style:italic; }

.eyebrow{
  font-family:var(--sans); font-size:.78rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; color:var(--berry);
  display:inline-flex; align-items:center; gap:.6em; margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:26px; height:1.5px; background:var(--berry); display:inline-block;
}
.eyebrow.gold{ color:var(--gold); }
.eyebrow.gold::before{ background:var(--gold); }
.eyebrow.on-dark{ color:var(--gold-soft); }
.eyebrow.on-dark::before{ background:var(--gold-soft); }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px, 9vw, 132px); }
.section.tight{ padding-block:clamp(48px,6vw,84px); }
.grid{ display:grid; gap:clamp(20px,3vw,40px); }
.center{ text-align:center; }
.measure{ max-width:64ch; }
.measure-sm{ max-width:48ch; }

.bg-sand{ background:var(--bg-sand); }
.bg-blush{ background:var(--bg-blush); }
.bg-plum{ background:var(--plum-deep); color:#F4E7E1; }
.bg-plum h1,.bg-plum h2,.bg-plum h3,.bg-plum h4{ color:#FBF1EC; }
.bg-paper{ background:var(--paper); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:600; font-size:1rem;
  padding:.92em 1.5em; border-radius:100px; border:1.5px solid transparent;
  transition:transform .18s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--berry); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--plum); box-shadow:var(--shadow-md); }
.btn-dark{ background:var(--plum-deep); color:#fff; }
.btn-dark:hover{ background:#000; }
.btn-ghost{ border-color:var(--line); color:var(--ink); background:transparent; }
.btn-ghost:hover{ border-color:var(--ink); background:var(--ink); color:var(--bg); }
.btn-light{ background:#fff; color:var(--plum-deep); }
.btn-light:hover{ background:var(--gold-soft); }
.btn-outline-light{ border-color:rgba(255,255,255,.45); color:#fff; }
.btn-outline-light:hover{ background:#fff; color:var(--plum-deep); }
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translateX(3px); }

.textlink{
  display:inline-flex; align-items:center; gap:.45em; font-weight:600; color:var(--berry);
  border-bottom:1.5px solid transparent; padding-bottom:1px; transition:border-color .2s, gap .2s;
}
.textlink:hover{ border-color:var(--berry); gap:.7em; }
.textlink.gold{ color:var(--gold); }
.textlink.gold:hover{ border-color:var(--gold); }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:80;
  background:rgba(251,247,243,.82); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.site-header .bar{ display:flex; align-items:center; justify-content:space-between; gap:24px; height:74px; }
.nav{ display:flex; align-items:center; gap:30px; }
.nav a{ font-size:.96rem; font-weight:500; color:var(--ink); position:relative; padding:6px 0; }
.nav a::after{ content:""; position:absolute; left:0; bottom:0; height:1.5px; width:0; background:var(--berry); transition:width .22s ease; }
.nav a:hover::after, .nav a.active::after{ width:100%; }
.nav a.active{ color:var(--berry); }
.header-cta{ display:flex; align-items:center; gap:14px; }
.menu-toggle{ display:none; background:none; border:none; padding:8px; color:var(--ink); }
.menu-toggle svg{ width:26px; height:26px; }

/* mobile nav */
.mobile-nav{ display:none; }
@media (max-width:980px){
  .nav, .header-cta .btn{ display:none; }
  .menu-toggle{ display:inline-flex; }
  .mobile-nav{
    display:block; position:fixed; inset:74px 0 0 0; z-index:79;
    background:var(--bg); padding:28px var(--gutter);
    transform:translateY(-12px); opacity:0; pointer-events:none; transition:.25s ease;
    overflow:auto;
  }
  .mobile-nav.open{ transform:none; opacity:1; pointer-events:auto; }
  .mobile-nav a{ display:block; font-family:var(--serif); font-size:1.7rem; padding:16px 0; border-bottom:1px solid var(--line-soft); }
  .mobile-nav .btn{ margin-top:24px; width:100%; justify-content:center; }
}

/* ---------- logo ---------- */
.logo{ display:inline-flex; align-items:center; gap:11px; }
.logo .mark{ width:42px; height:42px; flex:none; border-radius:50%; display:block; }
.logo .lockup{ display:flex; flex-direction:column; line-height:1; }
.logo .word{ font-family:var(--serif); font-weight:600; font-size:1.32rem; letter-spacing:.01em; color:var(--plum-deep); }
.logo .sub{ font-family:var(--sans); font-size:.55rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--blush-ink); margin-top:4px; }
.logo.on-dark .word{ color:#FBF1EC; }
.logo.on-dark .sub{ color:var(--gold-soft); }

/* ---------- footer ---------- */
.site-footer{ background:var(--plum-deep); color:#E7CFC9; padding-block:clamp(56px,7vw,90px) 36px; }
.site-footer a{ color:#E7CFC9; }
.footer-grid{ display:grid; grid-template-columns:1.6fr repeat(3,1fr); gap:40px; }
.site-footer h5{ font-family:var(--sans); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft); margin:0 0 18px; font-weight:700; }
.site-footer .flinks li{ margin-bottom:11px; }
.site-footer .flinks a{ color:#D9BEBA; opacity:.92; transition:opacity .2s, color .2s; font-size:.98rem; }
.site-footer .flinks a:hover{ color:#fff; opacity:1; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between; align-items:center;
  margin-top:54px; padding-top:26px; border-top:1px solid rgba(255,255,255,.13); font-size:.86rem; color:#C2A39F; }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; } .footer-grid .fbrand{ grid-column:1/-1; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }

/* ---------- cards ---------- */
.card{ background:var(--paper); border:1px solid var(--line-soft); border-radius:10px; overflow:hidden;
  box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .25s ease; }
.card.hover:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.card-pad{ padding:clamp(22px,3vw,34px); }

/* project cards */
.project-card{ display:block; position:relative; border-radius:12px; overflow:hidden; color:#fff; min-height:340px;
  box-shadow:var(--shadow-sm); transition:transform .25s, box-shadow .25s; }
.project-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.project-card .pc-body{ position:relative; z-index:2; padding:30px; display:flex; flex-direction:column; height:100%; min-height:340px; justify-content:flex-end; }
.project-card .pc-over{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(40,16,26,.05) 0%, rgba(40,16,26,.55) 55%, rgba(40,16,26,.9) 100%); }

/* ---------- stats ---------- */
.stat .num{ font-family:var(--serif); font-weight:600; font-size:clamp(2.6rem,5vw,4rem); line-height:.95; color:var(--plum); letter-spacing:-.02em; }
.stat .num.gold{ color:var(--gold); }
.stat .num.light{ color:#fff; }
.stat .lbl{ font-size:.96rem; color:var(--blush-ink); margin-top:.55em; max-width:24ch; }
.bg-plum .stat .lbl{ color:#D9BEBA; }

/* ---------- pills / tags ---------- */
.pill{ display:inline-flex; align-items:center; gap:.5em; font-size:.78rem; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; padding:.5em 1em; border-radius:100px; background:var(--bg-blush); color:var(--plum); }
.pill.gold{ background:rgba(184,134,60,.14); color:var(--gold); }
.pill.line{ background:transparent; border:1px solid var(--line); color:var(--blush-ink); }
.dot{ width:7px; height:7px; border-radius:50%; background:currentColor; }

/* ---------- image placeholders ---------- */
.ph{
  position:relative; overflow:hidden; background-color:var(--bg-sand);
  background-image:repeating-linear-gradient(135deg, rgba(107,42,67,.07) 0 2px, transparent 2px 11px);
  display:flex; align-items:center; justify-content:center; color:var(--blush-ink);
  border:1px solid var(--line-soft);
}
.ph.plum{ background-color:#54213A; background-image:repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 2px, transparent 2px 11px); color:#E7CFC9; border-color:rgba(255,255,255,.12); }
.ph .ph-tag{ font-family:"Hanken Grotesk",monospace; font-size:.74rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  text-align:center; padding:.6em 1.1em; line-height:1.4; max-width:80%; }
.ph .ph-tag::before{ content:"◳  "; opacity:.6; }
.ph.photo{ background-size:cover; background-position:center; background-repeat:no-repeat; border:none; }
.ph.photo.pos-top{ background-position:center 18%; }
.ph.photo .ph-tag{ display:none; }
.ph .ph-tag{ display:none; }   /* hide unfilled placeholder labels site-wide */
.ph:not(.photo){ background-image:none; }   /* drop the hatch on solid colour cards */

/* branded motif panel — used in place of a photo where none exists */
.proj-motif{ position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  background:linear-gradient(150deg, var(--motif-a,#7A3450), var(--motif-b,#4A1B30)); overflow:hidden; border:none; }
.proj-motif::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 22%, rgba(255,255,255,.12), transparent 62%); }
.proj-motif .motif-bloom{ position:relative; width:104px; height:104px; fill:rgba(255,255,255,.94);
  filter:drop-shadow(0 6px 16px rgba(0,0,0,.18)); }
.proj-motif .motif-cap{ position:relative; color:rgba(255,255,255,.82); font-family:var(--sans);
  font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; }

/* ---------- product mockups (Projects page) ---------- */
.device-wrap{ position:relative; display:flex; align-items:center; justify-content:center;
  overflow:hidden; border-radius:16px; box-shadow:var(--shadow-md); border:none; }

/* InsideHer — phone */
.insideher-wrap{ aspect-ratio:4/5; background:linear-gradient(155deg,#F6ECEF,#E7D4EE); }
.app-shot{ height:94%; width:auto; max-width:86%; object-fit:contain; border-radius:24px; box-shadow:0 22px 46px rgba(40,16,50,.34); }
.phone{ height:90%; aspect-ratio:9/19.2; background:#170c26; border:6px solid #0c0617;
  border-radius:30px; box-shadow:0 22px 46px rgba(40,16,50,.34); overflow:hidden; position:relative; }
.phone::before{ content:""; position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:34%; height:10px; background:#0c0617; border-radius:0 0 10px 10px; z-index:3; }
.phone-screen.ih{ position:absolute; inset:0; padding:28px 15px 15px;
  background:radial-gradient(120% 80% at 50% 0,#2c1746,#160b24 70%); display:flex; flex-direction:column; gap:13px; color:#fff; }
.ih-top{ display:flex; align-items:center; justify-content:space-between; }
.ih-eyebrow{ font-family:var(--sans); font-size:.5rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#f06ab0; }
.ih-chip{ font-size:.46rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#cbb8e0;
  border:1px solid rgba(255,255,255,.18); border-radius:100px; padding:3px 7px; }
.ih-dial{ position:relative; width:116px; height:116px; margin:4px auto 2px; }
.ih-ring{ position:absolute; inset:0; border-radius:50%;
  background:conic-gradient(from 200deg,#ff48a3,#c44dff 165deg,rgba(255,255,255,.08) 165deg 360deg); }
.ih-core{ position:absolute; inset:13px; border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#3a2150,#211232); display:flex; flex-direction:column;
  align-items:center; justify-content:center; box-shadow:inset 0 0 0 1px rgba(255,255,255,.06); }
.ih-core .d-lab{ font-size:.42rem; letter-spacing:.16em; color:#b8a3d0; }
.ih-core .d-num{ font-family:var(--serif); font-size:1.9rem; font-weight:600; line-height:1; }
.ih-core .d-ph{ font-size:.42rem; letter-spacing:.14em; text-transform:uppercase; color:#f06ab0; margin-top:2px; }
.ih-tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:6px; margin-top:auto; }
.ih-tile{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); border-radius:9px; padding:8px 4px; text-align:center; }
.ih-tile b{ display:block; font-family:var(--serif); font-size:.74rem; }
.ih-tile i{ font-style:normal; font-size:.44rem; letter-spacing:.08em; text-transform:uppercase; color:#b8a3d0; }

/* IWHF — funding desk */
.iwhf-wrap{ aspect-ratio:4/5; background:linear-gradient(155deg,#F4E9E6,#E7D3CF); padding:24px; }
.fund-desk{ width:100%; max-width:330px; background:#fff; border-radius:16px; box-shadow:0 20px 44px rgba(60,20,40,.16); overflow:hidden; }
.fd-head{ display:flex; align-items:center; justify-content:space-between; padding:13px 16px; border-bottom:1px solid var(--line); }
.fd-today{ font-family:var(--sans); font-size:.62rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blush-ink); }
.fd-live{ display:inline-flex; align-items:center; gap:6px; font-size:.58rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#9A7B2E; }
.fd-live i{ width:6px; height:6px; border-radius:50%; background:var(--gold); display:inline-block; }
.fd-list{ list-style:none; margin:0; padding:0; }
.fd-list li{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:11px 16px; border-bottom:1px solid var(--line-soft); }
.fd-list li:last-child{ border-bottom:none; }
.fd-l{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.fd-funder{ font-family:var(--sans); font-size:.55rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--berry); }
.fd-title{ font-family:var(--serif); font-size:.84rem; color:var(--plum-deep); line-height:1.25; }
.fd-r{ text-align:right; flex-shrink:0; }
.fd-r b{ display:block; font-family:"Hanken Grotesk",monospace; font-size:.72rem; font-weight:700; color:#2a1a22; letter-spacing:.02em; }
.fd-r span{ font-size:.56rem; color:#9b8a86; }

/* home IWHF card — mini funding feed */
.mini-desk{ display:flex; flex-direction:column; gap:7px; margin:16px 0 0; position:relative; z-index:2; }
.md-row{ display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.14); border-radius:9px; padding:9px 12px; }
.md-f{ font-size:.76rem; font-weight:600; color:#F0DCD8; }
.md-a{ font-family:"Hanken Grotesk",monospace; font-size:.76rem; font-weight:700; color:#fff; letter-spacing:.02em; white-space:nowrap; }

/* project cards shown as brand logos */
.project-card.logo-card{ display:flex; flex-direction:column; padding:26px 30px 30px; }
.logo-card .lc-logo{ flex:1; display:flex; align-items:center; justify-content:center; min-height:130px; padding:6px 0 18px; }
.logo-card .lc-logo .logo-art{ width:auto; height:auto; max-width:72%; max-height:170px; object-fit:contain; }
.logo-card .lc-logo .logo-art-gold{ max-width:82%; max-height:94px; }
.logo-card .lc-text .pill{ margin-bottom:11px; }
.logo-card .lc-text p{ font-size:.95rem; margin:0; max-width:44ch; }
.logo-card.lc-light .lc-text p{ color:var(--blush-ink); }
.logo-card.lc-dark .lc-text p{ color:#F0DCD8; }

/* ---------- partner / recognition logo wall ---------- */
.logo-wall{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.logo-wall .lw-cell{ background:var(--bg); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:34px 22px; min-height:128px; transition:background .25s; }
.logo-wall .lw-cell:hover{ background:var(--paper); }
.logo-wall .lw-name{ font-family:var(--serif); font-size:1.16rem; font-weight:600; color:var(--plum-deep); line-height:1.12; letter-spacing:.01em; }
.logo-wall .lw-sub{ font-family:var(--sans); font-size:.62rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--rose); margin-top:9px; }
@media (max-width:900px){ .logo-wall{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .logo-wall{ grid-template-columns:1fr; } }

/* ---------- misc ---------- */
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.kicker-num{ font-family:var(--serif); font-size:.95rem; color:var(--berry); font-weight:600; }
.badge-row{ display:flex; flex-wrap:wrap; gap:14px 26px; align-items:center; }
.overline-label{ font-size:.72rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--blush-ink); }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* utilities */
.flow > * + *{ margin-top:1.1em; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.maxw-720{ max-width:720px; } .maxw-820{ max-width:820px; }
.muted{ color:var(--blush-ink); }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,80px); align-items:center; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:980px){ .cols-4{ grid-template-columns:repeat(2,1fr); } .cols-3{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .cols-3,.cols-4,.cols-2{ grid-template-columns:1fr; } }

/* ===================== shared sub-page patterns ===================== */
/* page hero */
.page-hero{ position:relative; overflow:hidden; padding-block:clamp(56px,8vw,104px) clamp(40px,5vw,64px); background:var(--bg-sand); }
.page-hero.plum{ background:var(--plum-deep); color:#F4E7E1; }
.page-hero.plum h1{ color:#fff; }
.page-hero::after{ content:""; position:absolute; top:-25%; right:-8%; width:46vw; height:46vw; max-width:560px; max-height:560px;
  background:radial-gradient(circle, rgba(199,126,146,.20), transparent 64%); pointer-events:none; }
.page-hero.plum::after{ background:radial-gradient(circle, rgba(184,134,60,.18), transparent 64%); }
.page-hero .container{ position:relative; z-index:1; }
.page-hero p.lead{ margin-top:1.1rem; }
.page-hero.plum p.lead{ color:#E7CFC9; }

/* breadcrumb */
.crumb{ display:flex; align-items:center; gap:.55em; font-size:.85rem; color:var(--blush-ink); margin-bottom:22px; }
.crumb a{ color:var(--blush-ink); } .crumb a:hover{ color:var(--berry); }
.page-hero.plum .crumb, .page-hero.plum .crumb a{ color:var(--gold-soft); }

/* timeline */
.timeline{ position:relative; margin-top:20px; }
.timeline::before{ content:""; position:absolute; left:11px; top:8px; bottom:8px; width:2px; background:var(--line); }
.tl-item{ position:relative; padding:0 0 38px 48px; }
.tl-item::before{ content:""; position:absolute; left:4px; top:5px; width:16px; height:16px; border-radius:50%; background:var(--berry); box-shadow:0 0 0 4px var(--bg); }
.tl-item .yr{ font-family:var(--serif); font-weight:600; color:var(--berry); font-size:1.15rem; }
.tl-item h4{ margin:.2em 0 .35em; }
.tl-item p{ color:var(--blush-ink); margin:0; max-width:60ch; }

/* definition / value list */
.deflist{ display:grid; gap:0; }
.deflist .row{ display:grid; grid-template-columns:.4fr 1fr; gap:30px; padding:28px 0; border-top:1px solid var(--line); align-items:start; }
.deflist .row:last-child{ border-bottom:1px solid var(--line); }
.deflist .row h3{ color:var(--plum-deep); }
.deflist .row p{ margin:0; color:var(--blush-ink); }
@media (max-width:680px){ .deflist .row{ grid-template-columns:1fr; gap:8px; } }

/* simple feature with number */
.numbered .ni{ font-family:var(--serif); font-size:1.1rem; color:var(--berry); font-weight:600; }

/* quote */
.pullquote{ font-family:var(--serif); font-size:clamp(1.5rem,2.8vw,2.2rem); line-height:1.25; color:var(--plum-deep); font-weight:400; }
.pullquote.light{ color:#fff; }

/* CTA band reusable */
.cta-band{ background:linear-gradient(160deg,#4A1B2E,#2C0F1C); color:#F4E7E1; }
.cta-band h2{ color:#fff; }

/* media/press list */
.press-item{ display:grid; grid-template-columns:auto 1fr auto; gap:24px; align-items:center; padding:26px 0; border-top:1px solid var(--line); }
.press-item:last-child{ border-bottom:1px solid var(--line); }
.press-item .src{ font-family:var(--serif); font-size:1.05rem; color:var(--plum-deep); min-width:170px; }
.press-item .ttl{ font-size:1.05rem; }
.press-item .yr{ color:var(--blush-ink); font-size:.9rem; white-space:nowrap; }
.press-item:hover .ttl{ color:var(--berry); }
a.press-item .ext{ color:var(--rose); font-size:.85em; margin-left:.35em; opacity:.7; transition:opacity .2s, color .2s; }
a.press-item:hover .ext{ color:var(--berry); opacity:1; }
@media (max-width:680px){ .press-item{ grid-template-columns:1fr; gap:6px; } .press-item .src{ min-width:0; } }

/* award cards */
.award{ display:flex; gap:18px; align-items:flex-start; }
.award .ix{ font-family:var(--serif); color:var(--gold); font-size:1.4rem; font-weight:600; line-height:1; }

/* form */
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.field label{ font-size:.85rem; font-weight:600; letter-spacing:.02em; color:var(--ink); }
.field input,.field select,.field textarea{ font-family:var(--sans); font-size:1rem; padding:13px 15px; border:1px solid var(--line);
  border-radius:8px; background:#fff; color:var(--ink); transition:border-color .2s, box-shadow .2s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--berry); box-shadow:0 0 0 3px rgba(158,59,92,.12); }
.field textarea{ resize:vertical; min-height:130px; }

/* donation amount chips */
.amt-row{ display:flex; flex-wrap:wrap; gap:12px; }
.amt{ flex:1; min-width:90px; text-align:center; padding:16px 10px; border:1.5px solid var(--line); border-radius:10px; background:#fff;
  font-weight:600; transition:.18s; }
.amt .sub{ display:block; font-size:.78rem; font-weight:500; color:var(--blush-ink); margin-top:3px; }
.amt:hover{ border-color:var(--berry); }
.amt.active{ border-color:var(--berry); background:var(--bg-blush); color:var(--plum-deep); }

/* icon chip */
.ico-chip{ display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:12px;
  background:var(--bg-blush); color:var(--berry); font-size:1.3rem; flex:none; }
.bg-plum .ico-chip{ background:rgba(255,255,255,.1); color:var(--gold-soft); }
