/* ZALA · shared styles
   Hybrid voice: Montserrat ALL CAPS headlines (Constitution) + Inter 300 body
   + Fraunces italic accents (Design F restraint) + JetBrains Mono labels.
   Moon-grey floor with tiled ZALA mark for editorial sections.
   Black sections for cinematic strips. Cyan #13bbe2 single accent. */

:root{
  --zala-blue:#13bbe2;
  --moon:#cecece;
  --moon-soft:#d8d8d8;
  --ink:#070809;
  --ink-2:#1a1a1a;
  --ink-3:#3d3d3d;
  --muted:#6e6e6e;
  --rule:rgba(0,0,0,.10);
  --rule-strong:rgba(0,0,0,.22);
  --rule-dark:rgba(255,255,255,.12);

  --font-display:'Montserrat','Helvetica Neue',Arial,sans-serif;
  --font-body:'Inter','Helvetica Neue',Arial,sans-serif;
  --font-italic:'Fraunces',Georgia,serif;
  --font-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;

  --max:1280px;
  --gutter:48px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-weight:300;
  color:var(--ink);
  background:var(--moon);
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit}

/* ---- Brand floor: moon-grey + DENSER tiled ZALA mark (140px) + 82% overlay ---- */
/* LV-monogram-canvas density — small marks, tight grid, atmospheric not decorative. */
.floor{
  position:relative;
  background:var(--moon);
  background-image:url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='140'%20height='140'%20viewBox='0%200%20140%20140'%3E%3Cg%20fill='%2313bbe2'%3E%3Cg%20transform='translate(20,32)%20scale(0.016)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3Cg%20transform='translate(95,10)%20scale(0.009)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3Cg%20transform='translate(85,90)%20scale(0.011)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3Cg%20transform='translate(12,100)%20scale(0.008)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-size:140px;
  overflow:hidden;
}
.floor::before{
  content:"";position:absolute;inset:0;
  background:rgba(206,206,206,.82);
  pointer-events:none;
}
.floor > *{position:relative;z-index:1}

/* ---- Dark floor: black with the same dense ZALA tile, lower opacity ---- */
.floor-dark{
  position:relative;
  background:var(--ink);
  background-image:url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='140'%20height='140'%20viewBox='0%200%20140%20140'%3E%3Cg%20fill='%2313bbe2'%3E%3Cg%20transform='translate(20,32)%20scale(0.016)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3Cg%20transform='translate(95,10)%20scale(0.009)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3Cg%20transform='translate(85,90)%20scale(0.011)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3Cg%20transform='translate(12,100)%20scale(0.008)'%3E%3Cpath%20d='M2837.6,2130l-17.7-1.9c-35.4-3.3-72.4-4.9-109.7-4.9h-1104c-106,0-201.9-54.3-256.4-145.1c-54.3-90.4-57.3-199.8-7.9-292.8c160-299.8,267.6-711.5-92.9-1008L0.3,2610.7h3694.2C3487.9,2338.4,3180.7,2165.1,2837.6,2130z%20M365.5,0c209.2,275.1,520.3,449,867.8,481.9l12.3,0.9c34.5,3,69.6,4.7,104.3,4.7h1103.8c106.2,0,201.9,54.3,256.4,145.1c54.3,90.4,57.3,199.8,7.7,292.5c-159.5,300-267.1,711.8,93.2,1008L4059.9,0H365.5z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-size:140px;
  color:#fff;
  overflow:hidden;
}
.floor-dark::before{
  content:"";position:absolute;inset:0;
  background:rgba(7,8,9,.94);
  pointer-events:none;
}
.floor-dark > *{position:relative;z-index:1}
.floor-dark h1,.floor-dark h2,.floor-dark h3{color:#fff}
.floor-dark h1 .em,.floor-dark h2 .em{color:rgba(255,255,255,.6)}
.floor-dark .deck{color:rgba(255,255,255,.82)}
.floor-dark .deck em{color:#fff}
.floor-dark .deck b{color:#fff}

/* ---- Layout ---- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
section{padding:96px 0;position:relative}
section.tight{padding:64px 0}

/* ---- Typography primitives ---- */
.kicker{
  font-family:var(--font-mono);
  font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--zala-blue);
  margin-bottom:24px;display:flex;align-items:center;gap:14px;
}
.kicker::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.kicker.dark{color:var(--zala-blue)}
.kicker.dark::before{background:var(--zala-blue)}

h1,h2,h3{
  font-family:var(--font-display);
  font-weight:900;text-transform:uppercase;
  letter-spacing:-.028em;line-height:.92;
  margin:0 0 24px;color:var(--ink);
}
h1{font-size:clamp(48px,7.2vw,112px)}
h2{font-size:clamp(36px,5vw,76px)}
h3{font-size:clamp(22px,2.4vw,32px)}
h1 .blue,h2 .blue,h3 .blue{color:var(--zala-blue)}
h1 .em,h2 .em{
  font-family:var(--font-italic);font-style:italic;
  font-weight:400;text-transform:none;letter-spacing:-.012em;
  color:var(--ink-2);
}

/* Editorial display · for atmospheric scene-setters · Inter 200 italic */
.ed{
  font-family:var(--font-body);font-weight:200;
  font-size:clamp(40px,7vw,108px);
  line-height:.96;letter-spacing:-.038em;
  color:var(--ink);margin:0 0 24px;
}
.ed em{
  font-family:var(--font-italic);font-style:italic;
  font-weight:300;color:var(--zala-blue);
}
.ed .quiet{color:rgba(0,0,0,.42)}
.floor-dark .ed,.cinema-hero .ed,.strip .ed{color:#fff}
.floor-dark .ed em,.cinema-hero .ed em,.strip .ed em{color:var(--zala-blue)}
.floor-dark .ed .quiet,.cinema-hero .ed .quiet,.strip .ed .quiet{color:rgba(255,255,255,.36)}

/* Editorial small caps · interstitial labels */
.ed-cap{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;
  color:var(--zala-blue);margin-bottom:24px;
  display:inline-flex;align-items:center;gap:14px;
}
.ed-cap::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}

/* ---- Iconic display · billboard-stacked ALL CAPS ---- */
.icon-stamp{
  font-family:var(--font-display);font-weight:900;
  text-transform:uppercase;
  font-size:clamp(80px,16vw,260px);
  line-height:.78;letter-spacing:-.052em;
  margin:0 0 32px;color:#fff;
}
.icon-stamp .blue{color:var(--zala-blue)}
.icon-stamp .quiet{color:rgba(255,255,255,.42)}
.icon-stamp em{
  font-family:var(--font-italic);font-style:italic;
  font-weight:400;text-transform:none;
  color:rgba(255,255,255,.55);letter-spacing:-.014em;
}
.floor .icon-stamp{color:var(--ink)}
.floor .icon-stamp .quiet{color:rgba(0,0,0,.42)}
.floor .icon-stamp em{color:var(--ink-2)}

/* ---- IN / OUT contrast diptych ---- */
.contrast-half{
  position:relative;min-height:78vh;background:var(--ink);
  overflow:hidden;display:flex;align-items:flex-end;color:#fff;
}
.contrast-half .bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  will-change:transform;animation:slow-zoom 36s ease-in-out infinite alternate;
}
.contrast-half.in .bg{ filter:saturate(.72) contrast(1.22) brightness(.42) grayscale(.45) }
.contrast-half.out .bg{ filter:saturate(1.04) contrast(1.18) brightness(.66) }
.contrast-half .veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.28) 0%,rgba(0,0,0,.04) 36%,rgba(0,0,0,.20) 62%,rgba(0,0,0,.88) 100%);
}
.contrast-half .side-tag{
  position:absolute;top:50%;left:32px;transform:translateY(-50%) rotate(-90deg);
  transform-origin:center;
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  z-index:3;white-space:nowrap;
}
@media (max-width:880px){.contrast-half .side-tag{display:none}}
.contrast-half .wrap{position:relative;z-index:2;padding:96px var(--gutter);width:100%}
.contrast-half .lab{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;
  color:var(--zala-blue);margin-bottom:32px;
  display:inline-flex;align-items:center;gap:14px;
}
.contrast-half .lab::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.contrast-half h2{
  font-size:clamp(80px,15vw,220px);line-height:.80;letter-spacing:-.048em;
  color:#fff;margin-bottom:24px;
  text-shadow:0 3px 32px rgba(0,0,0,.5);
}
.contrast-half h2 .em{
  font-family:var(--font-italic);font-style:italic;font-weight:400;
  text-transform:none;color:rgba(255,255,255,.5);letter-spacing:-.018em;
}
.contrast-half .sub{
  font-family:var(--font-body);font-weight:300;
  font-size:clamp(17px,1.4vw,22px);line-height:1.55;
  color:rgba(255,255,255,.9);max-width:640px;margin-top:0;
  text-shadow:0 1px 14px rgba(0,0,0,.5);
}
.contrast-half .sub em{font-family:var(--font-italic);font-style:italic;color:#fff}

.contrast-rule{height:2px;background:var(--zala-blue);position:relative;z-index:5}

.contrast-synth{
  padding:140px 0;background:var(--ink);color:#fff;text-align:center;
  position:relative;overflow:hidden;
}
.contrast-synth::after{
  content:"§";position:absolute;top:-60px;right:-40px;
  font-family:var(--font-italic);font-style:italic;
  font-size:clamp(280px,40vw,640px);
  color:rgba(19,187,226,.05);line-height:.8;pointer-events:none;
}
.contrast-synth .wrap{position:relative;z-index:2}
.contrast-synth h2{
  font-size:clamp(96px,17vw,260px);line-height:.78;letter-spacing:-.05em;
  color:#fff;margin-bottom:24px;
}
.contrast-synth h2 .blue{color:var(--zala-blue)}
.contrast-synth .sub{
  font-family:var(--font-body);font-weight:300;
  font-size:clamp(18px,1.5vw,24px);line-height:1.55;
  color:rgba(255,255,255,.82);max-width:760px;margin:0 auto;
}
.contrast-synth .sub em{font-family:var(--font-italic);font-style:italic;color:#fff}

/* ---- IO LIVE BROADCAST · Apple TV × Spotify × NFL Network ---- */

/* LIVE indicator with pulse */
.live-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:#ff2a2a;
  box-shadow:0 0 0 0 rgba(255,42,42,.7);
  animation:live-pulse 1.6s infinite;
  margin-right:8px;vertical-align:middle;
}
@keyframes live-pulse{
  0%{box-shadow:0 0 0 0 rgba(255,42,42,.7)}
  70%{box-shadow:0 0 0 10px rgba(255,42,42,0)}
  100%{box-shadow:0 0 0 0 rgba(255,42,42,0)}
}
.on-air{color:#ff2a2a;font-weight:700;letter-spacing:.42em}

/* Today on IO · live broadcast banner */
.today-band{
  background:var(--ink);color:#fff;padding:0;border-bottom:6px solid var(--zala-blue);
  position:relative;overflow:hidden;
}
.today-band .head-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px var(--gutter);
  background:#000;border-bottom:1px solid rgba(255,255,255,.12);
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;color:rgba(255,255,255,.62);gap:14px;flex-wrap:wrap;
}
.today-band .head-row b{color:#fff;font-weight:500}
.today-band .now-strip{
  padding:56px var(--gutter) 48px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;
  max-width:var(--max);margin:0 auto;
}
@media (max-width:980px){.today-band .now-strip{grid-template-columns:1fr;gap:32px}}
.today-band .now-feature{}
.today-band .now-feature .lab{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  margin-bottom:18px;display:flex;align-items:center;gap:8px;
}
.today-band .now-feature h2{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(40px,6.2vw,84px);line-height:.92;letter-spacing:-.034em;
  text-transform:uppercase;color:#fff;margin:0 0 14px;
}
.today-band .now-feature h2 em{
  font-family:var(--font-italic);font-style:italic;font-weight:400;
  text-transform:none;color:rgba(255,255,255,.55);letter-spacing:-.014em;
}
.today-band .now-feature .when{
  font-family:var(--font-mono);font-size:12px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.78);
  margin-bottom:18px;
}
.today-band .now-feature .when b{color:var(--zala-blue);font-weight:700}
.today-band .now-feature .summary{
  font-family:var(--font-body);font-weight:300;font-size:16.5px;
  line-height:1.55;color:rgba(255,255,255,.86);max-width:560px;margin-bottom:24px;
}
.today-band .now-feature .summary em{font-family:var(--font-italic);font-style:italic;color:#fff}
.today-band .now-feature .cta-row{display:flex;gap:14px;flex-wrap:wrap}
.today-band .now-feature .btn{border-color:var(--zala-blue);color:var(--zala-blue)}
.today-band .now-feature .btn:hover{background:var(--zala-blue);color:var(--ink)}
.today-band .now-feature .btn.prim{background:var(--zala-blue);color:var(--ink)}
.today-band .now-feature .btn.prim:hover{background:#fff;border-color:#fff;color:var(--ink)}

.today-band .now-art{
  position:relative;aspect-ratio:16/10;background-size:cover;background-position:center;
  border:1px solid rgba(255,255,255,.20);overflow:hidden;
}
.today-band .now-art::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7) 100%);
}
.today-band .now-art .art-stamp{
  position:absolute;left:18px;bottom:18px;z-index:2;
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;color:rgba(255,255,255,.86);
}
.today-band .now-art .art-stamp b{color:var(--zala-blue);font-weight:700}

/* Today's schedule strip · 5 broadcasts */
.today-band .sched{
  display:grid;grid-template-columns:repeat(5,1fr);
  border-top:1px solid rgba(255,255,255,.18);
  background:#000;
}
@media (max-width:880px){.today-band .sched{grid-template-columns:repeat(2,1fr)}}
@media (max-width:460px){.today-band .sched{grid-template-columns:1fr}}
.sched-cell{
  padding:20px 18px;
  border-right:1px solid rgba(255,255,255,.10);
  display:flex;flex-direction:column;gap:6px;cursor:default;
  transition:background .15s;text-decoration:none;color:inherit;position:relative;
}
.sched-cell:last-child{border-right:0}
.sched-cell:hover{background:#0e1115}
.sched-cell.now{background:rgba(19,187,226,.10)}
.sched-cell.now::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--zala-blue);
}
.sched-cell .t{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.sched-cell.now .t{color:var(--zala-blue)}
.sched-cell .nm{font-family:var(--font-display);font-weight:900;font-size:14px;letter-spacing:-.008em;line-height:1.1;text-transform:uppercase;color:#fff}
.sched-cell .nm em{font-family:var(--font-italic);font-style:italic;font-weight:400;text-transform:none;color:rgba(255,255,255,.55)}
.sched-cell .stat{margin-top:4px;font-family:var(--font-mono);font-size:9.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.42)}
.sched-cell.now .stat .live{color:#ff2a2a;font-weight:700}

/* DISPATCHES feed · Spotify "What's New" row */
.dispatches{padding:120px 0;background:var(--moon)}
.dispatches .head{margin-bottom:48px;max-width:1080px}
.dispatches .head h2{margin-bottom:14px}
.dispatches .head .deck{max-width:780px}
.dispatch-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:1080px){.dispatch-row{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.dispatch-row{grid-template-columns:1fr}}
.disp-card{
  background:var(--ink);color:#fff;padding:24px 22px 22px;
  border-top:4px solid var(--zala-blue);
  text-decoration:none;display:flex;flex-direction:column;gap:10px;min-height:240px;
  transition:transform .15s,box-shadow .15s;
}
.disp-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -10px rgba(0,0,0,.3)}
.disp-card .date{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--zala-blue)}
.disp-card .cat{font-family:var(--font-mono);font-size:9.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.disp-card h3{font-family:var(--font-display);font-weight:900;font-size:18px;letter-spacing:-.010em;line-height:1.15;text-transform:uppercase;color:#fff;margin:0}
.disp-card h3 em{font-family:var(--font-italic);font-style:italic;font-weight:400;text-transform:none;color:rgba(255,255,255,.55)}
.disp-card .body{font-family:var(--font-body);font-weight:300;font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.78);margin-top:auto}
.disp-card .body em{font-family:var(--font-italic);font-style:italic;color:#fff}

/* ---- LIBRARY · reference register · Stripe Press × Wikipedia ---- */
.lib-hero{padding:140px 0 60px;background:var(--moon);border-bottom:1px solid var(--rule-strong)}
.lib-hero .wrap{max-width:1180px}
.lib-hero .eyebrow{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);margin-bottom:24px;display:inline-flex;align-items:center;gap:14px}
.lib-hero .eyebrow::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.lib-hero h1{font-family:var(--font-display);font-weight:900;font-size:clamp(56px,9vw,128px);line-height:.86;letter-spacing:-.044em;text-transform:uppercase;color:var(--ink);margin:0 0 24px;max-width:1080px}
.lib-hero h1 em{font-family:var(--font-italic);font-style:italic;font-weight:400;text-transform:none;color:var(--zala-blue);letter-spacing:-.014em}
.lib-hero .deck{font-family:var(--font-body);font-weight:300;font-size:clamp(17px,1.4vw,21px);line-height:1.55;color:var(--ink-2);max-width:780px}
.lib-hero .deck em{font-family:var(--font-italic);font-style:italic;color:var(--ink)}
.lib-hero .deck b{color:var(--ink);font-weight:500}
.lib-hero .meta{margin-top:60px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-top:24px;border-top:1px solid var(--rule);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-3)}
.lib-hero .meta b{color:var(--ink);font-weight:500}

.lib-toc{padding:80px 0 100px;background:var(--moon)}
.lib-toc .wrap{max-width:1180px}
.lib-toc .section{margin-bottom:56px}
.lib-toc .section:last-child{margin-bottom:0}
.lib-toc .section-head{display:flex;align-items:baseline;gap:18px;padding-bottom:16px;margin-bottom:24px;border-bottom:2px solid var(--ink)}
.lib-toc .section-head .num{font-family:var(--font-display);font-weight:900;font-size:48px;letter-spacing:-.028em;line-height:1;color:var(--zala-blue)}
.lib-toc .section-head h2{font-family:var(--font-display);font-weight:900;font-size:clamp(28px,3vw,40px);text-transform:uppercase;letter-spacing:-.020em;color:var(--ink);line-height:1;margin:0}
.lib-toc .section-head .ct{margin-left:auto;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-3)}
.lib-toc .list{display:grid;gap:1px;background:var(--rule-strong);border:1px solid var(--rule-strong)}
.lib-item{background:var(--moon);padding:24px 28px;display:grid;grid-template-columns:1fr 200px;gap:24px;text-decoration:none;color:inherit;transition:background .15s;align-items:start}
.lib-item:hover{background:var(--moon-soft)}
@media (max-width:760px){.lib-item{grid-template-columns:1fr;gap:14px}}
.lib-item .body .tag{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--zala-blue);margin-bottom:10px}
.lib-item .body h3{font-family:var(--font-display);font-weight:900;font-size:24px;letter-spacing:-.014em;line-height:1.1;text-transform:uppercase;color:var(--ink);margin:0 0 10px}
.lib-item .body h3 em{font-family:var(--font-italic);font-style:italic;font-weight:400;text-transform:none;letter-spacing:-.006em;color:var(--ink-2)}
.lib-item .body .abs{font-family:var(--font-body);font-weight:300;font-size:14.5px;line-height:1.55;color:var(--ink-2)}
.lib-item .body .abs em{font-family:var(--font-italic);font-style:italic;color:var(--ink)}
.lib-item .meta{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-3);line-height:1.85;text-align:right}
@media (max-width:760px){.lib-item .meta{text-align:left}}
.lib-item .meta b{color:var(--ink);font-weight:500}
.lib-item .meta .read::after{content:" →";color:var(--zala-blue)}

/* Article page · long-form reading register */
.art-hero{padding:140px 0 60px;background:var(--moon);border-bottom:1px solid var(--rule-strong)}
.art-hero .wrap{max-width:780px}
.art-hero .crumb{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-3);margin-bottom:32px}
.art-hero .crumb a{color:var(--zala-blue);text-decoration:none}
.art-hero .crumb a:hover{text-decoration:underline}
.art-hero .eyebrow{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);margin-bottom:24px;display:inline-flex;align-items:center;gap:14px}
.art-hero .eyebrow::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.art-hero h1{font-family:var(--font-display);font-weight:900;font-size:clamp(40px,5vw,68px);line-height:1;letter-spacing:-.028em;text-transform:uppercase;color:var(--ink);margin:0 0 24px}
.art-hero h1 em{font-family:var(--font-italic);font-style:italic;font-weight:400;text-transform:none;color:var(--zala-blue);letter-spacing:-.012em}
.art-hero .abstract{font-family:var(--font-body);font-weight:300;font-size:19px;line-height:1.6;color:var(--ink-2);margin:0}
.art-hero .abstract em{font-family:var(--font-italic);font-style:italic;color:var(--ink)}
.art-hero .meta-strip{margin-top:48px;padding-top:24px;border-top:1px solid var(--rule);display:grid;grid-template-columns:repeat(4,1fr);gap:24px;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-3)}
@media (max-width:680px){.art-hero .meta-strip{grid-template-columns:1fr 1fr}}
.art-hero .meta-strip b{display:block;color:var(--ink);font-weight:500;font-size:13px;letter-spacing:0;text-transform:none;margin-top:6px;font-family:var(--font-body)}

.art-body{padding:60px 0 100px;background:var(--moon)}
.art-body .wrap{max-width:780px}
.art-body p{font-family:var(--font-body);font-weight:300;font-size:17px;line-height:1.75;color:var(--ink-2);margin:0 0 24px}
.art-body p em{font-family:var(--font-italic);font-style:italic;color:var(--ink)}
.art-body p b{color:var(--ink);font-weight:600}
.art-body h2{font-family:var(--font-display);font-weight:900;font-size:clamp(26px,2.8vw,36px);text-transform:uppercase;letter-spacing:-.016em;line-height:1.1;color:var(--ink);margin:56px 0 24px}
.art-body h2 em{font-family:var(--font-italic);font-style:italic;font-weight:400;text-transform:none;color:var(--zala-blue);letter-spacing:-.008em}
.art-body h3{font-family:var(--font-display);font-weight:900;font-size:18px;text-transform:uppercase;letter-spacing:.04em;color:var(--zala-blue);margin:36px 0 14px}
.art-body blockquote{margin:36px 0;padding:24px 28px;border-left:3px solid var(--zala-blue);background:rgba(19,187,226,.06);font-family:var(--font-italic);font-style:italic;font-size:22px;line-height:1.4;color:var(--ink);letter-spacing:-.006em}
.art-body blockquote cite{display:block;margin-top:12px;font-family:var(--font-mono);font-style:normal;font-size:10.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-3)}
.art-body ul{margin:0 0 24px;padding:0;list-style:none}
.art-body ul li{font-family:var(--font-body);font-weight:300;font-size:17px;line-height:1.75;color:var(--ink-2);padding:8px 0 8px 24px;position:relative}
.art-body ul li::before{content:"§";position:absolute;left:0;top:8px;color:var(--zala-blue);font-family:var(--font-italic);font-style:italic;font-weight:500}
.art-body ul li em{font-family:var(--font-italic);font-style:italic;color:var(--ink)}
.art-body ul li b{color:var(--ink);font-weight:600}
.art-body .glossary{margin:36px 0;padding:24px 28px;border:1px solid var(--rule-strong);background:rgba(0,0,0,.02)}
.art-body .glossary .lab{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--zala-blue);margin-bottom:14px}
.art-body .glossary dt{font-family:var(--font-display);font-weight:900;font-size:16px;letter-spacing:-.008em;text-transform:uppercase;color:var(--ink);margin-top:14px}
.art-body .glossary dt:first-child{margin-top:0}
.art-body .glossary dd{font-family:var(--font-body);font-weight:300;font-size:15px;line-height:1.55;color:var(--ink-2);margin:6px 0 0;padding:0}

.art-refs{padding:48px 0;background:var(--ink);color:rgba(255,255,255,.78);border-top:6px solid var(--zala-blue)}
.art-refs .wrap{max-width:780px}
.art-refs .lab{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);margin-bottom:24px}
.art-refs h2{font-family:var(--font-display);font-weight:900;font-size:18px;text-transform:uppercase;letter-spacing:.04em;color:#fff;margin:0 0 18px}
.art-refs ol{margin:0 0 24px;padding-left:24px;font-family:var(--font-mono);font-size:12.5px;line-height:1.85;color:rgba(255,255,255,.78);letter-spacing:.04em}
.art-refs ol li{margin-bottom:10px}
.art-refs ol li b{color:#fff;font-weight:500}
.art-refs .related{margin-top:32px;padding-top:24px;border-top:1px solid rgba(255,255,255,.18);display:flex;gap:24px;flex-wrap:wrap;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.32em;text-transform:uppercase}
.art-refs .related a{color:var(--zala-blue);text-decoration:none}
.art-refs .related a:hover{color:#fff}
.art-refs .back{margin-top:24px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.42em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.art-refs .back a{color:var(--zala-blue);text-decoration:none}

/* ---- Sky-phase palette · per broadcast color identity ---- */
.sky-dawn   { --sky-1:#1a1547; --sky-2:#5a2b8c; --sky-3:#d4477e; --sky-accent:#d4477e; --sky-photo:url('/photos/out-dawn-paddler.jpg'); --sky-pos:center 12%; }
.sky-morning{ --sky-1:#0e7fa8; --sky-2:#13bbe2; --sky-3:#ffd166; --sky-accent:#ffd166; --sky-photo:url('/photos/combine-tripods-dawn.jpg'); --sky-pos:center 30%; }
.sky-noon   { --sky-1:#1e6bd6; --sky-2:#4299e1; --sky-3:#bfe1ff; --sky-accent:#4299e1; --sky-photo:url('/photos/horizon-blue.jpg'); --sky-pos:center 10%; }
.sky-golden { --sky-1:#d94e1a; --sky-2:#ff9d3a; --sky-3:#ffc94a; --sky-accent:#ff9d3a; --sky-photo:url('/photos/moment-silhouette-sunset.jpg'); --sky-pos:center 18%; }
.sky-dusk   { --sky-1:#2d1b69; --sky-2:#9d2b6a; --sky-3:#ec4899; --sky-accent:#ec4899; --sky-photo:url('/photos/combine-force-plate-night.jpg'); --sky-pos:center 8%; }

.has-sky{position:relative;overflow:hidden;background:var(--ink)}
.has-sky::before{
  content:"";position:absolute;inset:0;
  background-image:var(--sky-photo);
  background-size:cover;background-position:var(--sky-pos);
  filter:saturate(1.08) contrast(1.12) brightness(.85);
  z-index:0;
  transition:transform 1.6s ease-out;
}
.has-sky:hover::before{transform:scale(1.04)}
.has-sky::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(7,8,9,.20) 0%,
    rgba(7,8,9,.55) 45%,
    rgba(7,8,9,.92) 100%);
  pointer-events:none;z-index:1;
}
.has-sky > *{position:relative;z-index:2}
.has-sky .stripe-top{
  position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg,var(--sky-1),var(--sky-2),var(--sky-3));
  z-index:3;
}

/* Order chip with sky-gradient on broadcast cards */
.has-sky .ord{
  display:inline-block;
  padding:6px 14px;
  background:linear-gradient(90deg,var(--sky-1),var(--sky-2));
  color:#fff !important;
  letter-spacing:.36em;
  font-weight:700;
  width:fit-content;
  border-radius:1px;
  box-shadow:0 4px 16px -2px rgba(0,0,0,.4);
}
/* Make text fully readable on sky photo cards */
.has-sky .nm{color:#fff !important;text-shadow:0 2px 16px rgba(0,0,0,.55)}
.has-sky .nm em{color:rgba(255,255,255,.78) !important}
.has-sky .scene{color:rgba(255,255,255,.92) !important;text-shadow:0 1px 10px rgba(0,0,0,.5)}
.has-sky .scene em{color:#fff !important}

/* ---- Iconic posters · Pro · Youth · Lifestyle ---- */
.poster{
  position:relative;min-height:78vh;background:var(--ink);
  overflow:hidden;display:flex;align-items:flex-end;color:#fff;
}
.poster .bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:saturate(1.0) contrast(1.18) brightness(.64);
  will-change:transform;transition:transform 1.6s ease-out;
}
.poster:hover .bg{transform:scale(1.04)}
.poster .veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.20) 0%,rgba(0,0,0,.04) 36%,rgba(0,0,0,.20) 64%,rgba(0,0,0,.88) 100%);
}
.poster .side-tag{
  position:absolute;top:50%;left:32px;transform:translateY(-50%) rotate(-90deg);
  transform-origin:center;
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  z-index:3;white-space:nowrap;
}
@media (max-width:880px){.poster .side-tag{display:none}}
.poster .wrap{position:relative;z-index:2;padding:96px var(--gutter) 110px;width:100%}
.poster .ord{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  margin-bottom:32px;display:inline-flex;align-items:center;gap:14px;
}
.poster .ord::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.poster h2{
  font-size:clamp(112px,20vw,300px);line-height:.78;letter-spacing:-.052em;
  color:#fff;margin-bottom:28px;
  text-shadow:0 4px 32px rgba(0,0,0,.45);
}
.poster .deck{
  color:rgba(255,255,255,.92);max-width:720px;
  font-size:clamp(17px,1.4vw,22px);
  text-shadow:0 1px 14px rgba(0,0,0,.5);
}
.poster .deck em{font-family:var(--font-italic);font-style:italic;color:#fff}
.poster .deck b{font-weight:500;color:#fff}
.poster .stamp{
  position:absolute;bottom:42px;right:var(--gutter);z-index:3;
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;
  color:rgba(255,255,255,.62);text-align:right;max-width:340px;line-height:1.7;
}
.poster .stamp b{color:var(--zala-blue);font-weight:500}

.deck{
  max-width:780px;
  font-family:var(--font-body);font-weight:300;
  font-size:clamp(17px,1.5vw,22px);line-height:1.55;
  color:var(--ink-2);margin:0;
}
.deck em{
  font-family:var(--font-italic);font-style:italic;
  font-weight:400;color:var(--ink);
}
.deck b{font-weight:500;color:var(--ink)}

.mono{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-3);
}

.author{
  margin-top:48px;padding-top:24px;max-width:680px;
  border-top:1px solid var(--rule-strong);
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  line-height:1.85;
}
.author b{color:var(--ink);font-weight:700}

/* ---- Nav · institutional masthead ---- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:var(--moon);
  border-bottom:2px solid var(--ink);
}
.nav.dark{background:var(--ink);border-bottom:2px solid var(--zala-blue)}
.nav .strip-top{
  display:flex;justify-content:space-between;align-items:center;
  padding:6px var(--gutter);
  background:var(--ink);color:rgba(255,255,255,.62);
  font-family:var(--font-mono);font-size:9.5px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;
}
.nav .strip-top b{color:var(--zala-blue);font-weight:500}
.nav.dark .strip-top{background:#000;border-bottom:1px solid rgba(255,255,255,.12)}
.nav .strip-main{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px var(--gutter);
}
/* ═══ STICKY BRAND CORNER · top-left · Wolff Olins grey grammar ═══
   Quiet. Editorial. Native to the design system, not stuck on top.
   Moon-grey panel · thin rule · no blur · no shadow. */
.brand-corner{
  position:fixed;top:0;left:0;z-index:1000;
  display:flex;align-items:center;gap:10px;
  padding:14px 18px 12px 14px;
  background:var(--moon);
  border-right:1px solid var(--rule-strong);
  border-bottom:1px solid var(--rule-strong);
  text-decoration:none;
  transition:opacity .2s;
}
.brand-corner:hover{opacity:.78}
.brand-corner .bc-z{display:inline-block;width:30px;height:30px;background-image:url('/brand/logo-blue.svg');background-size:contain;background-repeat:no-repeat;background-position:center}
.brand-corner .bc-x{font-family:var(--font-italic);font-style:italic;font-size:13px;color:var(--ink-3);font-weight:300;opacity:.5}
.brand-corner .bc-aiio{display:inline-block;width:18px;height:32px;background-image:url('/brand/aiio-mark.svg');background-size:contain;background-repeat:no-repeat;background-position:center}
.brand-corner .bc-tagline{font-family:var(--font-mono);font-size:8px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-3);line-height:1.2;margin-left:4px;display:flex;flex-direction:column;gap:1px}
.brand-corner .bc-tagline b{color:var(--ink);font-weight:700;font-size:9px;letter-spacing:.36em}
@media(max-width:680px){
  .brand-corner{padding:10px 14px 10px 12px;gap:8px}
  .brand-corner .bc-z{width:24px;height:24px}
  .brand-corner .bc-aiio{width:15px;height:26px}
  .brand-corner .bc-x{font-size:11px}
  .brand-corner .bc-tagline{display:none}
}

.nav .mark-block{display:flex;align-items:center;gap:14px;text-decoration:none}
.nav .mark-block .marks{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav .mark-block .m-zala{display:inline-block;width:38px;height:38px;background-image:url('/brand/logo-blue.svg');background-size:contain;background-repeat:no-repeat;background-position:center}
.nav .mark-block .m-aiio{display:inline-block;width:26px;height:40px;background-image:url('/brand/aiio-mad-scientist.svg');background-size:contain;background-repeat:no-repeat;background-position:center}
.nav .mark-block .m-x{font-family:var(--font-italic);font-style:italic;font-size:16px;color:var(--ink);opacity:.32;font-weight:300}
.nav.dark .mark-block .m-x{color:rgba(255,255,255,.4)}
.nav .mark-block .mark-tagline{font-family:var(--font-mono);font-size:9px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--ink);opacity:.62;line-height:1.1;display:flex;flex-direction:column;gap:2px}
.nav .mark-block .mark-tagline b{color:var(--ink);font-weight:700;opacity:1;font-size:10.5px}
.nav.dark .mark-block .mark-tagline{color:rgba(255,255,255,.7)}
.nav.dark .mark-block .mark-tagline b{color:#fff}
.nav .mark-img{display:none}
.nav .mark{display:none}
@media(max-width:640px){
  .nav .mark-block .m-zala{width:30px;height:30px}
  .nav .mark-block .m-aiio{width:20px;height:32px}
  .nav .mark-block .mark-tagline{font-size:8px}
  .nav .mark-block .mark-tagline b{font-size:9px}
}
.nav .links{
  display:flex;gap:28px;align-items:center;
  font-family:var(--font-display);font-size:12px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
}
.nav .links a{color:var(--ink);text-decoration:none;transition:color .15s;padding:6px 0;border-bottom:2px solid transparent}
.nav .links a:hover{color:var(--zala-blue);border-bottom-color:var(--zala-blue)}
.nav.dark .links a{color:#fff}
.nav.dark .links a:hover{color:var(--zala-blue);border-bottom-color:var(--zala-blue)}
.nav .menu-btn{display:none;background:none;border:0;cursor:pointer;font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);padding:6px}
@media (max-width:880px){
  .nav .links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--moon);border-bottom:2px solid var(--ink)}
  .nav.dark .links{background:var(--ink);border-bottom:2px solid var(--zala-blue)}
  .nav .links.open{display:flex}
  .nav .links a{padding:18px var(--gutter);border-top:1px solid var(--rule);border-bottom:0;width:100%}
  .nav.dark .links a{border-top-color:rgba(255,255,255,.10)}
  .nav .menu-btn{display:block}
  .nav.dark .menu-btn{color:#fff}
  .nav .strip-top{display:none}
}

/* Push body content below the taller masthead */
.cinema-hero,.youth-hero,.life-hero,.su-hero,.zw-hero,.pro-hero{padding-top:120px !important}
@media (max-width:880px){
  .cinema-hero,.youth-hero,.life-hero,.su-hero,.zw-hero,.pro-hero{padding-top:90px !important}
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:16px 28px;background:transparent;
  border:1.5px solid var(--ink);color:var(--ink);
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  transition:all .15s;
}
.btn:hover{background:var(--ink);color:var(--moon)}
.btn.prim{background:var(--ink);color:var(--moon)}
.btn.prim:hover{background:var(--zala-blue);border-color:var(--zala-blue);color:var(--ink)}
.btn.blue{background:var(--zala-blue);border-color:var(--zala-blue);color:var(--ink)}
.btn.blue:hover{background:var(--ink);border-color:var(--ink);color:var(--moon)}
.btn.dark{border-color:#fff;color:#fff}
.btn.dark:hover{background:#fff;color:var(--ink)}

/* ---- Cinematic full-bleed hero ---- */
.cinema-hero{
  position:relative;min-height:100vh;
  background:var(--ink);color:#fff;
  display:flex;align-items:center;
  padding:0;overflow:hidden;
}
.cinema-hero .bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:saturate(1.02) contrast(1.14) brightness(.72);
  will-change:transform;
  animation:slow-zoom 30s ease-in-out infinite alternate;
}
@keyframes slow-zoom{ to{ transform:scale(1.06) } }
.cinema-hero .veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.32) 0%,rgba(0,0,0,.06) 30%,rgba(0,0,0,.20) 60%,rgba(0,0,0,.82) 100%);
}
.cinema-hero .side-tag{
  position:absolute;top:50%;left:32px;
  transform:translateY(-50%) rotate(-90deg);transform-origin:center;
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  z-index:3;white-space:nowrap;
}
@media (max-width:880px){.cinema-hero .side-tag{display:none}}
.cinema-hero .wrap{position:relative;z-index:2;padding:140px var(--gutter) 100px;width:100%}
.cinema-hero .lab{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  margin-bottom:36px;display:flex;align-items:center;gap:14px;
}
.cinema-hero .lab::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.cinema-hero h1{
  color:#fff;margin-bottom:28px;
  text-shadow:0 2px 32px rgba(0,0,0,.45);
}
.cinema-hero .deck{
  color:rgba(255,255,255,.92);
  text-shadow:0 1px 18px rgba(0,0,0,.6);
  max-width:780px;
}
.cinema-hero .deck em{color:#fff}
.cinema-hero .deck b{color:#fff;font-weight:500}
.cinema-hero .bottom-mark{
  position:absolute;left:var(--gutter);right:var(--gutter);bottom:42px;
  display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap;z-index:3;
  font-family:var(--font-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;color:rgba(255,255,255,.62);
}
.cinema-hero .bottom-mark b{color:#fff;font-weight:500}
.cinema-hero .bottom-mark .right{text-align:right}

/* ---- Cinematic strips (the after / during / before sequence) ---- */
.strip{
  position:relative;min-height:90vh;
  background:var(--ink);color:#fff;
  display:flex;align-items:flex-end;
  padding:0;overflow:hidden;
}
.strip .bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:saturate(1.0) contrast(1.16) brightness(.66);
  will-change:transform;
  transition:transform 1.6s ease-out,filter .3s;
}
.strip:hover .bg{transform:scale(1.04);filter:saturate(1.08) brightness(.74)}
.strip .veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.20) 0%,rgba(0,0,0,.05) 40%,rgba(0,0,0,.20) 60%,rgba(0,0,0,.86) 100%);
}
.strip .side-tag{
  position:absolute;top:50%;left:32px;
  transform:translateY(-50%) rotate(-90deg);transform-origin:center;
  font-family:var(--font-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.5em;text-transform:uppercase;color:var(--zala-blue);
  z-index:3;white-space:nowrap;
}
@media (max-width:880px){.strip .side-tag{display:none}}
.strip .wrap{position:relative;z-index:2;padding-top:80px;padding-bottom:96px;width:100%}
.strip .label{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;
  color:var(--zala-blue);margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
.strip .label::before{content:"";display:inline-block;width:36px;height:1px;background:var(--zala-blue)}
.strip h2{color:#fff;margin-bottom:20px;text-shadow:0 2px 24px rgba(0,0,0,.45)}
.strip .deck{color:rgba(255,255,255,.92);max-width:680px;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.strip .deck em{color:#fff}
.strip .stamp{
  position:absolute;bottom:42px;right:var(--gutter);z-index:3;
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;color:rgba(255,255,255,.55);
  text-align:right;
}
.strip .stamp b{color:var(--zala-blue);font-weight:500}

/* ---- Footer · unified 4-column ---- */
.foot{
  background:var(--ink);color:rgba(255,255,255,.62);
  padding:80px 0 32px;
}
.foot .wrap{display:grid;gap:48px}
.foot .turn{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(28px,4vw,52px);letter-spacing:-.024em;
  text-transform:uppercase;color:#fff;line-height:1;
}
.foot .turn .blue{color:var(--zala-blue)}
.foot .wordmark{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between}
.foot .wordmark img{height:36px;width:auto;display:block;opacity:.92}
.foot .wordmark .anthem{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.62);
}
.foot .wordmark .anthem b{color:#fff;font-weight:500}
.foot .foot-cols{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  padding:32px 0;
  border-top:1px solid rgba(255,255,255,.15);
  border-bottom:1px solid rgba(255,255,255,.15);
}
.foot .foot-cols h5{
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  letter-spacing:.42em;text-transform:uppercase;
  color:var(--zala-blue);margin:0 0 18px;
}
.foot .foot-cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot .foot-cols a{
  color:rgba(255,255,255,.78);text-decoration:none;
  font-family:var(--font-display);font-size:13px;font-weight:500;
  letter-spacing:.06em;text-transform:none;
  transition:color .15s;
}
.foot .foot-cols a:hover{color:var(--zala-blue)}
.foot .meta{
  display:flex;justify-content:space-between;align-items:center;
  gap:24px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.42);
}
.foot .meta b{color:#fff;font-weight:500}
.foot .meta a{color:rgba(255,255,255,.62);text-decoration:none}
.foot .meta a:hover{color:var(--zala-blue)}
@media(max-width:880px){
  .foot .foot-cols{grid-template-columns:repeat(2,1fr);gap:28px 24px}
}
@media(max-width:560px){
  .foot{padding:64px 0 28px}
  .foot .foot-cols{grid-template-columns:1fr}
  .foot .wordmark{flex-direction:column;align-items:flex-start;gap:14px}
}

/* ---- Forms ---- */
.field{margin-bottom:28px}
.field label{
  display:block;
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:10px;
}
.field label .req{color:var(--zala-blue);margin-left:4px}
.field input,.field textarea,.field select{
  width:100%;padding:14px 16px;
  background:rgba(255,255,255,.6);
  border:1.5px solid var(--rule-strong);
  font-family:var(--font-body);font-size:15px;font-weight:300;
  color:var(--ink);outline:none;
  transition:border-color .15s,background .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--zala-blue);background:#fff;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.5}
.field .help{
  margin-top:8px;
  font-family:var(--font-body);font-size:13px;font-weight:300;
  color:var(--ink-3);line-height:1.5;
}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:680px){.row2{grid-template-columns:1fr}}

/* ---- Page header (interior pages) ---- */
.phead{padding:140px 0 60px}
.phead .kicker{margin-top:0}

/* ---- Utilities ---- */
.tac{text-align:center}
.muted{color:var(--ink-3)}
.spacer-l{height:80px}
.spacer-m{height:48px}
