/* ============================================================
   BUHI CAMP PANTS — LET'S PARTY PANTY
   Vertical LP — Persistent Deep Forest × Neon
   ============================================================ */

:root{
  --bg: #050407;
  --bg-warm: #0d0a0c;
  --bg-warmer: #1d1610;
  --bg-deep: #020104;

  --ink: #f1ebde;
  --ink-2: #b9b0a0;
  --ink-3: #7d7367;
  --ink-dim: #58504a;
  --ink-earth: #a08762;
  --line: #2a221d;
  --line-2: #3a302a;

  --neon-pink: #ff2da0;
  --neon-pink-2: #ff5fb8;
  --neon-yellow: #d8ff00;
  --neon-yellow-2: #f0ff4d;

  --font-mincho: "Shippori Mincho B1", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --font-sans: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", system-ui, sans-serif;
  --font-mono: "DM Mono", ui-monospace, monospace;
  --font-en: "Anton", Impact, sans-serif;

  --content: 1180px;
  --content-tight: 880px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg-deep);
  color:var(--ink);
  font-family:var(--font-sans);
  font-weight:400;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt" 1;
  overflow-x:hidden;
  position:relative;
}

a{color:inherit;text-decoration:none}

/* ============================================================
   PERSISTENT FOREST WORLD — real photo background, fixed
   ============================================================ */
.forest-world{
  position:fixed;inset:0;z-index:0;
  overflow:hidden;
  pointer-events:none;
  background:
    /* dark teal cast on top */
    linear-gradient(180deg, rgba(2,3,6,.55) 0%, rgba(2,3,6,.35) 30%, rgba(0,0,0,.7) 100%),
    url("assets/forest-bg.png") center top / cover no-repeat,
    #020104;
}
.fw-sky,.fw-fog-far,.fw-fog-mid,.fw-trees{display:none}
.fw-moon{
  position:absolute;
  width:280px;height:280px;
  top:-40px;left:50%;transform:translateX(-50%);
  border-radius:50%;
  background:radial-gradient(circle at center,
    rgba(230,235,245,.18) 0%,
    rgba(180,195,215,.08) 30%,
    transparent 65%);
  filter:blur(20px);
  pointer-events:none;
}
.fw-fog-near{
  position:absolute;left:0;right:0;bottom:0;height:35%;
  background:linear-gradient(180deg, transparent, rgba(2,3,8,.5) 50%, rgba(0,0,3,.85));
}

/* glow orbs — neon presence in the forest, animated */
.fw-orb{
  position:absolute;
  width:520px;height:520px;
  border-radius:50%;
  filter:blur(110px);
  pointer-events:none;
  opacity:.32;
}
.fw-orb-pink{background:radial-gradient(circle,var(--neon-pink),transparent 60%)}
.fw-orb-yellow{background:radial-gradient(circle,var(--neon-yellow),transparent 60%);opacity:.18}
.fw-orb-1{left:-8%;top:8%;animation:orb1 22s ease-in-out infinite alternate}
.fw-orb-2{right:-5%;top:38%;animation:orb2 28s ease-in-out infinite alternate;width:380px;height:380px}
.fw-orb-3{left:35%;top:62%;animation:orb3 24s ease-in-out infinite alternate;opacity:.22}
.fw-orb-4{right:20%;top:78%;animation:orb4 26s ease-in-out infinite alternate;width:300px;height:300px}
.fw-orb-5{left:-3%;top:90%;animation:orb5 30s ease-in-out infinite alternate;opacity:.28}

@keyframes orb1{to{transform:translate(80px,40px) scale(1.15)}}
@keyframes orb2{to{transform:translate(-60px,80px) scale(1.1)}}
@keyframes orb3{to{transform:translate(40px,-60px) scale(.95)}}
@keyframes orb4{to{transform:translate(-50px,30px) scale(1.2)}}
@keyframes orb5{to{transform:translate(70px,-40px) scale(1.05)}}

.fw-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,.55) 90%);
}

/* global film grain */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:55;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.07 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;opacity:.55;
}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;
  background:linear-gradient(180deg, rgba(2,3,8,.85) 0%, rgba(2,3,8,0) 100%);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.brand{display:flex;align-items:center;gap:10px}
.brand-name{
  font-family:var(--font-en);font-size:22px;
  letter-spacing:.06em;color:var(--ink);
}
.brand-dot{
  color:var(--neon-pink);margin:0 4px;font-size:14px;
  text-shadow:0 0 10px var(--neon-pink);
}
.topnav{display:flex;align-items:center;gap:24px;font-size:13px}
.topnav a{
  color:var(--ink-2);
  transition:color .2s;
}
.topnav a:hover{color:var(--ink)}
.topnav-buy{
  font-family:var(--font-mono);font-size:12px;
  padding:8px 14px;border:1px solid var(--line-2);
  letter-spacing:.1em;
  background:rgba(0,0,0,.4);
  transition:all .2s;
}
.topnav-buy:hover{
  background:var(--neon-pink);color:#000;border-color:var(--neon-pink);
  box-shadow:0 0 18px rgba(255,45,160,.5);
}

/* ============================================================
   SECTIONS — sit on top of the forest world
   ============================================================ */
section{
  position:relative;
  padding:140px 32px;
  max-width:100vw;
  z-index:2;
}
/* per-section veil — translucent so forest shows through */
.section-veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(2,3,6,.55) 0%, rgba(2,3,6,.78) 50%, rgba(2,3,6,.55) 100%);
  z-index:-1;
}
.section-veil.veil-light{
  background:linear-gradient(180deg, rgba(2,3,6,.35) 0%, rgba(20,8,18,.55) 50%, rgba(2,3,6,.35) 100%);
}
.section-veil.veil-deep{
  background:linear-gradient(180deg, rgba(0,0,2,.78) 0%, rgba(0,0,2,.9) 50%, rgba(0,0,2,.78) 100%);
}

.section-head{
  display:flex;align-items:center;gap:14px;
  margin:0 auto 36px;max-width:var(--content);
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.2em;
}
.sec-num{
  color:var(--neon-pink);
  font-family:var(--font-en);font-size:28px;letter-spacing:.02em;
  line-height:1;
  text-shadow:0 0 18px rgba(255,45,160,.5);
}
.sec-tag{color:var(--ink-3)}

.h-mincho{
  font-family:var(--font-mincho);
  font-weight:700;
  font-size:clamp(36px,5.4vw,76px);
  line-height:1.35;
  letter-spacing:.01em;
  max-width:var(--content);
  margin:0 auto;
  text-wrap:pretty;
}
.h-mincho.center{text-align:center}

.sec-lead{
  font-family:var(--font-sans);font-size:14px;color:var(--ink-2);
  max-width:var(--content);margin:18px auto 0;
}

.ink-pink{color:var(--neon-pink)}
.ink-y{color:var(--neon-yellow)}
.ink-earth{color:var(--ink-earth)}
.glow-p{
  text-shadow:
    0 0 16px rgba(255,45,160,.8),
    0 0 40px rgba(255,45,160,.5),
    0 0 90px rgba(255,45,160,.3);
}
.glow-y{
  text-shadow:
    0 0 14px rgba(216,255,0,.7),
    0 0 36px rgba(216,255,0,.45);
}

/* ============================================================
   HERO — LET'S PARTY PANTY (massive type centerpiece)
   ============================================================ */
.hero{
  min-height:100vh;
  padding:130px 32px 100px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
}
.hero-grid{
  position:relative;z-index:3;
  max-width:1400px;margin:0 auto;width:100%;
  display:grid;
  grid-template-rows:auto 1fr auto;
  gap:40px;
  min-height:calc(100vh - 230px);
}
.hero-meta-top{
  display:flex;justify-content:space-between;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.2em;color:var(--ink-3);
}
.hero-tag-l{color:var(--neon-pink);text-shadow:0 0 12px rgba(255,45,160,.5)}

.hero-titlewrap{
  align-self:center;
  text-align:center;
  position:relative;
}
.hero-pre{
  font-family:var(--font-mincho);
  font-size:clamp(15px,1.4vw,20px);
  color:var(--ink-2);
  margin-bottom:28px;
  letter-spacing:.05em;
}
.hero-title{
  font-family:var(--font-en);
  font-weight:400;
  font-size:clamp(72px,14vw,240px);
  line-height:.88;
  letter-spacing:.005em;
  margin-bottom:20px;
}
.ht-line{display:block}
.ht-line-2{margin-top:-.05em}
.ht-line-3{margin-top:-.05em}
.hero-kana{
  font-family:var(--font-mono);font-size:clamp(11px,1vw,14px);
  letter-spacing:.45em;color:var(--ink-3);
  padding-top:18px;
  border-top:1px solid var(--line);
  display:inline-block;margin-top:8px;
}

.hero-meta-bot{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:32px;align-items:center;
}
.hm-colors{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.18em;color:var(--ink-2);
}
.sep-dot{
  display:inline-block;width:3px;height:3px;border-radius:50%;
  background:var(--ink-dim);margin:0 4px;
}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.dot-pink{background:var(--neon-pink);box-shadow:0 0 12px var(--neon-pink)}
.dot-yellow{background:var(--neon-yellow);box-shadow:0 0 12px var(--neon-yellow)}

.hm-ctas{display:flex;gap:12px;align-items:center;justify-content:center}
.btn-primary{
  display:inline-block;
  padding:16px 30px;
  background:var(--neon-pink);color:#0a0507;
  font-family:var(--font-sans);font-weight:700;font-size:14px;
  letter-spacing:.08em;
  box-shadow:0 0 36px rgba(255,45,160,.55),0 12px 30px rgba(0,0,0,.6);
  transition:transform .2s,box-shadow .2s;
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 52px rgba(255,45,160,.75),0 16px 40px rgba(0,0,0,.6);
}
.btn-ghost{
  display:inline-block;
  padding:16px 26px;
  border:1px solid var(--line-2);color:var(--ink);
  font-family:var(--font-mono);font-size:12px;letter-spacing:.15em;
  background:rgba(0,0,0,.4);
  transition:all .2s;
}
.btn-ghost:hover{border-color:var(--neon-yellow);color:var(--neon-yellow)}

.hm-tag{
  text-align:right;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.3em;color:var(--ink-3);line-height:1.7;
}

.hero-photo{
  position:absolute;
  right:-2vw;bottom:0;
  width:clamp(280px,32vw,480px);
  z-index:2;
  pointer-events:none;
  mix-blend-mode:screen;
}
.hero-photo img{
  width:100%;height:auto;display:block;
  filter:contrast(1.05) saturate(1.2)
    drop-shadow(0 0 100px rgba(255,45,160,.5));
  mask:radial-gradient(ellipse 70% 80% at 50% 55%, #000 30%, transparent 95%);
  -webkit-mask:radial-gradient(ellipse 70% 80% at 50% 55%, #000 30%, transparent 95%);
}
.hero-photo-glow{
  position:absolute;inset:-30%;
  background:radial-gradient(circle at 50% 60%,rgba(255,45,160,.45),transparent 60%);
  filter:blur(60px);
  z-index:-1;
  animation:pulse 4s ease-in-out infinite;
}
@keyframes pulse{50%{opacity:.6}}

.scroll-cue{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;
  color:var(--ink-3);z-index:3;
}
.cue-line{
  width:1px;height:40px;
  background:linear-gradient(180deg,var(--neon-pink),transparent);
  animation:cue 2s ease-in-out infinite;
  transform-origin:top;
}
@keyframes cue{
  0%,100%{transform:scaleY(.3);opacity:.5}
  50%{transform:scaleY(1);opacity:1}
}

/* ============================================================
   CONCEPT — どこにいても、お尻が目立つ
   ============================================================ */
.concept{
  text-align:center;
  padding:160px 32px;
}
.concept-inner{max-width:var(--content-tight);margin:0 auto;position:relative;z-index:2}
.concept-pre{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.3em;color:var(--ink-3);
  margin-bottom:30px;
}
.concept-h{
  font-family:var(--font-mincho);font-weight:800;
  font-size:clamp(36px,6vw,84px);
  line-height:1.4;letter-spacing:.005em;
  margin-bottom:48px;
  text-align:center;
}
.concept-body{
  font-family:var(--font-mincho);font-weight:500;
  font-size:clamp(17px,1.6vw,24px);
  line-height:1.95;color:var(--ink);
  margin-bottom:36px;
}
.concept-foot{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.15em;color:var(--ink-dim);
}

/* ============================================================
   STORY 01
   ============================================================ */
.story-grid{
  display:grid;grid-template-columns:1.4fr .6fr;gap:60px;
  max-width:var(--content);margin:0 auto;
  align-items:start;
}
.story-text .h-mincho{margin:0 0 40px}
.story-body{
  font-family:var(--font-mincho);
  font-size:clamp(18px,1.6vw,22px);
  line-height:2;color:var(--ink-2);
  margin-bottom:18px;
}
.story-body.em{color:var(--ink);font-weight:500}
.story-side{
  display:flex;flex-direction:column;align-items:flex-start;gap:20px;
  padding-top:14px;
}
.vline{width:1px;height:90px;background:var(--line-2)}
.vlabel{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;
  color:var(--ink-3);
}
.palette-strip{display:flex;gap:6px}
.palette-strip span{
  width:34px;height:60px;display:block;
  background:var(--c);
  box-shadow:inset 0 0 12px rgba(0,0,0,.3);
}

/* ============================================================
   TURN
   ============================================================ */
.turn{
  text-align:center;
  padding:160px 32px;
}
.turn-aurora{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 60% 40% at 30% 60%, rgba(255,45,160,.28), transparent 60%),
    radial-gradient(ellipse 40% 30% at 75% 30%, rgba(216,255,0,.14), transparent 60%);
  filter:blur(40px);
  pointer-events:none;
}
.turn-inner{position:relative;z-index:2;max-width:var(--content-tight);margin:0 auto}
.turn-pre{
  font-family:var(--font-mincho);
  font-size:clamp(20px,2.2vw,28px);
  color:var(--ink-2);margin-bottom:28px;letter-spacing:.04em;
}
.turn-title{
  font-family:var(--font-mincho);font-weight:800;
  font-size:clamp(48px,8vw,128px);
  line-height:1.1;letter-spacing:.01em;margin-bottom:40px;
}
.turn-body{
  font-family:var(--font-mincho);
  font-size:clamp(16px,1.5vw,22px);
  line-height:2;color:var(--ink-2);margin-bottom:48px;
}
.turn-foot{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.15em;color:var(--ink-dim);
}

/* ============================================================
   PRODUCT
   ============================================================ */
.product{
  text-align:center;
  overflow:hidden;
}
.product-lead{
  font-family:var(--font-mincho);
  font-size:18px;color:var(--ink-2);
  max-width:var(--content-tight);
  margin:24px auto 70px;line-height:2;
}
.product-hero{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  max-width:var(--content);margin:0 auto 60px;
}
.ph-card{
  position:relative;
  aspect-ratio:4/5;
  background:#020104;
  border:1px solid rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.ph-card img{
  position:relative;z-index:2;
  width:100%;height:100%;object-fit:cover;display:block;
  filter:contrast(1.05) saturate(1.1) brightness(.95);
}
.ph-card::after{
  content:"";position:absolute;inset:0;z-index:3;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.55));
  pointer-events:none;
}
.ph-spot{display:none}
.ph-label{
  position:absolute;left:0;right:0;bottom:24px;z-index:5;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  text-align:center;
}
.ph-en{font-family:var(--font-en);font-size:18px;letter-spacing:.15em;color:var(--ink)}
.ph-jp{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--ink-3)}
.product-sig{
  font-family:var(--font-en);
  font-size:clamp(40px,7vw,110px);
  letter-spacing:.04em;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,45,160,.4);
  text-align:center;line-height:1;
}

/* ============================================================
   COLORS
   ============================================================ */
.colors{overflow:hidden}
.colors h2.h-mincho{margin-bottom:8px}
.cs-stage{
  max-width:var(--content);margin:60px auto 0;
  display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;
}
.cs-tabs{display:flex;flex-direction:column;gap:14px}
.cs-tab{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;gap:18px;
  padding:18px 22px;
  background:rgba(0,0,0,.4);
  border:1px solid var(--line);
  color:var(--ink-2);
  font-family:var(--font-en);font-size:20px;letter-spacing:.06em;
  cursor:pointer;text-align:left;
  transition:all .3s;
}
.cs-tab:hover{border-color:var(--ink-3);background:rgba(0,0,0,.55)}
.cs-tab.active{
  border-color:var(--neon-pink);
  background:rgba(255,45,160,.08);
  color:var(--ink);
  box-shadow:inset 0 0 30px rgba(255,45,160,.1);
}
.cs-tab[data-color="yellow"].active{
  border-color:var(--neon-yellow);
  background:rgba(216,255,0,.08);
  box-shadow:inset 0 0 30px rgba(216,255,0,.1);
}
.cs-swatch{width:42px;height:42px;border-radius:6px;flex:0 0 auto}
.sw-pink{background:var(--neon-pink);box-shadow:0 0 22px var(--neon-pink)}
.sw-yellow{background:var(--neon-yellow);box-shadow:0 0 22px var(--neon-yellow)}
.cs-name{font-family:var(--font-en);font-size:22px}
.cs-kana{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;color:var(--ink-3)}

.cs-display{
  position:relative;
  min-height:520px;
  display:flex;align-items:center;justify-content:center;
}
.cs-photo{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .5s;z-index:2;
}
.cs-photo.active{opacity:1}
.cs-photo img{
  max-height:100%;max-width:100%;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.6));
}
.cs-photo[data-color="pink"] img{filter:drop-shadow(0 0 70px rgba(255,45,160,.55)) drop-shadow(0 30px 50px rgba(0,0,0,.5))}
.cs-photo[data-color="yellow"] img{filter:drop-shadow(0 0 70px rgba(216,255,0,.55)) drop-shadow(0 30px 50px rgba(0,0,0,.5))}

.cs-giant{
  position:absolute;
  font-family:var(--font-en);
  font-size:clamp(120px,18vw,260px);
  line-height:.85;letter-spacing:-.02em;
  color:transparent;opacity:0;transition:opacity .5s;
  z-index:1;pointer-events:none;white-space:nowrap;
}
.cs-giant.active{opacity:.45}
.cs-giant-pink{-webkit-text-stroke:1px var(--neon-pink)}
.cs-giant-yellow{-webkit-text-stroke:1px var(--neon-yellow)}

/* ============================================================
   PRINTS
   ============================================================ */
.print-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;
  max-width:var(--content);margin:50px auto 30px;
}
.print-card{display:flex;flex-direction:column;gap:18px}
.print-thumb{
  aspect-ratio:1.6/1;
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.05);
}
.pink-bg{
  background:radial-gradient(ellipse at 50% 60%, var(--neon-pink) 0%, #b00065 70%, #1a000c 100%);
  box-shadow:0 0 60px rgba(255,45,160,.25), inset 0 0 60px rgba(0,0,0,.4);
}
.yellow-bg{
  background:radial-gradient(ellipse at 50% 60%, var(--neon-yellow) 0%, #94b800 70%, #0c0c00 100%);
  box-shadow:0 0 60px rgba(216,255,0,.25), inset 0 0 60px rgba(0,0,0,.4);
}
.print-text{
  font-family:var(--font-en);font-size:clamp(40px,5.5vw,80px);
  color:#0a0507;letter-spacing:.04em;
}
.print-text.jp{font-family:var(--font-mincho);font-weight:800;font-size:clamp(34px,4.5vw,64px)}
.print-meta .print-label{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.2em;color:var(--ink-3);margin-bottom:8px;
}
.print-meta h4{
  font-family:var(--font-mincho);font-weight:700;
  font-size:clamp(18px,2vw,26px);
  margin-bottom:8px;line-height:1.4;
}
.print-meta p{font-size:13px;color:var(--ink-2);line-height:1.8}
.prints-foot{
  text-align:center;font-family:var(--font-mono);
  font-size:11px;letter-spacing:.15em;color:var(--ink-3);
  padding-top:24px;border-top:1px solid var(--line);
  max-width:var(--content);margin:0 auto;
}

/* ============================================================
   FOREST — deepest forest section, no veil interference
   ============================================================ */
.forest{
  padding:200px 32px;overflow:hidden;
  min-height:100vh;display:flex;align-items:center;
}
.forest-extra{position:absolute;inset:0;z-index:0;pointer-events:none}
.forest-glow{
  position:absolute;width:600px;height:600px;border-radius:50%;
  filter:blur(120px);
}
.forest-glow-p{
  background:radial-gradient(circle,var(--neon-pink),transparent 60%);
  right:5%;top:18%;opacity:.5;
  animation:floatp 8s ease-in-out infinite alternate;
}
.forest-glow-y{
  background:radial-gradient(circle,var(--neon-yellow),transparent 60%);
  left:8%;bottom:12%;opacity:.28;
  animation:floaty 10s ease-in-out infinite alternate;
}
@keyframes floatp{to{transform:translate(40px,-30px)}}
@keyframes floaty{to{transform:translate(-30px,20px)}}

.forest-inner{
  position:relative;z-index:2;
  max-width:var(--content);margin:0 auto;text-align:center;
}
.forest-kicker{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.3em;color:var(--ink-3);margin-bottom:32px;
}
.forest-title{
  font-family:var(--font-mincho);font-weight:800;
  font-size:clamp(48px,8vw,128px);
  line-height:1.15;letter-spacing:.005em;margin-bottom:48px;
  text-shadow:0 0 30px rgba(0,0,0,.8);
}
.forest-body{
  font-family:var(--font-mincho);
  font-size:clamp(16px,1.5vw,22px);
  line-height:2;color:var(--ink-2);margin-bottom:40px;
  text-shadow:0 0 20px rgba(0,0,0,.9);
}
.forest-tail{
  font-family:var(--font-mincho);
  font-size:clamp(18px,1.8vw,26px);
  line-height:1.9;color:var(--ink);
  text-shadow:0 0 20px rgba(0,0,0,.9);
}

/* ============================================================
   MODELS
   ============================================================ */
.model-row{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  max-width:var(--content);margin:50px auto 30px;
}
.model-card{display:flex;flex-direction:column;gap:20px}
.model-photo{
  position:relative;
  border:1px solid rgba(255,255,255,.04);
  border-radius:6px;overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,.7);
  background:#020104;
}
.model-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.5));
  pointer-events:none;
}
.model-photo img{
  width:100%;height:auto;display:block;
  filter:contrast(1.05) saturate(1.05) brightness(.95);
}
.model-tape{
  position:absolute;top:16px;left:16px;
  padding:6px 14px;
  font-family:var(--font-en);font-size:14px;letter-spacing:.15em;color:#0a0507;
}
.pink-tape{background:var(--neon-pink);box-shadow:0 0 24px rgba(255,45,160,.6)}
.yellow-tape{background:var(--neon-yellow);box-shadow:0 0 24px rgba(216,255,0,.6)}
.model-label{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.2em;color:var(--ink-3);margin-bottom:12px;
}
.model-quote{
  font-family:var(--font-mincho);font-weight:500;
  font-size:clamp(15px,1.4vw,20px);
  line-height:1.9;color:var(--ink);
}
.models-tail{
  text-align:center;
  font-family:var(--font-mincho);font-style:italic;
  font-size:15px;color:var(--ink-3);
  padding-top:30px;border-top:1px solid var(--line);
  max-width:var(--content);margin:0 auto;
}

/* ============================================================
   SPEC
   ============================================================ */
.spec-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);
  max-width:var(--content);margin:50px auto 0;
  background:rgba(0,0,0,.35);
}
.spec-col{padding:28px;border-right:1px solid var(--line)}
.spec-col:last-child{border-right:none}
.spec-h{
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.25em;color:var(--ink-3);margin-bottom:14px;
}
.spec-v{
  font-family:var(--font-mincho);font-weight:700;
  font-size:clamp(15px,1.4vw,20px);line-height:1.6;
}
.size-block{max-width:var(--content);margin:48px auto 0}
.size-block .spec-h{margin-bottom:18px}
.size-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);background:rgba(0,0,0,.3)}
.size-table th,.size-table td{
  text-align:left;padding:16px 22px;
  border-bottom:1px solid var(--line);
  font-size:13px;letter-spacing:.05em;
}
.size-table th{
  color:var(--ink-3);font-weight:400;text-transform:uppercase;
  font-size:10px;letter-spacing:.2em;border-bottom-color:var(--line-2);
}
.size-table tbody td:first-child{
  font-family:var(--font-en);
  font-size:24px;color:var(--ink);width:100px;
}
/* free size block */
.freesize{
  display:grid;grid-template-columns:auto 1fr;gap:32px;
  align-items:center;
  background:rgba(0,0,0,.35);
  border:1px solid var(--line);
  padding:32px 36px;
}
.fs-mark{
  font-family:var(--font-en);
  font-size:clamp(64px,7vw,108px);
  letter-spacing:.02em;
  color:var(--neon-pink);
  text-shadow:0 0 24px rgba(255,45,160,.55);
  line-height:1;
}
.fs-text{display:flex;flex-direction:column;gap:8px}
.fs-lead{
  font-family:var(--font-mincho);font-weight:700;
  font-size:clamp(18px,1.8vw,24px);
  line-height:1.5;color:var(--ink);
}
.fs-body{
  font-size:13px;color:var(--ink-2);line-height:1.9;
}
.hs-note{
  display:block;margin-top:6px;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.1em;color:var(--ink-3);
}
.spec-foot{
  font-family:var(--font-mono);font-size:11px;
  color:var(--ink-3);text-align:right;
  margin-top:16px;letter-spacing:.1em;
}

/* ============================================================
   HOW
   ============================================================ */
.how-steps{
  list-style:none;
  max-width:var(--content);margin:50px auto 36px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.how-steps li{
  background:rgba(0,0,0,.45);
  border:1px solid var(--line);
  padding:24px;
  display:flex;flex-direction:column;gap:14px;
  position:relative;
}
.hs-highlight{
  border-color:rgba(255,45,160,.4);
  background:rgba(255,45,160,.06);
}
.hs-num{
  font-family:var(--font-en);
  font-size:52px;line-height:1;color:var(--ink-3);
}
.hs-body h5{
  font-family:var(--font-mincho);font-weight:700;
  font-size:18px;line-height:1.4;margin-bottom:8px;
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
}
.hs-body p{font-size:13px;color:var(--ink-2);line-height:1.8}
.recommended{
  display:inline-block;
  font-family:var(--font-mono);font-size:9px;
  letter-spacing:.15em;
  background:var(--neon-pink);color:#000;
  padding:3px 8px;
  box-shadow:0 0 14px rgba(255,45,160,.6);
}
.how-warning{
  max-width:var(--content);margin:0 auto;
  display:grid;grid-template-columns:auto 1fr;gap:24px;
  align-items:center;
  padding:20px 24px;
  border:1px dashed var(--line-2);
  background:rgba(0,0,0,.4);
}
.hw-label{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.2em;color:var(--neon-yellow);
}
.how-warning p:last-child{font-size:12px;color:var(--ink-2);line-height:1.7}

/* ============================================================
   TRUTH
   ============================================================ */
.truth{
  text-align:center;
  padding:200px 32px;overflow:hidden;
}
.truth-glow{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:80vw;height:60vh;
  background:radial-gradient(ellipse,rgba(255,45,160,.22),transparent 65%);
  filter:blur(80px);
  z-index:0;pointer-events:none;
}
.truth-inner{
  position:relative;z-index:2;
  max-width:780px;margin:0 auto;
  display:flex;flex-direction:column;gap:22px;
}
.truth-pre{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.3em;color:var(--neon-pink);
  margin-bottom:24px;
  text-shadow:0 0 12px rgba(255,45,160,.5);
}
.truth-line{
  font-family:var(--font-mincho);font-weight:500;
  font-size:clamp(18px,2vw,28px);
  line-height:1.85;color:var(--ink);
}
.truth-line.big{
  font-size:clamp(26px,3.4vw,46px);
  font-weight:700;line-height:1.5;
}
.truth-line.dim{
  color:var(--ink-3);
  font-size:clamp(14px,1.5vw,20px);
}
.truth-divider{
  height:1px;background:var(--line-2);
  width:60px;margin:24px auto;
}
.truth-sig{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.25em;color:var(--ink-3);margin-top:40px;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:var(--content-tight);margin:50px auto 0}
.faq-item{
  border-top:1px solid var(--line);
  padding:22px 0;
}
.faq-item:last-of-type{border-bottom:1px solid var(--line)}
.faq-item summary{
  cursor:pointer;list-style:none;
  font-family:var(--font-mincho);font-weight:700;
  font-size:clamp(16px,1.5vw,20px);
  display:flex;justify-content:space-between;align-items:center;
  color:var(--ink);transition:color .2s;gap:24px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  font-family:var(--font-mono);font-size:22px;
  color:var(--neon-pink);transition:transform .25s;flex:0 0 auto;
}
.faq-item[open] summary::after{content:"−";transform:rotate(180deg)}
.faq-item summary:hover{color:var(--neon-pink)}
.faq-item p{
  margin-top:14px;font-size:14px;color:var(--ink-2);
  line-height:1.9;max-width:680px;
}

/* ============================================================
   OUTRO
   ============================================================ */
.outro{
  padding:200px 32px;overflow:hidden;
  text-align:center;
}
.outro-glow{
  position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);
  width:70vw;height:60vh;
  background:radial-gradient(ellipse,rgba(255,45,160,.35),transparent 60%);
  filter:blur(90px);
  z-index:0;pointer-events:none;
}
.outro-inner{position:relative;z-index:2;max-width:780px;margin:0 auto}
.outro-pre{
  font-family:var(--font-mono);font-size:12px;
  letter-spacing:.4em;color:var(--neon-pink);
  text-shadow:0 0 12px rgba(255,45,160,.5);margin-bottom:32px;
}
.outro-title{
  font-family:var(--font-mincho);font-weight:800;
  font-size:clamp(48px,7vw,108px);
  line-height:1.15;letter-spacing:.005em;margin-bottom:36px;
  text-shadow:0 0 30px rgba(0,0,0,.7);
}
.outro-sub{
  font-family:var(--font-mincho);
  font-size:clamp(16px,1.5vw,22px);
  line-height:2;color:var(--ink-2);margin-bottom:48px;
}
.outro-cta{
  display:inline-flex;align-items:center;gap:18px;
  padding:24px 40px;
  background:var(--neon-pink);color:#0a0507;
  font-family:var(--font-sans);font-weight:700;font-size:16px;
  letter-spacing:.08em;
  box-shadow:0 0 56px rgba(255,45,160,.8),0 20px 40px rgba(0,0,0,.5);
  transition:transform .2s,box-shadow .2s;
}
.outro-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 0 70px rgba(255,45,160,.95),0 24px 50px rgba(0,0,0,.5);
}
.cta-text{font-family:var(--font-mincho);font-weight:700;font-size:18px}
.cta-arrow{font-family:var(--font-en);font-size:22px}

.outro-socials{
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin-top:40px;
  font-family:var(--font-mono);font-size:13px;color:var(--ink-2);
  letter-spacing:.1em;
}
.outro-socials a{
  border-bottom:1px solid var(--line-2);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.outro-socials a:hover{color:var(--neon-yellow);border-color:var(--neon-yellow)}
.outro-socials .sep{color:var(--ink-dim)}
.outro-tag{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.4em;
  color:var(--ink-3);margin-top:48px;
  padding-top:32px;border-top:1px solid var(--line);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:rgba(2,1,4,.85);
  padding:50px 32px;
  position:relative;z-index:2;
  border-top:1px solid var(--line);
}
.footer-inner{
  max-width:var(--content);margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  text-align:center;
}
.footer-brand{
  font-family:var(--font-en);font-size:22px;
  letter-spacing:.06em;color:var(--ink);margin-bottom:6px;
}
.footer-meta{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;
  color:var(--ink-3);
}
.footer-meta.dim{color:var(--ink-dim);font-size:10px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px){
  section{padding:90px 22px}
  .topbar{padding:14px 20px}
  .topnav{gap:14px;font-size:12px}
  .topnav a:not(.topnav-buy){display:none}
  .hero{padding:110px 22px 90px}
  .hero-meta-top{font-size:9px}
  .hero-meta-bot{grid-template-columns:1fr;text-align:center}
  .hm-tag{text-align:center}
  .hero-photo{
    position:relative;right:auto;bottom:auto;
    width:60%;margin:0 auto;
  }
  .story-grid{grid-template-columns:1fr;gap:32px}
  .product-hero{grid-template-columns:1fr;gap:20px}
  .cs-stage{grid-template-columns:1fr;gap:28px}
  .cs-display{min-height:380px}
  .print-cards{grid-template-columns:1fr;gap:24px}
  .model-row{grid-template-columns:1fr;gap:30px}
  .spec-grid{grid-template-columns:1fr 1fr;border-right:none}
  .spec-col{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .spec-col:nth-child(2n){border-right:none}
  .how-steps{grid-template-columns:1fr 1fr;gap:14px}
  .how-warning{grid-template-columns:1fr;gap:10px}
  .turn{padding:110px 22px}
  .forest{padding:120px 22px}
  .truth{padding:120px 22px}
  .outro{padding:120px 22px}
  .h-mincho{font-size:clamp(30px,8vw,52px)}
}
