/*
Theme Name: Tash Architects
Theme URI: https://tasharchitects.com
Author: ARI Studio
Author URI: https://anesvarportfolio.netlify.app
Description: Editorial single-page architecture portfolio for Tash Architects. Plugin-free: custom Project post type, custom Work taxonomy, native contact enquiries, a one-click content importer, and a faithful scroll-driven SPA with instant in-page navigation.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tash-architects
*/

/* ============================================================
   Core editorial CSS (preserved verbatim from the original build)
   ============================================================ */

/* ============================================================
   TASH ARCHITECTS — Editorial redesign
   ============================================================ */
:root{
  --paper:#F2EEE5;
  --paper-2:#EAE4D7;
  --ink:#15140E;
  --ink-soft:#3A382E;
  --stone:#8C826F;
  --line:rgba(21,20,14,.14);
  --line-soft:rgba(21,20,14,.08);
  /* black + gold — brass tuned to "natural light", not luxury bling */
  --accent:#9A7223;
  --accent-soft:#C29A4E;
  --gold:#C9A24B;
  --gold-lite:#E7C871;
  --noir:#100F08;
  --noir-2:#1C1A10;
  --display:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Schibsted Grotesk", "Helvetica Neue", Arial, sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-2:cubic-bezier(.65,.05,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.lock{overflow:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--ink)}

/* grain overlay */
body::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;
  opacity:.045;mix-blend-mode:multiply;
  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='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- layout helpers ---------- */
.wrap{width:min(92vw,1480px);margin-inline:auto}
.col-pad{padding-inline:clamp(20px,5vw,72px)}
.eyebrow{
  font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--stone);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--stone);display:inline-block}
.display{font-family:var(--display);font-weight:340;line-height:.96;letter-spacing:-.015em}
.italic{font-style:italic;font-weight:340}
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}

/* ============================================================
   PRELOADER
   ============================================================ */
#loader{
  position:fixed;inset:0;z-index:10000;background:var(--paper);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(24px,5vw,64px);
}
#loader .mark{font-family:var(--display);font-size:clamp(34px,7vw,86px);line-height:.9;letter-spacing:-.02em}
#loader .mark span{display:block;overflow:hidden}
#loader .mark span i{display:block;transform:translateY(105%);transition:transform .9s var(--ease)}
#loader.go .mark span i{transform:none}
#loader .row{display:flex;justify-content:space-between;align-items:flex-end;margin-top:clamp(28px,6vh,72px);
  border-top:1px solid var(--line);padding-top:18px}
#loader .pc{font-family:var(--display);font-size:clamp(40px,9vw,110px);line-height:.85;font-weight:330}
#loader .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);max-width:240px;text-align:right}
#loader .bar{position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--ink)}
body.loaded #loader{transform:translateY(-101%);transition:transform 1.05s var(--ease-2) .25s;pointer-events:none}

/* ============================================================
   HEADER
   ============================================================ */
header{
  position:fixed;top:0;left:0;width:100%;z-index:60;
  display:flex;justify-content:space-between;align-items:center;
  padding:clamp(18px,2.4vw,30px) clamp(20px,5vw,72px);
  mix-blend-mode:difference;color:#fff;
}
header .logo{font-family:var(--display);font-size:clamp(17px,1.6vw,22px);letter-spacing:.01em;font-weight:420;line-height:1}
header .logo sup{font-size:.5em;vertical-align:super;font-family:var(--sans);font-weight:600}
header .logo small{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.24em;text-transform:uppercase;margin-top:5px;opacity:.8;font-weight:600}
.menu-btn{
  display:flex;align-items:center;gap:12px;background:none;border:none;color:inherit;cursor:pointer;
  font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
}
.menu-btn .bars{display:inline-flex;flex-direction:column;gap:4px;width:24px}
.menu-btn .bars i{height:1.5px;background:currentColor;display:block;transition:transform .4s var(--ease),opacity .3s}
.menu-btn[aria-expanded="true"] .bars i:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.menu-btn[aria-expanded="true"] .bars i:nth-child(2){opacity:0}
.menu-btn[aria-expanded="true"] .bars i:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

/* ============================================================
   MENU OVERLAY
   ============================================================ */
#menu{
  position:fixed;inset:0;z-index:55;background:var(--noir);color:var(--paper);
  clip-path:inset(0 0 100% 0);transition:clip-path .85s var(--ease-2);
  display:grid;grid-template-columns:1.1fr .9fr;align-items:center;
}
#menu.open{clip-path:inset(0 0 0 0)}
#menu .primary{padding:clamp(70px,9vh,110px) clamp(28px,6vw,90px) 50px;overflow-y:auto;max-height:100vh;max-height:100svh;scrollbar-width:none}
#menu .primary::-webkit-scrollbar{display:none}
#menu .nav-top,#menu .work-head{
  display:block;font-family:var(--display);font-size:clamp(32px,4.6vw,60px);line-height:1.08;
  font-weight:330;letter-spacing:-.02em;color:var(--paper);
}
#menu .nav-top{opacity:.55;transition:opacity .4s,padding-left .5s var(--ease)}
#menu .nav-top:hover{opacity:1;padding-left:.4em}
#menu .work-head{opacity:1;margin-top:6px}
#menu .nav-top .n,#menu .work-head .n{font-family:var(--sans);font-size:12px;font-weight:600;vertical-align:super;opacity:.5;margin-right:.5em}
/* category accordion */
#menu .cats{list-style:none;margin:10px 0 14px;padding-left:clamp(6px,1.4vw,22px)}
#menu .cat{border-bottom:1px solid rgba(242,238,229,.16)}
#menu .cat:first-child{border-top:1px solid rgba(242,238,229,.16)}
#menu .cat-tog{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:none;border:none;cursor:pointer;color:var(--paper);text-align:left;
  font-family:var(--sans);font-size:clamp(13.5px,1.5vw,18px);font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;padding:13px 0;opacity:.72;transition:opacity .3s,padding-left .4s var(--ease)}
#menu .cat-tog:hover{opacity:1;padding-left:6px}
#menu .cat-tog .ar{font-family:var(--sans);font-size:17px;font-weight:400;opacity:.6;transition:transform .4s var(--ease)}
#menu .cat.open .cat-tog{opacity:1}
#menu .cat.open .cat-tog .ar{transform:rotate(45deg)}
#menu .cat-panel{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
#menu .cat.open .cat-panel{max-height:640px}
#menu .cat-in{padding:2px 0 16px}
#menu .cat-in a{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:7px 0 7px 2px;
  color:var(--paper);opacity:.72;transition:opacity .3s,padding-left .4s var(--ease)}
#menu .cat-in a:hover{opacity:1;padding-left:8px}
#menu .cat-in a .pj{font-family:var(--display);font-size:clamp(16px,1.8vw,22px);font-weight:340;letter-spacing:-.01em}
#menu .cat-in a .pl{font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;white-space:nowrap}
#menu .cat-in .soon{font-family:var(--display);font-style:italic;font-size:14px;opacity:.4;display:block;padding:4px 0 2px}
/* secondary panel */
#menu .secondary{
  align-self:stretch;border-left:1px solid rgba(242,238,229,.18);
  padding:clamp(90px,12vh,150px) clamp(28px,4vw,60px) 60px;display:flex;flex-direction:column;
}
#menu .secondary .cap{font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.55;margin-bottom:22px;font-weight:600}
#menu .menu-blurb{font-family:var(--display);font-weight:330;font-size:clamp(20px,1.9vw,26px);line-height:1.3;opacity:.85;max-width:30ch}
#menu .foot{margin-top:auto;padding-top:34px;display:flex;justify-content:space-between;align-items:flex-end;
  font-size:12px;letter-spacing:.04em;opacity:.8;flex-wrap:wrap;gap:14px}
#menu .foot a:hover{text-decoration:underline}
.menu-open header{mix-blend-mode:normal;color:var(--paper)}

/* ============================================================
   IMAGE SYSTEM (photo + elegant designed fallback)
   ============================================================ */
.img{position:relative;overflow:hidden;background:var(--paper-2);isolation:isolate}
.img::before{ /* designed fallback gradient */
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(120% 90% at 18% 12%, rgba(255,255,255,.5), transparent 55%),
    linear-gradient(150deg,#cfc7b4,#a79d86 55%,#7e7563);
}
.img.g2::before{background:radial-gradient(120% 90% at 80% 10%,rgba(255,255,255,.45),transparent 55%),linear-gradient(150deg,#b7b9a6,#7f8470 60%,#565b48)}
.img.g3::before{background:radial-gradient(120% 90% at 20% 85%,rgba(255,255,255,.4),transparent 55%),linear-gradient(150deg,#d8cdbb,#b29f86 55%,#8a7559)}
.img.g4::before{background:radial-gradient(120% 90% at 75% 80%,rgba(255,255,255,.4),transparent 55%),linear-gradient(150deg,#c4c2bb,#9a978c 55%,#6f6c61)}
.img::after{ /* label shown over fallback, hidden once photo paints */
  content:attr(data-label);position:absolute;inset:0;z-index:2;
  display:flex;align-items:flex-end;padding:18px;
  font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.8);
}
.img img{position:relative;z-index:3;width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s var(--ease),opacity .8s ease;opacity:0}
.img img.ok{opacity:1}
.img img.failed{opacity:0}
.img.hoverable:hover img.ok{transform:scale(1.04)}

/* ============================================================
   HERO — project render, dusk + gold light
   ============================================================ */
.hero{position:relative;min-height:100svh;background:var(--noir);color:var(--paper);
  display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;
  padding:clamp(110px,16vh,170px) clamp(20px,5vw,72px) clamp(28px,5vh,54px)}

/* full-bleed render with a slow settle */
.hero .shot{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero .shot img{width:100%;height:100%;object-fit:cover;object-position:50% 58%;
  transform:scale(1.08);will-change:transform}
body.loaded .hero .shot img{animation:kb 14s var(--ease) forwards}
@keyframes kb{to{transform:scale(1)}}

/* scrim: darken top / left / bottom for legibility, let the lit facades glow through centre-right */
.hero .scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(16,15,8,.74) 0%, rgba(16,15,8,.10) 24%, rgba(16,15,8,0) 44%, rgba(16,15,8,.12) 64%, rgba(16,15,8,.88) 100%),
    linear-gradient(90deg, rgba(16,15,8,.80) 0%, rgba(16,15,8,.32) 30%, rgba(16,15,8,0) 58%)}

/* corner registration ticks — architect's drafting marks */
.hero .ticks{position:absolute;inset:clamp(14px,2vw,26px);z-index:2;pointer-events:none}
.hero .ticks i{position:absolute;width:16px;height:16px;opacity:.6}
.hero .ticks i::before,.hero .ticks i::after{content:"";position:absolute;background:var(--gold-lite)}
.hero .ticks i::before{width:16px;height:1px;top:0;left:0}
.hero .ticks i::after{width:1px;height:16px;top:0;left:0}
.hero .ticks i.tr{right:0;transform:scaleX(-1)}
.hero .ticks i.bl{bottom:0;transform:scaleY(-1)}
.hero .ticks i.br{right:0;bottom:0;transform:scale(-1)}

/* headline */
.hero h1{position:relative;z-index:3;font-family:var(--display);font-weight:340;
  font-size:clamp(50px,11.5vw,176px);line-height:.84;letter-spacing:-.035em;
  color:var(--paper);max-width:13ch;text-shadow:0 2px 40px rgba(16,15,8,.5)}
.hero h1 .word{display:block;overflow:hidden;padding-bottom:.04em}
.hero h1 .word > i{display:inline-block;font-style:normal;transform:translateY(112%)}
body.loaded .hero h1 .word > i{animation:rise 1.05s var(--ease) forwards;animation-delay:var(--d,0s)}
@keyframes rise{to{transform:none}}
.hero h1 em{font-style:italic}
/* the literal box around "box" — a thin gold frame that draws shut */
.hero h1 .boxed{position:relative;display:inline-block;padding:.02em .2em 0}
.hero h1 .boxed > b{font-weight:inherit;font-style:italic;position:relative;z-index:1;color:var(--gold-lite)}
.hero h1 .boxed::before{content:"";position:absolute;inset:.16em .04em .2em;border:1.6px solid var(--gold);
  box-shadow:0 0 24px rgba(231,200,113,.35);clip-path:inset(0 100% 0 0)}
body.loaded .hero h1 .boxed::before{animation:boxin .75s var(--ease) forwards;animation-delay:1.4s}
@keyframes boxin{to{clip-path:inset(0 0 0 0)}}

/* top + bottom rows */
.hero .top{position:relative;z-index:3;display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap}
.hero .top p{max-width:34ch;font-size:14.5px;color:rgba(242,238,229,.82);line-height:1.55;text-shadow:0 1px 18px rgba(16,15,8,.6)}
.hero .eyebrow{color:rgba(242,238,229,.72)}
.hero .eyebrow::before{background:rgba(242,238,229,.5)}
.hero .bottom{position:relative;z-index:3;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-top:auto}
.hero .scroll{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(242,238,229,.72);font-weight:600;display:flex;align-items:center;gap:10px}
.hero .scroll .dot{width:8px;height:8px;border-radius:50%;background:var(--gold-lite);animation:bob 1.8s var(--ease) infinite}
.hero .tagline{color:var(--gold-lite)}
.hero .tagline::before{background:var(--gold)}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

@media (max-width:820px){
  .hero .shot img{object-position:50% 56%}
  .hero h1{max-width:none}
  .hero .scrim{background:
    linear-gradient(180deg, rgba(16,15,8,.72) 0%, rgba(16,15,8,.18) 30%, rgba(16,15,8,.05) 50%, rgba(16,15,8,.3) 68%, rgba(16,15,8,.9) 100%)}
}
@media (prefers-reduced-motion:reduce){
  .hero .shot img{animation:none;transform:scale(1)}
  .hero h1 .word > i{transform:none;animation:none}
  .hero h1 .boxed::before{clip-path:none;animation:none}
  .hero .scroll .dot{animation:none}
}

/* ============================================================
   STATEMENT / INTRO band
   ============================================================ */
.statement{padding:clamp(80px,14vh,180px) clamp(20px,5vw,72px)}
.statement p{font-family:var(--display);font-weight:330;font-size:clamp(26px,4.4vw,62px);line-height:1.12;letter-spacing:-.015em;max-width:18ch}
.statement p em{font-style:italic;color:var(--accent)}.statement--split{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:clamp(30px,5vw,80px);align-items:center}.statement-img{aspect-ratio:3/2;width:100%}@media (max-width:1024px){.statement--split{grid-template-columns:1fr;gap:34px}}

/* dual hero images */
.figrow{display:grid;gap:clamp(12px,1.4vw,22px);padding:0 clamp(20px,5vw,72px) clamp(40px,8vh,110px)}
.figrow.two{grid-template-columns:1.55fr 1fr}
.figrow .img{aspect-ratio:16/10}
.figrow .img.tall{aspect-ratio:3/4}

/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:clamp(60px,10vh,120px) clamp(20px,5vw,72px);border-top:1px solid var(--line)}
.about .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:start}
.about h2{font-family:var(--display);font-weight:330;font-size:clamp(34px,5.6vw,86px);line-height:.98;letter-spacing:-.02em}
.about h2 em{font-style:italic;color:var(--accent)}
.about .body{display:flex;flex-direction:column;gap:22px;padding-top:10px}
.about .body p{font-size:15.5px;line-height:1.7;color:var(--ink-soft);max-width:46ch}
.about .meta{display:flex;gap:40px;flex-wrap:wrap;margin-top:8px}
.about .meta .stat{display:flex;flex-direction:column;gap:4px}
.about .meta .stat b{font-family:var(--display);font-size:clamp(30px,3.4vw,46px);font-weight:340;line-height:1}
.about .meta .stat span{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);font-weight:600}
.cluster{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:9vw;gap:clamp(10px,1.2vw,18px);
  padding:0 clamp(20px,5vw,72px) clamp(40px,8vh,110px)}
.cluster .img:nth-child(1){grid-column:1/4;grid-row:span 4}
.cluster .img:nth-child(2){grid-column:4/7;grid-row:span 3}
.cluster .img:nth-child(3){grid-column:4/7;grid-row:span 2}
.figrow.pair{grid-template-columns:1fr 1fr}
.figrow.pair .img{aspect-ratio:4/3}
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.2vw,18px);padding:0 clamp(20px,5vw,72px) clamp(40px,8vh,110px)}
.trio .img{aspect-ratio:4/3}
@media(max-width:760px){.figrow.pair{grid-template-columns:1fr 1fr}.trio{grid-template-columns:1fr}}

/* ============================================================
   MANIFESTO band
   ============================================================ */
.manifesto{background:var(--noir);color:var(--paper);padding:clamp(90px,16vh,200px) clamp(20px,5vw,72px);overflow:hidden}
.manifesto p{font-family:var(--display);font-weight:320;font-size:clamp(30px,5.4vw,80px);line-height:1.06;letter-spacing:-.02em;max-width:20ch}
.manifesto p em{font-style:italic;color:var(--gold-lite)}
.manifesto .tag{margin-top:34px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.6;font-weight:600}

/* marquee */
.marquee{overflow:hidden;white-space:nowrap;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(14px,2vh,26px) 0}
.marquee .track{display:inline-flex;align-items:center;animation:scroll 26s linear infinite}
.marquee span{font-family:var(--display);font-size:clamp(34px,6vw,84px);font-weight:320;letter-spacing:-.01em;padding:0 .35em;font-style:italic}
.marquee .ast{font-style:normal;color:var(--accent);font-family:var(--sans);transform:translateY(-.06em)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================================================
   VALUES
   ============================================================ */
.values{padding:clamp(70px,12vh,140px) clamp(20px,5vw,72px)}
.values .head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(40px,7vh,90px);flex-wrap:wrap}
.values .head h2{font-family:var(--display);font-weight:330;font-size:clamp(40px,7vw,110px);line-height:.9;letter-spacing:-.02em}
.values .row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(20px,3vw,48px)}
.value{border-top:1px solid var(--ink);padding-top:22px;display:flex;flex-direction:column}
.value .num{font-family:var(--display);font-size:13px;color:var(--stone)}
.value .img{aspect-ratio:4/5;margin:22px 0;border-radius:0}
.value h3{font-family:var(--display);font-weight:360;font-size:clamp(22px,2.4vw,32px);letter-spacing:-.01em;margin-bottom:14px}
.value p{font-size:14px;line-height:1.65;color:var(--ink-soft)}

/* ============================================================
   PROJECTS
   ============================================================ */
.projects{border-top:1px solid var(--line);position:relative;background:var(--paper)}
/* the tall wrapper creates the scroll distance; sticky child pins */
.hscroll{position:relative}
.hsticky{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.hhead{position:absolute;top:0;left:0;width:100%;z-index:5;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  padding:clamp(96px,13vh,140px) clamp(20px,5vw,72px) 0;pointer-events:none}
.hhead h2{font-family:var(--display);font-weight:330;font-size:clamp(26px,3.8vw,58px);line-height:.9;letter-spacing:-.02em}
.hhead .counter{font-family:var(--display);font-size:clamp(18px,2vw,26px);color:var(--stone);font-weight:340}
.hhead .counter b{color:var(--ink);font-weight:360}
.htrack{display:flex;align-items:center;gap:clamp(48px,8vw,140px);padding:0 clamp(20px,5vw,72px);will-change:transform}
.panel{flex:0 0 auto;display:flex;flex-direction:column}
/* intro & outro text panels */
.panel.lead{max-width:min(80vw,420px);gap:22px}
.panel.lead .eyebrow{margin-bottom:4px}
.panel.lead p{font-size:15.5px;line-height:1.65;color:var(--ink-soft)}
.panel.outro{align-items:flex-start;justify-content:center;gap:20px;max-width:min(70vw,360px)}
.panel.outro h3{font-family:var(--display);font-weight:330;font-size:clamp(30px,4vw,56px);line-height:.96;letter-spacing:-.02em}
.panel.outro a.allbtn{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;border:1px solid var(--ink);border-radius:60px;padding:16px 28px;transition:background .3s,color .3s}
.panel.outro a.allbtn:hover{background:var(--ink);color:var(--paper)}
/* project frames — scaled by JS as they pass viewport centre */
.pframe{display:flex;flex-direction:column;gap:18px}
.pframe .frame{will-change:transform,opacity;transform-origin:center center;backface-visibility:hidden}
.pframe .frame.sz-l{height:min(54vh,560px);aspect-ratio:4/3}
.pframe .frame.sz-p{height:min(64vh,680px);aspect-ratio:3/4}
.pframe .cap{display:flex;justify-content:space-between;align-items:baseline;gap:24px;border-top:1px solid var(--line);padding-top:14px}
.pframe .cap .l{display:flex;flex-direction:column;gap:4px}
.pframe .cap .pn{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);font-weight:600}
.pframe .cap .pt{font-family:var(--display);font-weight:350;font-size:clamp(22px,2.4vw,34px);line-height:1;letter-spacing:-.01em}
.pframe .cap .ploc{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);font-weight:600;white-space:nowrap;align-self:flex-end}
/* progress rail */
.hprogress{position:absolute;left:clamp(20px,5vw,72px);right:clamp(20px,5vw,72px);bottom:clamp(34px,6vh,60px);
  height:1px;background:var(--line);z-index:5}
.hprogress span{display:block;height:100%;background:var(--ink);transform-origin:left center;transform:scaleX(0)}
.hhint{position:absolute;right:clamp(20px,5vw,72px);bottom:clamp(48px,8vh,80px);z-index:5;font-size:10.5px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--stone);font-weight:600;display:flex;align-items:center;gap:10px}
.hhint .ln{width:30px;height:1px;background:var(--stone);display:inline-block;position:relative;overflow:hidden}
.hhint .ln::after{content:"";position:absolute;inset:0;background:var(--ink);animation:slide 2.2s var(--ease) infinite}
@keyframes slide{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* ============================================================
   QUOTE band
   ============================================================ */
.quote{padding:clamp(80px,16vh,200px) clamp(20px,5vw,72px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.quote h2{font-family:var(--display);font-weight:320;font-size:clamp(36px,6vw,96px);line-height:.96;letter-spacing:-.025em}
.quote h2 em{font-style:italic;color:var(--accent)}
.quote .side{display:flex;flex-direction:column;gap:26px;max-width:42ch}
.quote .side p{font-size:15.5px;line-height:1.7;color:var(--ink-soft)}
.quote .side{max-width:none}.quote .side .img{aspect-ratio:16/9}

/* ============================================================
   RECOGNITION / NEWS
   ============================================================ */
.news{padding:clamp(70px,12vh,140px) clamp(20px,5vw,72px);border-top:1px solid var(--line)}
.news .head{margin-bottom:clamp(34px,5vh,60px)}
.news .head h2{font-family:var(--display);font-weight:330;font-size:clamp(32px,5vw,72px);line-height:.95;letter-spacing:-.02em;margin-top:14px}
.news .item{display:grid;grid-template-columns:160px 1fr;gap:clamp(16px,3vw,50px);padding:clamp(20px,3vh,34px) 0;border-top:1px solid var(--line);align-items:baseline}
.news .item:last-child{border-bottom:1px solid var(--line)}
.news .item .date{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);font-weight:600}
.news .item p{font-size:15px;line-height:1.6;color:var(--ink-soft);max-width:62ch}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:var(--ink);color:var(--paper);padding:clamp(80px,14vh,170px) clamp(20px,5vw,72px) clamp(50px,8vh,90px)}
.contact .top{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(30px,5vw,80px);align-items:start}
.contact .eyebrow{color:rgba(242,238,229,.6)}
.contact .eyebrow::before{background:rgba(242,238,229,.6)}
.contact h2{font-family:var(--display);font-weight:320;font-size:clamp(44px,8.5vw,140px);line-height:.9;letter-spacing:-.03em;margin-top:18px}
.contact h2 em{font-style:italic;color:var(--accent-soft)}
.contact .lead{font-size:16px;line-height:1.7;color:rgba(242,238,229,.78);max-width:44ch;padding-top:14px}
.contact .lead a.mail{display:inline-block;margin-top:26px;font-family:var(--display);font-size:clamp(20px,2.4vw,30px);border-bottom:1px solid rgba(242,238,229,.4);padding-bottom:3px;transition:border-color .3s}
.contact .lead a.mail:hover{border-color:var(--paper)}
/* form */
.form{margin-top:clamp(48px,8vh,90px);border-top:1px solid rgba(242,238,229,.18);padding-top:clamp(30px,5vh,54px)}
.form .fields{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,44px) clamp(24px,4vw,60px)}
.field{display:flex;flex-direction:column;gap:10px}
.field label{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,238,229,.55);font-weight:600}
.field input,.field textarea{background:none;border:none;border-bottom:1px solid rgba(242,238,229,.3);
  color:var(--paper);font-family:var(--sans);font-size:16px;padding:6px 0;outline:none;transition:border-color .3s}
.field input::placeholder,.field textarea::placeholder{color:rgba(242,238,229,.35)}
.field input:focus,.field textarea:focus{border-color:var(--paper)}
.field.full{grid-column:1/-1}
.field textarea{resize:vertical;min-height:48px}
.form .submit{margin-top:clamp(30px,5vh,50px);display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:14px;background:var(--paper);color:var(--ink);border:none;cursor:pointer;
  font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  padding:18px 30px;border-radius:60px;transition:transform .4s var(--ease),background .3s,color .3s}
.btn:hover{transform:translateY(-2px);background:var(--accent-soft);color:var(--ink)}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}
.form .note{font-size:11px;color:rgba(242,238,229,.4);max-width:46ch;line-height:1.6}

/* ============================================================
   FOOTER feature project
   ============================================================ */
.feature{position:relative;min-height:88svh;display:flex;align-items:flex-end;overflow:hidden}
.feature .img{position:absolute;inset:0;z-index:0}
.feature .img::after{display:none}
.feature .scrim{position:absolute;inset:0;z-index:4;background:linear-gradient(to top,rgba(10,9,5,.7),rgba(10,9,5,.05) 55%,transparent)}
.feature .content{position:relative;z-index:5;color:var(--paper);padding:clamp(28px,6vw,72px);width:100%;
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.feature .content .lt .yr{font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.75;font-weight:600}
.feature .content .lt h3{font-family:var(--display);font-weight:330;font-size:clamp(44px,9vw,150px);line-height:.86;letter-spacing:-.03em;margin:10px 0}
.feature .content .lt p{max-width:34ch;font-size:14.5px;opacity:.85;line-height:1.55}
.feature .content .explore{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  border:1px solid rgba(242,238,229,.5);border-radius:60px;padding:16px 28px;transition:background .3s,color .3s;white-space:nowrap}
.feature .content .explore:hover{background:var(--paper);color:var(--ink)}

footer.end{background:var(--ink);color:var(--paper);padding:clamp(40px,6vh,72px) clamp(20px,5vw,72px) clamp(28px,4vh,40px)}
footer.end .top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;
  padding-bottom:40px;border-bottom:1px solid rgba(242,238,229,.16)}
footer.end .brand{font-family:var(--display);font-size:clamp(40px,9vw,120px);line-height:.86;font-weight:330;letter-spacing:-.02em}
footer.end .brand sup{font-size:.32em;vertical-align:super;font-family:var(--sans);font-weight:600}
footer.end .links{display:flex;gap:60px;flex-wrap:wrap}
footer.end .links .grp{display:flex;flex-direction:column;gap:12px}
footer.end .links .cap{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(242,238,229,.5);font-weight:600;margin-bottom:6px}
footer.end .links a{font-size:14px;color:rgba(242,238,229,.82);transition:color .3s}
footer.end .links a:hover{color:var(--paper)}
footer.end .bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:26px;
  font-size:11.5px;letter-spacing:.04em;color:rgba(242,238,229,.5)}

/* ============================================================
   PROJECT PAGES (client-side routed views)
   ============================================================ */
#project-pages{display:none}
body.on-project #project-pages{display:block}
body.on-project main{display:none}
.project-page{display:none}
.project-page.active{display:block;animation:ppIn .7s var(--ease) both}
@keyframes ppIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.pp{padding:clamp(120px,17vh,190px) clamp(20px,5vw,72px) 0}
.pp-back{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--stone);transition:gap .4s var(--ease),color .3s}
.pp-back:hover{gap:16px;color:var(--ink)}
.pp-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-top:30px}
.pp-cat{font-size:14px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600}
.pp-idx{font-family:var(--display);font-size:clamp(20px,2vw,28px);color:var(--stone);font-style:italic}
.pp-title{font-family:var(--display);font-weight:330;font-size:clamp(46px,10vw,150px);line-height:.86;letter-spacing:-.03em;margin-top:18px}
.pp-intro{font-family:var(--display);font-weight:330;font-size:clamp(22px,3.2vw,40px);line-height:1.12;letter-spacing:-.015em;
  max-width:24ch;margin-top:clamp(26px,4vh,46px)}
.pp-intro em{font-style:italic;color:var(--accent)}
.pp-lead{margin:clamp(34px,6vh,70px) clamp(20px,5vw,72px) 0}
.pp-lead .img{aspect-ratio:16/9;width:100%}
.pp-body{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:start;
  padding:clamp(50px,8vh,100px) clamp(20px,5vw,72px) 0}
.pp-meta{display:grid;grid-template-columns:1fr 1fr;gap:24px 30px;align-self:start;
  border-top:1px solid var(--ink);padding-top:26px}
.pp-meta .m b{display:block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);font-weight:600;margin-bottom:7px}
.pp-meta .m span{font-family:var(--display);font-size:clamp(17px,1.5vw,22px);font-weight:340;line-height:1.2}
.pp-text{display:flex;flex-direction:column;gap:20px}
.pp-text p{font-size:16px;line-height:1.72;color:var(--ink-soft);max-width:52ch}
.pp-gallery{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,1.4vw,22px);
  padding:clamp(40px,7vh,90px) clamp(20px,5vw,72px) 0}
.pp-gallery .img{aspect-ratio:4/5}
.pp-gallery .img.wide{grid-column:1/-1;aspect-ratio:16/8}
.pp-quote{padding:clamp(60px,11vh,150px) clamp(20px,5vw,72px)}
.pp-quote p{font-family:var(--display);font-weight:320;font-size:clamp(22px,3.2vw,40px);line-height:1.04;letter-spacing:-.015em;max-width:24ch}
.pp-quote p em{font-style:italic;color:var(--accent)}
.pp-next{display:block;background:var(--noir);color:var(--paper);padding:clamp(46px,8vh,96px) clamp(20px,5vw,72px);
  transition:background .4s}
.pp-next:hover{background:var(--noir-2)}
.pp-next .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.7;font-weight:600}
.pp-next .nm{font-family:var(--display);font-weight:330;font-size:clamp(38px,7vw,104px);line-height:.9;letter-spacing:-.02em;
  margin-top:14px;display:flex;align-items:center;gap:.3em}
.pp-next .nm .ar{font-family:var(--sans);font-weight:400;font-size:.5em}

@media(max-width:980px){
  #menu{grid-template-columns:1fr}
  #menu .secondary{border-left:none;padding-top:24px;padding-bottom:40px}
  #menu .menu-blurb{font-size:clamp(18px,5vw,24px)}
  .pp-body,.pp-gallery{grid-template-columns:1fr}
  .pp-meta{grid-template-columns:1fr 1fr;margin-bottom:10px}
  .about .grid,.quote,.contact .top,.contact .form .fields{grid-template-columns:1fr}
  .values .row{grid-template-columns:1fr}
  .value{padding-top:18px}
  .value .img{aspect-ratio:16/10;max-height:60vh}
  .figrow.two{grid-template-columns:1fr}
  .cluster{grid-template-columns:1fr 1fr;grid-auto-rows:34vw}
  .cluster .img:nth-child(1){grid-column:1/3;grid-row:span 1}
  .cluster .img:nth-child(2),.cluster .img:nth-child(3){grid-column:auto;grid-row:span 1}
  .quote .side{order:2}
  /* horizontal projects -> native swipe gallery on touch/small screens */
  .hscroll{height:auto!important}
  .hsticky{position:relative;height:auto;overflow:visible;justify-content:flex-start;padding:clamp(96px,13vh,130px) 0 clamp(40px,8vh,80px)}
  .hhead{position:static;padding:0 clamp(20px,5vw,40px) 22px}
  .htrack{transform:none!important;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;gap:clamp(20px,5vw,36px);padding:0 clamp(20px,5vw,40px);
    scrollbar-width:none;align-items:stretch}
  .htrack::-webkit-scrollbar{display:none}
  .panel{scroll-snap-align:center}
  .pframe .frame{transform:none!important;opacity:1!important}
  .pframe .frame.sz-l,.pframe .frame.sz-p{height:auto;width:74vw;max-width:520px}
  .pframe .frame.sz-l{aspect-ratio:4/5}
  .pframe .frame.sz-p{aspect-ratio:3/4}
  .panel.lead,.panel.outro{max-width:74vw;justify-content:center}
  .hprogress,.hhint{display:none}
}
@media(max-width:760px){
  header{padding:16px 20px}
  .hero{padding-top:96px}
  .news .item{grid-template-columns:1fr}
  footer.end .links{gap:34px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
}

/* ---- project-page rich sections (added for Korean Art Museum) ---- */
.pp-section{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;
  padding:clamp(40px,7vh,90px) clamp(20px,5vw,72px) 0}
.pp-section .pp-sec-media .img{aspect-ratio:4/5;width:100%}
.pp-section.wide-media .pp-sec-media .img{aspect-ratio:3/2}
.pp-section.rev .pp-sec-media{order:2}
.pp-subh{font-family:var(--display);font-weight:340;font-size:clamp(24px,3vw,42px);letter-spacing:-.015em;line-height:1;margin-bottom:6px}
.pp-list{list-style:none;display:flex;flex-direction:column;gap:13px;margin:4px 0}
.pp-list li{position:relative;padding-left:22px;font-size:15px;line-height:1.62;color:var(--ink-soft);max-width:54ch}
.pp-list li::before{content:"";position:absolute;left:0;top:.72em;width:10px;height:1px;background:var(--accent)}
.pp-list li b{color:var(--ink);font-weight:600}
#menu .cat-in .pj-soon{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:7px 0 7px 2px;opacity:.38}
#menu .cat-in .pj-soon .pj{font-family:var(--display);font-size:clamp(16px,1.8vw,22px);font-weight:340;letter-spacing:-.01em}
#menu .cat-in .pj-soon .pl{font-family:var(--sans);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase}
@media(max-width:980px){ .pp-section{grid-template-columns:1fr} .pp-section.rev .pp-sec-media{order:0} }


/* tata: hero video + portrait media */
.pp-video{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--ink)}
.pp-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.pp-section.portrait-media .pp-sec-media .img{aspect-ratio:5/6}
@media(max-width:980px){ .pp-video{aspect-ratio:4/3} }


/* ============================================================
   RESPONSIVE — unified phone + tablet layout
   One consistent stacked, swipe-based experience across all
   phones and tablets (portrait AND landscape). Desktops keep the
   pinned editorial layout. Touch tablets are matched via
   pointer:coarse so landscape iPads (≈1024–1366px) collapse too,
   mirroring the JS gate (min-width:981 + hover/fine = desktop).
   ============================================================ */
@media (max-width:1024px), (pointer:coarse) and (max-width:1366px){
  /* menu overlay -> single column */
  #menu{grid-template-columns:1fr}
  #menu .secondary{border-left:none;padding-top:24px;padding-bottom:40px}
  #menu .menu-blurb{font-size:clamp(18px,5vw,24px)}

  /* collapse every multi-column content grid */
  .about .grid,
  .quote,
  .contact .top,
  .contact .form .fields,
  .pp-body,
  .pp-gallery,
  .pp-section,
  .values .row,
  .figrow.two{grid-template-columns:1fr}
  .pp-section.rev .pp-sec-media{order:0}
  .quote .side{order:2}
  .pp-meta{grid-template-columns:1fr 1fr;margin-bottom:10px}
  .value{padding-top:18px}
  .value .img{aspect-ratio:16/10;max-height:60vh}
  .cluster{grid-template-columns:1fr 1fr;grid-auto-rows:34vw}
  .cluster .img:nth-child(1){grid-column:1/3;grid-row:span 1}
  .cluster .img:nth-child(2),.cluster .img:nth-child(3){grid-column:auto;grid-row:span 1}
  .news .item{grid-template-columns:130px 1fr}

  /* projects: pinned horizontal scroll -> native swipe gallery */
  .hscroll{height:auto!important}
  .hsticky{position:relative;height:auto;overflow:visible;justify-content:flex-start;
    padding:clamp(96px,13vh,130px) 0 clamp(40px,8vh,80px)}
  .hhead{position:static;padding:0 clamp(20px,5vw,40px) 22px}
  .htrack{transform:none!important;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;gap:clamp(20px,5vw,40px);padding:0 clamp(20px,5vw,40px);
    scrollbar-width:none;align-items:stretch}
  .htrack::-webkit-scrollbar{display:none}
  .panel{scroll-snap-align:center}
  .pframe .frame{transform:none!important;opacity:1!important}
  .pframe .frame.sz-l,.pframe .frame.sz-p{height:auto;width:74vw;max-width:560px}
  .pframe .frame.sz-l{aspect-ratio:4/5}
  .pframe .frame.sz-p{aspect-ratio:3/4}
  .panel.lead,.panel.outro{max-width:74vw;justify-content:center}
  .hprogress,.hhint{display:none}

  .pp-video{aspect-ratio:4/3}
}

/* ---- phones ---- */
@media (max-width:600px){
  header{padding:14px 18px}
  .hero{padding-top:90px}
  .news .item{grid-template-columns:1fr;gap:6px}
  footer.end .links{gap:30px}
  footer.end .top{gap:26px}
  .pframe .frame.sz-l,.pframe .frame.sz-p{width:84vw}
  .panel.lead,.panel.outro{max-width:84vw}
  .pp-gallery .img.wide{aspect-ratio:16/10}
  .pp-meta{gap:18px 20px}
}

/* ---- very small phones: meta to single column ---- */
@media (max-width:360px){
  .pp-meta{grid-template-columns:1fr}
}


/* ---- competition boards (full-width, uncropped) ---- */
.pp-boards{margin:clamp(30px,6vh,80px) clamp(20px,5vw,72px) 0;display:flex;flex-direction:column;gap:clamp(18px,2.8vw,44px)}
.pp-boards.pp-lead-boards{margin-top:clamp(34px,6vh,70px)}
.pp-board-item{display:flex;flex-direction:column}
.pp-boards .pp-board{background:var(--paper-2);border:1px solid var(--line-soft)}
.pp-boards .pp-board img{object-fit:contain}
.pp-board-cap{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-top:12px}
@media(max-width:980px){ .pp-boards{margin-left:clamp(14px,4vw,72px);margin-right:clamp(14px,4vw,72px)} }

/* ---- narrative prose blocks between full-width boards ---- */
.pp-prose{margin:clamp(34px,6vh,72px) clamp(20px,5vw,72px) 0;max-width:920px}
.pp-prose .pp-subh{margin-bottom:16px}
.pp-prose .pp-text{gap:16px}
#page-adaptive-stadium .pp{padding-top:clamp(140px,18vh,210px)}
#page-adaptive-stadium .pp-title{font-size:clamp(44px,8vw,112px);line-height:.9}

/* ============================================================
   WORDPRESS-SPECIFIC ADDITIONS (only new rules; nothing above is overridden)
   ============================================================ */
/* Keep fixed overlays clear of the WP admin bar when logged in */
.admin-bar header,
.admin-bar #loader,
.admin-bar #menu{ top:32px; }
@media screen and (max-width:782px){
  .admin-bar header,
  .admin-bar #loader,
  .admin-bar #menu{ top:46px; }
}

/* Real contact form: validation + status states */
.contact .field.error input,
.contact .field.error textarea{ border-color:#b4452f; }
.contact .form-status{ font-size:13px; letter-spacing:.02em; margin-top:12px; min-height:1.2em; }
.contact .form-status.ok{ color:var(--accent); }
.contact .form-status.err{ color:#b4452f; }
.contact .btn[disabled]{ opacity:.55; pointer-events:none; }
/* honeypot — visually hidden, bots fill it, humans don't */
.contact .hp-field{ position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden; }

/* No-JS safety: never hide content behind the loader if JS is off */
.no-js #loader{ display:none; }
.no-js .img img{ opacity:1; }
.no-js .project-page{ display:block; }
