/* ============================================================
   VASSILIKI — shared design system
   Gallery-minimal · monochrome canvas · elongated-diamond motif
   ============================================================ */
:root{
  --paper:#F5F3EE; --ink:#17160F; --muted:#736E62; --faint:#8d8779;
  --line:#1716100f; --line2:#17161022; --line3:#17161038;
  --accent:#CE2A26; --black:#0C0C0B; --paper-d:#ECE9E2; --muted-d:#9a958c;
  --serif:'Noto Serif',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --maxw:1320px; --pad:clamp(20px,5vw,64px);
  --diamond:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='116' height='200' viewBox='0 0 116 200'%3E%3Cpolygon points='58,0 116,100 58,200 0,100' fill='%23000'/%3E%3C/svg%3E");
  --diamond-w:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='116' height='200' viewBox='0 0 116 200'%3E%3Cpolygon points='58,0 116,100 58,200 0,100' fill='%23fff'/%3E%3C/svg%3E");
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);line-height:1.62;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

/* fixed background layers (injected by app.js) */
.v-tex{position:fixed;inset:0;z-index:-1;pointer-events:none;background-image:var(--diamond);background-size:116px 200px;opacity:.045}
.v-grain{position:fixed;inset:0;z-index:9990;pointer-events:none;background-image:var(--grain);opacity:.035;mix-blend-mode:multiply}
#v-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:9995}

/* ---------- custom cursor (fine pointer only) ---------- */
.v-cursor,.v-ring{position:fixed;top:0;left:0;z-index:9996;pointer-events:none;border-radius:50%;
  mix-blend-mode:difference;opacity:0;transition:opacity .3s}
.v-cursor{width:7px;height:7px;background:#fff;margin:-3.5px 0 0 -3.5px}
.v-ring{width:40px;height:40px;border:1px solid #fff;margin:-20px 0 0 -20px;transition:opacity .3s,width .25s var(--ease),height .25s var(--ease),margin .25s var(--ease)}
body.has-cursor .v-cursor,body.has-cursor .v-ring{opacity:1}
body.has-cursor.cur-hot .v-ring{width:64px;height:64px;margin:-32px 0 0 -32px}
.v-ring .lab{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);
  font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:0;transition:opacity .25s}
body.cur-hot .v-ring .lab{opacity:1}
@media (pointer:coarse){.v-cursor,.v-ring{display:none}}

/* ---------- header ---------- */
.v-head{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--pad);transition:background .45s,color .45s,border-color .45s;
  background:color-mix(in srgb,var(--paper) 58%,transparent);backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid transparent}
.v-head.solid{border-bottom-color:var(--line);background:color-mix(in srgb,var(--paper) 84%,transparent)}
.v-head.dark{color:var(--paper-d);background:color-mix(in srgb,var(--black) 42%,transparent);border-bottom-color:#ffffff1c}
.v-head .brand{font-family:var(--serif);font-weight:500;font-size:21px;letter-spacing:.34em;text-indent:.34em}
.v-head nav{display:flex;align-items:center;gap:clamp(12px,1.8vw,30px)}
.v-head nav a.nl{font-size:12px;letter-spacing:.17em;text-transform:uppercase;color:var(--muted);position:relative;transition:color .25s}
.v-head.dark nav a.nl{color:var(--muted-d)}
.v-head nav a.nl:hover,.v-head nav a.nl.active{color:currentColor}
.v-head nav a.nl::after{content:"";position:absolute;left:0;right:100%;bottom:-7px;height:1.5px;background:var(--accent);transition:right .35s var(--ease)}
.v-head nav a.nl:hover::after,.v-head nav a.nl.active::after{right:0}
.v-head .lang{font-size:11px;letter-spacing:.12em;border:1px solid var(--line2);border-radius:20px;padding:5px 11px;color:var(--muted)}
.v-head .lang b{color:currentColor}
@media(max-width:860px){.v-head nav a.nl{display:none}}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:clamp(78px,11vh,148px) var(--pad)}
.eyebrow{font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin:0 0 22px;font-weight:500}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap;margin-bottom:clamp(32px,5vw,58px)}
.sec-head h2{font-family:var(--serif);font-weight:300;font-size:clamp(32px,5vw,58px);margin:0;letter-spacing:-.005em;line-height:1.02}
.sec-head .meta{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.more{display:inline-flex;align-items:center;gap:9px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:4px;transition:gap .3s}
.more:hover{gap:16px}
.dark-sec{background:var(--black);color:var(--paper-d);position:relative;overflow:hidden}
.dark-sec::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:var(--diamond-w);background-size:116px 200px;opacity:.06}
.dark-sec .wrap{position:relative;z-index:1}
.dark-sec .eyebrow{color:#fff}

/* ---------- motion primitives ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
.lines .ln{overflow:hidden;display:block}
.lines .ln>span{display:block;transform:translateY(112%);transition:transform .95s var(--ease);transition-delay:var(--d,0s)}
.lines.in .ln>span{transform:none}
.clip{clip-path:inset(0 0 100% 0);transition:clip-path 1.05s var(--ease)}
.clip.in{clip-path:inset(0 0 0 0)}
.clip img{transform:scale(1.07);transition:transform 1.3s var(--ease)}
.clip.in img{transform:scale(1)}
html.reveal-all .reveal{opacity:1!important;transform:none!important}
html.reveal-all .lines .ln>span{transform:none!important}
html.reveal-all .clip{clip-path:inset(0 0 0 0)!important}
html.reveal-all .clip img{transform:none!important}
@media(prefers-reduced-motion:reduce){
  .reveal,.lines .ln>span,.clip,.clip img{opacity:1!important;transform:none!important;clip-path:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ---------- HERO ---------- */
/* hero — centered image band, edges masked into the diamond field on L/R */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.hero .stage,.hero .veil{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:min(1140px,72vw);overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 16%,#000 84%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 16%,#000 84%,transparent 100%)}
.hero .stage{z-index:0}
.hero .stage img{width:100%;height:100%;object-fit:cover;object-position:50% 0%;transform:translateY(8%) scale(1.18);animation:kenburns 26s ease-out forwards}
@keyframes kenburns{from{transform:translateY(8%) scale(1.18)}to{transform:translateY(5.5%) scale(1.26)}}
.hero .veil{z-index:1;pointer-events:none;background:linear-gradient(180deg,#0b1a2e22 0%,#0b1a2e00 24%,#0b1a2e00 46%,#07111e88 100%)}
.hero .inner{position:relative;z-index:2;width:100%;text-align:center;padding:0 var(--pad) clamp(48px,9vh,104px)}
.hero .kick{color:#fff;font-size:14px;letter-spacing:.34em;text-transform:uppercase;margin:0 0 16px;opacity:.94;text-shadow:0 2px 18px #0008}
.hero h1{font-family:var(--serif);font-weight:400;color:#fff;margin:0;line-height:.96;
  font-size:clamp(52px,12vw,172px);letter-spacing:.07em;text-shadow:0 4px 50px #0005,0 2px 16px #0007}
.hero .tag{color:#fff;font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(19px,2.4vw,31px);margin:16px auto 0;max-width:30ch;opacity:.96;text-shadow:0 2px 20px #0008}
.hero .cue{position:absolute;left:50%;bottom:22px;z-index:3;transform:translateX(-50%);color:#fff;font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.82;display:flex;flex-direction:column;align-items:center;gap:8px;text-shadow:0 1px 10px #0009}
.hero .cue i{width:1px;height:34px;background:#fff;animation:cue 1.9s ease-in-out infinite;transform-origin:top}
@keyframes cue{0%,100%{transform:scaleY(.3);opacity:.4}50%{transform:scaleY(1);opacity:1}}
.hero-stagger{opacity:0;transform:translateY(30px);animation:rise 1.1s var(--ease) forwards;animation-delay:var(--d,0s)}
@keyframes rise{to{opacity:1;transform:none}}
.page-hero{padding:clamp(140px,22vh,240px) var(--pad) clamp(40px,7vh,90px);border-bottom:1px solid var(--line2)}
.page-hero .kick{color:var(--accent);font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;margin:0 0 18px}
.page-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(44px,8vw,120px);margin:0;letter-spacing:-.02em;line-height:.98}
.page-hero p{max-width:60ch;margin:22px 0 0;font-size:16px;color:#46423a}

/* ---------- statement ---------- */
.statement .lede{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3.7vw,52px);line-height:1.14;letter-spacing:-.01em;margin:0;max-width:22ch}
.statement .lede b{color:var(--accent);font-weight:400;font-style:italic}
.statement .body{margin-top:30px;font-size:16.5px;color:#46423a;max-width:54ch}

/* ---------- STAT BANDS ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
.stat{border-top:1px solid var(--line3);padding-top:22px}
.dark-sec .stat{border-top-color:#ffffff2e}
.stat .n{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5.6vw,80px);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat .l{font-size:12.5px;color:var(--muted);margin-top:14px;line-height:1.45;max-width:24ch}
.dark-sec .stat .l{color:var(--muted-d)}
.stat .src{font-size:11px;color:var(--faint);margin-top:10px;font-style:italic;opacity:0;max-height:0;overflow:hidden;transition:opacity .4s,max-height .4s}
.stat:hover .src{opacity:.85;max-height:80px}
@media(max-width:820px){.stats{grid-template-columns:repeat(2,1fr);gap:34px 24px}}

/* ---------- installations (alternating blocks) ---------- */
.inst{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,5vw,72px);align-items:center;margin-bottom:clamp(60px,9vw,120px)}
.inst:nth-child(even) .inst-txt{order:2}
.inst figure{margin:0;overflow:hidden;background:#fff;border:1px solid var(--line2);aspect-ratio:4/3}
.inst figure img{width:100%;height:100%;object-fit:cover}
.inst .yr{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin:0 0 14px}
.inst h3{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.6vw,46px);margin:0 0 16px;line-height:1.05}
.inst p{margin:0 0 16px;font-size:15.5px;color:#46423a;max-width:52ch}
@media(max-width:840px){.inst{grid-template-columns:1fr;gap:22px}.inst:nth-child(even) .inst-txt{order:0}}

/* ---------- works grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,30px)}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid{grid-template-columns:1fr}}
.card{cursor:pointer}
.card figure{margin:0;overflow:hidden;background:#fff;border:1px solid var(--line2);aspect-ratio:4/5;position:relative}
.card img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.card:hover img{transform:scale(1.06)}
.card h3{font-family:var(--serif);font-weight:400;font-size:20px;margin:15px 0 2px}
.card p{margin:0;font-size:12.5px;color:var(--muted)}

/* ---------- horizontal strip ---------- */
.strip-wrap{overflow:hidden}
.strip{display:grid;grid-auto-flow:column;grid-auto-columns:min(80vw,460px);gap:clamp(14px,2vw,28px);
  overflow-x:auto;scroll-snap-type:x mandatory;padding:6px var(--pad) 34px;scrollbar-width:thin}
.strip::-webkit-scrollbar{height:6px}.strip::-webkit-scrollbar-thumb{background:#00000022;border-radius:6px}
.strip .item{scroll-snap-align:center;cursor:pointer}
.strip figure{margin:0;overflow:hidden;background:#fff;border:1px solid var(--line2);height:62vh;min-height:380px}
.strip img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.strip .item:hover img{transform:scale(1.05)}
.strip figcaption{margin-top:13px;font-size:12.5px;color:var(--muted)}
.strip figcaption b{display:block;font-family:var(--serif);font-weight:400;font-size:18px;color:var(--ink);margin-bottom:2px}

/* ---------- index lists (series / exhibitions) with hover preview ---------- */
.ilist{border-top:1px solid var(--line2)}
.ilist a,.ilist .row{display:flex;justify-content:space-between;align-items:baseline;gap:24px;padding:clamp(14px,2.4vw,26px) 4px;border-bottom:1px solid var(--line2);transition:padding-left .45s var(--ease),background .4s;position:relative}
.ilist a::before{content:"\2192";position:absolute;left:2px;top:50%;transform:translate(-12px,-50%);color:var(--accent);opacity:0;font-size:20px;transition:opacity .4s,transform .45s var(--ease)}
.ilist a:hover{padding-left:40px;background:#ffffff55}
.ilist a:hover::before{opacity:1;transform:translate(0,-50%)}
.ilist .t{font-family:var(--serif);font-weight:300;font-size:clamp(22px,3.4vw,44px);letter-spacing:-.01em;padding-bottom:3px;transition:color .3s;
  background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-position:0 94%;background-size:0% 1.5px;transition:color .3s,background-size .55s var(--ease)}
.ilist a:hover .t{color:var(--accent);background-size:100% 1.5px}
.ilist .y{font-size:12.5px;color:var(--muted);letter-spacing:.08em;white-space:nowrap;transition:color .3s,transform .45s var(--ease)}
.ilist a:hover .y{color:var(--ink);transform:translateX(-4px)}
.v-preview{position:fixed;top:0;left:0;width:300px;height:220px;z-index:120;pointer-events:none;opacity:0;
  background-size:cover;background-position:center;border-radius:2px;box-shadow:0 30px 60px #0003;
  transform:translate(-50%,-50%) scale(.85);transition:opacity .35s,transform .5s var(--ease);clip-path:inset(0 0 0 0)}
.v-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* ---------- pull-quotes (critical voices) ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,32px)}
@media(max-width:880px){.quotes{grid-template-columns:1fr}}
.quote{border-top:2px solid var(--ink);padding-top:24px}
.quote .q{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(18px,1.5vw,21px);line-height:1.4;margin:0 0 20px}
.quote .by{font-size:12.5px;letter-spacing:.04em;color:var(--ink);font-weight:500}
.quote .by span{display:block;color:var(--muted);font-weight:400;font-size:12px;letter-spacing:.02em;margin-top:3px}

/* ---------- feature full-bleed ---------- */
.feature{position:relative;height:96vh;min-height:560px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.feature .ph{position:absolute;inset:0;z-index:0;overflow:hidden}
.feature .ph img{width:100%;height:118%;object-fit:cover;will-change:transform}
.feature .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0007,#0002 35%,#0001 60%,#0006)}
.feature .cap{position:relative;z-index:1;color:#fff;padding:0 24px}
.feature .cap .ey{font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;opacity:.9;margin:0 0 14px}
.feature .cap h2{font-family:var(--serif);font-weight:300;font-size:clamp(32px,6vw,82px);margin:0;line-height:1.02;text-shadow:0 3px 40px #0007}
.feature .cap p{margin:16px auto 0;max-width:46ch;font-size:15px;opacity:.92}

/* ---------- biography teaser / prose ---------- */
.bio-grid{display:grid;grid-template-columns:1fr .82fr;gap:clamp(28px,5vw,72px);align-items:center}
.bio-grid .lede{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3.2vw,42px);line-height:1.14;margin:0}
.bio-grid p.body{margin:24px 0 0;font-size:16px;color:#46423a;max-width:50ch}
.bio-grid .pic{aspect-ratio:3/4;background:#fff;border:1px solid var(--line2);overflow:hidden}
.bio-grid .pic img{width:100%;height:100%;object-fit:cover}
@media(max-width:860px){.bio-grid{grid-template-columns:1fr}.bio-grid .pic{order:-1;aspect-ratio:4/3}}
.prose{max-width:66ch;font-size:17px;line-height:1.8;color:#2b2922}
.prose p{margin:0 0 1.4em}
.prose p:first-of-type::first-letter{font-family:var(--serif);float:left;font-size:4.2em;line-height:.82;padding:6px 14px 0 0;color:var(--accent)}
.prose.fr{font-style:italic}

/* ---------- timeline ---------- */
.timeline{border-left:1px solid var(--line3);margin-left:6px}
.timeline .tl{position:relative;padding:0 0 30px 30px}
.timeline .tl::before{content:"";position:absolute;left:-4.5px;top:7px;width:8px;height:8px;border-radius:50%;background:var(--accent)}
.timeline .tl .yr{font-family:var(--serif);font-size:18px;color:var(--ink);margin-bottom:4px}
.timeline .tl .tx{font-size:15px;color:#46423a;max-width:60ch}

/* ---------- catalog (works pages) ---------- */
.cat-group{margin-bottom:clamp(40px,6vw,80px)}
.cat-group h3{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3.4vw,40px);margin:0 0 6px}
.cat-group .gmeta{font-size:12.5px;letter-spacing:.06em;color:var(--muted);margin-bottom:26px}
.cat{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,24px)}
@media(max-width:1000px){.cat{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.cat{grid-template-columns:repeat(2,1fr)}}
.cat .it figure{margin:0;overflow:hidden;background:#fff;border:1px solid var(--line2);aspect-ratio:1;cursor:pointer}
.cat .it img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.cat .it:hover img{transform:scale(1.05)}
.cat .it .ti{font-family:var(--serif);font-size:16px;margin:11px 0 1px}
.cat .it .di{font-size:11.5px;color:var(--muted);line-height:1.4}

/* ---------- exhibitions table ---------- */
.exh{border-top:1px solid var(--line2)}
.exh .row{display:grid;grid-template-columns:92px 1fr auto;gap:24px;padding:14px 4px;border-bottom:1px solid var(--line2);align-items:baseline;transition:background .3s}
.exh .row:hover{background:#ffffff55}
.exh .yr{font-family:var(--serif);font-size:18px;color:var(--accent)}
.exh .ti{font-size:15px}
.exh .pl{font-size:12.5px;color:var(--muted);text-align:right}
@media(max-width:600px){.exh .row{grid-template-columns:64px 1fr}.exh .pl{grid-column:2;text-align:left;margin-top:-6px}}

/* ---------- forms ---------- */
.field{margin-bottom:20px}
.field label{display:block;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field textarea{width:100%;background:#fff;border:1px solid var(--line3);padding:13px 14px;font-family:var(--sans);font-size:15px;color:var(--ink)}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.btn{display:inline-block;background:var(--ink);color:var(--paper);border:none;padding:15px 34px;font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:background .3s}
.btn:hover{background:var(--accent)}

/* ---------- contact / footer ---------- */
.contact-c{text-align:center}
.contact-c h2{font-family:var(--serif);font-weight:300;font-size:clamp(40px,7vw,104px);margin:0 0 16px;letter-spacing:-.02em}
.contact-c .mail{font-family:var(--serif);font-style:italic;font-size:clamp(20px,3vw,30px);border-bottom:1px solid var(--accent);padding-bottom:3px}
.socials{margin:40px 0 0;display:flex;gap:26px;justify-content:center;flex-wrap:wrap}
.socials a{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:color .25s}
.socials a:hover{color:var(--accent)}
.v-foot{border-top:1px solid var(--line2);padding:clamp(40px,6vw,72px) var(--pad) 30px}
.v-foot .fin{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.v-foot .brand{font-family:var(--serif);font-size:20px;letter-spacing:.3em}
.v-foot nav{display:flex;gap:20px;flex-wrap:wrap}
.v-foot nav a{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.v-foot nav a:hover{color:var(--accent)}
.v-foot .legal{max-width:var(--maxw);margin:36px auto 0;font-size:11.5px;letter-spacing:.06em;color:var(--faint);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.v-foot .legal a{color:var(--faint)}.v-foot .legal a:hover{color:var(--accent)}

/* ---------- lightbox ---------- */
#v-lb{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:#0b0b0af5;backdrop-filter:blur(6px);padding:4vh 4vw}
#v-lb.open{display:flex;animation:lbf .35s ease}
@keyframes lbf{from{opacity:0}to{opacity:1}}
#v-lb img{max-width:100%;max-height:84vh;object-fit:contain;box-shadow:0 30px 80px #000a}
#v-lb .cap{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:#e9e6df;font-size:13px}
#v-lb .cap b{font-family:var(--serif);display:block;font-size:18px;margin-bottom:2px}
#v-lb .x{position:absolute;top:20px;right:26px;color:#fff;font-size:30px;line-height:1;cursor:pointer;opacity:.8}
#v-lb .x:hover{opacity:1}

/* ===== mail link (works outside .contact-c too) ===== */
.mail{font-family:var(--serif);font-style:italic;border-bottom:1px solid var(--accent);padding-bottom:3px;transition:color .25s}
.mail:hover{color:var(--accent)}

/* ===== typographic scale-up (+~22% on small elements) ===== */
.v-head nav a.nl{font-size:14px}
.v-head .lang{font-size:13px}
.eyebrow{font-size:13.5px}
.sec-head .meta{font-size:14px}
.more{font-size:13.5px}
.statement .body{font-size:19px}
.stat .l{font-size:15px}
.stat .src{font-size:13px}
.inst .yr{font-size:14px}
.inst p{font-size:17.5px}
.card h3{font-size:22px}
.card p{font-size:15px}
.strip figcaption{font-size:15px}
.strip figcaption b{font-size:20px}
.ilist .y{font-size:14.5px}
.quote .q{font-size:clamp(19px,1.5vw,23px)}
.quote .by{font-size:14.5px}
.quote .by span{font-size:13.5px}
.feature .cap .ey{font-size:13px}
.feature .cap p{font-size:17px}
.bio-grid p.body{font-size:18px}
.page-hero .kick{font-size:13.5px}
.page-hero p{font-size:18px}
.prose{font-size:19px;line-height:1.85}
.timeline .tl .yr{font-size:20px}
.timeline .tl .tx{font-size:16.5px}
.cat-group .gmeta{font-size:14.5px}
.cat .it .ti{font-size:19px}
.cat .it .di{font-size:14px}
.exh .yr{font-size:20px}
.exh .ti{font-size:17px}
.exh .pl{font-size:14.5px}
.field label{font-size:13.5px}
.field input,.field textarea{font-size:16.5px}
.btn{font-size:13.5px}
.socials a{font-size:14px}
.v-foot nav a{font-size:14px}
.v-foot .legal{font-size:13px}
.lang{font-size:13px}

/* ===== interactive diamond field ===== */
.v-field{position:fixed;inset:0;z-index:-1;pointer-events:none}
body.has-field .v-tex{display:none}

/* ===== mobile menu (injected by app.js) ===== */
.v-burger{display:none;width:30px;height:18px;position:relative;background:none;border:0;cursor:pointer;color:inherit;padding:0}
.v-burger span{position:absolute;left:0;right:0;height:2px;background:currentColor;transition:transform .35s var(--ease),opacity .25s}
.v-burger span:nth-child(1){top:0}.v-burger span:nth-child(2){top:8px}.v-burger span:nth-child(3){top:16px}
body.menu-open .v-burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open .v-burger span:nth-child(2){opacity:0}
body.menu-open .v-burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.v-menu{position:fixed;inset:0;z-index:205;background:var(--paper);display:flex;flex-direction:column;justify-content:center;gap:2px;padding:84px var(--pad);transform:translateY(-100%);transition:transform .55s var(--ease);visibility:hidden}
body.menu-open .v-menu{transform:none;visibility:visible}
.v-menu a{font-family:var(--serif);font-weight:300;font-size:clamp(30px,8vw,52px);color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line2);letter-spacing:-.01em}
.v-menu a:hover{color:var(--accent)}
@media(max-width:860px){ .v-head nav{display:none} .v-burger{display:block} }

/* ===== mobile layout ===== */
@media(max-width:720px){
  :root{--pad:20px}
  .wrap{padding:clamp(60px,9vh,88px) var(--pad)}
  .hero{min-height:540px}
  .hero .stage,.hero .veil{width:90vw;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
  .hero h1{font-size:clamp(44px,16vw,86px)}
  .sec-head{margin-bottom:30px}
  .sec-head h2{font-size:clamp(30px,9vw,46px)}
  .stats{grid-template-columns:1fr 1fr;gap:26px 16px}
  .stat .n{font-size:clamp(38px,12vw,58px)}
  .inst{grid-template-columns:1fr;gap:18px;margin-bottom:48px}
  .grid{grid-template-columns:1fr 1fr;gap:12px}
  .quotes{grid-template-columns:1fr;gap:24px}
  .bio-grid{grid-template-columns:1fr}
  .cat{grid-template-columns:1fr 1fr;gap:12px}
  .feature{height:78vh;min-height:440px}
  .prose{font-size:17px}
  .prose p:first-of-type::first-letter{font-size:3.4em}
  .page-hero{padding-top:118px}
  .v-foot .fin{flex-direction:column;gap:18px}
}
@media(max-width:440px){ .grid,.cat{grid-template-columns:1fr} .stats{grid-template-columns:1fr} }
