/* ==========================================================
   HORTUS. Landscape Studio — Deep Forest Night Palette
   Full rewrite: new colors, new animations, interactive gallery
   ========================================================== */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{margin:0;padding:0}

:root{
  /* Deep forest night palette — distinct from prior cream/matcha */
  --bg:#0B1410;
  --bg-lift:#131D17;
  --bg-card:#1A261D;
  --bg-soft:#0F1A13;

  --ink:#EFE6D2;
  --ink-dim:#A8A99A;
  --ink-faint:#65685C;

  --gold:#D4A24C;
  --gold-d:#8C6820;
  --gold-soft:#E8C28A;
  --sage:#8FA083;
  --terra:#B6634A;

  --hair:rgba(239,230,210,.10);
  --hair-s:rgba(239,230,210,.20);
  --hair-gold:rgba(212,162,76,.24);

  --f-display:"Cormorant Garamond","Playfair Display",Georgia,serif;
  --f-body:"Figtree","Helvetica Neue",system-ui,sans-serif;
  --f-mono:"IBM Plex Mono",ui-monospace,monospace;

  --pad-x:clamp(20px,4vw,64px);
  --sec-y:clamp(80px,10vw,160px);

  --ease:cubic-bezier(.22,.9,.3,1);
  --ease-out:cubic-bezier(.19,1,.22,1);
}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  font-variant-ligatures:common-ligatures;
}
img,svg,video,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;padding:0;color:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p,dl,dt,dd,figure,blockquote,fieldset,legend{margin:0;padding:0;border:0}

::selection{background:var(--gold);color:var(--bg)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ============ GLOBAL LABELS ============ */
.eye{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.04em;
  color:var(--gold-soft);
  background:var(--bg);
}

.sec-head{
  display:flex;flex-direction:column;gap:18px;
  padding:0 var(--pad-x) clamp(40px,5vw,72px);
  max-width:1400px;margin:0 auto;
}
.sec-t{
  font-family:var(--f-display);
  font-size:clamp(40px,6vw,96px);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-.01em;
  color:var(--ink);
  background:var(--bg);
  max-width:18ch;
}
.sec-t em{font-style:italic;color:var(--gold);font-weight:400}
.sec-t-light{color:var(--ink)}
.sec-p{
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.55;
  color:var(--ink-dim);
  background:var(--bg);
  max-width:58ch;
}
.sec-p-light{color:var(--ink-dim)}

/* ============ TEXT REVEAL ============ */
[data-split]{
  display:block;
  overflow:hidden;
  line-height:inherit;
}
[data-split] > .w{
  display:inline-block;
  transform:translateY(110%);
  opacity:0;
  transition:transform .9s var(--ease-out),opacity .8s var(--ease-out);
  transition-delay:calc(var(--wi,0) * .06s);
  will-change:transform,opacity;
}
[data-split].is-in > .w{transform:translateY(0);opacity:1}

[data-reveal]{
  opacity:0;
  transform:translateY(26px);
  transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);
  will-change:opacity,transform;
}
[data-reveal].is-in{opacity:1;transform:translateY(0)}

body.no-js [data-split],
body.no-js [data-reveal]{opacity:1;transform:none}
body.no-js [data-split] > .w{opacity:1;transform:none}

/* ============ SCROLL RAIL (right edge) ============ */
.rail{
  position:fixed;
  right:24px;top:50%;transform:translateY(-50%);
  z-index:30;
  display:flex;flex-direction:column;gap:12px;
  align-items:flex-end;
  pointer-events:none;
}
.rail>*{pointer-events:auto}
.rail-label{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;
  color:var(--ink-faint);
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  margin-bottom:12px;
  background:var(--bg);
  padding:4px 0;
}
.rail-list{display:flex;flex-direction:column;gap:4px;position:relative}
.rail-list li{
  display:flex;align-items:center;gap:12px;
  justify-content:flex-end;
  padding:6px 2px;
  cursor:pointer;
  transition:color .3s var(--ease);
  color:var(--ink-faint);
}
.rail-list li span{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  width:22px;text-align:right;
  color:inherit;background:var(--bg);
  transition:color .3s var(--ease);
}
.rail-list li em{
  font-family:var(--f-body);font-size:13px;font-style:normal;
  opacity:0;transform:translateX(10px);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  color:var(--ink);background:var(--bg);
  font-weight:500;
}
.rail-list li:hover em,
.rail-list li.is-active em{opacity:1;transform:translateX(0)}
.rail-list li.is-active{color:var(--gold)}
.rail-list li.is-active span{color:var(--gold)}
.rail-list li::after{
  content:"";width:14px;height:1px;background:currentColor;
  transform:scaleX(.57);transform-origin:right;
  transition:transform .3s var(--ease);
}
.rail-list li.is-active::after{transform:scaleX(1)}
@media (max-width:1100px){.rail{display:none}}

/* ============ NAV ============ */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:40;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:clamp(16px,2vw,32px);
  padding:20px var(--pad-x);
  background:linear-gradient(to bottom,rgba(11,20,16,.92),rgba(11,20,16,.4) 70%,rgba(11,20,16,0));
  backdrop-filter:blur(12px) saturate(1.2);
  -webkit-backdrop-filter:blur(12px) saturate(1.2);
  transition:background .3s var(--ease);
}
.nav.is-solid{background:var(--bg);border-bottom:1px solid var(--hair)}

.nav-logo{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.lg-emblem{display:inline-flex;color:var(--gold)}
.lg-wm{
  font-family:var(--f-display);
  font-size:26px;
  font-weight:500;
  letter-spacing:-.015em;
  background:var(--bg);
}
.lg-wm i{font-style:italic;color:var(--gold);font-weight:400;display:inline-block;transform:translateY(-.06em)}

.nav-center{
  display:inline-flex;align-items:center;gap:10px;
  justify-self:center;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-dim);background:var(--bg);
  padding:6px 14px;
  border:1px solid var(--hair);
  border-radius:999px;
}
.nc-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(212,162,76,.6);animation:dotGlow 2.6s ease-in-out infinite}
@keyframes dotGlow{0%,100%{box-shadow:0 0 0 0 rgba(212,162,76,.7)}50%{box-shadow:0 0 0 8px rgba(212,162,76,0)}}
@media (max-width:820px){.nav-center{display:none}}

.nav-right{display:inline-flex;align-items:center;gap:10px;justify-self:end}
.nav-tel{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink);background:var(--bg);
  padding:10px 14px;
  border:1px solid var(--hair);
  border-radius:999px;
  transition:border-color .25s var(--ease),color .25s var(--ease);
}
.nav-tel:hover{border-color:var(--gold);color:var(--gold)}
@media (max-width:680px){.nav-tel{display:none}}

.chapter-btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 18px;
  border:1px solid var(--hair-s);
  border-radius:999px;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;
  transition:background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease);
}
.chapter-btn:hover{border-color:var(--gold);color:var(--gold)}
.cb-lines{display:inline-flex;flex-direction:column;gap:3px}
.cb-lines i{display:block;width:14px;height:1px;background:currentColor;transition:transform .3s var(--ease),opacity .2s}
.cb-lines i:nth-child(2){width:10px}
body.ch-open .cb-lines i:nth-child(1){transform:translateY(4px) rotate(45deg);width:14px}
body.ch-open .cb-lines i:nth-child(2){opacity:0}
body.ch-open .cb-lines i:nth-child(3){transform:translateY(-4px) rotate(-45deg);width:14px}

/* ============ CHAPTER DRAWER ============ */
.chapter{
  position:fixed;inset:0;z-index:60;
  padding:clamp(20px,4vw,40px) var(--pad-x);
  background:var(--bg);
  display:grid;
  grid-template-rows:auto 1fr auto;
  gap:clamp(24px,3vw,40px);
  opacity:0;pointer-events:none;
  clip-path:circle(0% at calc(100% - 80px) 40px);
  transition:clip-path .65s var(--ease-out),opacity .3s var(--ease);
  overflow-y:auto;
}
body.ch-open .chapter{opacity:1;pointer-events:auto;clip-path:circle(160% at calc(100% - 80px) 40px)}

.chapter-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 80% at 85% 15%,rgba(212,162,76,.08) 0%,transparent 60%),
    radial-gradient(50% 60% at 10% 90%,rgba(143,160,131,.06) 0%,transparent 55%);
  pointer-events:none;
}
.chapter-head{
  display:flex;justify-content:space-between;align-items:center;
  position:relative;
}
.ch-meta{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-faint);background:var(--bg);
}
.ch-close{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;
  border:1px solid var(--hair-s);
  border-radius:999px;
  color:var(--ink);background:var(--bg);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;
}
.ch-close:hover{border-color:var(--gold)}

.chapter-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(14px,2vw,28px);
  align-self:center;
  position:relative;
  max-width:1400px;
  width:100%;
  margin:0 auto;
}
@media (max-width:900px){.chapter-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.chapter-grid{grid-template-columns:1fr}}

.ch-item{
  position:relative;
  display:flex;flex-direction:column;gap:12px;
  padding:0;
  border-radius:18px;
  overflow:hidden;
  background:var(--bg-lift);
  border:1px solid var(--hair);
  opacity:0;transform:translateY(30px);
  transition:opacity .5s var(--ease-out),transform .5s var(--ease-out),border-color .3s var(--ease);
  min-height:180px;
}
body.ch-open .ch-item{opacity:1;transform:translateY(0);transition-delay:calc(.24s + var(--i) * .06s)}
.ch-item:hover{border-color:var(--gold)}
.ci-img{display:block;aspect-ratio:4/3;overflow:hidden;background:var(--bg-card)}
.ci-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.7) saturate(.85);transition:transform .8s var(--ease),filter .4s var(--ease)}
.ch-item:hover .ci-img img{transform:scale(1.08);filter:brightness(.85) saturate(1)}
.ci-n{
  position:absolute;top:14px;left:14px;
  font-family:var(--f-display);font-size:14px;font-style:italic;color:var(--gold);
  padding:4px 10px;background:rgba(11,20,16,.6);border:1px solid var(--hair-gold);border-radius:999px;
}
.ci-t{
  font-family:var(--f-display);
  font-size:22px;font-weight:500;letter-spacing:-.01em;
  color:var(--ink);background:var(--bg-lift);
  padding:14px 18px 18px;
}

.chapter-foot{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  padding-top:18px;
  border-top:1px solid var(--hair);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;color:var(--ink-dim);background:var(--bg);
  position:relative;
}
.chapter-foot a{color:var(--gold)}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;
  font-family:var(--f-body);
  font-size:14px;font-weight:500;
  border-radius:999px;
  border:1px solid transparent;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
  cursor:pointer;
}
.btn-gold{background:var(--gold);color:var(--bg);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-soft);border-color:var(--gold-soft);transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--ink);border:1px solid var(--hair-s)}
.btn-line:hover{border-color:var(--ink);transform:translateY(-2px)}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:100svh;
  padding:clamp(120px,14vh,180px) var(--pad-x) clamp(48px,6vw,80px);
  display:grid;
  grid-template-rows:auto 1fr auto auto;
  align-content:center;
  gap:clamp(22px,3vh,38px);
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
#heroImg{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.38) saturate(.95) contrast(1.05);
  transform:scale(1.08);
  transform-origin:center center;
  transition:transform 0s;
}
.hero-vignette{
  position:absolute;inset:0;
  background:
    radial-gradient(65% 55% at 50% 45%,transparent 0%,rgba(11,20,16,.35) 65%,rgba(11,20,16,.9) 100%),
    linear-gradient(to bottom,rgba(11,20,16,.5) 0%,rgba(11,20,16,0) 30%,rgba(11,20,16,.7) 100%);
}
.hero>*:not(.hero-bg){position:relative;z-index:1}

.hero-marks{
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-dim);background:transparent;
}
.hm-chapter{display:inline-flex;align-items:center;gap:8px;background:transparent}
.hm-chapter .tick{color:var(--gold)}
.hm-tag{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--gold-soft)}

.hero-h{
  font-family:var(--f-display);
  font-size:clamp(56px,9vw,180px);
  font-weight:400;
  line-height:.95;
  letter-spacing:-.02em;
  color:var(--ink);
  margin:0;
  background:transparent;
  position:relative;
}
.hh-row{display:block}
.hh-i{font-style:italic;color:var(--gold);font-weight:300}
.hh-dot{
  display:inline-block;
  width:18px;height:18px;border-radius:50%;background:var(--gold);
  margin-left:6px;transform:translateY(-.15em);
  box-shadow:0 0 24px rgba(212,162,76,.5);
  animation:dotGlow 2.6s ease-in-out infinite;
  opacity:0;
  transition:opacity .4s .8s var(--ease);
}
.hero-h.is-in + .hero-p ~ .hh-dot,
.hero-h .hh-dot{opacity:1}

.hero-p{
  font-family:var(--f-body);
  font-size:clamp(15px,1.2vw,18px);
  line-height:1.55;
  color:var(--ink-dim);
  background:transparent;
  max-width:52ch;
  letter-spacing:.005em;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,2.4vw,32px);
  padding-top:clamp(24px,3vw,36px);
  border-top:1px solid var(--hair);
  margin-top:clamp(30px,4vw,48px);
}
@media (max-width:720px){.hero-stats{grid-template-columns:repeat(2,1fr);gap:24px}}

.hero-stats li{
  display:flex;flex-direction:column;gap:6px;
  background:transparent;
  transform:translateY(20px);opacity:0;
  transition:transform .8s var(--ease-out),opacity .8s var(--ease-out);
  transition-delay:calc(var(--i,0) * .1s + .6s);
}
.hero-stats.is-in li{transform:translateY(0);opacity:1}
.hero-stats li[data-float="0"]{--i:0}
.hero-stats li[data-float="1"]{--i:1}
.hero-stats li[data-float="2"]{--i:2}
.hero-stats li[data-float="3"]{--i:3}

.hs-n{
  font-family:var(--f-display);
  font-size:clamp(40px,4.5vw,68px);
  font-weight:400;
  line-height:1;
  letter-spacing:-.02em;
  color:var(--gold);
  background:transparent;
}
.hs-l{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink-dim);
  background:transparent;
  line-height:1.45;
}

.hero-scroll{
  position:absolute;
  right:var(--pad-x);bottom:40px;
  display:flex;align-items:center;gap:12px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink-dim);background:transparent;
  z-index:2;
}
.hs-line{display:inline-block;width:48px;height:1px;background:var(--hair-s);position:relative;overflow:hidden}
.hs-line i{position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;animation:hsRun 2.6s var(--ease) infinite}
@keyframes hsRun{0%{transform:scaleX(0);transform-origin:left}50%{transform:scaleX(1);transform-origin:left}51%{transform-origin:right}100%{transform:scaleX(0);transform-origin:right}}
@media (max-width:720px){.hero-scroll{display:none}}

/* ============ PHILOSOPHY ============ */
.philo{
  position:relative;
  padding:var(--sec-y) var(--pad-x);
  display:grid;
  gap:clamp(28px,3.4vw,56px);
  justify-items:center;
  text-align:center;
  overflow:hidden;
}
.philo-bg{position:absolute;inset:0;z-index:0}
.philo-bg img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.28) saturate(.7) blur(1px);
  transform:scale(1.06);
}
.philo>*:not(.philo-bg){position:relative;z-index:1;max-width:1100px}
.philo::after{
  content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(ellipse at center,rgba(11,20,16,.2) 0%,rgba(11,20,16,.85) 80%);
}
.philo-q{
  font-family:var(--f-display);
  font-size:clamp(26px,4vw,56px);
  font-weight:400;
  font-style:italic;
  line-height:1.2;
  letter-spacing:-.005em;
  color:var(--ink);
  background:transparent;
  text-align:center;
}
.philo-q em{color:var(--gold);font-style:italic;font-weight:500}
.philo-q span{display:block}
.philo-cap{
  display:flex;gap:24px;flex-wrap:wrap;justify-content:center;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-dim);background:transparent;
  padding-top:24px;
  border-top:1px solid var(--hair);
  max-width:400px;width:100%;
  justify-content:space-between;
}
.pc-l{color:var(--gold);background:transparent}
.pc-r{background:transparent}

/* ============ GALLERY ============ */
.gallery{
  padding:var(--sec-y) 0 clamp(40px,5vw,80px);
  position:relative;
}
.gallery .sec-head{max-width:1560px;padding:0 var(--pad-x) clamp(40px,5vw,72px)}
.gallery .sec-head{position:relative}
.drag-hint{
  position:absolute;right:var(--pad-x);bottom:clamp(40px,5vw,72px);
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;
  border:1px solid var(--hair);border-radius:999px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-dim);background:var(--bg);
}
.drag-hint svg{color:var(--gold)}

.gal-viewport{
  overflow:hidden;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  padding-left:var(--pad-x);
}
.gal-viewport.is-drag{cursor:grabbing}
.gal-track{
  display:flex;
  gap:clamp(18px,2vw,32px);
  padding:4px 0 24px 0;
  will-change:transform;
  transition:transform .9s var(--ease-out);
}
.gcard{
  flex:0 0 clamp(280px,36vw,460px);
  display:flex;flex-direction:column;gap:14px;
  cursor:pointer;
  position:relative;
}
.gc-media{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  border-radius:18px;
  background:var(--bg-lift);
  border:1px solid var(--hair);
}
.gc-media img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.78) saturate(.95);
  transform:scale(1.02);
  transition:transform 1.1s var(--ease),filter .5s var(--ease);
}
.gcard:hover .gc-media img{transform:scale(1.08);filter:brightness(.95) saturate(1)}
.gc-zoom{
  position:absolute;top:16px;right:16px;
  width:42px;height:42px;border-radius:50%;
  background:rgba(11,20,16,.6);
  backdrop-filter:blur(8px);
  border:1px solid var(--hair-s);
  color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(.8);
  transition:opacity .25s var(--ease),transform .25s var(--ease);
}
.gcard:hover .gc-zoom{opacity:1;transform:scale(1)}

.gc-meta{display:flex;flex-direction:column;gap:8px;padding:0 2px}
.gc-n{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--gold);background:var(--bg);
}
.gc-meta h3{
  font-family:var(--f-display);
  font-size:clamp(22px,2.2vw,30px);
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--ink);background:var(--bg);
  line-height:1.1;
}
.gc-meta dl{
  display:flex;gap:18px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:12px;
  color:var(--ink-dim);background:var(--bg);
}
.gc-meta dl div{display:inline-flex;gap:6px;background:var(--bg)}
.gc-meta dt{color:var(--ink-faint);letter-spacing:.04em;text-transform:uppercase;background:var(--bg)}
.gc-meta dd{color:var(--ink);background:var(--bg)}

.gal-nav{
  display:flex;align-items:center;gap:16px;
  padding:0 var(--pad-x);
  max-width:1560px;margin:24px auto 0;
}
.gn-btn{
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--hair-s);
  color:var(--ink);background:var(--bg);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .2s var(--ease);
}
.gn-btn:hover{background:var(--gold);color:var(--bg);border-color:var(--gold);transform:translateY(-2px)}
.gn-btn:disabled{opacity:.3;pointer-events:none}
.gn-prog{flex:1;height:1px;background:var(--hair);position:relative;overflow:hidden}
.gn-prog i{position:absolute;left:0;top:0;bottom:0;width:100%;background:var(--gold);transform:scaleX(.16);transform-origin:left;transition:transform .5s var(--ease)}

/* ============ LIGHTBOX ============ */
.lb{
  position:fixed;inset:0;z-index:100;
  background:rgba(11,20,16,.96);
  backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;
  padding:clamp(20px,4vw,48px);
  opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease);
}
.lb.is-open{opacity:1;pointer-events:auto}
.lb-fig{
  max-width:1200px;width:100%;max-height:calc(100vh - 96px);
  display:flex;flex-direction:column;gap:18px;
  transform:scale(.96);opacity:0;
  transition:transform .5s var(--ease-out),opacity .35s var(--ease);
  margin:0;
}
.lb.is-open .lb-fig{transform:scale(1);opacity:1;transition-delay:.05s}
.lb-fig img{
  width:100%;max-height:calc(100vh - 170px);
  object-fit:contain;
  border-radius:12px;
  background:var(--bg-lift);
}
.lb-fig figcaption{
  font-family:var(--f-display);font-size:20px;font-style:italic;
  color:var(--ink);background:var(--bg);text-align:center;
}

.lb-close{
  position:absolute;top:24px;right:24px;
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--hair-s);color:var(--ink);background:transparent;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .25s var(--ease),transform .2s var(--ease);
}
.lb-close:hover{background:var(--gold);color:var(--bg);transform:rotate(90deg)}

.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:54px;height:54px;border-radius:50%;
  border:1px solid var(--hair-s);color:var(--ink);background:rgba(11,20,16,.6);
  backdrop-filter:blur(6px);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .25s var(--ease),border-color .25s var(--ease);
}
.lb-prev{left:24px}
.lb-next{right:24px}
.lb-nav:hover{background:var(--gold);color:var(--bg);border-color:var(--gold)}

.lb-counter{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-dim);background:var(--bg);
  padding:6px 14px;border:1px solid var(--hair);border-radius:999px;
}

/* ============ PROCESS — VERTICAL TIMELINE ============ */
.process{
  padding:var(--sec-y) var(--pad-x);
  background:var(--bg-soft);
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.prc-grid{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:clamp(24px,4vw,72px);
  max-width:1400px;margin:0 auto;
}
@media (max-width:860px){.prc-grid{grid-template-columns:60px 1fr;gap:20px}}

.prc-spine{
  position:sticky;top:120px;
  align-self:start;
  height:400px;
  display:grid;
  grid-template-rows:1fr auto 1fr;
  align-items:center;
  justify-items:center;
}
.spine-line{
  position:relative;
  width:1px;height:100%;
  background:var(--hair-s);
  grid-row:1 / -1;grid-column:1;
  justify-self:center;
  overflow:hidden;
}
.spine-line i{
  position:absolute;left:0;right:0;top:0;
  height:100%;background:var(--gold);
  transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease);
}
.spine-dots{
  grid-row:1 / -1;grid-column:1;
  display:flex;flex-direction:column;justify-content:space-between;
  height:100%;
  justify-self:center;
  padding:20px 0;
}
.sd{
  width:38px;height:38px;border-radius:50%;
  background:var(--bg);
  border:1px solid var(--hair-s);
  color:var(--ink-faint);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:13px;font-style:italic;font-weight:500;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);
}
.sd.is-on{background:var(--gold);color:var(--bg);border-color:var(--gold);transform:scale(1.05)}
.sd.is-past{border-color:var(--gold);color:var(--gold)}

.prc-body{display:flex;flex-direction:column;gap:clamp(56px,8vw,120px)}
.pr-step{display:flex;flex-direction:column;gap:12px;padding-bottom:clamp(12px,2vw,24px)}
.pr-no{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--gold);background:var(--bg-soft);
}
.pr-step h3{
  font-family:var(--f-display);
  font-size:clamp(28px,3.6vw,48px);
  font-weight:400;
  line-height:1.05;
  letter-spacing:-.015em;
  color:var(--ink);background:var(--bg-soft);
  max-width:16ch;
}
.pr-step p{
  font-family:var(--f-body);
  font-size:16px;line-height:1.6;
  color:var(--ink-dim);background:var(--bg-soft);
  max-width:56ch;
}
.pr-kv{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-top:8px;
}
.pr-kv span{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink);background:var(--bg-lift);
  padding:6px 12px;
  border:1px solid var(--hair);border-radius:999px;
}

/* ============ SERVICES — STUDIO ESTATE PLAN ============ */
.services{
  padding:var(--sec-y) var(--pad-x) clamp(80px,10vw,160px);
  max-width:1560px;margin:0 auto;
  position:relative;
}
.services .sec-head{padding-bottom:clamp(32px,4vw,56px)}

.srv-estate{
  display:grid;
  grid-template-columns:minmax(360px, 46%) 1fr;
  gap:clamp(24px,3vw,64px);
  align-items:start;
}
@media (max-width:960px){.srv-estate{grid-template-columns:1fr;gap:28px}}

/* ----- STICKY PLAN ----- */
.plan{
  position:sticky;top:clamp(90px,10vh,140px);
  align-self:start;
  color:var(--sage);
}
.plan-frame{
  position:relative;
  border:1px solid var(--hair);
  border-radius:4px;
  background:
    linear-gradient(180deg,rgba(212,162,76,.02),rgba(11,20,16,0) 40%),
    var(--bg-soft);
  padding:18px;
  overflow:hidden;
}
.plan-frame::before{
  content:"";position:absolute;inset:6px;
  border:1px dashed rgba(143,160,131,.18);
  border-radius:2px;pointer-events:none;
}
.plan-frame::after{
  /* grid background */
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(143,160,131,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(143,160,131,.05) 1px,transparent 1px);
  background-size:40px 40px;
  pointer-events:none;
  opacity:.6;
}
.plan-svg{
  position:relative;z-index:2;
  width:100%;height:auto;display:block;
  color:var(--sage);
  transform-origin:center;
}
.plan-corner{
  position:absolute;z-index:3;
  font-family:var(--f-mono);font-size:10px;
  letter-spacing:.04em;
  color:var(--ink-faint);
  background:var(--bg-soft);
  padding:3px 8px;
  text-transform:uppercase;
}
.plan-corner em{color:var(--gold);font-style:italic;font-family:var(--f-display);font-size:14px;letter-spacing:0;text-transform:none;padding-left:4px}
.plan-corner--tl{top:10px;left:10px}
.plan-corner--tr{top:10px;right:10px}
.plan-corner--bl{bottom:10px;left:10px}
.plan-corner--br{bottom:10px;right:10px}

/* SVG zone interaction */
.p-zone{opacity:.42;transition:opacity .6s var(--ease)}
.p-zone .p-pin{transition:fill .4s var(--ease),stroke .4s var(--ease),r .4s var(--ease)}
.p-zone text{transition:fill .4s var(--ease)}
.p-zone .p-hatch line,
.p-zone .p-dots circle,
.p-zone .p-boxwood,
.p-zone .p-scatter circle,
.p-zone .p-trees,
.p-zone .p-path-line{transition:stroke .4s var(--ease),fill .4s var(--ease),opacity .4s var(--ease)}

.services[data-active-zone="1"] .p-zone[data-zone="1"],
.services[data-active-zone="2"] .p-zone[data-zone="2"],
.services[data-active-zone="3"] .p-zone[data-zone="3"],
.services[data-active-zone="4"] .p-zone[data-zone="4"],
.services[data-active-zone="5"] .p-zone[data-zone="5"],
.services[data-active-zone="6"] .p-zone[data-zone="6"]{
  opacity:1;
  color:var(--gold);
}
.services[data-active-zone="1"] .p-zone[data-zone="1"] .p-pin,
.services[data-active-zone="2"] .p-zone[data-zone="2"] .p-pin,
.services[data-active-zone="3"] .p-zone[data-zone="3"] .p-pin,
.services[data-active-zone="4"] .p-zone[data-zone="4"] .p-pin,
.services[data-active-zone="5"] .p-zone[data-zone="5"] .p-pin,
.services[data-active-zone="6"] .p-zone[data-zone="6"] .p-pin{
  fill:var(--gold);stroke:var(--gold);
  filter:drop-shadow(0 0 6px rgba(212,162,76,.6));
}
.services[data-active-zone="1"] .p-zone[data-zone="1"] text,
.services[data-active-zone="2"] .p-zone[data-zone="2"] text,
.services[data-active-zone="3"] .p-zone[data-zone="3"] text,
.services[data-active-zone="4"] .p-zone[data-zone="4"] text,
.services[data-active-zone="5"] .p-zone[data-zone="5"] text,
.services[data-active-zone="6"] .p-zone[data-zone="6"] text{
  fill:var(--bg);font-weight:500;
}

/* ----- ENTRIES (right) ----- */
.srv-entries{
  display:flex;flex-direction:column;
  gap:0;
  counter-reset:sent;
}
.sent{
  position:relative;
  padding:clamp(32px,4vw,56px) 0;
  border-bottom:1px solid var(--hair);
  transition:transform .5s var(--ease);
}
.sent:first-child{border-top:1px solid var(--hair)}
.sent.is-active{
  transform:translateX(clamp(12px,1.6vw,24px));
}
.sent::before{
  content:"";position:absolute;left:0;top:0;bottom:0;
  width:2px;background:var(--gold);
  transform:scaleY(0);transform-origin:top;
  transition:transform .55s var(--ease);
}
.sent.is-active::before{transform:scaleY(1)}

.se-head{
  display:flex;align-items:center;gap:12px;
  margin-bottom:16px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--gold);background:var(--bg);
  text-transform:uppercase;
}
.se-tick{flex:1;height:1px;background:var(--hair);display:block;position:relative;overflow:hidden}
.se-tick::after{content:"";position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease)}
.sent.is-active .se-tick::after{transform:scaleX(1)}

.sent h3{
  font-family:var(--f-display);
  font-size:clamp(32px,4vw,58px);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-.018em;
  color:var(--ink);background:var(--bg);
  margin:0 0 18px;
  max-width:16ch;
}
.se-lead{
  font-family:var(--f-body);
  font-size:clamp(15px,1.2vw,17px);
  line-height:1.6;
  color:var(--ink-dim);background:var(--bg);
  max-width:58ch;
  margin-bottom:20px;
}

.se-incl{
  display:flex;flex-direction:column;gap:2px;
  margin:0 0 24px;
  padding:16px 0;
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.se-incl li{
  display:grid;
  grid-template-columns:1fr auto;
  gap:16px;
  padding:6px 0;
  font-family:var(--f-body);font-size:14px;line-height:1.5;
  color:var(--ink);background:var(--bg);
}
.se-incl li span:first-child{color:var(--ink)}
.se-incl li span:last-child{
  font-family:var(--f-mono);font-size:12px;color:var(--ink-faint);background:var(--bg);
  letter-spacing:.02em;
  align-self:center;
}

.se-foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
}
.se-px{
  font-family:var(--f-display);
  font-size:clamp(24px,2.6vw,36px);
  font-weight:400;
  color:var(--gold);background:var(--bg);
  letter-spacing:-.01em;
}
.se-px em{font-family:var(--f-mono);font-size:11px;font-style:normal;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);margin-right:6px;vertical-align:middle;background:var(--bg)}
.se-px u{font-family:var(--f-mono);font-size:13px;font-weight:400;text-decoration:none;color:var(--gold-soft);margin-left:4px;letter-spacing:.02em;background:var(--bg)}
.se-go{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink);background:var(--bg);
  padding:10px 16px;
  border:1px solid var(--hair-s);
  border-radius:999px;
  transition:border-color .25s var(--ease),color .25s var(--ease),background .25s var(--ease),transform .2s var(--ease);
}
.se-go:hover{border-color:var(--gold);color:var(--gold);transform:translateX(4px)}

@media (max-width:960px){
  .plan{position:static}
  .plan-frame{max-width:500px;margin:0 auto 16px}
}

/* ============ FLORA — HERBARIUM WALL ============ */
.flora{
  padding:var(--sec-y) var(--pad-x);
  background:var(--bg-soft);
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.herb-wall{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(20px,3vw,48px);
  max-width:1400px;margin:0 auto;
}
@media (max-width:960px){.herb-wall{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.herb-wall{grid-template-columns:1fr}}

.herb{
  display:flex;flex-direction:column;gap:12px;
  transform:rotate(calc(var(--r,0) * 1deg));
  transition:transform .5s var(--ease);
}
.herb[data-r="-3"]{--r:-2}
.herb[data-r="-2"]{--r:-1.4}
.herb[data-r="-1"]{--r:-.8}
.herb[data-r="1"]{--r:.8}
.herb[data-r="2"]{--r:1.4}
.herb[data-r="3"]{--r:2}
.herb:hover{transform:rotate(0) translateY(-8px)}

.hb-frame{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--bg-lift);
  border:1px solid var(--hair-s);
  border-radius:6px;
  padding:10px;
  box-shadow:0 18px 40px rgba(0,0,0,.4),0 1px 0 rgba(239,230,210,.04) inset;
}
.hb-frame::before,.hb-frame::after{
  content:"";position:absolute;width:10px;height:10px;
  background:var(--gold);border-radius:50%;opacity:.4;
  z-index:2;
}
.hb-frame::before{top:6px;left:6px}
.hb-frame::after{bottom:6px;right:6px}
.hb-frame img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.1) saturate(.9) brightness(.92);
  transition:transform .9s var(--ease),filter .4s var(--ease);
}
.herb:hover .hb-frame img{transform:scale(1.06);filter:saturate(1.1) brightness(1)}

.hb-label{
  display:flex;flex-direction:column;gap:2px;
  padding:4px 2px;
  font-family:var(--f-body);
}
.hb-gen{
  font-family:var(--f-display);
  font-size:22px;font-weight:500;letter-spacing:-.01em;
  color:var(--ink);background:var(--bg-soft);
  line-height:1.1;
}
.hb-sp{
  font-family:var(--f-display);
  font-size:16px;color:var(--gold);background:var(--bg-soft);
}
.hb-sp em{font-style:italic}
.hb-ua{
  font-family:var(--f-body);font-size:14px;
  color:var(--ink-dim);background:var(--bg-soft);
  margin-top:4px;
}
.hb-tags{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-faint);background:var(--bg-soft);
  margin-top:4px;
}

/* ============ SEASONS — INTERACTIVE CALENDAR ============ */
.seasons{
  padding:var(--sec-y) var(--pad-x);
  max-width:1400px;margin:0 auto;
}
.sea-wrap{display:flex;flex-direction:column;gap:clamp(32px,4vw,56px)}

.sea-months{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:4px;
  border:1px solid var(--hair);
  padding:8px;
  border-radius:999px;
  background:var(--bg-lift);
  overflow-x:auto;
}
@media (max-width:680px){.sea-months{grid-template-columns:repeat(6,1fr);border-radius:16px}}
.sm-item{
  padding:12px 4px;
  border-radius:999px;
  text-align:center;
  cursor:pointer;
  font-family:var(--f-mono);
  transition:background .3s var(--ease),color .3s var(--ease),transform .2s var(--ease);
  display:flex;flex-direction:column;gap:2px;align-items:center;
}
.sm-item span{font-size:10px;letter-spacing:.04em;color:var(--ink-faint);background:var(--bg-lift)}
.sm-item em{
  font-style:normal;
  font-family:var(--f-body);font-size:13px;font-weight:500;
  color:var(--ink-dim);background:var(--bg-lift);
}
.sm-item:hover{background:var(--bg-card)}
.sm-item.is-on{background:var(--gold);transform:scale(1.02)}
.sm-item.is-on span,.sm-item.is-on em{color:var(--bg);background:var(--gold)}

.sea-panel{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:clamp(24px,3vw,48px);
  padding:clamp(24px,3vw,40px);
  border:1px solid var(--hair);
  border-radius:24px;
  background:var(--bg-lift);
}
@media (max-width:820px){.sea-panel{grid-template-columns:1fr}}

.sp-left{display:flex;flex-direction:column;gap:14px}
.sp-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--gold);background:var(--bg-lift);
  align-self:flex-start;
}
.sp-tag i{width:6px;height:6px;background:var(--gold);border-radius:50%;display:inline-block;animation:dotGlow 2.6s ease-in-out infinite}
.sp-m{
  font-family:var(--f-display);
  font-size:clamp(40px,5vw,72px);
  font-weight:400;line-height:1;letter-spacing:-.02em;
  color:var(--ink);background:var(--bg-lift);
}
.sp-sub{
  font-family:var(--f-display);font-style:italic;
  font-size:20px;color:var(--gold);background:var(--bg-lift);
}
.sp-work{
  display:flex;flex-direction:column;gap:10px;
  padding-top:12px;
  border-top:1px solid var(--hair);
  margin-top:6px;
}
.sp-work li{
  font-family:var(--f-body);font-size:15px;
  color:var(--ink);background:var(--bg-lift);
  line-height:1.5;
  padding-left:22px;position:relative;
}
.sp-work li::before{
  content:"";position:absolute;left:0;top:10px;
  width:10px;height:1px;background:var(--gold);
}

.sp-right{
  display:flex;flex-direction:column;gap:14px;
}
.sp-right img{
  width:100%;aspect-ratio:5/4;object-fit:cover;
  border-radius:16px;
  filter:saturate(.9) brightness(.9);
}
.sp-weather{
  display:flex;gap:12px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-dim);background:var(--bg-lift);
}
.sp-weather span{
  padding:6px 12px;border:1px solid var(--hair);border-radius:999px;background:var(--bg-lift);
}

/* ============ PRINCIPALS ============ */
.princ{
  padding:var(--sec-y) var(--pad-x);
  background:var(--bg-soft);
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.pr-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(32px,4vw,72px);
  max-width:1400px;margin:0 auto;
}
@media (max-width:860px){.pr-grid{grid-template-columns:1fr}}

.pr-card{display:flex;flex-direction:column;gap:24px}
.pr-photo{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  border-radius:12px;
  background:var(--bg-lift);
  border:1px solid var(--hair);
}
.pr-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.7) brightness(.82) contrast(1.02);
  transform:scale(1.04);
  transition:transform 1.2s var(--ease),filter .5s var(--ease);
}
.pr-card:hover .pr-photo img{transform:scale(1.1);filter:saturate(1) brightness(.95)}

.pr-info{display:flex;flex-direction:column;gap:12px}
.pr-role{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--gold);background:var(--bg-soft);
}
.pr-name{
  font-family:var(--f-display);
  font-size:clamp(34px,3.8vw,56px);
  font-weight:400;line-height:1;letter-spacing:-.02em;
  color:var(--ink);background:var(--bg-soft);
}
.pr-bio{
  font-family:var(--f-body);font-size:16px;line-height:1.6;
  color:var(--ink-dim);background:var(--bg-soft);
}
.pr-q{
  font-family:var(--f-display);
  font-size:20px;font-style:italic;line-height:1.35;
  color:var(--gold);background:var(--bg-soft);
  padding:18px 0 12px;
  border-top:1px solid var(--hair);
  max-width:38ch;
}
.pr-sign{
  font-family:var(--f-display);font-style:italic;font-size:22px;
  color:var(--ink);background:var(--bg-soft);
  transform:rotate(-3deg);
  align-self:flex-start;
  padding:6px 0;
}

/* ============ WITNESS ============ */
.witness{
  padding:var(--sec-y) var(--pad-x);
  max-width:1400px;margin:0 auto;
}
.w-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(24px,3vw,48px);
}
@media (max-width:900px){.w-grid{grid-template-columns:1fr}}

.w-note{display:flex;flex-direction:column;gap:18px}
.wn-photo{
  aspect-ratio:5/4;overflow:hidden;border-radius:12px;
  border:1px solid var(--hair);background:var(--bg-lift);
}
.wn-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.9) brightness(.9);
  transition:transform 1.2s var(--ease),filter .4s var(--ease);
}
.w-note:hover .wn-photo img{transform:scale(1.06);filter:saturate(1) brightness(1)}

.w-note blockquote{
  font-family:var(--f-display);
  font-size:clamp(17px,1.4vw,20px);
  font-style:italic;line-height:1.45;letter-spacing:-.005em;
  color:var(--ink);background:var(--bg);
  padding-left:18px;
  border-left:2px solid var(--gold);
}
.w-note figcaption{
  display:flex;flex-direction:column;gap:2px;
  padding-top:12px;
  border-top:1px solid var(--hair);
}
.wn-name{
  font-family:var(--f-body);font-size:14px;font-weight:500;
  color:var(--ink);background:var(--bg);
}
.wn-sub{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  color:var(--gold);background:var(--bg);
}

/* ============ REQUEST ============ */
.request{
  position:relative;
  padding:var(--sec-y) var(--pad-x);
  overflow:hidden;
  border-top:1px solid var(--hair);
}
.req-bg{position:absolute;inset:0;z-index:0}
.req-bg img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.25) saturate(.75) blur(3px);
}
.req-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(11,20,16,.9) 0%,rgba(11,20,16,.6) 50%,rgba(11,20,16,.85) 100%);
}
.req-inner{
  position:relative;z-index:1;
  max-width:1100px;margin:0 auto;
  padding:clamp(28px,4vw,56px);
  background:rgba(19,29,23,.7);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  border:1px solid var(--hair-s);
  border-radius:28px;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}

.req-form{display:flex;flex-direction:column;gap:28px;position:relative}

.rf-steps{
  display:flex;gap:24px;flex-wrap:wrap;
  padding-bottom:20px;border-bottom:1px solid var(--hair);
  margin-bottom:8px;
}
.rfs{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-faint);background:transparent;
}
.rfs i{
  width:30px;height:30px;border-radius:50%;
  border:1px solid var(--hair-s);
  display:inline-flex;align-items:center;justify-content:center;
  font-style:normal;font-size:12px;
  color:var(--ink-faint);background:transparent;
  transition:background .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease);
}
.rfs.is-on{color:var(--gold);background:transparent}
.rfs.is-on i{background:var(--gold);border-color:var(--gold);color:var(--bg)}
.rfs.is-done i{background:rgba(212,162,76,.15);border-color:var(--gold);color:var(--gold)}

.rf-step{display:none;flex-direction:column;gap:22px;animation:none}
.rf-step.is-on{display:flex;animation:stepIn .5s var(--ease-out)}
@keyframes stepIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

.rf-step legend{
  font-family:var(--f-display);
  font-size:clamp(22px,2.6vw,34px);
  font-weight:400;letter-spacing:-.01em;
  color:var(--ink);background:transparent;
}

.rf-opts{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
@media (max-width:720px){.rf-opts{grid-template-columns:1fr 1fr}}
.rf-opts label{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;
  border:1px solid var(--hair-s);
  border-radius:14px;
  font-family:var(--f-body);font-size:14px;
  color:var(--ink);background:transparent;
  cursor:pointer;
  transition:border-color .25s var(--ease),background .25s var(--ease),transform .2s var(--ease);
}
.rf-opts label:hover{border-color:var(--gold);transform:translateY(-2px);background:rgba(212,162,76,.06)}
.rf-opts input{
  appearance:none;width:14px;height:14px;border-radius:50%;
  border:1px solid var(--hair-s);flex:none;
  transition:background .2s,border-color .2s,box-shadow .2s;
}
.rf-opts input:checked{background:var(--gold);border-color:var(--gold);box-shadow:inset 0 0 0 3px var(--bg-lift)}
.rf-opts label:has(input:checked){border-color:var(--gold);background:rgba(212,162,76,.08)}

.rf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:640px){.rf-row{grid-template-columns:1fr}}
.rf-field{display:flex;flex-direction:column;gap:8px}
.rf-field-full{grid-column:1 / -1}
.rf-l{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--gold-soft);background:transparent;
}
.rf-field input,.rf-field select,.rf-field textarea{
  font-family:var(--f-body);font-size:15px;
  color:var(--ink);
  background:rgba(11,20,16,.4);
  border:1px solid var(--hair);
  border-radius:10px;
  padding:12px 14px;
  outline:none;
  width:100%;
  transition:border-color .25s var(--ease),background .25s var(--ease);
}
.rf-field input:focus,.rf-field select:focus,.rf-field textarea:focus{border-color:var(--gold);background:rgba(11,20,16,.65)}
.rf-field textarea{resize:vertical;min-height:84px}
.rf-field select option{background:var(--bg);color:var(--ink)}

.rf-consent{
  display:flex;align-items:flex-start;gap:10px;
  font-family:var(--f-body);font-size:13px;
  color:var(--ink-dim);background:transparent;
  cursor:pointer;line-height:1.5;
}
.rf-consent input{
  appearance:none;width:16px;height:16px;border:1px solid var(--hair-s);border-radius:4px;
  flex:none;margin-top:2px;background:transparent;
  transition:background .2s,border-color .2s;position:relative;
}
.rf-consent input:checked{background:var(--gold);border-color:var(--gold)}
.rf-consent input:checked::after{content:"";position:absolute;left:4px;top:0;width:7px;height:12px;border:solid var(--bg);border-width:0 2px 2px 0;transform:rotate(45deg)}

.rf-foot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.rf-foot .btn-line{margin-right:auto}
.rf-err{font-family:var(--f-mono);font-size:12px;color:var(--terra);background:transparent}

.rf-ok{
  display:flex;flex-direction:column;gap:12px;
  padding:24px 0;
}
.ok-ico{
  width:72px;height:72px;border-radius:50%;
  background:var(--gold);color:var(--bg);
  display:inline-flex;align-items:center;justify-content:center;
  animation:okPop .6s var(--ease-out);
}
@keyframes okPop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.rf-ok h3{
  font-family:var(--f-display);
  font-size:clamp(24px,2.8vw,36px);
  font-weight:400;letter-spacing:-.01em;
  color:var(--ink);background:transparent;
}
.rf-ok h3 em{font-style:italic;color:var(--gold);font-weight:500}
.rf-ok p{font-family:var(--f-body);font-size:15px;color:var(--ink-dim);background:transparent;line-height:1.5}
.rf-ok p span{color:var(--ink);background:transparent;font-weight:500}
.ok-sub{font-size:13px!important;color:var(--ink-faint)!important}

/* ============ CONTACT ============ */
.contact{
  padding:var(--sec-y) var(--pad-x);
  max-width:1400px;margin:0 auto;
}
.con-grid{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:clamp(32px,4vw,72px);
  align-items:start;
}
@media (max-width:860px){.con-grid{grid-template-columns:1fr}}

.con-body{display:flex;flex-direction:column;gap:24px}
.con-body .sec-head{padding:0;max-width:100%}
.con-list{
  display:flex;flex-direction:column;gap:4px;margin-top:4px;
}
.con-list div{
  display:grid;grid-template-columns:120px 1fr;gap:16px;
  padding:14px 0;
  border-bottom:1px solid var(--hair);
}
.con-list dt{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-faint);background:var(--bg);
}
.con-list dd{
  font-family:var(--f-body);font-size:16px;line-height:1.4;
  color:var(--ink);background:var(--bg);
}
.con-list a{color:var(--gold);background:var(--bg)}

.con-map{
  position:relative;
  min-height:clamp(400px,60vh,620px);
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--hair-s);
}
.con-map iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;
  filter:invert(.92) saturate(.6) hue-rotate(180deg) contrast(.95);
}
.map-ping{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:20px;height:20px;
  display:inline-flex;align-items:center;justify-content:center;
  pointer-events:none;z-index:2;
}
.map-ping i{position:absolute;inset:0;border-radius:50%;background:var(--gold);animation:ping 2.4s var(--ease) infinite}
.map-ping i:nth-child(1){width:10px;height:10px;top:5px;left:5px;animation:none;opacity:1;background:var(--gold);box-shadow:0 0 10px var(--gold)}
.map-ping i:nth-child(2){animation-delay:0s}
.map-ping i:nth-child(3){animation-delay:.8s}
@keyframes ping{0%{transform:scale(.5);opacity:.8}100%{transform:scale(2.5);opacity:0}}

/* ============ FOOTER ============ */
.foot{
  background:var(--bg-soft);
  color:var(--ink);
  padding:clamp(56px,6vw,96px) var(--pad-x) clamp(22px,2vw,32px);
  display:flex;flex-direction:column;gap:clamp(48px,6vw,88px);
  border-top:1px solid var(--hair);
}
.foot-top{
  display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:clamp(32px,4vw,64px);
  max-width:1400px;margin:0 auto;width:100%;
}
@media (max-width:760px){.foot-top{grid-template-columns:1fr}}
.fc{display:flex;flex-direction:column;gap:10px}
.fc-l{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--gold);background:var(--bg-soft);margin-bottom:6px;
}
.fc a{
  font-family:var(--f-body);font-size:15px;color:var(--ink-dim);background:var(--bg-soft);
  padding:2px 0;transition:color .25s var(--ease);
}
.fc a:hover{color:var(--gold)}
.fc-sub p{
  font-family:var(--f-body);font-size:14px;color:var(--ink-dim);background:var(--bg-soft);
  line-height:1.5;max-width:42ch;margin-bottom:8px;
}
.fsub{
  position:relative;
  display:flex;align-items:center;
  border-bottom:1px solid var(--hair-s);
  padding:6px 0;
}
.fsub input{
  flex:1;background:var(--bg-soft);border:0;outline:none;
  font-family:var(--f-body);font-size:15px;color:var(--ink);
  padding:10px 0;
}
.fsub input::placeholder{color:var(--ink-faint)}
.fsub button{
  width:40px;height:40px;border-radius:50%;
  background:var(--gold);color:var(--bg);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .25s var(--ease);
}
.fsub button:hover{background:var(--gold-soft)}
.fs-ok{
  position:absolute;left:0;bottom:-20px;
  font-family:var(--f-mono);font-size:12px;color:var(--gold);background:var(--bg-soft);
}

.foot-mark{
  font-family:var(--f-display);
  font-size:clamp(110px,22vw,340px);
  line-height:.9;
  letter-spacing:-.04em;
  text-align:center;color:var(--ink);background:var(--bg-soft);
  font-weight:400;
  overflow:hidden;
  position:relative;
}
.foot-mark span{display:inline-block;background:var(--bg-soft);transition:transform 3s var(--ease)}
.foot-mark:hover span{transform:translateX(-12px)}
.foot-mark i{font-style:italic;color:var(--gold);background:var(--bg-soft)}

.foot-base{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-top:22px;border-top:1px solid var(--hair);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;color:var(--ink-faint);background:var(--bg-soft);
  max-width:1400px;margin:0 auto;width:100%;
}
.foot-base a{color:var(--gold);background:var(--bg-soft)}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;scroll-behavior:auto!important}
  [data-split]>.w,[data-reveal]{opacity:1 !important;transform:none !important}
}
