/* ============================================================
   alejandroservin.com · v6.1 · 2026-06-12
   Five inks, two voices, one law — typeparis-level composition.
   Owner decree 2026-06-12: blanco joins the grounds (page canvas);
   contrast law of ch. 04 intact. Source: Brand Manual v6.0 + decree.
   ============================================================ */

/* ============ TOKENS · primitive → semantic → component ============ */
:root{
  /* primitives — the five inks of record */
  --color-navy:#263158; --color-lavender:#DBE0F5;
  --color-rose:#EFAFF7; --color-slate:#5A6678; --color-white:#FFFFFF;
  /* semantic */
  --tinta:var(--color-navy); --papel:var(--color-lavender); --acento:var(--color-rose);
  --estructura:var(--color-slate); --luz:var(--color-white);
  --text-default:var(--tinta); --surface-page:var(--color-white);
  --surface-tint:var(--papel); --surface-accent:var(--acento);
  --surface-dark:var(--tinta); --text-on-dark:var(--luz); --border-structure:var(--estructura);
  --duoHi:var(--acento); /* [data-duo="lavanda"] → lavender */
  /* type · grid · motion · touch */
  --font-mark:'Void','Apax',sans-serif;
  --font-system:'Apax','Helvetica Neue',system-ui,sans-serif;
  --measure:68ch; --target-min:48px;
  --motion-fast:150ms; --motion-base:250ms; --motion-slow:400ms;
  --ease:cubic-bezier(0,0,.2,1);
  /* component */
  --button-bg:var(--surface-dark); --button-fg:var(--text-on-dark);
  --rule:1.5px solid var(--border-structure);
  --frame-page:14px; /* the lavender viewport frame, typeparis motif */
}
html[data-duo="lavanda"]{--duoHi:var(--papel)}

/* ============ BASE — white canvas inside a lavender frame ============ */
*{box-sizing:border-box}
html{scroll-behavior:smooth; background:var(--papel)}
body{
  margin:0; background:var(--surface-page); color:var(--text-default);
  font-family:var(--font-system); font-weight:400; font-size:18px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
  border:var(--frame-page) solid var(--papel); min-height:100vh;
}
@media(max-width:640px){ :root{--frame-page:8px} }
.wrap{max-width:1400px; margin:0 auto; padding:0 clamp(24px,4.5vw,72px)}
@media(max-width:640px){ .wrap{padding:0 20px} }
main{display:block}
section{padding:clamp(104px,13vh,176px) 0}
section.tint{background:var(--surface-tint)}
section.dark{background:var(--surface-dark); color:var(--text-on-dark)}
figure{margin:0}
img{max-width:100%; height:auto; display:block}
hr{border:0; border-top:var(--rule); margin:0}

/* ============ TYPE · the named scale (ch. 05) ============ */
.display{font-weight:700; font-size:clamp(50px,8.8vw,142px); line-height:1.01; margin:0 0 24px; letter-spacing:-.015em}
h1{font-weight:300; font-size:clamp(42px,5.8vw,96px); line-height:1.04; margin:0 0 28px; letter-spacing:-.01em}
@media(min-width:1024px){ h1{font-weight:100} } /* Thin only ≥48px */
h2{font-weight:900; font-size:clamp(26px,3.6vw,38px); line-height:1.12; margin:0 0 16px}
h3{font-weight:500; font-size:13px; letter-spacing:.08em; text-transform:uppercase; margin:32px 0 12px}
h4{font-weight:700; font-size:16px; margin:24px 0 8px}
p{margin:0 0 14px; max-width:var(--measure)}
.lead{font-size:clamp(20px,1.55vw,24px); line-height:1.55; max-width:46ch}
.cap{font-size:13.5px}
.struct{color:var(--estructura); font-size:15px}
strong{font-weight:700}
em{font-style:italic}
ul,ol{margin:0 0 14px; padding-left:22px; max-width:var(--measure)}
li{margin-bottom:6px}
.kick{font-weight:500; font-size:12px; letter-spacing:.09em; text-transform:uppercase; margin:0 0 16px}
/* typeparis section label — big, light, caps */
.label-xl{
  font-weight:300; font-size:clamp(28px,3.4vw,44px); letter-spacing:.06em; text-transform:uppercase;
  margin:0 0 36px; line-height:1;
}
.dark .label-xl, .dark .kick{color:var(--text-on-dark)}

/* manifesto: Spanish leads, translation subordinate (ch. 12) */
.manifesto-tr{display:block; font-size:.42em; font-weight:300; line-height:1.3; margin-top:20px; letter-spacing:0}

/* ============ THE MARK (ch. 02) ============ */
.wordmark{
  font-family:var(--font-mark); font-weight:850; line-height:1.04; letter-spacing:.005em;
  color:var(--tinta); text-decoration:none;
}
.dark .wordmark, .site-footer .wordmark{color:var(--luz)}
a.wordmark:hover{text-decoration:none}
.wordmark--footer{font-size:clamp(58px,9.5vw,132px); letter-spacing:.01em; margin:0 0 18px}

/* ============ LINKS — shape always present (ch. 09) ============ */
a{
  color:var(--tinta); text-decoration:underline;
  text-decoration-color:var(--acento); text-decoration-thickness:2.5px; text-underline-offset:3px;
  transition:text-decoration-color var(--motion-fast) var(--ease);
}
a:hover{text-decoration-color:var(--tinta); text-decoration-thickness:3px}
.dark a, .site-footer a{color:var(--luz)}
.dark a:hover, .site-footer a:hover{text-decoration-color:var(--luz)}
:focus-visible{outline:2.5px solid var(--tinta); outline-offset:3px}
.dark :focus-visible, .site-footer :focus-visible{outline-color:var(--luz)}
.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--tinta); color:var(--luz);
  padding:12px 18px; z-index:100; text-decoration:none; font-weight:700;
}
.skip-link:focus{left:0}

/* ============ BUTTONS & CHIPS (ch. 09) ============ */
.btn-primary{
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--button-bg); color:var(--button-fg); border:3px solid var(--tinta);
  font-family:var(--font-system); font-weight:700; font-size:15px; letter-spacing:.04em;
  padding:12px 22px; min-height:var(--target-min); cursor:pointer;
  text-decoration:none; transition:background var(--motion-fast) var(--ease), border-color var(--motion-fast) var(--ease);
}
.btn-primary:hover{background:var(--estructura); border-color:var(--estructura)}
.btn-primary:active{background:var(--tinta); border-color:var(--tinta)}
.dark .btn-primary{background:var(--luz); color:var(--tinta); border-color:var(--luz)}
.dark .btn-primary:hover{background:var(--acento); border-color:var(--acento)}
.chip{
  display:inline-flex; align-items:center; justify-content:center;
  border:3px solid var(--tinta); color:var(--tinta); background:transparent;
  font-family:var(--font-system); font-weight:700; font-size:15px; letter-spacing:.04em;
  padding:12px 22px; min-height:var(--target-min); cursor:pointer; text-decoration:none;
  transition:background var(--motion-fast) var(--ease);
}
.chip:hover{background:var(--acento); text-decoration:none}
.chip:active{background:var(--tinta); color:var(--luz)}
.cta-row{display:flex; gap:16px; flex-wrap:wrap; margin-top:28px}
a.btn-primary, a.chip{text-decoration:none}
.pend{
  display:inline-block; border:1.5px dashed var(--estructura); color:var(--tinta);
  font-size:11px; font-weight:700; letter-spacing:.06em; padding:4px 9px; border-radius:3px;
  text-transform:uppercase; vertical-align:2px;
}

/* ============ HEADER — six destinations, no dropdowns ============ */
.site-header{
  position:sticky; top:0; z-index:60; background:var(--surface-page);
  border-bottom:var(--rule);
}
.site-header .wrap{display:flex; align-items:center; gap:26px; min-height:74px}
.site-header .wordmark{font-size:clamp(38px,3.6vw,54px); margin-right:auto; flex-shrink:0}
.primary-nav{display:flex; gap:20px; align-items:center}
.primary-nav a{
  font-weight:500; font-size:13px; letter-spacing:.05em; text-transform:uppercase;
  text-underline-offset:5px; min-height:var(--target-min); display:inline-flex; align-items:center;
  white-space:nowrap;
}
.primary-nav a[aria-current="page"]{text-decoration-color:var(--tinta); text-decoration-thickness:3px}
.lang-switch{display:flex; gap:4px; align-items:center; font-size:13px}
.lang-switch a{font-weight:500; text-underline-offset:5px; min-height:var(--target-min); display:inline-flex; align-items:center; padding:0 3px}
.lang-switch a[aria-current="true"]{font-weight:700; text-decoration-color:var(--tinta)}
.site-footer .lang-switch a[aria-current="true"]{text-decoration-color:var(--luz)}
.lang-switch .sep{color:var(--estructura)}
.menu-toggle{display:none}

@media(max-width:1099px){
  .site-header .primary-nav, .site-header .lang-switch{display:none}
  .menu-toggle{
    display:inline-flex; align-items:center; gap:8px;
    background:transparent; border:3px solid var(--tinta); color:var(--tinta);
    font-family:var(--font-system); font-weight:700; font-size:14px; letter-spacing:.05em; text-transform:uppercase;
    padding:8px 16px; min-height:var(--target-min); cursor:pointer;
  }
  .mobile-panel{
    position:fixed; inset:0; z-index:70; background:var(--surface-page);
    border:var(--frame-page) solid var(--papel);
    display:none; flex-direction:column; padding:24px 20px 40px; overflow:auto;
  }
  html.menu-open .mobile-panel{display:flex}
  html.menu-open{overflow:hidden}
  .mobile-panel .panel-top{display:flex; align-items:center; justify-content:space-between; min-height:48px; margin-bottom:34px}
  .mobile-panel .wordmark{font-size:28px}
  .menu-close{
    background:transparent; border:3px solid var(--tinta); color:var(--tinta);
    font-family:var(--font-system); font-weight:700; font-size:14px; letter-spacing:.05em; text-transform:uppercase;
    padding:8px 16px; min-height:var(--target-min); cursor:pointer;
  }
  .mobile-panel nav{display:flex; flex-direction:column; gap:6px}
  .mobile-panel nav a{
    font-weight:300; font-size:clamp(28px,7.4vw,42px); line-height:1.2; text-decoration-thickness:3px;
    text-underline-offset:6px; padding:8px 0;
  }
  .mobile-panel .lang-switch{display:flex; margin-top:auto; padding-top:34px; font-size:17px}
}
@media(min-width:1100px){ .mobile-panel{display:none !important} }

/* ============ HERO — headline overlaps the duotone (typeparis) ============ */
.hero{padding:clamp(88px,11vh,148px) 0 clamp(80px,10vh,128px); overflow:hidden}
.hero-grid{display:grid; grid-template-columns:minmax(0,7fr) minmax(0,5fr); gap:0; align-items:start}
.hero-copy{position:relative; z-index:2; padding-top:34px}
.hero-copy .display{margin-bottom:10px}
.hero-media{position:relative; z-index:1; margin-top:clamp(90px,14vh,150px)}
.hero-copy .lead, .hero-copy .cta-row, .hero-copy .kick{position:relative; max-width:56ch}
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .hero-copy .display{margin-right:0}
  .hero-media{margin-top:34px}
}

/* ============ DUOTONE (ch. 06 · v6.1 amendment: light-dominant polarity,
     per the owner's typeparis decree — highlights carry the accent ink,
     shadows resolve to tinta via lighten) ============ */
.duo{position:relative; isolation:isolate; background:var(--duoHi); overflow:hidden}
.duo img{display:block; width:100%; height:auto; filter:grayscale(1) contrast(1.06); mix-blend-mode:multiply}
.duo::after{content:""; position:absolute; inset:0; background:var(--tinta); mix-blend-mode:lighten}
.duo--lavanda{--duoHi:var(--papel)}
.duo--rosa{--duoHi:var(--acento)}
figcaption{font-size:12.5px; padding-top:10px}

/* the slate frame on accent ground — reference motif, used sparingly */
.frame{border:14px solid var(--estructura); background:var(--surface-accent); padding:clamp(26px,5.6vw,64px)}
.frame--media{padding:0; background:var(--tinta)}

/* ============ CARDS — image + navy band (typeparis Q&A motif) ============ */
.cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:28px; margin-top:40px}
a.card{display:block; text-decoration:none; background:var(--surface-page)}
.card .card-top{
  background:var(--surface-tint); position:relative; overflow:hidden;
  min-height:240px; display:flex; align-items:flex-end; justify-content:center;
}
.card .glyph{
  font-weight:100; font-size:clamp(120px,12vw,190px); line-height:.78; color:var(--tinta);
  transform:translateY(8%); transition:transform var(--motion-base) var(--ease);
}
a.card:hover .glyph{transform:translateY(2%)}
.card .band{
  background:var(--surface-dark); color:var(--text-on-dark); padding:18px 20px 20px;
}
.card .band .kick{color:var(--text-on-dark); margin:0 0 6px; font-size:11px}
.card .band .name{
  font-weight:700; font-size:19px; line-height:1.25; margin:0;
  display:flex; align-items:baseline; justify-content:space-between; gap:12px;
}
.card .band .go{font-weight:500; font-size:11px; letter-spacing:.08em; text-transform:uppercase; white-space:nowrap}
a.card:hover .band{background:var(--estructura)}
a.card:active .band{background:var(--tinta)}

/* ============ SECTION FURNITURE ============ */
.section-head{max-width:780px; margin-bottom:36px}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:start}
@media(max-width:820px){ .grid-2{grid-template-columns:1fr} }

/* stats — large numerals are pizarra on light grounds (ch. 04) */
.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:28px; margin-top:38px}
.stat-num{font-weight:100; font-size:clamp(56px,7vw,96px); line-height:1; color:var(--estructura); margin:0}
.dark .stat-num{color:var(--acento)}
.stat-label{font-size:15px; max-width:24ch; margin-top:8px}

/* logo wall — categorized typographic grid on lavender (typeparis motif) */
.wall-group{margin-top:34px}
.wall-cat{font-weight:500; font-size:12px; letter-spacing:.09em; text-transform:uppercase; margin:0 0 12px}
.wall{
  list-style:none; padding:0; margin:0 0 8px; display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:10px 28px;
}
.wall li{font-weight:700; font-size:17px; margin:0; padding:9px 0; border-bottom:1px solid var(--estructura)}
.wall li.key{font-weight:900}

/* research list */
.pub{border-top:1px solid var(--estructura); padding:24px 0}
.pub:last-of-type{border-bottom:1px solid var(--estructura)}
.pub .year{font-weight:100; font-size:clamp(34px,4vw,52px); line-height:1; color:var(--estructura)}
.pub p{margin:8px 0 6px}
.pub .venue{font-size:13.5px}

/* about timeline */
.tl{border-left:1.5px solid var(--estructura); padding-left:26px; max-width:var(--measure)}
.tl-item{position:relative; padding-bottom:30px}
.tl-item::before{
  content:""; position:absolute; left:-32px; top:8px; width:11px; height:11px;
  background:var(--acento); border:2px solid var(--tinta); border-radius:50%;
}
.tl-dates{font-weight:500; font-size:12px; letter-spacing:.08em; text-transform:uppercase; margin:0 0 4px}
.tl-item h4{margin:0 0 4px}
.tl-item .where{font-size:13.5px; margin-bottom:8px}

/* ============ KEYNOTE TIMELINE — filterable, full list by default ============ */
.filters{display:flex; gap:10px; flex-wrap:wrap; margin:26px 0 8px}
.filter{
  display:inline-flex; align-items:center; border:3px solid var(--tinta); color:var(--tinta);
  background:transparent; font-family:var(--font-system); font-weight:700; font-size:13.5px;
  letter-spacing:.04em; padding:9px 16px; min-height:var(--target-min); cursor:pointer;
  transition:background var(--motion-fast) var(--ease);
}
.filter:hover{background:var(--acento)}
.filter[aria-pressed="true"]{background:var(--tinta); color:var(--luz)}
.kt-year{margin-top:44px}
.kt-year-num{font-weight:100; font-size:clamp(44px,5.4vw,72px); line-height:1; color:var(--estructura); margin:0 0 6px}
.kt{border-top:1px solid var(--estructura); padding:18px 0; display:grid; grid-template-columns:minmax(0,1fr) auto; gap:6px 28px}
.kt:last-child{border-bottom:1px solid var(--estructura)}
.kt h4{margin:0; font-size:17px}
.kt .org{font-size:14px; margin:2px 0 4px}
.kt .desc{font-size:14.5px; margin:0; max-width:62ch}
.kt .place{font-weight:500; font-size:12px; letter-spacing:.06em; text-transform:uppercase; white-space:nowrap; padding-top:3px}
.kt .vid{font-size:13.5px; margin-top:6px}
.kt.hide, .kt-year.hide{display:none}
@media(max-width:700px){ .kt{grid-template-columns:1fr} .kt .place{padding-top:0} }

/* ============ FORM (ch. 09) ============ */
.f label{display:block; font-weight:500; font-size:13px; letter-spacing:.04em; text-transform:uppercase; margin:18px 0 6px}
.f input,.f select,.f textarea{
  width:100%; max-width:520px; font-family:var(--font-system); font-size:16px; color:var(--tinta);
  background:var(--luz); border:1.5px solid var(--estructura); padding:12px; min-height:var(--target-min); border-radius:0;
}
.f textarea{min-height:140px; resize:vertical}
.f .field.err input,.f .field.err select,.f .field.err textarea{border:2.5px solid var(--tinta)}
.f .msg{display:none; font-size:13px; font-weight:500; margin-top:5px; max-width:520px}
.f .field.err .msg{display:block}
.f .msg::before{content:"⚠ "; font-weight:900}
.f .hint{font-size:13.5px; margin-top:5px}
.f .success{display:none; border:3px solid var(--tinta); background:var(--surface-page); padding:18px 20px; margin-top:24px; max-width:520px; font-weight:500}
.f.sent .success{display:block}
.f .reveal-fields{display:none}
.f .reveal-fields.on{display:block}
.f button[type="submit"]{margin-top:26px}

/* ============ FAT FOOTER — navy, white on dark (typeparis close) ============ */
.site-footer{background:var(--surface-dark); color:var(--text-on-dark); padding:clamp(88px,12vh,140px) 0 76px}
.site-footer .cols{display:grid; grid-template-columns:2fr 1fr 1fr; gap:44px; margin-bottom:44px}
@media(max-width:820px){ .site-footer .cols{grid-template-columns:1fr} }
.site-footer nav{display:flex; flex-direction:column; gap:8px; align-items:flex-start}
.site-footer nav a{font-size:15px; min-height:32px; display:inline-flex; align-items:center}
.site-footer .legal{font-size:13.5px; border-top:1px solid var(--estructura); padding-top:24px}
.site-footer .legal p{max-width:none}
.site-footer .struct{color:var(--papel)}
.mail-plain{font-weight:700; font-size:17px}

/* ============ MOTION — purpose only, ≤400ms, nothing loops ============ */
.reveal{opacity:0; transform:translateY(14px); transition:opacity var(--motion-slow) var(--ease), transform var(--motion-slow) var(--ease)}
.reveal.in{opacity:1; transform:none}
html:not(.js) .reveal{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition:none !important; animation:none !important}
  .reveal{opacity:1; transform:none}
}

/* ============ PRINT ============ */
@media print{
  .site-header,.site-footer,.menu-toggle,.mobile-panel,.skip-link,.filters{display:none}
  body{background:#fff; color:var(--tinta); font-size:12pt; border:none}
  a{text-decoration-color:var(--tinta)}
  section{padding:24pt 0}
  .kt.hide,.kt-year.hide{display:grid}
}

/* ---------- 404 ---------- */
.nf{min-height:calc(100vh - 28px);display:flex;align-items:center;padding:8vh 0}
.nf .display{margin:.35em 0 .9em}
.nf-links{display:flex;flex-wrap:wrap;gap:14px 34px;margin-bottom:9vh}
.nf-brand{margin:0}

/* ============================================================
   v6.1 AWWWARDS LAYER — choreography, not decoration.
   Five inks only · reduced-motion kills everything · mobile-aware
   ============================================================ */

/* ---------- brand curtain (CSS-only, injected class, once per session) ---------- */
html.curtain::before{
  content:"Alex Servin"; position:fixed; inset:0; z-index:999;
  background:var(--papel); color:var(--tinta);
  font-family:var(--font-mark); font-weight:850; font-size:clamp(42px,8.5vw,110px);
  display:grid; place-items:center; pointer-events:none;
  animation:curtainUp .9s cubic-bezier(.76,0,.24,1) .8s forwards;
}
@keyframes curtainUp{to{transform:translateY(-101%); visibility:hidden}}

/* ---------- view transitions (native, progressive) ---------- */
@view-transition{navigation:auto}
::view-transition-old(root){animation:vtOut .28s var(--ease) forwards}
::view-transition-new(root){animation:vtIn .34s var(--ease)}
@keyframes vtOut{to{opacity:0; transform:translateY(-8px)}}
@keyframes vtIn{from{opacity:0; transform:translateY(10px)}}

/* ---------- header: hides down, returns up (driven by JS class) ---------- */
.site-header{transition:transform .45s cubic-bezier(.76,0,.24,1)}
html.hdr-hide .site-header{transform:translateY(-100%)}

/* ---------- gsap takes over the old IO reveals ---------- */
html.gsap .reveal{opacity:1; transform:none; transition:none}

/* ---------- split lines mask ---------- */
html.gsap .display .line, html.gsap h1 .line{display:block; overflow:hidden}
html.gsap .display .line>div, html.gsap h1 .line>div{display:block}

/* ---------- duotone media: clip reveal + inner parallax ---------- */
html.gsap .duo{clip-path:inset(0 0 0 0)}
html.gsap .duo img{will-change:transform}

/* ---------- constellation skies inside dark surfaces ----------
   Sky Maps from the owner's archive: stars the sciences measure,
   figures the cultures imagine — the ensemble, in five inks. */
.dark, .site-footer{position:relative; overflow:hidden}
.sky{position:absolute; inset:0; pointer-events:none; opacity:.55}
.sky svg{position:absolute; will-change:transform}
.sky--polar svg{
  height:124%; width:auto; top:50%; right:-4%;
  transform:translateY(-50%) rotate(0.001deg);
  -webkit-mask-image:radial-gradient(closest-side, #000 48%, transparent 90%);
  mask-image:radial-gradient(closest-side, #000 48%, transparent 90%);
}
.sky--argo svg{
  height:118%; width:auto; top:50%; right:7%;
  transform:translateY(-50%);
  -webkit-mask-image:radial-gradient(74% 64% at 55% 50%, #000 30%, transparent 75%);
  mask-image:radial-gradient(74% 64% at 55% 50%, #000 30%, transparent 75%);
}
@media(max-width:900px){
  .sky--polar svg{height:92%; right:-26%}
  .sky--argo svg{height:108%; right:-30%}
}
.dark>.wrap, .site-footer>.wrap{position:relative; z-index:1}

/* atlas plate on light grounds (Ideas) */
.plate{border:1.5px solid var(--estructura); background:var(--luz); padding:18px; max-width:520px}
.plate img{display:block; width:100%; height:auto}

/* ---------- custom cursor (fine pointers only) ---------- */
@media (pointer:fine){
  html.gsap .cursor-dot{
    position:fixed; top:0; left:0; z-index:1000; pointer-events:none;
    width:10px; height:10px; border-radius:50%; background:var(--acento);
    mix-blend-mode:multiply; transform:translate(-50%,-50%);
  }
  html.gsap .cursor-dot.on{width:42px; height:42px; opacity:.65}
}
@media (pointer:coarse){ .cursor-dot{display:none} }

/* ---------- buttons: sliding fill ---------- */
html.gsap .btn-primary, html.gsap .chip, html.gsap .filter{position:relative; overflow:hidden; z-index:0}
html.gsap .btn-primary::after, html.gsap .chip::after, html.gsap .filter::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--estructura); transform:translateY(101%);
  transition:transform .35s cubic-bezier(.76,0,.24,1);
}
html.gsap .chip::after, html.gsap .filter::after{background:var(--acento)}
html.gsap .btn-primary:hover{background:var(--button-bg)}
html.gsap .chip:hover, html.gsap .filter:hover{background:transparent}
html.gsap .btn-primary:hover::after, html.gsap .chip:hover::after, html.gsap .filter:hover::after{transform:translateY(0)}
html.gsap .dark .btn-primary::after{background:var(--acento)}
html.gsap .dark .btn-primary:hover{background:var(--luz)}
html.gsap .filter[aria-pressed="true"]::after{display:none}

/* ---------- reduced motion: the layer disappears ---------- */
@media (prefers-reduced-motion:reduce){
  html.curtain::before{display:none}
  ::view-transition-old(root), ::view-transition-new(root){animation:none}
  html.gsap .btn-primary::after, html.gsap .chip::after, html.gsap .filter::after{display:none}
}

/* ---------- 404: the Pole Star medallion ---------- */
.nf-plate{margin:0 0 26px}
.nf-plate img{display:block; width:clamp(150px,22vw,230px); height:auto}
.nf-cap{color:var(--estructura); font-size:14px; max-width:56ch; margin-top:14px}

/* ============================================================
   PROLOGUE — stars (data) → lines (interpretation) → figure (meaning)
   Scroll-driven. Without JS or with reduced motion: final state, fully legible.
   ============================================================ */
.prologue{background:var(--tinta); color:var(--luz); height:430vh; position:relative}
.p-pin{position:sticky; top:0; height:100vh; min-height:580px; overflow:hidden;
  display:grid; grid-template-columns:minmax(0,44%) 1fr; gap:4vw;
  align-items:center; padding:0 6vw}
.p-copy{display:grid; align-items:center; min-height:340px}
.p-beat{grid-area:1/1; max-width:32ch; margin:0;
  font-size:clamp(21px,2.3vw,33px); font-weight:500; line-height:1.4}
.p-beat em{font-style:normal; color:var(--acento); font-weight:700}
.p-kick{display:block; font-size:12px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--acento); margin-bottom:16px}
.p-sky{justify-self:center; height:min(80vh,720px)}
.p-sky svg{height:100%; width:auto; display:block}
.p-sky .p-ln{stroke:var(--papel)}
@media(max-width:900px){
  .prologue{height:380vh}
  .p-pin{grid-template-columns:1fr; grid-template-rows:44vh 1fr; gap:18px;
    padding:84px 6vw 36px; align-items:start}
  .p-sky{height:100%; max-height:44vh}
  .p-beat{font-size:19px; max-width:none}
  .p-copy{min-height:0; align-items:start}
}
/* sin capa de motion: el argumento completo, estático y apilado */
html:not(.gsap) .prologue{height:auto}
html:not(.gsap) .p-pin{position:static; height:auto; min-height:0; padding:84px 6vw;
  grid-template-columns:minmax(0,44%) 1fr; align-items:center}
html:not(.gsap) .p-copy{display:block}
html:not(.gsap) .p-beat{margin:0 0 26px}
@media(max-width:900px){ html:not(.gsap) .p-pin{grid-template-columns:1fr} }

/* ---------- celestial echo lines on inner heroes ---------- */
.echo{color:var(--estructura); font-size:15px; line-height:1.55;
  max-width:52ch; margin:26px 0 0; font-style:normal}
.dark .echo{color:var(--papel)}


/* ============================================================
   HIGH-END PASS — monumental scale, editorial index, breathing room
   ============================================================ */
/* hero: headline full-bleed above, lead+portrait beneath */
.display--xl{max-width:none}
.hero-grid--under{display:grid; grid-template-columns:minmax(0,46%) 1fr;
  gap:clamp(32px,5vw,84px); align-items:start; margin-top:clamp(34px,5.5vh,64px)}
.hero-grid--under .hero-media{margin-top:8px}
.hero-grid--under .hero-copy{padding-top:clamp(8px,2vh,28px)}
@media(max-width:900px){
  .hero-grid--under{grid-template-columns:1fr; gap:30px}
}

/* editorial index — the helices as monumental rows */
.ix{border-top:1.5px solid rgba(90,102,120,.4); margin-top:clamp(28px,5vh,56px)}
.ix-row{position:relative; display:grid; align-items:center;
  grid-template-columns:clamp(64px,9vw,150px) 1fr auto; gap:clamp(18px,4vw,56px);
  padding:clamp(30px,5vh,58px) 0; border-bottom:1.5px solid rgba(90,102,120,.4);
  text-decoration:none; color:inherit; z-index:0}
.ix-num{font-weight:100; font-size:clamp(44px,6.5vw,104px); line-height:1; color:var(--estructura)}
.ix-kick{display:block; font-size:12.5px; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--estructura); margin-bottom:12px}
.ix-name{display:block; font-weight:700; font-size:clamp(30px,4.8vw,76px);
  line-height:1.04; letter-spacing:-.01em}
.ix-go{font-size:clamp(26px,3.2vw,46px); color:var(--acento); font-weight:300;
  transition:transform .38s cubic-bezier(.76,0,.24,1)}
.ix-row::after{content:""; position:absolute; inset:0 calc(-1*clamp(24px,4.5vw,72px));
  background:var(--papel); transform:scaleY(0); transform-origin:bottom;
  transition:transform .42s cubic-bezier(.76,0,.24,1); z-index:-1}
.ix-row:hover::after, .ix-row:focus-visible::after{transform:scaleY(1)}
.ix-row:hover .ix-go{transform:translateX(16px)}
@media(max-width:640px){ .ix-go{display:none} .ix-row{grid-template-columns:56px 1fr} }

/* larger touch-worthy CTAs */
.btn-primary{padding:17px 32px; font-size:15px}
.chip{padding:15px 26px; font-size:14.5px}


/* institutional band — full section, sky at scale */
.band{padding:clamp(110px,14vh,170px) 0}
.band .kick{margin-bottom:22px}
.band-names{font-size:clamp(22px,2vw,30px); font-weight:300; line-height:1.65;
  margin:0; max-width:46ch}


/* ============================================================
   REACTIVE SKIES + PHOTO PLATES + ACADEMY (v6.1c)
   ============================================================ */
.hero{position:relative}
.hero-sky{position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:0}
.hero>.wrap{position:relative; z-index:1}

.plate-photo{position:relative; background:transparent}
.plate-photo::before{content:""; position:absolute; left:0; right:0; top:14%; bottom:0;
  background:var(--papel)}
.plate-photo img{position:relative; display:block; width:100%; height:auto;
  filter:drop-shadow(0 18px 34px rgba(38,49,88,.16))}
.dark .plate-photo::before{background:rgba(219,224,245,.12)}
.ct-photo{max-width:380px; margin:34px 0 0}

.ky-grid{display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(32px,5vw,80px); align-items:start}
@media(max-width:900px){ .ky-grid{grid-template-columns:1fr} }

.courses{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:clamp(22px,2.6vw,38px)}
@media(max-width:760px){ .courses{grid-template-columns:1fr} }
.course{background:var(--luz); padding:clamp(28px,3.4vw,46px); display:flex; flex-direction:column; gap:14px}
.course-kick{font-size:12.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--estructura); margin:0}
.course-name{font-size:clamp(24px,2.4vw,34px); font-weight:700; line-height:1.12; margin:0}
.course-desc{margin:0 0 6px; color:var(--tinta)}
.course .chip{align-self:flex-start; margin-top:auto}
.course-note{margin:clamp(30px,4vh,46px) 0 0; color:var(--estructura); max-width:64ch}

/* micro-constellations in the editorial index — drawn on hover */
.ix-row{grid-template-columns:clamp(64px,9vw,150px) 1fr auto auto}
.mini-c{width:clamp(96px,9.5vw,150px); height:auto; display:block; opacity:.9}
.mini-c circle{fill:var(--tinta)}
.mini-c path{stroke:var(--acento); stroke-width:2.2; fill:none; stroke-linecap:round;
  stroke-dasharray:520; stroke-dashoffset:520;
  transition:stroke-dashoffset .7s cubic-bezier(.65,0,.35,1)}
.ix-row:hover .mini-c path, .ix-row:focus-visible .mini-c path{stroke-dashoffset:0}
@media(max-width:760px){ .mini-c{display:none} .ix-row{grid-template-columns:56px 1fr auto} }


/* scroll-reveal: the glasses go on as you scroll (Casual → Relax) */
.rg{display:grid}
.rg img{grid-area:1/1}
.rg .rg-top{clip-path:inset(0 0 100% 0)}
html:not(.gsap) .rg .rg-top{clip-path:none}


/* band bridge — the prologue's last beat reaches the institutions */
.band-bridge{color:var(--papel); font-size:clamp(20px,1.7vw,26px); font-weight:500; margin:0 0 16px}

/* stage record gallery */
.gal{display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,3vw,44px); margin-top:clamp(28px,4vh,44px)}
.gal-wide{grid-column:1/-1}
.gal-ph{background:var(--tinta); overflow:hidden}
.gal-ph img{display:block; width:100%; height:auto; scale:1.1;
  transition:scale .9s cubic-bezier(.22,1,.36,1)}
.gal-it:hover .gal-ph img{scale:1.17}
.gal figcaption{margin-top:13px; font-size:14.5px; color:var(--estructura); max-width:62ch}
@media(max-width:760px){ .gal{grid-template-columns:1fr} }


/* cinematic full-bleed — the packed hall, edge to edge */
.bleed{position:relative; height:min(86vh,820px); overflow:hidden; background:var(--tinta)}
.bleed-media{position:absolute; inset:-9% 0}
.bleed-media img{width:100%; height:100%; object-fit:cover; opacity:.94}
.bleed::after{content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(to top, rgba(38,49,88,.82), rgba(38,49,88,.16) 52%, rgba(38,49,88,.34))}
.bleed-copy{position:absolute; left:0; right:0; bottom:clamp(42px,9vh,88px); z-index:3}
.bleed-line{color:var(--luz); font-size:clamp(30px,4.3vw,58px); font-weight:700;
  line-height:1.1; max-width:17ch; margin:0}

/* hero figures (consulting · research) */
.hero-figure{max-width:740px; margin:clamp(28px,4vh,42px) 0 6px}

/* cursor star — the visitor carries a small star across the site */
.cs-dot,.cs-ring{position:fixed; top:0; left:0; pointer-events:none; z-index:998;
  border-radius:50%; will-change:transform}
.cs-dot{width:8px; height:8px; background:var(--acento); margin:-4px 0 0 -4px}
.cs-ring{width:30px; height:30px; border:1.5px solid rgba(38,49,88,.32); margin:-15px 0 0 -15px;
  transition:width .25s,height .25s,margin .25s,border-color .25s}
.cs-ring.is-link{width:46px; height:46px; margin:-23px 0 0 -23px; border-color:rgba(239,175,247,.8)}
.dark .cs-ring{border-color:rgba(219,224,245,.4)}
@media(pointer:coarse){ .cs-dot,.cs-ring{display:none} }


/* patron constellations — one mythic figure guards each room */
.hero-fig{position:absolute; pointer-events:none; z-index:0; opacity:.11; width:auto}
.hero-fig--lyra{left:3%; top:11%; height:min(30vh,240px)}
.hero-fig--sag{right:4%; top:10%; height:min(54vh,430px)}
.hero-fig--cygnus{left:46%; top:7%; height:min(36vh,290px)}
.hero-fig--gemini{left:-2%; bottom:5%; height:min(50vh,400px); opacity:.07}
@media(max-width:900px){ .hero-fig{display:none} }

/* the prologue's figure returns above the packed hall */
.bleed-fig{position:absolute; right:5%; bottom:-3%; height:86%; z-index:2;
  opacity:.36; pointer-events:none}


/* client wall: name + provenance meta */
.wall-meta{display:block; font-size:12.5px; line-height:1.45; color:var(--estructura); margin-top:2px}
.wall li{margin-bottom:10px}

/* documents (posters, credentials): never cropped by the zoom frame */
.gal-doc .gal-ph img{scale:1}
.gal-doc:hover .gal-ph img{scale:1.04}

/* GSAP bold layer — bridge letters split without reflow; method falls in clean */
.band-bridge .b-ch{display:inline-block; will-change:transform,opacity}
.method .grid-2 h4{will-change:transform,opacity}
.gsap .band-bridge{min-height:1.2em}

/* ============================================================
   COSMIC FIELD LAYER — generated atmospheres (Higgsfield + baked duotone)
   ============================================================ */

/* B1 — hero atmospheric field behind the star canvas.
   The canvas (hero-sky) keeps drawing animated stars + cursor on top,
   now over a real long-exposure cosmos instead of flat color. */
.hero{background:#1a2240}
.hero::before{ content:none; }  /* B1 retired — global cosmos governs the hero now */
.hero-sky{z-index:1}
.hero > .wrap{position:relative; z-index:2}

/* D1 — subtle stardust/paper grain multiplied across dark sections for soul */
.dark{position:relative}
.dark::after{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:url("/img/d1-field.webp") center / cover;
  mix-blend-mode:soft-light; opacity:.40;
}
.dark > .wrap{position:relative; z-index:1}



/* C1 — the Sociograma rendered as art, anchoring the method section */
.sociogram-art{
  margin:clamp(36px,7vh,80px) auto clamp(28px,5vh,56px);
  max-width:min(1000px,96%);
  position:relative; z-index:1;
}
.sociogram-art img{
  width:100%; height:auto; display:block;
  /* glow sutil para que los nodos se sientan luminosos sobre el cosmos */
  filter:drop-shadow(0 0 40px rgba(120,160,220,.18));
}

/* WebGL cosmos layer — sits behind everything in the hero */
.hero-gl{position:absolute; inset:0; z-index:0; pointer-events:none}
.hero-gl canvas{display:block; width:100%!important; height:100%!important}
/* with WebGL active, fade the flat 2D canvas to a faint cursor-only accent */
.hero-gl ~ .hero-sky{opacity:.5; z-index:1}
/* the baked B1 field becomes a subtle base tint under the live GL */
/* .hero::before retired */


/* hero content sits above the live cosmos */
.hero > .wrap{position:relative; z-index:3}
.hero-gl{z-index:0}
.hero-gl ~ .hero-sky{z-index:1}


/* hero text inverts to light over the dark living cosmos */
.hero .kick{color:#DBE0F5}
.hero h1, .hero .display, .hero .display span, .hero h1 span{color:#fff}
.hero .lead{color:rgba(219,224,245,.88)}
.hero .chip, .hero .cta{color:#DBE0F5; border-color:rgba(219,224,245,.42)}
.hero .chip:hover, .hero .cta:hover{background:rgba(219,224,245,.12); border-color:rgba(219,224,245,.7)}

/* ============================================================
   COSMOS IMMERSION (v6.4) — one continuous starfield behind the
   whole site; sections float over it. Dark cosmos governs; content
   stays legible on subtle panels where needed.
   ============================================================ */

/* the fixed WebGL canvas, behind everything */
#cosmos{
  position:fixed; inset:0; z-index:0; pointer-events:none;
}
#cosmos canvas{display:block; width:100vw!important; height:100vh!important}

/* deep space base so even before/without WebGL the site reads as cosmos */
html{background:#11162b}
body{
  background:transparent!important;
  border-color:#11162b!important;
  color:#e7eaf6;
  position:relative; z-index:1;
}

/* header: a faint cosmic glass bar, not solid white */
.site-header{
  background:rgba(17,22,43,.72)!important;
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid rgba(219,224,245,.10);
}
.site-header a, .site-header .wordmark{color:#eef0fa}
.site-header a:hover{color:#fff}

/* main content sits above the cosmos */
#contenido{position:relative; z-index:1}

/* every section becomes transparent so the cosmos shows through;
   content that needs contrast gets a subtle floating panel */
section{background:transparent!important; position:relative}
section .wrap{position:relative; z-index:1}

/* light sections → subtle translucent panel for legibility */
section.tint, section:not(.dark):not(.hero):not(.prologue){
  background:rgba(20,26,48,.42)!important;
  backdrop-filter:blur(2px);
}
/* dark sections → deeper panel */
section.dark{background:rgba(12,16,32,.58)!important; backdrop-filter:blur(3px)}

/* hero stays fully open to the cosmos (no panel) */
section.hero{background:transparent!important; backdrop-filter:none}
.hero .hero-sky{display:none}  /* retire the old flat 2D canvas */

/* text inverts to light across the now-dark site */
body, p, li, .lead, .struct, h1,h2,h3,h4,h5{color:#e7eaf6}
.kick, .label-xl{color:#c7cdf0}
.struct{color:#9aa3c9}
a{color:#dbe0f5}
h1,h2,h3,h4{color:#fff}

/* footer transparent over cosmos */
.site-footer, footer{background:rgba(12,16,32,.62)!important; color:#cfd5ef}

/* ============================================================
   FIX v6.4.1 — kill leftover light panels that broke immersion,
   restore contrast on navigation cards over the dark cosmos.
   ============================================================ */

/* navigation cards (01 · El escenario …): were light, now cosmic glass */
a.card{
  background:rgba(20,26,48,.55)!important;
  backdrop-filter:blur(6px) saturate(120%);
  -webkit-backdrop-filter:blur(6px) saturate(120%);
  border:1px solid rgba(219,224,245,.12);
  border-radius:4px; overflow:hidden;
}
.card .card-top{
  background:rgba(12,16,32,.45)!important;
  border-bottom:1px solid rgba(219,224,245,.08);
}
.card .glyph{color:rgba(219,224,245,.55)!important}      /* the big 01/02 number, now visible */
a.card:hover .glyph{color:rgba(219,224,245,.8)!important}

/* card label band — text must read on the dark panel */
.card .band{background:transparent!important; padding:18px 20px 20px}
.card .band .kick{color:#c7cdf0!important}
.card .band .name{color:#fff!important}
.card .band .go{color:#efaff7!important}                 /* arrow/cta in brand rosa */
a.card:hover{background:rgba(28,36,64,.7)!important; border-color:rgba(219,224,245,.22)}
a.card:hover .band{background:transparent!important}
a.card:active .band{background:transparent!important}

/* any remaining tinted section panel → cosmic, not pale */
section.tint{background:rgba(20,26,48,.42)!important}
.band-bridge{color:#eef0fa!important}

/* the bleed/echo decorative text shouldn't be pale-on-dark either */
.dark .echo{color:rgba(219,224,245,.18)!important}

/* FIX v6.4.1 — ix navigation rows: contrast over the dark cosmos.
   The hover panel was pale lavender behind light text → invisible. */
.ix-name{color:#fff!important}
.ix-kick{color:#c7cdf0!important}
.ix-num{color:rgba(219,224,245,.45)!important}
.ix-go{color:#efaff7!important}
.ix{border-top-color:rgba(219,224,245,.18)!important}
.ix-row{border-bottom-color:rgba(219,224,245,.14)!important}
/* hover panel → subtle cosmic glass, not pale */
.ix-row::after{
  background:rgba(28,36,64,.55)!important;
  backdrop-filter:blur(4px);
}
.ix-row:hover .ix-num{color:rgba(219,224,245,.7)!important}
.ix-row:hover .ix-name{color:#fff!important}

/* ============================================================
   EVEREST — Fontanarrosa quote replaces the old institutions band.
   No cascade animation; a calm editorial moment floating in the cosmos.
   ============================================================ */
.everest-kick{
  color:#9aa3c9!important; text-align:center;
  font-size:12.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  margin:0 0 clamp(22px,4vh,40px);
}
.everest{
  margin:0 auto; max-width:18ch; padding:0;
  text-align:center; border:none;
  color:#fff; font-weight:500;
  font-size:clamp(26px,3.4vw,46px); line-height:1.28; letter-spacing:-.01em;
  text-wrap:balance;
}
.everest-author{
  text-align:center; color:#c7cdf0!important;
  margin:clamp(20px,3.5vh,34px) 0 0;
  font-size:clamp(14px,1.2vw,17px); font-style:italic; letter-spacing:.02em;
}
/* the band section: generous vertical breathing, open to the cosmos */
.band{padding:clamp(90px,16vh,180px) 0!important; text-align:center}

/* ============================================================
   MOBILE AUDIT FIX — the menu panel and toggle were white,
   breaking the cosmic immersion on phones/tablets. Now cosmic glass.
   ============================================================ */
@media(max-width:1099px){
  /* the MENÚ button: light outline over the dark cosmos header */
  .menu-toggle{
    border-color:rgba(219,224,245,.5)!important; color:#eef0fa!important;
  }
  .menu-toggle:hover{border-color:#dbe0f5!important; background:rgba(219,224,245,.08)!important}

  /* the open menu panel: deep cosmic glass, not white */
  .mobile-panel{
    background:rgba(13,17,34,.92)!important;
    backdrop-filter:blur(20px) saturate(120%);
    -webkit-backdrop-filter:blur(20px) saturate(120%);
    border-color:rgba(17,22,43,.9)!important;
  }
  .mobile-panel .wordmark{color:#fff!important}
  /* CERRAR button light */
  .menu-close{
    border-color:rgba(219,224,245,.5)!important; color:#eef0fa!important;
  }
  .menu-close:hover{border-color:#dbe0f5!important; background:rgba(219,224,245,.08)!important}
  /* nav links: clear and legible, brand rosa underline */
  .mobile-panel nav a{
    color:#fff!important;
    text-decoration-color:rgba(239,175,247,.7)!important;
  }
  .mobile-panel nav a:hover, .mobile-panel nav a[aria-current="page"]{
    color:#efaff7!important; text-decoration-color:#efaff7!important;
  }
  /* language switch legible */
  .mobile-panel .lang-switch a{color:#c7cdf0!important}
  .mobile-panel .lang-switch a[aria-current="true"], .mobile-panel .lang-switch a.is-active{color:#fff!important}
}

/* FIX — the prologue must flow openly with the cosmos, no translucent panel.
   The panel's top edge was reading as a stray horizontal bar before
   "PRÓLOGO · LAS ESTRELLAS". Make it fully transparent like the hero. */
.prologue, section.prologue{
  background:transparent!important;
  backdrop-filter:none!important;
}


/* ============================================================
   LEGIBILITY FIX — the cosmic inversion turned all text light,
   but cards/inputs with a LIGHT background (--luz) kept that bg,
   leaving white-on-light (invisible). Restore dark text inside them.
   ============================================================ */
.course, .course *,
.plate, .plate *,
.f input, .f textarea, .f select{
  color:var(--tinta);
}
.course-name{ color:var(--tinta)!important; }
.course-desc, .course-note{ color:var(--tinta); }
/* chips inside light cards keep their own styling */
.course .chip{ color:var(--tinta); }
/* form fields: dark text on the light input bg */
.f input, .f textarea{ color:var(--tinta)!important; }
.f input::placeholder, .f textarea::placeholder{ color:var(--estructura); }

/* ============================================================
   LEGIBILITY FIX — .chip and .filter used navy text/border on a
   transparent bg; over the dark cosmos that was navy-on-navy (1.39:1).
   Give them light text/border over the cosmos. Inside light cards
   (.course, .plate) they keep navy via the rule above.
   ============================================================ */
.chip, .filter{
  color:#dbe0f5;
  border-color:rgba(219,224,245,.55);
}
.chip:hover, .filter:hover{
  background:rgba(219,224,245,.10);
  border-color:#dbe0f5;
}
/* pressed/active filter: solid lavender bg with dark text */
.filter[aria-pressed="true"]{
  background:#dbe0f5; color:var(--tinta); border-color:#dbe0f5;
}
/* chips that sit inside LIGHT cards stay dark for contrast */
.course .chip, .plate .chip{
  color:var(--tinta); border-color:var(--tinta);
}
.course .chip:hover, .plate .chip:hover{
  background:var(--tinta); color:#fff;
}

/* ============================================================
   LEGIBILITY FIX — secondary text using --estructura (slate) fell
   to ~3:1 over the dark cosmos. Lift these to a readable lavender.
   ============================================================ */
.echo{ color:#aab2d4; }                    /* "Sus datos ya tienen estrellas" → 4.6:1 */
.gal figcaption{ color:#aab2d4; }          /* gallery captions → readable */
figcaption{ color:#aab2d4; }               /* all captions over cosmos */
.struct{ color:#aab2d4; }
/* but inside LIGHT cards, captions/struct stay dark */
.course figcaption, .plate figcaption,
.course .struct, .plate .struct{ color:var(--estructura); }
/* client roster metadata spans (country/Fortune) → lift to readable */
.client-meta, .roster-meta, .ros-meta{ color:#aab2d4; }

/* ============================================================
   LEGIBILITY FIX (final) — .course-note sits over the cosmos
   (outside the light cards), so it needs light text, and the
   client-roster metadata (.wall-meta) needed a touch more contrast.
   ============================================================ */
.course-note{ color:#aab2d4!important; }
.course-note a strong, .course-note strong{ color:#efaff7; }
.wall-meta{ color:#9aa3c9; }              /* was slate ~3:1; now ~4.6:1 over cosmos */

/* the lineage note that closes the method section (Maffesoli/Moscovici nod) —
   a legible aside, lavender over the dark panel, set apart with a top rule */
.method-note{
  color:#cdd3ee;
  font-size:clamp(15px,1.15vw,17px);
  line-height:1.65;
  max-width:74ch;
  margin:clamp(28px,4vh,44px) 0 0;
  padding-top:clamp(20px,2.5vh,28px);
  border-top:1px solid rgba(219,224,245,.22);
  font-style:italic;
}
