/* ============================================================
   POKORNY DESIGN — premium studio portfolio
   Design system + layout + components
   ============================================================ */

/* ---------- Delight typeface ---------- */
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-thin.otf") format("opentype");       font-weight:100; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-extralight.otf") format("opentype"); font-weight:200; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-light.otf") format("opentype");      font-weight:300; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-regular.otf") format("opentype");    font-weight:400; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-medium.otf") format("opentype");     font-weight:500; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-semibold.otf") format("opentype");   font-weight:600; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-bold.otf") format("opentype");       font-weight:700; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-extrabold.otf") format("opentype");  font-weight:800; font-style:normal; font-display:swap; }
@font-face{ font-family:"Delight"; src:url("assets/fonts/delight-black.otf") format("opentype");      font-weight:900; font-style:normal; font-display:swap; }

/* ---------- Tokens ---------- */
:root{
  --paper:        #FFFFFF;
  --paper-2:      #FFFFFF;
  --card:         #ECECEC;
  --ink:          #16150F;
  --ink-soft:     #46443B;
  --muted:        #8C887C;
  --line:         rgba(22,21,15,.14);
  --line-soft:    rgba(22,21,15,.08);

  --accent:       #2F9680;   /* brand green */
  --accent-deep:  #226F5E;
  --accent-ink:   #0E2A23;
  --warm:         #C8782A;   /* sparse secondary */
  --on-accent:    #F1F4EE;

  --ff-sans: "Delight", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --ff-mono: "Delight", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --pad: clamp(20px, 5vw, 80px);     /* page side padding */
  --maxw: 2040px;

  --e-out: cubic-bezier(.16,1,.3,1);
  --e-io:  cubic-bezier(.65,.05,.36,1);

  --r-lg: 22px;
  --r-md: 16px;

  /* themeable surface tokens (light defaults) */
  --nav-bg:          rgba(255,255,255,.55);
  --nav-bg-scrolled: rgba(255,255,255,.82);
  --surface-ink:     #16150F;   /* dark cards (featured) */
  --surface-fg:      #F1F4EE;   /* text on dark cards */
  --contact-bg:      #31383F;
  --contact-fg:      #F1F4EE;
  --chip-bg:         rgba(255,255,255,.9);
  --shadow:          rgba(0,0,0,.4);
  color-scheme: light;
}

/* ============================================================
   DARK MODE — premium, no pure black, WCAG AA
   !important wins over legacy inline custom-props
   ============================================================ */
html[data-theme="dark"]{
  --paper:        #15191B !important;   /* deep cool charcoal, not black */
  --paper-2:      #15191B !important;
  --card:         #242B2D !important;
  --ink:          #ECEEED !important;   /* off-white, eye-friendly */
  --ink-soft:     #A7ADAD !important;   /* AA ~7:1 */
  --muted:        #7B8284 !important;   /* AA ~4.6:1 */
  --line:         rgba(255,255,255,.14) !important;
  --line-soft:    rgba(255,255,255,.07) !important;

  --accent:       #5EF4C7 !important;   /* bright mint for dark */
  --accent-deep:  #46E6BD !important;
  --on-accent:    #06231C !important;   /* dark text on bright accent */

  --nav-bg:          rgba(19,23,25,.55) !important;
  --nav-bg-scrolled: rgba(17,20,22,.85) !important;
  --surface-ink:     #1E2528 !important;  /* elevated dark card */
  --surface-fg:      #ECEEED !important;
  --contact-bg:      #262B30 !important;  /* slate footer (dark) */
  --contact-fg:      #ECF3EF !important;
  --chip-bg:         rgba(26,31,33,.82) !important;
  --shadow:          rgba(0,0,0,.6) !important;
  color-scheme: dark;
}

/* smooth, brief cross-theme transition (added by JS only when toggling) */
html.theme-anim,
html.theme-anim *,
html.theme-anim *::before,
html.theme-anim *::after{
  transition: background-color .5s var(--e-out), color .5s var(--e-out),
              border-color .5s var(--e-out), fill .5s var(--e-out),
              stroke .5s var(--e-out), box-shadow .5s var(--e-out) !important;
}

/* dark-mode refinements */
html[data-theme="dark"] .hero__aura{ opacity:.62; }
html[data-theme="dark"] .hero__aura .blob{ mix-blend-mode:screen; }
html[data-theme="dark"] .featured__media{ background:#0a1411; }
/* contrast: arrow inside the bright-mint hover circle must be dark, not white */
html[data-theme="dark"] .featured__cta:hover .circ{ color:#15191B; }
html[data-theme="dark"] .about,
html[data-theme="dark"] .faq{ background-color:var(--paper) !important; }
/* dark-mode signature bubble: white surface, ink text */
html[data-theme="dark"] .about__sig{ background:#FFFFFF !important; color:var(--paper) !important; }
/* dark-mode footer mail button: hover → white fill, dark text */
html[data-theme="dark"] .contact__mail:hover{ background:#FFFFFF !important; color:#15191B !important; border-color:#FFFFFF !important; }

/* ---------- Reset ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scrollbar-gutter:stable; }
body{
  font-family:var(--ff-sans);
  background:var(--paper);
  color:var(--ink);
  font-size:18px;
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ 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(--accent); color:var(--on-accent); }

/* When Lenis is active */
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ position:relative; padding-block:clamp(80px,12vh,160px); }

.eyebrow{
  font-family:var(--ff-mono);
  font-size:12.5px;
  font-weight:400;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow .idx{ color:var(--accent); }

.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:32px; flex-wrap:wrap;
  padding-bottom:clamp(32px,5vw,64px);
  border-bottom:1px solid var(--line);
}
.section-head h2{
  font-size:clamp(2.1rem,5.2vw,3.9rem);
  font-weight:400;
  letter-spacing:-.03em;
  line-height:1.02;
}
.section-head .note{
  max-width:38ch; color:var(--ink-soft); font-size:1rem; line-height:1.55; font-weight:300;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  padding:15px 26px; border-radius:100px;
  font-size:1rem; font-weight:400; letter-spacing:.01em;
  white-space:nowrap;
  position:relative; overflow:hidden;
  transition:transform .5s var(--e-out), color .45s var(--e-out), background-color .45s var(--e-out);
  will-change:transform;
}
.btn .ico{ width:16px; height:16px; flex:0 0 auto; transition:transform .5s var(--e-out); }
.btn--accent{ background:var(--accent); color:var(--on-accent); }
.btn--accent:hover{ background:var(--accent-deep); }
.btn--solid{ background:var(--ink); color:var(--paper); }
.btn--light{ background:var(--ink); color:var(--paper); }
.btn--light:hover{ background:#000; }
.btn--ghost{ border:1px solid var(--line); color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn:hover .ico{ transform:translate(3px,-3px); }
.btn--onlight{ background:var(--paper); color:var(--ink); }
.btn--onlight:hover{ background:#fff; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  background-color:var(--nav-bg);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  transition:transform .6s var(--e-out), background-color .5s ease, box-shadow .5s ease, padding .5s ease, backdrop-filter .5s ease;
}
.nav.scrolled{
  background-color:var(--nav-bg-scrolled);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  box-shadow:0 14px 40px -26px var(--shadow);
  padding-block:13px;
}
.nav.hidden{ transform:translateY(-110%); }
.nav__brand{ display:flex; align-items:center; gap:0; }
.brand-logo{ display:block; width:auto; }
.nav__brand .brand-logo{ height:22px; }
.brand-logo--light{ display:none; }
html[data-theme="dark"] .nav__brand .brand-logo--dark{ display:none; }
html[data-theme="dark"] .nav__brand .brand-logo--light{ display:block; }
.nav__links{ display:flex; align-items:center; gap:38px; }
.nav__links a{
  font-size:.97rem; position:relative; color:var(--ink-soft);
  transition:color .35s ease;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-5px; height:1.5px; width:100%;
  background:var(--accent); transform:scaleX(0); transform-origin:right;
  transition:transform .45s var(--e-out);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after,
.nav__links a.active::after{ transform:scaleX(1); transform-origin:left; }
.nav__links a.active{ color:var(--ink); }
.nav__cta{ display:flex; align-items:center; gap:16px; }
.nav__cta .btn{ padding:11px 20px; font-size:.95rem; min-width:158px; justify-content:center; }

/* theme toggle (sun / moon) */
.theme-toggle{
  flex:0 0 auto; width:44px; height:44px; border-radius:50%;
  border:1px solid var(--line); display:grid; place-items:center;
  position:relative; overflow:hidden; color:var(--ink);
  transition:background-color .4s var(--e-out), color .4s var(--e-out), border-color .4s var(--e-out), transform .35s var(--e-out);
}
.theme-toggle:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.theme-toggle:active{ transform:scale(.9); }
.theme-toggle .ti{ position:absolute; width:23px; height:23px; transition:opacity .45s var(--e-out), transform .6s var(--e-out); }
.ti{ stroke-width:1.4; }
.theme-toggle .ti--moon{ opacity:1; transform:rotate(0) scale(1); }
.theme-toggle .ti--sun{ opacity:0; transform:rotate(-90deg) scale(.3); }
html[data-theme="dark"] .theme-toggle .ti--moon{ opacity:0; transform:rotate(90deg) scale(.3); }
html[data-theme="dark"] .theme-toggle .ti--sun{ opacity:1; transform:rotate(0) scale(1); }
.nav__burger{
  display:none; position:relative; place-items:center;
  width:46px; height:46px; border:1px solid var(--line); border-radius:50%;
  background:transparent; transition:background-color .4s var(--e-out), border-color .4s var(--e-out);
}
/* ---- Burger SVG icons — reliable cross-browser, explicit ink color ---- */
.nav__burger .burger-ham,
.nav__burger .burger-x{
  position:absolute; color:var(--ink);
  transition:opacity .32s var(--e-out), transform .38s var(--e-out);
}
.nav__burger .burger-ham{ opacity:1; transform:scale(1) rotate(0deg); width:20px; height:14px; }
.nav__burger .burger-x{ opacity:0; transform:scale(.65) rotate(-30deg); width:14px; height:14px; }
.menu-open .nav__burger .burger-ham{ opacity:0; transform:scale(.65) rotate(30deg); }
.menu-open .nav__burger .burger-x{ opacity:1; transform:scale(1) rotate(0deg); }
/* bright mode: dark X via var(--ink)=#16150F; dark mode: white X via var(--ink)=#ECEEED */
.menu-open .nav__burger{ border-color:var(--ink); }
.nav__burger:focus{ outline:none; }
.nav__burger:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }

/* nav right cluster + language switcher */
.nav__end{ display:flex; align-items:center; gap:clamp(20px,3vw,34px); }
.lang{ display:inline-flex; align-items:center; gap:9px; flex:0 0 auto; }
.lang__btn{
  font-family:var(--ff-mono); font-size:12.5px; letter-spacing:.08em; line-height:1;
  color:var(--muted); position:relative; padding:2px 1px 5px; cursor:pointer;
  transition:color .35s ease;
}
.lang__btn::after{
  content:""; position:absolute; left:1px; right:1px; bottom:0; height:1.5px;
  background:var(--ink); transform:scaleX(0); transform-origin:center;
  transition:transform .45s var(--e-out);
}
.lang__btn:hover{ color:var(--ink-soft); }
.lang__btn.active{ color:var(--ink); }
.lang__btn.active::after{ transform:scaleX(1); }
.lang__sep{ font-family:var(--ff-mono); font-size:12px; color:var(--muted); opacity:.4; user-select:none; }

/* language swap fade */
main, footer.contact, #pd{ transition:opacity .26s var(--e-out); }
.lang-anim main, .lang-anim footer.contact, .lang-anim #pd{ opacity:.12; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100svh; position:relative; overflow:hidden;
  padding-bottom:0;
  display:flex; flex-direction:column;
}
/* content column stays at content width; aura breaks out to full screen width */
.hero__inner{
  flex:1; display:flex; flex-direction:column;
  width:100%; max-width:var(--maxw); margin-inline:auto;
  padding-inline:var(--pad); padding-top:clamp(96px,12vh,140px);
}
/* ---- Organic drifting background gradient (ambient, not centered on text) ---- */
.hero__aura{
  position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.hero__aura .blob{
  position:absolute; border-radius:50%;
  filter:blur(80px); opacity:.55; will-change:transform;
}
.hero__aura .b1{
  width:52vw; height:52vw; max-width:780px; max-height:780px;
  left:-10%; top:-6%;
  background:radial-gradient(circle at 50% 50%, color-mix(in oklab, var(--accent) 44%, #ffffff), transparent 66%);
  animation:auraDrift1 18.4s ease-in-out infinite;
}
.hero__aura .b2{
  width:44vw; height:44vw; max-width:640px; max-height:640px;
  right:-8%; top:14%;
  background:radial-gradient(circle at 50% 50%, color-mix(in oklab, var(--accent) 30%, #ffffff), transparent 68%);
  animation:auraDrift2 23.2s ease-in-out infinite;
}
.hero__aura .b3{
  width:38vw; height:38vw; max-width:560px; max-height:560px;
  left:34%; bottom:-20%;
  background:radial-gradient(circle at 50% 50%, color-mix(in oklab, var(--accent-deep) 26%, #ffffff), transparent 70%);
  animation:auraDrift3 15.2s ease-in-out infinite;
}
/* subtle grain — kills any banding without muddiness */
.hero__aura::after{
  content:""; position:absolute; inset:0; opacity:.18; mix-blend-mode:soft-light;
  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='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}
@keyframes auraDrift1{
  0%,100%{ transform:translate(0,0) scale(1); }
  33%{    transform:translate(15vw,9vh) scale(1.14); }
  66%{    transform:translate(7vw,-6vh) scale(.95); }
}
@keyframes auraDrift2{
  0%,100%{ transform:translate(0,0) scale(1); }
  50%{    transform:translate(-17vw,11vh) scale(1.16); }
}
@keyframes auraDrift3{
  0%,100%{ transform:translate(0,0) scale(1); }
  40%{    transform:translate(-11vw,-13vh) scale(1.12); }
  72%{    transform:translate(9vw,-5vh) scale(.94); }
}
@media (max-width:760px){
  .hero__aura .blob{ filter:blur(54px); opacity:.5; }
}
.hero__top, .hero__main, .hero__bottom{ position:relative; z-index:2; }
.hero__top{ display:flex; justify-content:space-between; gap:24px; align-items:flex-start; }
.hero__avail{
  display:inline-flex; align-items:center; gap:18px;
  font-family:var(--ff-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft);
}
.dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); position:relative; }
.dot::after{ content:""; position:absolute; inset:-5px; border-radius:50%; border:1px solid var(--accent); opacity:.5; animation:ping 2.4s var(--e-out) infinite; }
@keyframes ping{ 0%{ transform:scale(.6); opacity:.7 } 80%,100%{ transform:scale(1.7); opacity:0 } }

.hero__main{ flex:1; display:grid; grid-template-columns:1fr auto; gap:clamp(28px,5vw,80px); align-items:center; align-content:center; padding-block:clamp(20px,4vh,44px); }
.hero__title{
  font-weight:300; letter-spacing:-.035em; line-height:.92;
  font-size:clamp(2.6rem, 8vw, 7rem);
  text-transform:uppercase;
}
.hero__title .l > span{ display:block; font-weight:300; }
.hero__title .l > span.bold{ font-weight:400; }
.hero__title .l{ display:block; overflow:hidden; padding-top:.2em; margin-top:-.2em; }
.hero__role{
  display:flex; align-items:center; gap:18px; margin-top:clamp(18px,2.6vw,30px);
  font-family:var(--ff-mono); font-size:clamp(.8rem,1.4vw,1rem); letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft);
}
.hero__role .bar{ height:1px; width:clamp(40px,8vw,120px); background:var(--line); }

.hero__aside{ width:clamp(190px,24vw,320px); flex:0 0 auto; }
.hero__portrait{
  width:100%; aspect-ratio:728/940; border-radius:var(--r-md); overflow:hidden;
  background:var(--paper-2); position:relative;
  box-shadow:0 40px 80px -50px rgba(22,21,15,.5);
}
.hero__portrait::after{
  content:""; position:absolute; inset:0; border-radius:var(--r-md);
  box-shadow:inset 0 0 0 1px rgba(22,21,15,.07); pointer-events:none;
}
.hero__portrait img{ width:100%; height:100%; object-fit:cover; will-change:transform; }
.hero__lead{
  margin-top:18px; font-size:1rem; line-height:1.55; color:var(--ink-soft); max-width:34ch; font-weight:300;
}

.hero__bottom{ border-top:1px solid var(--line); }
.marquee{
  display:flex; overflow:hidden; user-select:none; padding-block:clamp(26px,3vw,38px);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.marquee__row{ display:flex; flex-shrink:0; gap:0; animation:marq 32s linear infinite; }
.marquee:hover .marquee__row{ animation-play-state:paused; }
.marquee__row span{
  display:inline-flex; align-items:center; gap:26px; padding-right:26px;
  font-size:clamp(1.2rem,2.4vw,2rem); font-weight:400; letter-spacing:-.01em; white-space:nowrap;
}
.marquee__row span::before{ content:"\2726"; color:var(--accent); font-size:.62em; }
@keyframes marq{ to{ transform:translateX(-100%) } }

/* ============================================================
   WORK
   ============================================================ */
.work .section-head{ margin-bottom:clamp(40px,5vw,72px); }

.featured{
  position:relative; border-radius:var(--r-lg);
  background:transparent; color:var(--surface-fg);
  display:grid; grid-template-columns:1.15fr 1fr; min-height:min(72vh,640px);
  margin-bottom:clamp(20px,3vw,40px);
}
.featured__media{ position:relative; background:#0c1c17; border-radius:var(--r-lg) 0 0 var(--r-lg); clip-path:inset(0 round var(--r-lg) 0 0 var(--r-lg)); }
.featured__media img{ width:100%; height:100%; object-fit:cover; will-change:transform; transition:transform 1.1s var(--e-out); }
.featured:hover .featured__media img{ transform:scale(1.06); }
.featured__body{ padding:clamp(28px,3.4vw,56px); display:flex; flex-direction:column; justify-content:space-between; gap:32px; background:var(--surface-ink); border-radius:0 var(--r-lg) var(--r-lg) 0; }
.featured__tag{
  align-self:flex-start;
  font-family:var(--ff-mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); border:1px solid rgba(47,150,128,.45); padding:7px 13px; border-radius:100px;
}
.featured__title{ font-size:clamp(2rem,3.6vw,3.4rem); font-weight:400; letter-spacing:-.025em; line-height:1; }
.featured__meta{ display:flex; gap:40px; flex-wrap:wrap; margin-top:22px; }
.featured__meta div{ display:flex; flex-direction:column; gap:4px; }
.featured__meta dt{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:rgba(241,244,238,.5); }
.featured__meta dd{ font-size:1.05rem; }
.featured__cta{ display:inline-flex; align-items:center; gap:12px; font-weight:400; color:var(--surface-fg); }
.featured__cta .circ{
  width:48px; height:48px; border-radius:50%; border:1px solid rgba(241,244,238,.3);
  display:grid; place-items:center; transition:.5s var(--e-out);
}
.featured__cta:hover .circ{ background:var(--accent); border-color:var(--accent); transform:rotate(45deg); }
.featured__cta .circ svg{ width:17px; height:17px; }

/* project grid */
.grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,2.4vw,40px); }
.project{ position:relative; cursor:pointer; display:block; }
.project__media{
  position:relative; border-radius:var(--r-md); clip-path:inset(0 round var(--r-md));
  aspect-ratio:4/3; background:transparent;
}
.project__media image-slot,
.project__media .ph{ width:100%; height:100%; display:block; }
.project__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--e-out); }
.project:hover .project__media img{ transform:scale(1.05); }
.project__num{
  position:absolute; top:14px; left:14px; z-index:3;
  display:inline-flex; align-items:center; justify-content:center; line-height:1;
  font-family:var(--ff-mono); font-size:11.5px; letter-spacing:.1em;
  background:var(--chip-bg); backdrop-filter:blur(6px);
  padding:9px 12px 6px; border-radius:100px; color:var(--ink);
}
.project__arrow{
  position:absolute; top:14px; right:14px; z-index:3;
  width:46px; height:46px; border-radius:50%; background:#ffffff;
  display:grid; place-items:center;
  transform:scale(.5) rotate(-30deg); opacity:0;
  transition:.55s var(--e-out);
}
.project:hover .project__arrow{ transform:scale(1) rotate(0); opacity:1; }
.project__arrow svg{ width:18px; height:18px; }
.project__info{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding:18px 4px 0; }
.project__title{ font-size:1.45rem; font-weight:400; letter-spacing:-.02em; }
.project__cat{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; }

/* image-slot styling (shadow parts) */
.project__media image-slot{ width:100%; height:100%; color:var(--ink-soft); font-family:var(--ff-mono); font-size:13px; }
.project__media image-slot::part(frame){
  background:repeating-linear-gradient(135deg, var(--card) 0 20px, var(--paper-2) 20px 40px);
  border-radius:0;
}

/* motion toggle */
.no-motion .marquee__row{ animation:none !important; }
.no-motion .hero__aura .blob{ animation:none !important; }
.no-motion .dot::after{ display:none; }
.no-motion .featured__media img,
.no-motion #heroPortrait{ transform:none !important; }

/* striped placeholder for empty slots fallback */
.ph-stripe{
  width:100%; height:100%;
  background:
    repeating-linear-gradient(135deg, var(--card) 0 22px, var(--paper-2) 22px 44px);
  display:grid; place-items:center;
}
.ph-stripe span{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

/* premium project placeholders — unique per project until real assets are added */
.proj-ph{
  width:100%; height:100%; display:grid; place-items:center;
  position:relative; overflow:hidden; border-radius:inherit;
  background:#1C1912;
}
.proj-ph::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 60% at 75% 25%, rgba(255,255,255,.055) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 25% 75%, rgba(255,255,255,.025) 0%, transparent 50%);
  pointer-events:none;
}
.proj-ph::after{
  content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(135deg, transparent 0 32px, rgba(255,255,255,.012) 32px 64px);
  pointer-events:none;
}
.proj-ph__name{
  position:relative; z-index:1;
  font-size:clamp(3.2rem,7.5vw,5.6rem); font-weight:300; letter-spacing:-.04em; line-height:1;
  color:rgba(241,244,238,.08); transition:color .55s var(--e-out);
}
.project:hover .proj-ph__name{ color:rgba(241,244,238,.15); }

/* per-project tonal backgrounds */
.proj-ph[data-proj="nom"]{ background:#1C1912; }
.proj-ph[data-proj="nom"] .proj-ph__name{ color:rgba(241,244,238,.08); }
.proj-ph[data-proj="lifelab"]{ background:#0B1C14; }
.proj-ph[data-proj="lifelab"] .proj-ph__name{ color:rgba(94,244,199,.1); }
.proj-ph[data-proj="nom-menu"]{ background:#1D1208; }
.proj-ph[data-proj="nom-menu"] .proj-ph__name{ color:rgba(241,244,238,.08); }
.project:hover .proj-ph[data-proj="lifelab"] .proj-ph__name{ color:rgba(94,244,199,.2); }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ background:var(--paper); }
.about__grid{ display:grid; grid-template-columns:minmax(280px,0.72fr) minmax(0,1.28fr); gap:clamp(48px,7vw,130px); align-items:center; }
.about__portrait{ position:relative; }
.about__portrait .img{
  border-radius:var(--r-md); overflow:hidden; width:100%; aspect-ratio:728/900; background:var(--card);
}
.about__portrait img{ width:100%; height:100%; object-fit:cover; object-position:50% 22%; display:block; }
.about__sig{
  position:absolute; right:-14px; bottom:-14px;
  background:var(--accent); color:var(--on-accent); border-radius:14px;
  padding:14px 18px; font-family:var(--ff-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; line-height:1.5;
  box-shadow:0 20px 40px -20px rgba(0,0,0,.4);
}
.about__body h2{ font-size:clamp(1.9rem,3.6vw,3rem); font-weight:400; letter-spacing:-.03em; line-height:1.08; margin-bottom:30px; }
.about__body p{ font-size:clamp(1.05rem,1.5vw,1.26rem); line-height:1.62; color:var(--ink-soft); margin-bottom:22px; max-width:60ch; font-weight:300; }
.about__body p strong{ color:var(--ink); font-weight:400; }
.about__skills{ display:flex; flex-wrap:wrap; gap:10px; margin:34px 0 38px; }
.about__skills span{
  font-family:var(--ff-mono); font-size:12.5px; letter-spacing:.04em; text-transform:uppercase;
  border:1px solid var(--line); border-radius:100px; padding:9px 16px; color:var(--ink-soft);
}

/* ============================================================
   SERVICES + FAQ (accordion)
   ============================================================ */
.acc__item{ border-bottom:1px solid var(--line); }
.acc__head{
  width:100%; display:flex; align-items:center; gap:24px;
  padding:clamp(22px,2.6vw,34px) 0; text-align:left;
}
.acc__idx{ font-family:var(--ff-mono); font-size:13px; letter-spacing:.06em; color:var(--accent); flex:0 0 auto; width:42px; }
.acc__title{ flex:1; font-size:clamp(1.4rem,2.8vw,2.1rem); font-weight:400; letter-spacing:-.02em; transition:color .4s ease, transform .5s var(--e-out); }
.acc__sign{ flex:0 0 auto; width:26px; height:26px; position:relative; }
.acc__sign::before, .acc__sign::after{
  content:""; position:absolute; top:50%; left:50%; background:var(--ink);
  transform:translate(-50%,-50%); transition:transform .45s var(--e-out), background-color .4s ease;
}
.acc__sign::before{ width:16px; height:1.6px; }
.acc__sign::after{ width:1.6px; height:16px; }
.acc__item.open .acc__sign::after{ transform:translate(-50%,-50%) scaleY(0); }
.acc__item.open .acc__title{ color:var(--accent); transform:translateX(6px); }
.acc__item:hover .acc__title{ transform:translateX(6px); }
.acc__panel{ overflow:hidden; height:0; transition:height .5s var(--e-io); }
.acc__inner{ padding:0 0 clamp(26px,3vw,38px) 66px; display:grid; grid-template-columns:1.4fr 1fr; gap:40px; }
.acc__inner p{ color:var(--ink-soft); font-size:1.08rem; line-height:1.62; max-width:54ch; font-weight:300; }
.acc__tags{ display:flex; flex-wrap:wrap; gap:8px; align-content:flex-start; }
.acc__tags span{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--line); border-radius:100px; padding:7px 13px; }

.faq{ background:var(--paper); }
.faq .acc__inner{ grid-template-columns:1fr; padding-left:66px; }
.faq .acc__title{ font-size:clamp(1.15rem,2vw,1.5rem); }

/* ============================================================
   CONTACT / FOOTER
   ============================================================ */
.contact{ background:var(--contact-bg); color:var(--contact-fg); position:relative; overflow:hidden; }
.contact .wrap{ position:relative; z-index:2; }
.contact__top{ padding-block:clamp(72px,11vh,150px); display:grid; grid-template-columns:1.4fr .6fr; gap:60px; align-items:baseline; }
.contact__lead{ font-family:var(--ff-mono); font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; color:rgba(241,244,238,.7); }
.contact h2{ font-size:clamp(2.6rem,8vw,6.6rem); font-weight:300; letter-spacing:-.035em; line-height:.94; margin:22px 0 34px; }
.contact__mail{
  display:inline-flex; align-items:center; gap:14px; font-size:clamp(1.05rem,1.9vw,1.4rem); font-weight:400;
  padding:15px 28px; border-radius:100px; border:1px solid rgba(241,244,238,.45);
  transition:background-color .7s var(--e-out), color .7s var(--e-out), border-color .7s var(--e-out);
}
.contact__mail:hover{ background:#2F9680; color:#fff; border-color:#2F9680; }
.contact__mail .ico, .contact__mail svg{ transition:transform .7s var(--e-out); }
.contact__mail:hover svg{ transform:translate(3px,-3px); }
.contact__side{ display:flex; flex-direction:row; gap:clamp(36px,4vw,72px); justify-self:end; }
.contact__col h4{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:rgba(241,244,238,.6); margin-bottom:14px; }
.contact__col ul{ list-style:none; display:flex; flex-direction:column; gap:9px; }
.contact__col a{ font-size:1.05rem; opacity:.92; position:relative; width:fit-content; }
.contact__col a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .4s var(--e-out); }
.contact__col a:hover::after{ transform:scaleX(1); transform-origin:left; }

.contact__bottom{
  border-top:1px solid rgba(241,244,238,.22);
  padding-block:30px 38px;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.contact__bottom img{ height:30px; opacity:.95; }
/* footer mark sits on dark slate in BOTH themes → always light */
.contact__mark{ display:inline-flex; align-items:center; }
.contact__mark .brand-logo{ height:30px; opacity:.95; }
.contact__mark .brand-logo--dark{ display:none; }
.contact__mark .brand-logo--light{ display:block; }
.contact__bottom .cp{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.06em; color:rgba(241,244,238,.8); }
.contact__bottom .top-link{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; display:inline-flex; gap:8px; align-items:center; }
/* NAHORU → outlined pill on tablet/desktop in BOTH themes (layout parity; per-theme colors unchanged) */
@media (min-width:769px){
  .contact__bottom .top-link{
    border:1px solid rgba(241,244,238,.5); border-radius:100px; padding:13px 22px;
    transition:background-color .5s var(--e-out), color .5s var(--e-out), border-color .5s var(--e-out);
  }
  .contact__bottom .top-link:hover{ border-color:rgba(241,244,238,.9); }
}
.contact__giant{
  position:absolute; left:0; right:0; bottom:-4%; z-index:1;
  font-weight:700; text-align:center; line-height:.8;
  font-size:clamp(7rem,28vw,30rem); letter-spacing:-.04em;
  color:rgba(241,244,238,.07); pointer-events:none; user-select:none; text-transform:uppercase;
}

/* ============================================================
   DARK MODE FOOTER — mint surface, charcoal ink (design spec)
   Applied ONLY in dark mode; light mode footer is unchanged.
   ============================================================ */
html[data-theme="dark"] .contact{
  background:#5EF4C7;
  color:#15191B;
}
html[data-theme="dark"] .contact__lead{ color:rgba(21,25,27,.66); }
html[data-theme="dark"] .contact__col h4{ color:rgba(21,25,27,.62); }
html[data-theme="dark"] .contact__col a{ opacity:.92; }

/* email button → solid charcoal, light label */
html[data-theme="dark"] .contact__mail{
  background:#15191B; color:#ECF3EF; border-color:#15191B;
}
html[data-theme="dark"] .contact__mail:hover{
  background:#FFFFFF; color:#15191B; border-color:#FFFFFF;
}

/* logo mark → dark variant on the mint surface */
html[data-theme="dark"] .contact__mark .brand-logo--light{ display:none; }
html[data-theme="dark"] .contact__mark .brand-logo--dark{ display:block; }

/* dividers + meta → charcoal */
html[data-theme="dark"] .contact__bottom{ border-top-color:rgba(21,25,27,.2); }
html[data-theme="dark"] .contact__bottom .cp{ color:rgba(21,25,27,.78); }

/* NAHORU → outlined charcoal pill */
html[data-theme="dark"] .contact__bottom .top-link{
  border:1px solid rgba(21,25,27,.5); border-radius:100px; padding:13px 22px;
  transition:background-color .5s var(--e-out), color .5s var(--e-out), border-color .5s var(--e-out);
}
html[data-theme="dark"] .contact__bottom .top-link:hover{
  background:#15191B; color:#5EF4C7; border-color:#15191B;
}

/* ============================================================
   Reveal animations
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(34px); transition:opacity 1.05s var(--e-out), transform 1.05s var(--e-out); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal-line]{ display:block; transform:translateY(105%); transition:transform 1s var(--e-out); }
.in [data-reveal-line], [data-reveal-line].in{ transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  [data-reveal]{ opacity:1; transform:none; }
  [data-reveal-line]{ transform:none; }
}

/* ============================================================
   Custom cursor
   ============================================================ */
.cursor{
  position:fixed; top:0; left:0; z-index:9000; pointer-events:none;
  width:10px; height:10px; border-radius:50%; background:var(--accent);
  transform:translate(-50%,-50%); transition:width .35s var(--e-out), height .35s var(--e-out), background-color .35s, opacity .3s;
  mix-blend-mode:difference; opacity:0;
}
.cursor.lg{ width:74px; height:74px; background:var(--accent); mix-blend-mode:normal; }
.cursor__txt{
  position:fixed; top:0; left:0; z-index:9001; pointer-events:none;
  transform:translate(-50%,-50%) scale(.4); opacity:0;
  font-family:var(--ff-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:#fff;
  transition:opacity .3s, transform .4s var(--e-out);
}
.cursor__txt.show{ opacity:1; transform:translate(-50%,-50%) scale(1); }
/* custom cursor removed — native cursor on all breakpoints */
.cursor,.cursor__txt{ display:none !important; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .about__grid{ grid-template-columns:1fr; }
  .about__portrait{ max-width:380px; }
}
@media (max-width:1080px){
  .nav__links{ gap:26px; }
}
@media (max-width:900px){
  body{ font-size:17px; }
  .featured{ grid-template-columns:1fr; }
  .featured__media{ min-height:340px; border-radius:var(--r-lg) var(--r-lg) 0 0; clip-path:inset(0 round var(--r-lg) var(--r-lg) 0 0); }
  .featured__body{ border-radius:0 0 var(--r-lg) var(--r-lg); }
  .about__grid{ grid-template-columns:1fr; }
  .about__portrait{ max-width:420px; }
  .about__portrait .img{ aspect-ratio:728/900; }
  .acc__inner{ grid-template-columns:1fr; gap:18px; padding-left:0; }
  .contact__top{ grid-template-columns:1fr; align-items:flex-start; gap:40px; }
  .contact__side{ flex-direction:row; gap:clamp(28px,9vw,64px); justify-self:start; }
  .contact__col{ flex:0 0 auto; }
}
/* ── Navbar switches to hamburger at ≤1163.98px (1164px is the narrowest desktop navbar) ── */
@media (max-width:1163.98px){
  .nav__links a:not(.nav__back){ display:none; }
  .nav__cta{ display:none; }
  .nav__end > .lang{ display:none; }
  .nav__end > .theme-toggle{ display:none; }
  .nav--detail .nav__end > .theme-toggle{ display:grid; }
  .nav__end{ gap:0; }
  .nav--detail .nav__end{ gap:6px; }
  button.nav__burger{ display:grid; }
  a.nav__burger{ display:none; }
}
@media (max-width:768px){
  .grid{ grid-template-columns:1fr; }
  .section-head{ align-items:flex-start; }
  .project__title{ font-size:1.3rem; }

  /* tighter vertical rhythm on phones */
  .section{ padding-block:clamp(52px,9vh,78px); }

  /* ---- responsive hero ---- */
  .hero{ min-height:auto; }
  .hero__inner{ padding-top:clamp(98px,15vh,124px); }
  .hero__top{ flex-wrap:wrap; gap:10px 16px; }
  .hero__top .eyebrow{ display:none; }
  .hero__main{ grid-template-columns:1fr; align-items:start; gap:clamp(20px,5vw,30px); padding-block:clamp(18px,4vh,30px) clamp(22px,5vh,34px); }
  .hero__title{ font-size:clamp(2.9rem,15.5vw,4.8rem); }
  .hero__role{ margin-top:16px; }
  .hero__aside{ display:flex; align-items:flex-end; gap:18px; width:100%; }
  .hero__portrait{ width:min(48%,196px); flex:0 0 auto; aspect-ratio:3/4; }
  .hero__lead{ margin-top:0; max-width:none; flex:1; }
  .marquee{ padding-block:20px; }

  /* ---- footer: columns side-by-side, NAHORU above the divider ---- */
  .contact__top{ padding-block:clamp(52px,9vh,82px); }
  /* both themes: logo + NAHORU share one row, copyright below */
  .contact__bottom{ flex-direction:row; flex-wrap:wrap; align-items:center; gap:22px 0; border-top:none; padding-block:0 34px; }
  .contact__bottom .contact__mark{ order:0; }
  .contact__bottom .top-link{ order:0; width:auto; margin-left:auto; justify-content:center; padding:11px 20px; border:1px solid rgba(241,244,238,.5); border-radius:100px; }
  .contact__bottom .cp{ order:2; flex-basis:100%; width:100%; border-top:1px solid rgba(241,244,238,.22); padding-top:24px; margin-top:4px; }

  /* dark-mode footer (design spec): logo + NAHORU share a row, then divider, copyright last */
  html[data-theme="dark"] .contact__bottom{
    flex-direction:row; flex-wrap:wrap; align-items:center;
    gap:22px 0; border-top:none; padding-block:0 30px;
  }
  html[data-theme="dark"] .contact__bottom .contact__mark{ order:0; }
  html[data-theme="dark"] .contact__bottom .top-link{
    order:1; width:auto; margin-left:auto; justify-content:center;
    padding:11px 20px; border:1px solid rgba(21,25,27,.5); border-radius:100px;
  }
  html[data-theme="dark"] .contact__bottom .cp{
    order:2; flex-basis:100%; width:100%;
    border-top:1px solid rgba(21,25,27,.2); padding-top:24px; margin-top:4px;
  }
}
@media (max-width:420px){
  .hero__aside{ flex-direction:column; align-items:flex-start; gap:16px; }
  /* portrait left-aligned with content */
  .hero__portrait{ width:46.5%; align-self:flex-start; }
  .nav--detail .nav__back span{ display:none; }
}
html.menu-open, html.menu-open body{ overflow:hidden; }

/* show mobile-menu controls only inside the menu */
.mobile-menu__controls{ display:none; }

/* Mobile menu overlay */
/* Mobile menu overlay — 120Hz ProMotion spring */
.mobile-menu{
  position:fixed; inset:0; z-index:90; background:var(--paper);
  display:flex; flex-direction:column; justify-content:flex-start;
  padding:clamp(96px,17vh,150px) var(--pad) calc(var(--pad) + env(safe-area-inset-bottom));
  overflow-y:auto;
  opacity:0; visibility:hidden;
  transform:translateY(-12px) scale(.99);
  transform-origin:top center;
  will-change:transform,opacity;
  transition:
    opacity .38s cubic-bezier(0.22,1,0.36,1),
    transform .42s cubic-bezier(0.22,1,0.36,1),
    visibility .38s;
}
.mobile-menu.open{ opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.mobile-menu__nav{ display:flex; flex-direction:column; }
.mobile-menu a.mm-link{
  display:flex; align-items:baseline; justify-content:flex-end; gap:16px; text-align:right;
  font-size:clamp(2.1rem,10vw,3.2rem); font-weight:300; letter-spacing:-.03em;
  padding:13px 0; border-bottom:1px solid var(--line); color:var(--ink);
  opacity:0; transform:translateY(16px);
  transition:opacity .42s cubic-bezier(0.22,1,0.36,1), transform .42s cubic-bezier(0.22,1,0.36,1), color .25s ease;
  -webkit-tap-highlight-color:transparent;
}
/* design: clean right-aligned links, no index numbers */
.mobile-menu a.mm-link .mm-num{ display:none; }
.mobile-menu.open a.mm-link{ opacity:1; transform:translateY(0); }
.mobile-menu.open a.mm-link:nth-child(1){ transition-delay:.08s; }
.mobile-menu.open a.mm-link:nth-child(2){ transition-delay:.13s; }
.mobile-menu.open a.mm-link:nth-child(3){ transition-delay:.18s; }
.mobile-menu.open a.mm-link:nth-child(4){ transition-delay:.23s; }
.mobile-menu__foot{
  margin-top:0; flex:1; padding-top:34px; display:flex; flex-direction:column; gap:22px;
  opacity:0; transform:translateY(10px);
  transition:opacity .42s cubic-bezier(0.22,1,0.36,1) .26s, transform .42s cubic-bezier(0.22,1,0.36,1) .26s;
}
.mobile-menu.open .mobile-menu__foot{ opacity:1; transform:translateY(0); }
.mobile-menu__cta{
  display:inline-flex; align-self:flex-end; align-items:center; gap:12px;
  background:var(--accent); color:var(--on-accent); padding:16px 28px; border-radius:100px;
  font-size:1.05rem; transition:background-color .4s var(--e-out);
}
.mobile-menu__cta svg{ width:16px; height:16px; transition:transform .5s var(--e-out); }
.mobile-menu__cta:active svg{ transform:translate(3px,-3px); }
.mobile-menu__social{ display:flex; justify-content:space-between; gap:24px; font-family:var(--ff-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; }
.mobile-menu__social a{ color:var(--ink-soft); min-height:44px; display:inline-flex; align-items:center; }

/* mobile menu utility controls (lang + theme) */
@media (max-width:1163.98px){
  .mobile-menu__controls{
    display:flex; align-items:center; justify-content:space-between; gap:16px;
    padding-top:24px; margin-top:auto; border-top:1px solid var(--line);
  }
}
.mobile-menu__controls .lang{ display:inline-flex; align-items:center; gap:6px; }
.mobile-menu__controls .lang__btn{
  min-width:52px; min-height:44px; padding:0 14px; border-radius:100px;
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--ff-mono); font-size:13px; letter-spacing:.08em;
  color:var(--muted); border:1px solid var(--line); background:transparent;
  transition:color .3s ease, background-color .3s ease, border-color .3s ease;
}
.mobile-menu__controls .lang__btn.active{ color:var(--on-accent); background:var(--accent); border-color:var(--accent); }
/* mobile menu uses filled pill buttons — no underline (underline is desktop-only) */
.mobile-menu__controls .lang__btn::after{ display:none; }
.mobile-menu__controls .lang__sep{ display:none; }
.mobile-menu__controls .theme-toggle{
  width:48px; height:48px; flex:0 0 auto;
  display:grid; place-items:center; gap:0;
}
.mobile-menu__controls .theme-label{
  font-family:var(--ff-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);
}
.mobile-menu__theme{ display:inline-flex; align-items:center; gap:12px; }

/* ============================================================
   PROJECT DETAIL PAGE
   ============================================================ */
.nav__back{ display:inline-flex; align-items:center; gap:9px; font-size:.97rem; color:var(--ink-soft); transition:color .3s ease; }
.nav__back:hover{ color:var(--ink); }
.nav__back svg{ width:15px; height:15px; transition:transform .45s var(--e-out); }
.nav__back:hover svg{ transform:translateX(-4px); }
.nav--detail .nav__links{ flex:1; justify-content:center; gap:0; }

/* Prevent FOUC: ensure #pd always has viewport height before JS renders */
#pd:empty{ min-height:100vh; }

.pd-hero{ padding-top:clamp(130px,18vh,190px); padding-bottom:clamp(40px,6vw,70px); }
.pd-hero__cat{ display:flex; align-items:center; gap:14px; }
.pd-hero__cat .ln{ height:1px; width:48px; background:var(--line); }
.pd-title{ font-size:clamp(2.8rem,9vw,7rem); font-weight:300; letter-spacing:-.04em; line-height:.96; margin:24px 0 0; text-transform:uppercase; }
.pd-lead{ font-size:clamp(1.15rem,1.8vw,1.5rem); font-weight:300; line-height:1.5; color:var(--ink-soft); max-width:52ch; margin-top:30px; }
.pd-meta{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:clamp(40px,5vw,64px); padding-top:34px; border-top:1px solid var(--line); }
.pd-meta dt{ font-family:var(--ff-mono); font-size:11px; font-weight:400; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:9px; }
.pd-meta dd{ font-size:1.05rem; font-weight:400; }

.pd-figure{ width:100%; border-radius:var(--r-lg); overflow:hidden; background:var(--card); aspect-ratio:16/9; }
.pd-figure image-slot{ width:100%; height:100%; color:var(--ink-soft); font-family:var(--ff-mono); }
.pd-figure image-slot::part(frame){ background:repeating-linear-gradient(135deg, var(--card) 0 24px, var(--paper-2) 24px 48px); border-radius:0; }

.pd-block{ display:grid; grid-template-columns:0.42fr 1fr; gap:clamp(30px,6vw,90px); align-items:start; padding-block:clamp(56px,8vw,104px); }
.pd-block + .pd-block{ border-top:1px solid var(--line); }
.pd-block__label{ font-family:var(--ff-mono); font-size:12px; font-weight:400; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); padding-top:8px; }
.pd-block__body h3{ font-size:clamp(1.6rem,3vw,2.4rem); font-weight:400; letter-spacing:-.025em; line-height:1.1; margin-bottom:22px; }
.pd-block__body p{ font-size:clamp(1.05rem,1.4vw,1.22rem); font-weight:300; line-height:1.65; color:var(--ink-soft); margin-bottom:18px; max-width:62ch; }
.pd-block__body p strong{ color:var(--ink); font-weight:500; }
.pd-tags{ display:flex; flex-wrap:wrap; gap:9px; margin-top:30px; }
.pd-tags span{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.04em; text-transform:uppercase; border:1px solid var(--line); border-radius:100px; padding:8px 15px; color:var(--ink-soft); }

.pd-gallery{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2vw,28px); padding-bottom:clamp(40px,6vw,80px); }
.pd-gallery .pd-figure{ aspect-ratio:4/3; }
.pd-gallery .pd-figure.wide{ grid-column:1 / -1; aspect-ratio:16/8; }

/* Live site shows only real imagery — empty gallery slots are hidden from
   visitors and the whole gallery collapses if it has no filled images. In
   admin (CMS) mode everything reappears so the gallery stays fully editable. */
.pd-gallery .pd-figure:has(image-slot:not([data-filled])){ display:none; }
.pd-gallery:not(:has(image-slot[data-filled])){ display:none; }
body.pd-cms-on .pd-gallery:not(:has(image-slot[data-filled])){ display:grid; }
body.pd-cms-on .pd-gallery .pd-figure:has(image-slot:not([data-filled])){ display:block; }

.pd-next{ border-top:1px solid var(--line); }
.pd-next a{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding-block:clamp(48px,7vw,96px); }
.pd-next__lab{ font-family:var(--ff-mono); font-size:12px; font-weight:400; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:16px; }
.pd-next__title{ font-size:clamp(2.2rem,6vw,4.6rem); font-weight:400; letter-spacing:-.035em; line-height:1; text-transform:uppercase; transition:transform .55s var(--e-out), color .4s ease; }
.pd-next a:hover .pd-next__title{ transform:translateX(14px); color:var(--accent); }
.pd-next__arrow{ flex:0 0 auto; width:clamp(60px,7vw,88px); height:clamp(60px,7vw,88px); border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; transition:.55s var(--e-out); }
.pd-next a:hover .pd-next__arrow{ background:var(--accent); border-color:var(--accent); transform:rotate(45deg); }
.pd-next__arrow svg{ width:24px; height:24px; }
.pd-next a:hover .pd-next__arrow svg path{ stroke:var(--on-accent); }

@media (max-width:900px){
  .pd-meta{ grid-template-columns:1fr 1fr; gap:28px 24px; }
  .pd-block{ grid-template-columns:1fr; gap:18px; }
  .pd-block__label{ padding-top:0; }
  .pd-gallery{ grid-template-columns:1fr; }
  .pd-gallery .pd-figure.wide{ aspect-ratio:4/3; }
}
