/* =============================================================================
   MACIEJ MAŁECKI — DRAWING ARCHIVE
   Visual system: Tactical-Telemetry / Industrial Brutalism (dark substrate)
   Motion: "Premium" personality — cubic-bezier(.4,0,.2,1), 0% overshoot
   Author: front-end build for WordPress hand-off
   ----------------------------------------------------------------------------
   TABLE OF CONTENTS
   01 Tokens          06 HUD frame
   02 Reset/base      07 Hero
   03 Typography      08 Sections (statement, plates, density, exhibitions, contact)
   04 Layout helpers  09 Lightbox
   05 Reveal/motion   10 Responsive  11 Reduced-motion / focus
============================================================================= */

/* 01 · TOKENS ------------------------------------------------------------- */
:root{
  /* substrate — never pure black (deactivated CRT) */
  --bg:        #0a0a0a;
  --bg-2:      #0f0f0f;
  --surface:   #141414;
  --surface-2: #181818;

  /* ink / phosphor */
  --fg:        #ececec;      /* primary text  (~17:1 on --bg)            */
  --fg-dim:    #b4afa4;      /* captions / mono secondary (~9:1)         */
  --fg-faint:  #6c6c6c;      /* tertiary, large only                    */
  --hair:      #2a2a2a;      /* hairline rules                          */
  --hair-2:    #1d1d1d;

  /* the only accent: aviation / registration red, used sparingly */
  --red:       #e61919;

  /* graph paper (millimetre) — echo of the artist's substrate */
  --grid-fine:   rgba(255,255,255,.022);
  --grid-coarse: rgba(255,255,255,.040);
  --grid-unit:   26px;     /* coarse cell */

  /* type */
  --display: "Archivo","Helvetica Neue",Arial,sans-serif;
  --mono:    "Space Mono","SFMono-Regular",ui-monospace,monospace;

  /* spacing scale */
  --gutter: clamp(18px, 4.2vw, 64px);   /* page side padding            */
  --pad-section: clamp(72px, 12vh, 168px);

  /* motion */
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --dur-1: .42s;   /* standard   */
  --dur-2: .62s;   /* slow       */
  --dur-3: .9s;    /* reveal     */

  --maxw: 1680px;
}

/* 02 · RESET / BASE ------------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--mono);
  background:var(--bg);
  color:var(--fg);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* millimetre graph-paper substrate + faint vignette */
  background-image:
    linear-gradient(var(--grid-coarse) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-coarse) 1px, transparent 1px),
    linear-gradient(var(--grid-fine) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-fine) 1px, transparent 1px),
    radial-gradient(120% 80% at 50% -10%, #131313 0%, var(--bg) 60%);
  background-size:
    calc(var(--grid-unit)*5) calc(var(--grid-unit)*5),
    calc(var(--grid-unit)*5) calc(var(--grid-unit)*5),
    var(--grid-unit) var(--grid-unit),
    var(--grid-unit) var(--grid-unit),
    100% 100%;
  background-attachment: fixed, fixed, fixed, fixed, fixed;
}
/* global film-grain noise (very low opacity) */
body::after{
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img,picture,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
::selection{ background:var(--red); color:#fff; }

/* 03 · TYPOGRAPHY --------------------------------------------------------- */
.eyebrow,
.mono{
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:clamp(.62rem,.72vw,.74rem);
  color:var(--fg-dim);
}
.eyebrow{ display:inline-flex; align-items:center; gap:.7ch; }
.eyebrow .tick{ color:var(--red); }

.display{
  font-family:var(--display);
  font-weight:900;
  text-transform:uppercase;
  line-height:.86;
  letter-spacing:-.035em;
  color:var(--fg);
}
h1,h2,h3{ font-family:var(--display); font-weight:900; text-transform:uppercase; }

.h-mega{ font-size:clamp(3.4rem, 15vw, 13rem); line-height:.82; letter-spacing:-.05em; }
.h-xl  { font-size:clamp(2.4rem, 7vw, 6rem);  line-height:.88; letter-spacing:-.04em; }
.h-lg  { font-size:clamp(1.7rem, 4vw, 3.4rem); line-height:.92; letter-spacing:-.03em; }

.lede{
  font-family:var(--display);
  font-weight:500;
  text-transform:none;
  letter-spacing:-.01em;
  line-height:1.18;
  font-size:clamp(1.3rem,2.7vw,2.2rem);
  color:var(--fg);
  max-width:24ch;
}
.body{
  font-family:var(--mono);
  font-size:clamp(.84rem,1.05vw,.96rem);
  line-height:1.75;
  color:var(--fg-dim);
  max-width:62ch;
}
.body strong{ color:var(--fg); font-weight:700; }

/* 04 · LAYOUT ------------------------------------------------------------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ position:relative; z-index:2; padding-block:var(--pad-section); }
.rule{ height:1px; background:var(--hair); border:0; }
.rule--bleed{ width:100%; }

/* section index label (eyebrow row that spans full width) */
.sec-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:1rem; padding-bottom:1.4rem; border-bottom:1px solid var(--hair);
  flex-wrap:wrap;
}
.sec-head__id{ color:var(--fg-faint); }

/* datasheet (definition-list telemetry) */
.sheet{ display:grid; gap:0; border-top:1px solid var(--hair); }
.sheet__row{
  display:grid; grid-template-columns:minmax(7.5rem,auto) 1fr; gap:1rem;
  padding:.7rem 0; border-bottom:1px solid var(--hair-2);
}
.sheet__row dt{ font-family:var(--mono); text-transform:uppercase; letter-spacing:.12em;
  font-size:.66rem; color:var(--fg-faint); }
.sheet__row dd{ font-family:var(--mono); font-size:.8rem; color:var(--fg); letter-spacing:.04em; }

/* corner-bracket utility */
.brackets{ position:relative; }
.brackets::before,.brackets::after{
  content:""; position:absolute; width:14px; height:14px; pointer-events:none;
  border:1px solid var(--fg-dim); opacity:.55;
}
.brackets::before{ top:-1px; left:-1px; border-right:0; border-bottom:0; }
.brackets::after{ bottom:-1px; right:-1px; border-left:0; border-top:0; }

/* 05 · REVEAL / MOTION ---------------------------------------------------- */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:
   opacity var(--dur-2) var(--ease), transform var(--dur-2) var(--ease); will-change:opacity,transform; }
[data-reveal].is-in{ opacity:1; transform:none; }
[data-reveal-img]{ clip-path:inset(0 100% 0 0); transition:clip-path var(--dur-3) var(--ease-out); will-change:clip-path; }
[data-reveal-img].is-in{ clip-path:inset(0 0 0 0); }
[data-stagger]>*{ opacity:0; transform:translateY(18px); transition:
   opacity var(--dur-1) var(--ease), transform var(--dur-1) var(--ease); }
[data-stagger].is-in>*{ opacity:1; transform:none; }
[data-stagger].is-in>*:nth-child(1){ transition-delay:.00s; }
[data-stagger].is-in>*:nth-child(2){ transition-delay:.07s; }
[data-stagger].is-in>*:nth-child(3){ transition-delay:.14s; }
[data-stagger].is-in>*:nth-child(4){ transition-delay:.21s; }
[data-stagger].is-in>*:nth-child(5){ transition-delay:.28s; }
[data-stagger].is-in>*:nth-child(6){ transition-delay:.35s; }

/* 06 · HUD FRAME ---------------------------------------------------------- */
.hud{ position:fixed; inset:0; z-index:60; pointer-events:none; }
.hud__bar{
  position:absolute; left:0; right:0; display:flex; justify-content:space-between;
  align-items:center; gap:1rem; padding:.55rem var(--gutter);
  font-family:var(--mono); text-transform:uppercase; letter-spacing:.18em;
  font-size:.6rem; color:var(--fg-dim);
  background:linear-gradient(var(--bg),rgba(10,10,10,0));
}
.hud__bar--top{ top:0; }
.hud__bar--bot{ bottom:0; background:linear-gradient(rgba(10,10,10,0),var(--bg)); }
.hud__bar span{ white-space:nowrap; }
.hud__bar .mid{ color:var(--fg-faint); }
.hud__brand b{ color:var(--fg); font-weight:700; }
.hud__corner{ position:absolute; width:26px; height:26px; border:1.5px solid var(--fg-dim); opacity:.5; }
.hud__corner.tl{ top:14px; left:14px; border-right:0; border-bottom:0; }
.hud__corner.tr{ top:14px; right:14px; border-left:0; border-bottom:0; }
.hud__corner.bl{ bottom:14px; left:14px; border-right:0; border-top:0; }
.hud__corner.br{ bottom:14px; right:14px; border-left:0; border-top:0; }
.hud--draw .hud__corner{ animation:cornerIn .8s var(--ease-out) both; }
@keyframes cornerIn{ from{ opacity:0; transform:scale(.4); } to{ opacity:.5; transform:none; } }

/* primary nav (in-flow, top) */
.nav{ position:fixed; top:0; left:0; right:0; z-index:55; pointer-events:none; }
.nav__inner{
  pointer-events:auto; display:flex; justify-content:space-between; align-items:center;
  padding:1.7rem var(--gutter) .9rem;
}
.nav__links{ display:flex; gap:1.6rem; align-items:center; }
.nav a{ font-family:var(--mono); text-transform:uppercase; letter-spacing:.16em; font-size:.68rem;
  color:var(--fg-dim); position:relative; padding:.4rem 0; }
.nav a::after{ content:""; position:absolute; left:0; right:100%; bottom:.1rem; height:1px;
  background:var(--fg); transition:right var(--dur-1) var(--ease); }
.nav a:hover{ color:var(--fg); } .nav a:hover::after{ right:0; }
.nav__cta{ color:var(--fg)!important; }
.nav__cta .arw{ color:var(--red); }
.nav__burger{ display:none; }

/* skip link */
.skip{ position:absolute; left:-9999px; top:0; z-index:120;
  background:var(--fg); color:var(--bg); padding:.7rem 1rem; font-family:var(--mono);
  font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; }
.skip:focus{ left:.6rem; top:.6rem; }

/* 07 · HERO --------------------------------------------------------------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  overflow:hidden; z-index:2; padding-bottom:clamp(4rem,10vh,8rem); }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; object-position:center;
  filter:grayscale(1) contrast(1.06) brightness(.62); transform:scale(1.06);
  animation:heroDrift 26s ease-in-out infinite alternate; }
@keyframes heroDrift{ from{ transform:scale(1.06) translate3d(0,0,0); }
  to{ transform:scale(1.12) translate3d(-1.5%, -1.5%, 0); } }
.hero__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,10,10,.55) 0%, rgba(10,10,10,.25) 40%, rgba(10,10,10,.92) 100%); }
/* scanlines */
.hero__scan{ position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.5;
  background:repeating-linear-gradient(0deg, transparent 0 2px, rgba(0,0,0,.18) 2px 4px); }
.hero__inner{ position:relative; z-index:2; width:100%; }
.hero__eyebrow{ margin-bottom:1.4rem; }
.hero__title{ display:block; }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line>span{ display:block; }
.hero__sub{ margin-top:1.6rem; display:flex; gap:clamp(1rem,4vw,3rem); flex-wrap:wrap; align-items:flex-end; }
.hero__lede{ max-width:30ch; }
.hero__meta{ display:flex; flex-direction:column; gap:.3rem; }
.hero__cue{ position:absolute; right:var(--gutter); bottom:clamp(3.4rem,9vh,7rem); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.6rem; color:var(--fg-dim); }
.hero__cue .line{ width:1px; height:46px; background:linear-gradient(var(--fg-dim),transparent);
  animation:cueline 2.2s var(--ease) infinite; transform-origin:top; }
@keyframes cueline{ 0%{ transform:scaleY(0); opacity:0;} 40%{ opacity:1;} 100%{ transform:scaleY(1); opacity:0;} }
.hero__cue span{ writing-mode:vertical-rl; font-family:var(--mono); font-size:.58rem;
  letter-spacing:.3em; text-transform:uppercase; }

/* index marquee (plate codes) */
.ticker{ position:relative; z-index:2; border-block:1px solid var(--hair);
  overflow:hidden; white-space:nowrap; padding-block:.7rem; background:rgba(10,10,10,.4); }
.ticker__track{ display:inline-flex; gap:3rem; padding-left:3rem; animation:scrollx 38s linear infinite; }
.ticker__track span{ font-family:var(--mono); text-transform:uppercase; letter-spacing:.2em;
  font-size:.7rem; color:var(--fg-dim); display:inline-flex; gap:1ch; align-items:center; }
.ticker__track span b{ color:var(--fg); font-weight:700; }
.ticker__track span i{ color:var(--red); font-style:normal; }
@keyframes scrollx{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* 08 · SECTIONS ----------------------------------------------------------- */

/* -- statement -- */
.statement{ position:relative; }
.statement__grid{ display:grid; grid-template-columns:1.6fr .9fr; gap:clamp(2rem,6vw,6rem);
  align-items:start; margin-top:clamp(2.5rem,6vw,4.5rem); }
.statement__ghost{ position:absolute; right:var(--gutter); top:-2vw; z-index:0; pointer-events:none;
  font-family:var(--display); font-weight:900; font-size:clamp(8rem,26vw,26rem); line-height:.7;
  color:#fff; opacity:.022; letter-spacing:-.06em; }
.statement__body p+p{ margin-top:1.4rem; }
.statement__side{ position:relative; z-index:1; }

/* -- plates (archive) -- */
.plates{ padding-top:clamp(2rem,5vw,3rem); }
.plate{ position:relative; z-index:2; }
.plate+.plate{ margin-top:clamp(4rem,9vw,9rem); }

.figure{ position:relative; overflow:hidden; background:var(--surface); border:1px solid var(--hair); }
.figure img{ width:100%; height:auto; filter:grayscale(1) contrast(1.04); transition:
   transform var(--dur-2) var(--ease), filter var(--dur-2) var(--ease); }
.figure__btn{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.figure__hud{ position:absolute; inset:0; pointer-events:none; opacity:0;
  transition:opacity var(--dur-1) var(--ease); }
.figure__hud .ix{ position:absolute; left:1rem; bottom:1rem; font-family:var(--mono);
  font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--fg);
  background:rgba(10,10,10,.6); padding:.45rem .7rem; }
.figure__hud .vw{ position:absolute; right:1rem; top:1rem; font-family:var(--mono);
  font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--fg);
  display:inline-flex; gap:.6ch; }
.figure__hud .vw .arw{ color:var(--red); }
.figure:hover img{ transform:scale(1.03); filter:grayscale(1) contrast(1.12) brightness(1.05); }
.figure:hover .figure__hud{ opacity:1; }
.figure:focus-within .figure__hud{ opacity:1; }

.cap{ margin-top:1.1rem; display:grid; gap:.8rem; }
.cap__top{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; flex-wrap:wrap; }
.cap__no{ color:var(--red); }
.cap__title{ font-size:clamp(1.4rem,3vw,2.3rem); }
.cap__meta{ display:flex; flex-wrap:wrap; gap:1.4rem; padding-top:.7rem; border-top:1px solid var(--hair); }
.cap__meta div{ display:flex; flex-direction:column; gap:.2rem; }
.cap__meta dt{ font-family:var(--mono); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase; color:var(--fg-faint); }
.cap__meta dd{ font-family:var(--mono); font-size:.78rem; color:var(--fg); letter-spacing:.04em; }

/* plate layout variants */
.plate--full .figure{ aspect-ratio:auto; }
.plate--split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; }
.plate--split .cap{ margin-top:0; }
.plate--duo{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3rem); align-items:start; }
.plate--duo .plate{ margin-top:0; }

/* -- density strip -- */
.density{ background:var(--bg-2); border-block:1px solid var(--hair); overflow:hidden; }
.density__head{ display:grid; grid-template-columns:1fr; gap:1.6rem; }
.density__stats{ display:flex; flex-wrap:wrap; gap:clamp(1.5rem,5vw,4rem); margin-top:2.2rem; }
.stat{ display:flex; flex-direction:column; gap:.4rem; }
.stat b{ font-family:var(--display); font-weight:900; font-size:clamp(2.4rem,6vw,4.6rem);
  line-height:.85; letter-spacing:-.03em; color:var(--fg); }
.stat b .u{ font-size:.4em; color:var(--fg-dim); margin-left:.3ch; }
.stat span{ font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--fg-faint); }
.crops{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hair);
  margin-top:clamp(2.5rem,6vw,4rem); border:1px solid var(--hair); }
.crop{ position:relative; overflow:hidden; aspect-ratio:1/1; background:var(--surface); }
.crop img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.1);
  transition:transform 6s linear; }
.crop:hover img{ transform:scale(1.35); }
.crop figcaption{ position:absolute; left:.6rem; bottom:.6rem; font-family:var(--mono); font-size:.56rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--fg); background:rgba(10,10,10,.6); padding:.3rem .5rem; }

/* -- exhibitions / bio -- */
.bio__grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(2rem,6vw,5rem); align-items:start;
  margin-top:clamp(2.5rem,6vw,4rem); }
.portrait{ position:relative; border:1px solid var(--hair); background:var(--surface); overflow:hidden; }
.portrait img{ width:100%; height:auto; filter:grayscale(1) contrast(1.05) brightness(.95); }
.portrait figcaption{ font-family:var(--mono); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--fg-dim); padding:.8rem 1rem; border-top:1px solid var(--hair); display:flex; justify-content:space-between; }
.cv{ margin-top:2.2rem; }
.cv h3{ font-size:.8rem; font-family:var(--mono); letter-spacing:.2em; color:var(--fg-faint); margin-bottom:1rem; }
.cv__list{ list-style:none; padding:0; border-top:1px solid var(--hair); }
.cv__list li{ display:grid; grid-template-columns:5.5rem 1fr auto; gap:1rem; align-items:baseline;
  padding:.9rem 0; border-bottom:1px solid var(--hair-2); }
.cv__list .yr{ font-family:var(--mono); color:var(--red); font-size:.78rem; letter-spacing:.05em; }
.cv__list .ven{ font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:.92rem; letter-spacing:.01em; }
.cv__list .city{ font-family:var(--mono); color:var(--fg-faint); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; }

/* -- contact -- */
.contact{ position:relative; }
.contact__big{ display:flex; align-items:flex-start; gap:1ch; flex-wrap:wrap; }
.contact__big .arw{ color:var(--red); font-size:.6em; }
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem);
  margin-top:clamp(2.5rem,6vw,4rem); align-items:start; }
.maillink{ font-family:var(--display); font-weight:700; text-transform:none; letter-spacing:-.01em;
  font-size:clamp(1.2rem,3vw,2rem); color:var(--fg); display:inline-flex; align-items:center; gap:.6ch;
  border-bottom:1px solid var(--hair); padding-bottom:.3rem; transition:border-color var(--dur-1) var(--ease); }
.maillink:hover{ border-color:var(--fg); }
.maillink .arw{ color:var(--red); }

.form{ display:grid; gap:1.1rem; }
.field{ display:grid; gap:.4rem; }
.field label{ font-family:var(--mono); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--fg-faint); }
.field input,.field textarea{
  font-family:var(--mono); font-size:.85rem; color:var(--fg); background:var(--surface);
  border:1px solid var(--hair); padding:.8rem .9rem; border-radius:0; width:100%;
  transition:border-color var(--dur-1) var(--ease); }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--fg); }
.field textarea{ resize:vertical; min-height:120px; }
.submit{ justify-self:start; font-family:var(--mono); text-transform:uppercase; letter-spacing:.18em;
  font-size:.72rem; color:var(--bg); background:var(--fg); padding:.95rem 1.6rem;
  display:inline-flex; gap:.8ch; align-items:center; transition:transform var(--dur-1) var(--ease), background var(--dur-1) var(--ease); }
.submit:hover{ background:var(--red); color:#fff; }
.submit:active{ transform:translateY(1px); }

/* 09 · FOOTER ------------------------------------------------------------- */
.foot{ position:relative; z-index:2; border-top:1px solid var(--hair); padding-block:clamp(3rem,7vw,5rem) 2rem; }
.foot__cols{ display:flex; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
.foot__col h4{ font-family:var(--mono); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--fg-faint); margin-bottom:.9rem; }
.foot__col a, .foot__col p{ display:block; font-family:var(--mono); font-size:.74rem; color:var(--fg-dim);
  letter-spacing:.04em; padding:.18rem 0; }
.foot__col a:hover{ color:var(--fg); }
.foot__mark{ font-family:var(--display); font-weight:900; text-transform:uppercase; letter-spacing:-.05em;
  font-size:clamp(3rem,16vw,15rem); line-height:.8; color:#fff; opacity:.05; margin-top:clamp(2rem,6vw,4rem);
  white-space:nowrap; overflow:hidden; }
.foot__legal{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  margin-top:2rem; padding-top:1.4rem; border-top:1px solid var(--hair-2);
  font-family:var(--mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color:var(--fg-faint); }
.totop{ display:inline-flex; gap:.6ch; align-items:center; color:var(--fg-dim); }
.totop:hover{ color:var(--fg); } .totop .arw{ color:var(--red); }

/* 10 · LIGHTBOX ----------------------------------------------------------- */
.lb{ position:fixed; inset:0; z-index:200; display:none; }
.lb[open],.lb.is-open{ display:grid; }
.lb{ grid-template-rows:auto 1fr auto; background:rgba(7,7,7,.97); padding:clamp(.8rem,3vw,2rem); }
.lb__bar{ display:flex; justify-content:space-between; align-items:center; gap:1rem;
  font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--fg-dim); }
.lb__close{ display:inline-flex; gap:.6ch; align-items:center; color:var(--fg); padding:.5rem; }
.lb__close:hover .x{ color:var(--red); }
.lb__stage{ display:grid; place-items:center; overflow:auto; padding:clamp(.6rem,2vw,1.4rem) 0; }
.lb__stage img{ max-width:100%; max-height:78vh; width:auto; height:auto; filter:grayscale(1) contrast(1.05);
  border:1px solid var(--hair); }
.lb__cap{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-family:var(--mono); font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; color:var(--fg-dim); }
.lb__cap b{ color:var(--fg); }
.lb__nav{ display:inline-flex; gap:1.4rem; }
.lb__nav button{ color:var(--fg-dim); font-family:var(--mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; }
.lb__nav button:hover{ color:var(--fg); }

/* 11 · RESPONSIVE --------------------------------------------------------- */
@media (max-width: 1100px){
  .statement__grid{ grid-template-columns:1fr; }
  .bio__grid{ grid-template-columns:1fr; }
  .contact__grid{ grid-template-columns:1fr; }
}
@media (max-width: 860px){
  .nav__links{ display:none; }
  .nav__burger{ display:inline-flex; pointer-events:auto; }
  .plate--split{ grid-template-columns:1fr; }
  .plate--duo{ grid-template-columns:1fr; gap:clamp(3rem,9vw,5rem); }
  .crops{ grid-template-columns:repeat(2,1fr); }
  .hud__bar span.hide-sm{ display:none; }
  .hero__cue{ display:none; }
}
@media (max-width: 540px){
  .crops{ grid-template-columns:1fr; }
  .cv__list li{ grid-template-columns:1fr; gap:.2rem; }
  .cv__list .city{ justify-self:start; }
  .hud__corner{ width:18px; height:18px; }
  .foot__legal{ flex-direction:column; }
}

/* 12 · A11Y — focus + reduced motion ------------------------------------- */
:focus-visible{ outline:2px solid var(--red); outline-offset:3px; }
.figure__btn:focus-visible{ outline-offset:-3px; }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important;
    transition-duration:.001ms!important; scroll-behavior:auto!important; }
  [data-reveal],[data-stagger]>*{ opacity:1!important; transform:none!important; }
  [data-reveal-img]{ clip-path:none!important; }
  .hero__bg img{ animation:none; transform:scale(1.04); }
  .ticker__track,.hero__cue .line{ animation:none; }
  .ticker__track{ transform:none; }
}
