/* =========================================================
   Katja Steinführer Photography — "der Moment"
   Dark, cinematic, editorial. Mobile-first.
   ========================================================= */

/* ---------- Fonts (local) ---------- */
@font-face{font-family:'Bricolage Grotesque';src:url('../fonts/BricolageGrotesque-Variable.woff2') format('woff2'),url('https://cdn.jsdelivr.net/npm/@fontsource-variable/bricolage-grotesque@5/files/bricolage-grotesque-latin-wght-normal.woff2') format('woff2');font-weight:400 800;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/HankenGrotesk-Variable.woff2') format('woff2'),url('https://cdn.jsdelivr.net/npm/@fontsource-variable/hanken-grotesk@5/files/hanken-grotesk-latin-wght-normal.woff2') format('woff2');font-weight:300 600;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/HankenGrotesk-VariableItalic.woff2') format('woff2'),url('https://cdn.jsdelivr.net/npm/@fontsource-variable/hanken-grotesk@5/files/hanken-grotesk-latin-wght-italic.woff2') format('woff2');font-weight:300 600;font-style:italic;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --ink:#0a0a0b;            /* near-black background */
  --ink-2:#121214;          /* raised surface */
  --ink-3:#1c1c20;          /* card / input */
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(255,255,255,.22);
  --bone:#f3efe9;           /* warm white text */
  --muted:#a4a09a;          /* secondary text */
  --muted-2:#6f6c68;        /* tertiary */
  --ember:#c9a24f;          /* warm accent (Herz & Bauch) */
  --ember-soft:#e3c87a;
  --gold:#c9a24f;
  --gold-soft:#e3c87a;
  --gold-deep:#9c7634;
  --gold-ink:#2a2008;       /* dark text/icon on gold fills */
  --font-display:'Bricolage Grotesque',system-ui,sans-serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --maxw:1500px;
  --ease:cubic-bezier(.6,.01,.15,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}

body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--ember);color:var(--gold-ink)}

/* ---------- Scroll-snap pager ---------- */
.pager{
  height:100dvh;
  overflow-y:scroll;
  scroll-snap-type:y mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;
}
.pager::-webkit-scrollbar{display:none}
.panel{
  position:relative;
  min-height:100dvh;
  scroll-snap-align:start;
  scroll-snap-stop:always;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
}

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-size:clamp(.66rem,.62rem + .3vw,.78rem);
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
}
.eyebrow .dot{color:var(--ember)}
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:.98;letter-spacing:-.02em}
.display{
  font-size:clamp(2.7rem,1.4rem + 9vw,8.5rem);
  font-weight:800;
  line-height:.9;
  letter-spacing:-.03em;
}
.lede{
  font-size:clamp(1.05rem,.96rem + .5vw,1.4rem);
  color:var(--muted);
  font-weight:300;
  max-width:46ch;
}
em.serif{font-family:var(--font-display);font-style:italic;font-weight:500;color:var(--bone)}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(1rem,2.2vw,1.6rem) clamp(1.1rem,3.5vw,2.6rem);
  background:linear-gradient(180deg,rgba(10,10,11,.65) 0%,rgba(10,10,11,.25) 60%,transparent 100%);
  pointer-events:none;
}
.nav > *{pointer-events:auto}
.brand{
  font-family:var(--font-display);
  font-weight:700;font-size:1.25rem;letter-spacing:-.01em;color:#fff;
  line-height:1;display:flex;flex-direction:column;gap:.18em;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.brand-logo{width:clamp(240px,27vw,330px);height:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.55)) brightness(1.15)}
.brand small{font-family:var(--font-body);font-weight:500;font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.nav-links{display:none;gap:2.1rem;align-items:center}
.nav-links a{font-size:.88rem;letter-spacing:.04em;color:#fff;position:relative;padding:.2rem 0;text-shadow:0 1px 3px rgba(0,0,0,.35);font-weight:500}
.nav-links a.active{color:var(--gold-soft)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--gold);transition:right .4s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}

.menu-toggle{display:flex;flex-direction:column;gap:5px;padding:.5rem;color:#fff}
.menu-toggle span{display:block;width:26px;height:2px;background:#fff;transition:transform .35s var(--ease),opacity .25s}
body.menu-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){opacity:0}
body.menu-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile overlay menu */
.mobile-menu{
  position:fixed;inset:0;z-index:55;
  background:rgba(8,8,9,.97);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;gap:.35rem;
  padding:0 clamp(1.4rem,8vw,4rem);
  opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s;
}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.7rem,7vw,2.5rem);letter-spacing:-.02em;
  color:var(--bone);padding:.14em 0;display:flex;align-items:baseline;gap:.6rem;
  opacity:0;transform:translateY(18px);transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.mobile-menu a .idx{font-family:var(--font-body);font-size:.8rem;letter-spacing:.2em;color:var(--ember);font-weight:500}
body.menu-open .mobile-menu a{opacity:1;transform:none}
body.menu-open .mobile-menu a:nth-child(1){transition-delay:.08s}
body.menu-open .mobile-menu a:nth-child(2){transition-delay:.14s}
body.menu-open .mobile-menu a:nth-child(3){transition-delay:.20s}
body.menu-open .mobile-menu a:nth-child(4){transition-delay:.26s}
body.menu-open .mobile-menu a:nth-child(5){transition-delay:.32s}
body.menu-open .mobile-menu a:nth-child(6){transition-delay:.38s}

/* ---------- Page progress dots ---------- */
.dots{
  position:fixed;z-index:50;right:clamp(.7rem,1.6vw,1.4rem);top:50%;transform:translateY(-50%);
  display:none;flex-direction:column;gap:.85rem;
}
.dots button{width:8px;height:8px;border-radius:50%;background:transparent;border:1.5px solid #fff;opacity:.6;transition:all .3s var(--ease);padding:0}
.dots button.active{background:#fff;opacity:1;transform:scale(1.15)}

/* =========================================================
   HERO
   ========================================================= */
.hero{justify-content:flex-end}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(10,10,11,.55) 0%,rgba(10,10,11,.1) 30%,rgba(10,10,11,.35) 62%,rgba(10,10,11,.96) 100%),
    radial-gradient(120% 80% at 80% 10%,transparent,rgba(10,10,11,.5));
}
.hero-inner{
  position:relative;z-index:2;
  padding:0 clamp(1.2rem,4vw,3rem) clamp(2.4rem,7vh,5rem);
  width:100%;max-width:var(--maxw);margin:0 auto;
}
.hero h1{margin:.35em 0 .45em}
.hero .display .ember{color:var(--ember)}
.hero-row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.6rem}
.hero-tag{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:clamp(1.1rem,.9rem + 1vw,1.7rem);color:var(--bone);max-width:24ch;line-height:1.25}
.hero-cats{display:flex;gap:1.4rem;flex-wrap:wrap;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.hero-cats span{position:relative;padding-left:1.1rem}
.hero-cats span::before{content:"";position:absolute;left:0;top:.5em;width:5px;height:5px;border-radius:50%;background:var(--ember)}

.scrollcue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--muted);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase}
.scrollcue .line{width:1px;height:34px;background:linear-gradient(var(--muted),transparent);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =========================================================
   PHILOSOPHY / ABOUT
   ========================================================= */
.philo{background:var(--ink)}
.philo-wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:6rem clamp(1.2rem,4vw,3rem) 3rem;display:grid;gap:clamp(2rem,5vw,4.5rem);grid-template-columns:1fr}
.philo-statement{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,1.1rem + 5.2vw,4.6rem);line-height:1.02;letter-spacing:-.025em;max-width:18ch}
.philo-statement .ember{color:var(--ember)}
.philo-col p{color:var(--muted);font-size:clamp(1rem,.95rem + .4vw,1.18rem);font-weight:300;margin-bottom:1.1rem;max-width:52ch}
.philo-col p strong{color:var(--bone);font-weight:500}
.philo-meta{display:flex;gap:2.6rem;flex-wrap:wrap;margin-top:1.8rem;padding-top:1.8rem;border-top:1px solid var(--line)}
.philo-meta .stat{display:flex;flex-direction:column;gap:.2rem}
.philo-meta .num{font-family:var(--font-display);font-weight:700;font-size:clamp(1.7rem,1.2rem + 2vw,2.8rem);line-height:1;color:var(--bone)}
.philo-meta .lab{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}

/* =========================================================
   GALLERY (coverflow)
   ========================================================= */
.gallery{background:var(--ink)}
.gallery.alt{background:var(--ink-2)}
.gallery-head{
  position:absolute;z-index:6;top:clamp(7rem,14vh,9rem);left:0;right:0;
  display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;
  padding:0 clamp(1.2rem,4vw,3rem);width:100%;max-width:var(--maxw);margin:0 auto;
  pointer-events:none;
}
.gallery-head .gh-left{display:flex;flex-direction:column;gap:.5rem}
.gallery-title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,1.2rem + 5vw,4.4rem);line-height:.9;letter-spacing:-.03em}
.gallery-title .ember{color:var(--ember)}
.gallery-count{font-size:.88rem;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}

/* subcategory chips */
.subcats{display:flex;gap:.5rem;flex-wrap:wrap;pointer-events:auto;justify-content:flex-end;max-width:60%}
.subcats button{
  font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;
  padding:.6rem 1.1rem;border:1px solid var(--line-strong);border-radius:4px;color:var(--muted);
  transition:all .3s var(--ease);white-space:nowrap;background:rgba(255,255,255,.04);font-weight:500;
}
.subcats button:hover{color:var(--bone);border-color:var(--bone);background:rgba(255,255,255,.08)}
.subcats button.active{background:var(--ember);border-color:var(--ember);color:var(--gold-ink);font-weight:600}

/* stage */
.stage{
  position:relative;z-index:2;width:100%;height:100dvh;
  display:flex;align-items:center;justify-content:center;
  perspective:1800px;touch-action:pan-y;
}
.track{position:relative;width:100%;height:min(58vh,62%);transform-style:preserve-3d}
.slide{
  position:absolute;top:50%;left:50%;
  width:min(80vw,1080px);height:100%;
  margin-left:calc(min(80vw,1080px) / -2);
  transform:translateY(-50%);
  will-change:transform,filter,opacity;
  transition:transform .8s var(--ease),filter .8s var(--ease),opacity .8s var(--ease);
}
.slide figure{position:relative;width:100%;height:100%;overflow:hidden;background:var(--ink-3);border-radius:3px}
.slide img{width:100%;height:100%;object-fit:cover;object-position:center}
.slide.is-active figure{box-shadow:0 40px 120px -30px rgba(0,0,0,.85)}
/* Soft vignette + fine light rim on PREVIEW thumbnails only (not the lightbox full view) */
.slide figure::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:2;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.2),inset 0 0 46px 6px rgba(8,8,9,.5),inset 0 0 120px 26px rgba(8,8,9,.34);
}
/* Portrait-oriented galleries: taller track, narrower slides, contain images */
.portrait .track{height:min(58vh,62%)}
.portrait .slide{width:min(38vw,480px);margin-left:calc(min(38vw,480px) / -2)}
.portrait .slide img{object-fit:contain;background:var(--ink-3)}

/* Category page solo gallery: slightly smaller slides */
.gallery-solo .slide{width:min(65vw,920px);margin-left:calc(min(65vw,920px) / -2)}
.gallery-solo.portrait .slide{width:min(38vw,480px);margin-left:calc(min(38vw,480px) / -2)}
.slide:not(.is-active){filter:blur(7px) brightness(.42) saturate(.85)}
.slide:not(.is-active) figure{cursor:pointer}
.slide-cap{
  position:absolute;left:0;bottom:0;z-index:3;
  padding:1.4rem 1.5rem;width:100%;
  background:linear-gradient(transparent,rgba(8,8,9,.85));
  font-size:.92rem;letter-spacing:.03em;color:var(--bone);
  opacity:0;transform:translateY(8px);transition:opacity .6s .25s var(--ease),transform .6s .25s var(--ease);
  display:flex;align-items:center;gap:.7rem;
}
.slide-cap b{font-weight:600}
.slide-cap .tag{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ember)}
.slide.is-active .slide-cap{opacity:1;transform:none}

/* controls */
.stage-nav{position:absolute;z-index:8;top:50%;transform:translateY(-50%);width:clamp(44px,5vw,60px);height:clamp(44px,5vw,60px);border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;background:rgba(10,10,11,.4);backdrop-filter:blur(6px);color:#fff;transition:background .3s,border-color .3s,transform .3s}
.stage-nav:hover{background:var(--ember);border-color:var(--ember);color:var(--gold-ink)}
.stage-nav.prev{left:clamp(.6rem,2vw,1.6rem)}
.stage-nav.next{right:clamp(.6rem,2vw,1.6rem)}
.stage-nav svg{width:42%;height:42%}

.stage-foot{
  position:absolute;z-index:6;bottom:clamp(1.4rem,4vh,2.4rem);left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:1.1rem;font-variant-numeric:tabular-nums;
}
.stage-foot .idx{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--bone)}
.stage-foot .sep{flex:0 0 auto;width:64px;height:2px;background:var(--line);position:relative;overflow:hidden;border-radius:2px}
.stage-foot .sep i{position:absolute;left:0;top:0;height:100%;background:var(--ember);transition:width .6s var(--ease)}
.stage-foot .total{font-size:.95rem;color:var(--muted)}
.stage-foot .play{margin-left:.4rem;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.45rem}
.stage-foot .play .ic{width:9px;height:9px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 0 var(--ember);animation:pulse 2.2s infinite}
.stage-foot .play.paused .ic{background:var(--muted-2);animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(201,162,79,.5)}70%{box-shadow:0 0 0 7px rgba(201,162,79,0)}100%{box-shadow:0 0 0 0 rgba(201,162,79,0)}}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{background:var(--ink-2)}
.contact-wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:6rem clamp(1.2rem,4vw,3rem) 2.5rem;display:grid;gap:clamp(2rem,5vw,4rem);grid-template-columns:1fr}
.contact-intro h2{font-size:clamp(2.2rem,1.3rem + 6vw,5rem);line-height:.92}
.contact-intro h2 .ember{color:var(--ember)}
.contact-intro p{color:var(--muted);font-weight:300;margin-top:1.1rem;max-width:42ch;font-size:1.05rem}
.contact-details{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.contact-details a,.contact-details span{display:flex;align-items:center;gap:.8rem;color:var(--bone);font-size:1rem}
.contact-details .lab{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);min-width:74px}
.contact-details a:hover{color:var(--ember)}

/* form tabs */
.form-card{background:var(--ink);border:1px solid var(--line);border-radius:6px;padding:clamp(1.3rem,3vw,2.2rem)}
.tabs{display:flex;gap:.4rem;margin-bottom:1.6rem;border-bottom:1px solid var(--line);padding-bottom:0}
.tabs button{font-size:.95rem;letter-spacing:.04em;padding:.7rem .2rem;color:var(--muted);position:relative;font-weight:600}
.tabs button::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--ember);transform:scaleX(0);transition:transform .35s var(--ease)}
.tabs button.active{color:var(--bone)}
.tabs button.active::after{transform:scaleX(1)}
.tabs button + button{margin-left:1.4rem}

form{display:none;flex-direction:column;gap:1.05rem}
form.active{display:flex}
.field{display:flex;flex-direction:column;gap:.45rem}
.field label{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:#cbc6bd;font-weight:600}
.field label .req{color:var(--ember)}
.field input,.field textarea,.field select{
  background:var(--ink-3);border:1px solid var(--line);border-radius:4px;
  padding:.9rem .95rem;color:var(--bone);font-family:inherit;font-size:1.02rem;
  transition:border-color .25s,background .25s;width:100%;
}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ember);background:#1f1f23}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a4a09a' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.05rem}
.btn{
  margin-top:.4rem;background:linear-gradient(180deg,var(--gold-soft),var(--gold) 55%,var(--gold-deep));color:var(--gold-ink);font-weight:600;font-size:.92rem;letter-spacing:.02em;
  padding:1rem 1.4rem;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  transition:transform .25s var(--ease),filter .25s;
}
.btn:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn svg{width:16px;height:16px}
.form-note{font-size:.88rem;color:var(--muted);margin-top:.2rem;line-height:1.55}

/* ---------- PWA / QR share card ---------- */
.pwa-card{display:flex;gap:1.4rem;align-items:center;margin-top:2rem;padding-top:1.8rem;border-top:1px solid var(--line)}
.pwa-qr{flex:0 0 auto;width:128px;height:128px;background:var(--bone);border-radius:11px;padding:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -16px rgba(0,0,0,.7),inset 0 0 0 1px rgba(255,255,255,.06)}
.pwa-qr svg{width:100%;height:100%;display:block}
.pwa-copy{display:flex;flex-direction:column;gap:.5rem;min-width:0}
.pwa-copy h3{font-family:var(--font-display);font-weight:700;font-size:clamp(1.2rem,1rem + .6vw,1.5rem);letter-spacing:-.01em;line-height:1;color:var(--bone)}
.pwa-copy p{color:var(--muted);font-size:.9rem;font-weight:300;line-height:1.5;max-width:36ch}
.pwa-actions{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;margin-top:.35rem}
.pwa-install{margin-top:0;padding:.72rem 1.1rem;font-size:.82rem}
.pwa-install svg{width:15px;height:15px}
.pwa-link{font-size:.82rem;letter-spacing:.04em;color:var(--gold-soft);border-bottom:1px solid transparent;transition:border-color .3s var(--ease)}
.pwa-link:hover{border-color:var(--gold)}
@media(max-width:560px){
  .pwa-card{gap:1.1rem}
  .pwa-qr{width:108px;height:108px}
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-foot{
  scroll-snap-align:end;background:var(--ink);border-top:1px solid var(--line);
  padding:clamp(2.2rem,5vw,3.4rem) clamp(1.2rem,4vw,3rem) 1.6rem;
}
.foot-grid{width:100%;max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-start}
.foot-brand{font-family:var(--font-display);font-weight:700;font-size:1.5rem;letter-spacing:-.01em}
.foot-brand .foot-logo{width:clamp(140px,14vw,200px);height:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4)) brightness(1.15)}
.foot-brand small{display:block;font-family:var(--font-body);font-weight:400;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-2);margin-top:.4rem}
.foot-links{display:flex;gap:1.8rem;flex-wrap:wrap;font-size:.86rem;color:var(--muted)}
.foot-links a:hover{color:var(--ember)}
.foot-social{display:flex;gap:1rem}
.foot-social a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .3s}
.foot-social a:hover{color:var(--gold-ink);border-color:var(--ember);background:var(--ember)}
.foot-social svg{width:17px;height:17px}
.foot-base{width:100%;max-width:var(--maxw);margin:2.2rem auto 0;padding-top:1.4rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.74rem;color:var(--muted-2)}

/* =========================================================
   LEGAL PAGES
   ========================================================= */
.legal{max-width:760px;margin:0 auto;padding:clamp(10rem,18vh,12rem) clamp(1.2rem,5vw,2rem) 5rem}
.legal a.back{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2.5rem}
.legal a.back:hover{color:var(--ember)}
.legal h1{font-size:clamp(2.2rem,1.5rem + 4vw,3.6rem);margin-bottom:2rem}
.legal h2{font-family:var(--font-display);font-size:1.3rem;margin:2.4rem 0 .8rem;color:var(--bone)}
.legal h3{font-family:var(--font-body);font-weight:600;font-size:1rem;margin:1.4rem 0 .4rem}
.legal p,.legal li{color:var(--muted);font-weight:300;margin-bottom:.7rem;font-size:.98rem;line-height:1.7}
.legal strong{color:var(--bone);font-weight:500}
.legal ul{padding-left:1.2rem;margin-bottom:1rem}
.legal .ph{background:rgba(201,162,79,.14);border:1px dashed var(--ember);border-radius:4px;color:var(--ember-soft);padding:.05em .4em;font-style:normal;font-weight:500}
.legal .card{background:var(--ink-2);border:1px solid var(--line);border-radius:6px;padding:1.4rem 1.6rem;margin:1.4rem 0}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (min-width:680px){
  .field-row{grid-template-columns:1fr 1fr}
}
@media (min-width:900px){
  .nav-links{display:flex}
  .menu-toggle{display:none}
  .dots{display:flex}
  .philo-wrap{grid-template-columns:1.05fr .95fr;align-items:center;padding-top:0;padding-bottom:0;min-height:100dvh}
  .contact-wrap{grid-template-columns:.85fr 1.15fr;align-items:center;padding-top:0;padding-bottom:0;min-height:100dvh}
}
@media (max-width:899px){
  .philo-wrap,.contact-wrap{padding-top:9rem}
  .philo,.contact{justify-content:flex-start}
  .subcats{max-width:100%}
}
/* Tablet: 4:3 slider aspect */
@media (min-width:561px) and (max-width:899px){
  .slide{width:min(75vw,800px);margin-left:calc(min(75vw,800px) / -2)}
  .track{height:clamp(40vh,56vw,55vh)}
  .gallery-solo .slide{width:min(70vw,800px);margin-left:calc(min(70vw,800px) / -2)}
  /* Portrait on tablet */
  .portrait .slide{width:min(42vw,420px);margin-left:calc(min(42vw,420px) / -2)}
  .portrait .track{height:clamp(40vh,56vw,55vh)}
}
/* Phone: ~1:1 square slider */
@media (max-width:560px){
  .slide{width:min(88vw,540px);margin-left:calc(min(88vw,540px) / -2)}
  .gallery-head{flex-direction:column;gap:1rem}
  .subcats{justify-content:flex-start}
  .stage-nav{display:none}
  .track{height:clamp(45vh,85vw,60vh)}
  .gallery-solo .slide{width:min(88vw,540px);margin-left:calc(min(88vw,540px) / -2)}
  /* Portrait on phone */
  .portrait .slide{width:min(65vw,360px);margin-left:calc(min(65vw,360px) / -2)}
  .portrait .track{height:clamp(45vh,85vw,60vh)}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.18s !important}
  .scrollcue{display:none}
}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lb{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.lb.lb-open{opacity:1;visibility:visible}
.lb-bg{position:absolute;inset:0;background:rgba(6,6,7,.96);backdrop-filter:blur(6px)}
.lb-img{position:relative;z-index:2;max-width:92vw;max-height:88vh;object-fit:contain;border-radius:2px;opacity:0;transform:scale(.96);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.lb-open .lb-img{opacity:1;transform:none}
.lb-close{position:absolute;z-index:5;top:clamp(1rem,3vh,1.8rem);right:clamp(1rem,3vw,1.8rem);width:44px;height:44px;border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.06);transition:background .25s,border-color .25s}
.lb-close:hover{background:var(--ember);border-color:var(--ember);color:var(--gold-ink)}
.lb-close svg{width:20px;height:20px}
.lb-arr{position:absolute;z-index:5;top:50%;transform:translateY(-50%);width:clamp(44px,5vw,56px);height:clamp(44px,5vw,56px);border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.06);transition:background .25s,border-color .25s}
.lb-arr:hover{background:var(--ember);border-color:var(--ember);color:var(--gold-ink)}
.lb-arr svg{width:40%;height:40%}
.lb-prev{left:clamp(.8rem,2vw,1.6rem)}
.lb-next{right:clamp(.8rem,2vw,1.6rem)}
.lb-foot{position:absolute;z-index:5;bottom:clamp(1rem,3vh,1.8rem);left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-size:.9rem;color:var(--muted)}
.lb-foot .lb-idx{color:var(--bone);font-weight:700}
@media(max-width:560px){.lb-arr{display:none}}

/* =========================================================
   BLOG / NEWS
   ========================================================= */
.blog-panel{background:var(--ink-2)}
.blog-wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:clamp(5rem,10vh,7rem) clamp(1.2rem,4vw,3rem);display:flex;flex-direction:column;gap:clamp(1.5rem,3vh,2.5rem);height:100%;justify-content:center}
.blog-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.blog-label{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,1.2rem+4vw,3.6rem);line-height:.92;letter-spacing:-.025em}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,1.4vw,1.4rem)}
.blog-card{background:var(--ink);border:1px solid var(--line);border-radius:4px;overflow:hidden;text-decoration:none;color:var(--bone);transition:border-color .4s var(--ease),transform .4s var(--ease)}
.blog-card:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.blog-card-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-body{padding:clamp(.8rem,1.5vw,1.4rem)}
.blog-card-date{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.4rem}
.blog-card-title{font-family:var(--font-display);font-weight:700;font-size:clamp(.95rem,.85rem+.5vw,1.2rem);line-height:1.2;letter-spacing:-.01em;margin-bottom:.5rem}
.blog-card-excerpt{font-size:.86rem;color:var(--muted);font-weight:300;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-more{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:color .3s var(--ease)}
.blog-more:hover{color:var(--ember)}
.blog-more svg{width:14px;height:14px}
@media(max-width:699px){.blog-grid{grid-template-columns:1fr;gap:.8rem}}
@media(min-width:700px) and (max-width:999px){.blog-grid{grid-template-columns:1fr 1fr}.blog-grid .blog-card:last-child{display:none}}

/* =========================================================
   MOBILE-FIRST TYPOGRAPHY
   ========================================================= */
@media(max-width:480px){
  body{font-size:15px;line-height:1.6}
  .display{font-size:clamp(2.4rem,10vw,3.4rem)}
  .lede{font-size:1rem}
  .eyebrow{font-size:.64rem}
  .philo-statement{font-size:clamp(1.6rem,6vw,2.4rem)}
  .contact-intro h2{font-size:clamp(1.8rem,8vw,2.8rem)}
  .field input,.field textarea,.field select{font-size:16px} /* prevents iOS zoom */
}

/* =========================================================
   LANGUAGE SWITCHER
   ========================================================= */
.lang-switch{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;letter-spacing:.08em;font-weight:500}
.lang-switch a{color:var(--muted-2);text-decoration:none;padding:.1rem .15rem;transition:color .3s var(--ease)}
.lang-switch a::after{display:none !important}
.lang-switch a:hover{color:var(--bone)}
.lang-switch a.active{color:var(--ember);font-weight:700}
.lang-switch .sep{color:var(--line-strong);font-size:.65rem}
.mobile-lang{display:flex;gap:1.6rem;margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.mobile-lang a{font-size:1.05rem;letter-spacing:.12em;color:var(--muted);text-decoration:none;font-weight:600;transition:color .3s var(--ease)}
.mobile-lang a:hover{color:var(--bone)}
.mobile-lang a.active{color:var(--ember)}
