/* ============================================================
   SOIE — Premium Hair Care
   Faithful reconstruction of ouraring.com UI language
   (warm editorial wellness-luxe · big rounded cinematic modules
    · scene tabs · press strip) translated for SOIE.
   Real Oura tokens: cream #f7f1e8 · text #4a4741 · Editorial New
   + Akkurat · radius 20/24/40 · pill 100px · tracking -2px.
   ============================================================ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --paper:#f9fbfa; --cream:#edf4f1; --cream-2:#e2ede9; --sand:#d6e4de;
  --ink:#15201d; --ink-2:#21302a; --taupe:#42514c; --taupe-2:#697a73; --mute:#93a39c;
  --gold:#5fa499; --gold-deep:#3a867a; --gold-soft:#a6cfc7;
  --rose:#cfe3dd; --rose-deep:#a6ccc4; --olive:#6f9a86;
  --line:rgba(21,32,29,.12); --line-soft:rgba(21,32,29,.07);

  --serif:"Fraunces","Shippori Mincho B1","Times New Roman",serif;
  --jp-serif:"Shippori Mincho B1","Fraunces",serif;
  --sans:"Inter","Noto Sans JP",system-ui,sans-serif;

  --maxw:1440px; --pad:48px;
  --r-sm:14px; --r:24px; --r-lg:40px; --r-xl:64px;
  --ease:cubic-bezier(.4,0,.2,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --smooth:cubic-bezier(.16,1,.3,1);
}

html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--sans); background:var(--cream); color:var(--ink);
  line-height:1.85; font-size:16px; letter-spacing:.01em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  text-wrap:pretty; overflow-x:hidden;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
::selection { background:var(--gold-soft); color:var(--ink); }

/* grain + progress ------------------------------------------- */
.grain {
  position:fixed; inset:0; z-index:9000; pointer-events:none;
  opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.progress { position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft)); z-index:9500; transition:width .1s linear; }

/* helpers ---------------------------------------------------- */
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.wrap-narrow { max-width:1180px; margin:0 auto; padding:0 var(--pad); }
.section { padding:clamp(80px,11vw,168px) 0; position:relative; }
.eyebrow {
  font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.34em;
  text-transform:uppercase; color:var(--gold-deep); display:inline-flex; align-items:center; gap:14px;
}
.eyebrow::before { content:""; width:30px; height:1px; background:var(--gold); }
.eyebrow.center::after { content:""; width:30px; height:1px; background:var(--gold); }

/* "詳細を見る" text link (Oura) */
.tlink {
  display:inline-flex; align-items:center; gap:10px; margin-top:28px;
  font-size:13px; font-weight:600; letter-spacing:.06em; color:var(--ink);
  padding-bottom:5px; border-bottom:1px solid var(--ink); width:fit-content;
  transition:gap .35s var(--spring), color .3s var(--ease), border-color .3s var(--ease);
}
.tlink .ar { transition:transform .35s var(--spring); }
.tlink:hover { gap:16px; color:var(--gold-deep); border-color:var(--gold-deep); }

/* buttons ---------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; gap:10px; font-family:var(--sans);
  font-size:13px; font-weight:600; letter-spacing:.1em; padding:16px 32px;
  border-radius:100px; cursor:pointer; border:1px solid var(--ink);
  background:var(--ink); color:var(--cream);
  transition:transform .4s var(--spring), background .35s var(--ease), color .35s var(--ease), box-shadow .4s var(--ease);
}
.btn .ar { transition:transform .4s var(--spring); }
.btn:hover { transform:translateY(-3px); box-shadow:0 16px 34px rgba(28,26,23,.2); }
.btn:hover .ar { transform:translateX(4px); }
.btn.ghost { background:transparent; color:var(--ink); }
.btn.ghost:hover { background:var(--ink); color:var(--cream); }
.btn.sm { padding:12px 24px; font-size:12px; }

/* ============================================================ HEADER */
.announce { background:var(--ink); color:var(--cream); font-size:11.5px; letter-spacing:.16em;
  text-transform:uppercase; text-align:center; padding:10px 16px; font-weight:500; position:relative; z-index:1001; }
.announce span { opacity:.85; }

.header { position:sticky; top:0; z-index:1000; background:rgba(246,240,230,0);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease); padding:24px 0; }
.header.solid { background:rgba(246,240,230,.85); backdrop-filter:blur(18px) saturate(1.1);
  -webkit-backdrop-filter:blur(18px) saturate(1.1); box-shadow:0 1px 0 var(--line-soft); padding:15px 0; }
.nav { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand { font-family:var(--serif); font-weight:400; font-size:27px; letter-spacing:.42em; padding-left:.42em;
  color:var(--ink); line-height:1; transition:font-size .5s var(--ease); }
.header.solid .brand { font-size:23px; }
.nav-links { display:flex; gap:36px; align-items:center; }
.nav-links a { font-size:12.5px; letter-spacing:.1em; color:var(--taupe); font-weight:500; position:relative; padding:4px 0; transition:color .3s var(--ease); }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-1px; width:0; height:1px; background:var(--gold-deep); transition:width .35s var(--ease); }
.nav-links a:hover { color:var(--ink); }
.nav-links a:hover::after { width:100%; }

.burger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; }
.burger span { width:24px; height:1.5px; background:var(--ink); transition:.3s var(--ease); }
.drawer { position:fixed; inset:0; z-index:1200; background:var(--cream); display:flex; flex-direction:column;
  justify-content:center; align-items:center; gap:6px; opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s var(--ease); }
.drawer.open { opacity:1; visibility:visible; }
.drawer a { font-family:var(--serif); font-size:30px; font-weight:300; color:var(--ink); padding:12px; }
.drawer .close { position:absolute; top:24px; right:28px; font-size:30px; cursor:pointer; font-family:var(--serif); }

/* ============================================================ HERO (full-bleed cinematic) */
.hero { position:relative; height:100vh; height:100svh; min-height:640px; display:flex; align-items:flex-end; overflow:hidden; }
.hero-bg { position:absolute; inset:0; z-index:0; background-color:var(--sand);
  background-image:
    linear-gradient(165deg, rgba(225,238,232,.14), rgba(168,200,190,.28)),
    url("images/hero.jpg");
  background-size:cover; background-position:center; background-repeat:no-repeat; transform:scale(1.06); will-change:transform; }
.hero-bg::after { content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(28,26,23,.20) 0%, transparent 24%, transparent 44%, rgba(28,26,23,.62) 100%); }
.hero-inner { position:relative; z-index:2; width:100%; padding-bottom:clamp(56px,8vw,104px); }
.hero-eyebrow { color:#fff; opacity:.92; margin-bottom:26px; }
.hero-eyebrow::before { background:rgba(255,255,255,.7); }
.hero h1 { font-family:var(--serif); font-weight:300; color:#fff; font-size:clamp(52px,10vw,168px);
  line-height:.94; letter-spacing:-.025em; text-shadow:0 2px 50px rgba(28,26,23,.28); }
.hero h1 .it { font-style:italic; }
.hero .hero-sub { margin-top:30px; max-width:460px; color:rgba(255,255,255,.92); font-size:clamp(15px,1.5vw,17px);
  line-height:1.95; text-shadow:0 1px 14px rgba(28,26,23,.3); }
.hero-cta { margin-top:36px; display:flex; gap:28px; align-items:center; flex-wrap:wrap; }
.hero .btn { background:var(--cream); color:var(--ink); border-color:var(--cream); }
.hero .btn:hover { background:#fff; }
.hero .tlink { margin-top:0; color:#fff; border-color:rgba(255,255,255,.6); }
.hero .tlink:hover { color:#fff; border-color:#fff; }
.scroll-hint { position:absolute; bottom:30px; right:var(--pad); z-index:3; writing-mode:vertical-rl;
  font-size:10.5px; letter-spacing:.3em; text-transform:uppercase; color:rgba(255,255,255,.8); display:flex; align-items:center; gap:14px; }
.scroll-hint::after { content:""; width:1px; height:54px; background:rgba(255,255,255,.6); animation:scrollLine 2.2s var(--ease) infinite; transform-origin:top; }
@keyframes scrollLine { 0%{transform:scaleY(0);} 40%{transform:scaleY(1);} 100%{transform:scaleY(0); transform-origin:bottom;} }

/* ============================================================ INTRO */
.intro { background:var(--paper); }
.intro .wrap { display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(48px,7vw,120px); align-items:center; }
.intro-quote { font-family:var(--serif); font-weight:300; font-size:clamp(30px,4.2vw,56px); line-height:1.28; letter-spacing:-.018em; text-wrap:balance; }
.intro-quote em { font-style:italic; color:var(--gold-deep); }
.intro-body p { color:var(--taupe); font-size:16px; line-height:2.05; }
.intro-body p + p { margin-top:22px; }
.intro-sign { margin-top:30px; font-family:var(--serif); font-style:italic; font-size:21px; color:var(--ink); }

/* ============================================================ SECTION HEAD */
.shead { max-width:820px; margin:0 auto clamp(54px,6vw,90px); text-align:center; }
.shead.left { margin-left:0; text-align:left; }
.shead .eyebrow { margin-bottom:24px; }
.shead h2 { font-family:var(--serif); font-weight:300; font-size:clamp(32px,5vw,72px); line-height:1.06; letter-spacing:-.025em; text-wrap:balance; }
.shead h2 em { font-style:italic; color:var(--gold-deep); }
.shead p { margin-top:24px; color:var(--taupe); font-size:16.5px; line-height:2; }

/* ============================================================ CINEMATIC MODULE STACK (Oura core) */
.collection { background:var(--cream); }
.cmod { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,100px); align-items:center; }
.cmod + .cmod { margin-top:clamp(72px,9vw,150px); }
.cmod.rev .cmod-text { order:2; }
.cmod-media { position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:5/4; background:var(--sand);
  box-shadow:0 30px 70px rgba(28,26,23,.14); }
.cmod-media .ph { position:absolute; inset:0; background-size:cover; background-position:center; will-change:transform; transition:transform 1.2s var(--smooth); }
.cmod:hover .cmod-media .ph { transform:scale(1.05); }
.cmod-badge { position:absolute; top:22px; left:22px; z-index:2; font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:600; background:rgba(250,246,238,.92); color:var(--gold-deep); padding:8px 16px; border-radius:100px; }
.cmod-num { font-family:var(--serif); font-style:italic; font-size:18px; color:var(--gold-deep); }
.cmod-text h3 { font-family:var(--serif); font-weight:300; font-size:clamp(30px,4.2vw,60px); line-height:1.08;
  letter-spacing:-.02em; margin-top:14px; text-wrap:balance; }
.cmod-text .jp { font-size:13px; letter-spacing:.16em; color:var(--mute); margin-top:10px; font-weight:500; }
.cmod-text p { margin-top:24px; color:var(--taupe); font-size:16px; line-height:2; max-width:480px; }
.cmod-scent { margin-top:22px; display:inline-flex; gap:10px; align-items:baseline; font-size:13.5px; color:var(--taupe-2);
  border:1px solid var(--line); border-radius:100px; padding:9px 18px; }
.cmod-scent b { color:var(--ink); font-weight:600; }

/* price band */
.priceband { margin-top:clamp(72px,9vw,140px); }
.price-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.price-cell { background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--r); padding:34px 26px; text-align:center;
  transition:transform .5s var(--smooth), box-shadow .5s var(--smooth); }
.price-cell:hover { transform:translateY(-8px); box-shadow:0 24px 50px rgba(28,26,23,.1); }
.price-cell .pn { font-size:13px; color:var(--taupe-2); letter-spacing:.04em; }
.price-cell .pv { font-family:var(--serif); font-size:34px; margin-top:10px; font-weight:400; }
.price-cell .pv small { font-size:15px; color:var(--mute); }
.price-cell .pu { font-size:11.5px; color:var(--mute); margin-top:6px; letter-spacing:.06em; }
.price-foot { text-align:center; margin-top:22px; font-size:12.5px; color:var(--mute); letter-spacing:.04em; }

/* ============================================================ FORMULA (design module, Oura "デザインと機能性") */
.formula { background:var(--paper); }
.formula .cmod-media { aspect-ratio:4/5; }
.formula h2 { font-family:var(--serif); font-weight:300; font-size:clamp(30px,4.2vw,56px); line-height:1.1; letter-spacing:-.022em; text-wrap:balance; }
.formula h2 em { font-style:italic; color:var(--gold-deep); }
.formula .lead { margin-top:24px; color:var(--taupe); font-size:16.5px; line-height:2; max-width:520px; }
.feat-list { margin-top:38px; }
.feat { display:grid; grid-template-columns:46px 1fr; gap:20px; align-items:start; padding:24px 0; border-top:1px solid var(--line); }
.feat:last-child { border-bottom:1px solid var(--line); }
.feat .fn { font-family:var(--serif); font-style:italic; font-size:20px; color:var(--gold-deep); }
.feat h4 { font-size:16px; font-weight:600; }
.feat p { margin-top:6px; font-size:14px; color:var(--taupe-2); line-height:1.8; }
.free-from { margin-top:34px; display:flex; flex-wrap:wrap; gap:10px; }
.chip { font-size:12px; letter-spacing:.04em; color:var(--taupe); border:1px solid var(--line); border-radius:100px; padding:9px 17px; background:var(--cream); }
.chip b { color:var(--gold-deep); font-weight:700; }

/* ============================================================ FRAGRANCE (dark) */
.fragrance { background:var(--ink); color:var(--cream); }
.fragrance .eyebrow { color:var(--gold-soft); }
.fragrance .eyebrow::before, .fragrance .eyebrow.center::after { background:var(--gold-soft); }
.fragrance .shead h2 { color:var(--cream); } .fragrance .shead h2 em { color:var(--gold-soft); }
.fragrance .shead p { color:rgba(246,240,230,.7); }
.frag-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.frag { padding:48px 38px; border:1px solid rgba(246,240,230,.16); border-radius:var(--r); transition:background .5s var(--ease), transform .5s var(--smooth); }
.frag:hover { background:rgba(246,240,230,.04); transform:translateY(-6px); }
.frag .num { font-family:var(--serif); font-style:italic; font-size:16px; color:var(--gold-soft); }
.frag h3 { font-family:var(--serif); font-weight:300; font-size:30px; margin-top:14px; }
.frag .frag-en { font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); margin-top:8px; }
.frag p { margin-top:18px; color:rgba(246,240,230,.72); font-size:14.5px; line-height:1.95; }

/* ============================================================ SCENE TABS (Oura lifestyle showcase) */
.method { background:var(--cream-2); }
.scene { display:grid; grid-template-columns:1fr; gap:0; }
.scene-stage { position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:16/8; background:var(--sand);
  box-shadow:0 40px 90px rgba(28,26,23,.16); }
.scene-panel { position:absolute; inset:0; opacity:0; visibility:hidden; transition:opacity .8s var(--ease), visibility .8s var(--ease); }
.scene-panel.active { opacity:1; visibility:visible; }
.scene-panel .ph { position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.04); }
.scene-panel::after { content:""; position:absolute; inset:0; background:linear-gradient(110deg, rgba(28,26,23,.55) 0%, rgba(28,26,23,.15) 45%, transparent 70%); }
.scene-cap { position:absolute; left:clamp(28px,4vw,60px); bottom:clamp(28px,4vw,56px); z-index:2; color:#fff; max-width:460px; }
.scene-cap .sn { font-family:var(--serif); font-style:italic; font-size:18px; color:var(--gold-soft); }
.scene-cap h4 { font-family:var(--serif); font-weight:300; font-size:clamp(28px,3.6vw,46px); line-height:1.1; margin-top:6px; }
.scene-cap .se { font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.8); margin-top:10px; }
.scene-cap p { margin-top:14px; font-size:14.5px; line-height:1.85; color:rgba(255,255,255,.9); }
.scene-tabs { display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:14px; border-top:1px solid var(--line); }
.scene-tab { text-align:left; background:none; border:none; cursor:pointer; padding:24px 18px; position:relative;
  font-family:var(--sans); color:var(--taupe-2); transition:color .3s var(--ease); }
.scene-tab::before { content:""; position:absolute; top:-1px; left:0; height:2px; width:0; background:var(--gold-deep); transition:width .5s var(--ease); }
.scene-tab.active::before { width:100%; }
.scene-tab.active { color:var(--ink); }
.scene-tab .tn { font-family:var(--serif); font-style:italic; font-size:15px; color:var(--gold-deep); }
.scene-tab .tt { display:block; font-size:18px; font-weight:600; margin-top:6px; letter-spacing:.04em; font-family:var(--serif); }
.method-tag { text-align:center; margin-top:60px; font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(22px,3vw,36px); color:var(--ink); }

/* ============================================================ PRESS / VOICES (Oura "メディア掲載") */
.voices { background:var(--paper); }
.voices .shead { margin-bottom:clamp(40px,5vw,64px); }
.voice-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.voice { background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--r); padding:40px 34px; }
.voice .stars { color:var(--gold-deep); font-size:13px; letter-spacing:.3em; }
.voice blockquote { font-family:var(--serif); font-weight:300; font-size:21px; line-height:1.6; margin-top:18px; letter-spacing:-.005em; }
.voice .who { margin-top:22px; font-size:12.5px; letter-spacing:.06em; color:var(--mute); }
.voice .who b { color:var(--ink); font-weight:600; }
.logos { margin-top:clamp(48px,6vw,80px); display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:18px 44px; }
.logos span { font-family:var(--serif); font-style:italic; font-size:20px; color:var(--taupe-2); opacity:.7; }

/* ============================================================ SALON */
.salon { background:var(--ink); color:var(--cream); }
.salon .eyebrow { color:var(--gold-soft); } .salon .eyebrow::before, .salon .eyebrow.center::after { background:var(--gold-soft); }
.salon .shead h2 { color:var(--cream); } .salon .shead h2 em { color:var(--gold-soft); }
.salon .shead p { color:rgba(246,240,230,.7); }
.val-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.val { padding:44px 34px; border:1px solid rgba(246,240,230,.16); border-radius:var(--r); transition:transform .5s var(--smooth), background .5s var(--ease); }
.val:hover { transform:translateY(-8px); background:rgba(246,240,230,.04); }
.val .vn { font-family:var(--serif); font-style:italic; font-size:18px; color:var(--gold-soft); }
.val h4 { font-size:18px; font-weight:600; margin-top:14px; line-height:1.5; }
.val p { margin-top:14px; color:rgba(246,240,230,.7); font-size:14px; line-height:1.9; }
.salon-pull { text-align:center; margin-top:64px; }
.salon-pull p { font-family:var(--serif); font-weight:300; font-size:clamp(26px,3.6vw,46px); line-height:1.4; color:var(--cream); }
.salon-pull em { font-style:italic; color:var(--gold-soft); }

/* ============================================================ GIFT */
.gift { background:var(--rose); color:var(--ink); }
.gift .cmod-media { aspect-ratio:4/5; }
.gift h2 { font-family:var(--serif); font-weight:300; font-size:clamp(30px,4.2vw,56px); line-height:1.1; letter-spacing:-.022em; text-wrap:balance; }
.gift .lead { margin-top:24px; color:var(--ink-2); font-size:16.5px; line-height:2; max-width:480px; }
.gift-list { margin-top:30px; display:grid; grid-template-columns:1fr 1fr; gap:0 30px; }
.gift-list li { list-style:none; display:flex; gap:12px; align-items:baseline; font-size:14.5px; color:var(--ink-2);
  padding:14px 0; border-bottom:1px solid rgba(28,26,23,.16); }
.gift-list li::before { content:"—"; color:var(--gold-deep); }

/* ============================================================ BRAND STORY */
.brandstory { background:var(--paper); text-align:center; }
.brandstory .shead { margin-bottom:clamp(36px,4vw,52px); }
.bs-body { max-width:760px; margin:0 auto; }
.bs-body p { color:var(--taupe); font-size:16.5px; line-height:2.1; }
.bs-body p + p { margin-top:24px; }
.bs-body p:first-child { font-family:var(--serif); font-weight:300; font-style:italic; font-size:clamp(22px,3vw,32px); color:var(--ink); line-height:1.55; letter-spacing:-.01em; }

/* ============================================================ STORY / FOUNDER */
.story { background:var(--cream); }
.founder { display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,6vw,100px); align-items:center; }
.founder-img { aspect-ratio:4/5; border-radius:var(--r-lg); overflow:hidden; background:var(--sand); position:relative; box-shadow:0 30px 70px rgba(28,26,23,.14); }
.founder-img .ph { position:absolute; inset:0; background-size:cover; background-position:center; }
.founder .eyebrow { margin-bottom:24px; }
.founder blockquote { font-family:var(--serif); font-weight:300; font-size:clamp(28px,3.6vw,48px); line-height:1.32; letter-spacing:-.018em; text-wrap:balance; }
.founder blockquote em { font-style:italic; color:var(--gold-deep); }
.founder .fp { margin-top:26px; color:var(--taupe); font-size:15px; line-height:2; }
.founder .fp + .fp { margin-top:18px; }
.founder .sign { margin-top:30px; display:flex; align-items:baseline; gap:14px; }
.founder .sign .role { font-size:12px; letter-spacing:.14em; color:var(--mute); text-transform:uppercase; }
.founder .sign .name { font-family:var(--serif); font-style:italic; font-size:26px; }

/* ============================================================ FUTURE (full-bleed cinematic CTA) */
.future { position:relative; overflow:hidden; color:#fff; text-align:center; padding:clamp(120px,16vw,220px) 0; }
.future-bg { position:absolute; inset:0; z-index:0; background-color:var(--ink);
  background-image:radial-gradient(120% 90% at 50% 0%, rgba(95,164,153,.34), transparent 60%), linear-gradient(180deg,#1d2a26,#101814); }
.future .wrap { position:relative; z-index:2; }
.future .eyebrow { color:var(--gold-soft); justify-content:center; } .future .eyebrow::before, .future .eyebrow.center::after { background:var(--gold-soft); }
.future h2 { font-family:var(--serif); font-weight:300; font-size:clamp(36px,6.5vw,104px); line-height:1.02; letter-spacing:-.03em; text-wrap:balance; }
.future h2 em { font-style:italic; color:var(--gold-soft); }
.future p { max-width:640px; margin:30px auto 0; color:rgba(246,240,230,.75); font-size:16px; line-height:2; }
.future .btn { margin-top:44px; background:var(--cream); color:var(--ink); border-color:var(--cream); }

/* ============================================================ COMPANY */
.company { background:var(--paper); }
.company .wrap { display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(40px,6vw,100px); }
.ctable { width:100%; border-collapse:collapse; }
.ctable tr { border-bottom:1px solid var(--line); }
.ctable th { text-align:left; vertical-align:top; padding:20px 0; width:210px; font-size:12px; letter-spacing:.14em; color:var(--mute); font-weight:600; text-transform:uppercase; }
.ctable td { padding:20px 0; font-size:14.5px; color:var(--ink-2); line-height:1.8; }
.ctable td a { border-bottom:1px solid var(--gold); }

/* ============================================================ FOOTER */
.footer { background:var(--ink); color:var(--cream); padding:96px 0 40px; }
.footer-pay { display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap;
  padding-bottom:40px; margin-bottom:56px; border-bottom:1px solid rgba(246,240,230,.14); }
.footer-pay .pl { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); }
.footer-pay .pm { display:flex; gap:10px; flex-wrap:wrap; }
.footer-pay .pm span { font-size:11px; letter-spacing:.08em; color:rgba(246,240,230,.7); border:1px solid rgba(246,240,230,.2); border-radius:6px; padding:7px 12px; }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; padding-bottom:60px; border-bottom:1px solid rgba(246,240,230,.14); }
.footer-brand .b { font-family:var(--serif); font-size:34px; letter-spacing:.4em; padding-left:.4em; }
.footer-brand .legal { margin-top:12px; font-size:13px; letter-spacing:.14em; color:var(--gold-soft); font-weight:500; }
.footer-brand p { margin-top:18px; color:rgba(246,240,230,.6); font-size:13.5px; max-width:300px; line-height:1.9; }
.fcol h5 { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:20px; }
.fcol a { display:block; color:rgba(246,240,230,.78); font-size:13.5px; padding:7px 0; transition:color .3s var(--ease); }
.fcol a:hover { color:var(--cream); }
.footer-bot { display:flex; justify-content:space-between; align-items:center; padding-top:30px; gap:20px; flex-wrap:wrap; }
.footer-bot small { color:rgba(246,240,230,.5); font-size:12px; letter-spacing:.05em; }

/* ============================================================ REVEAL */
.reveal { opacity:0; transform:translateY(34px); transition:opacity 1s var(--smooth), transform 1.1s var(--smooth); }
.reveal.in { opacity:1; transform:none; }
.reveal.d1 { transition-delay:.08s; } .reveal.d2 { transition-delay:.16s; }
.reveal.d3 { transition-delay:.24s; } .reveal.d4 { transition-delay:.32s; }

/* opening sequence */
body:not(.loaded) .header, body:not(.loaded) .hero-inner { opacity:0; }
.header { transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease), opacity .9s var(--ease) .2s; }
.hero-inner { transition:opacity 1.2s var(--ease) .35s, transform 1.3s var(--smooth) .35s; transform:translateY(24px); }
body.loaded .hero-inner { opacity:1; transform:none; }
body.loaded .header { opacity:1; }
.hero-bg { opacity:0; transform:scale(1.12); transition:opacity 1.6s var(--ease), transform 2.4s var(--smooth); }
body.loaded .hero-bg { opacity:1; transform:scale(1.06); }

/* ============================================================ RESPONSIVE */
@media (max-width:1024px){
  :root{ --pad:32px; }
  .intro .wrap, .cmod, .cmod.rev .cmod-text, .formula .cmod, .gift .cmod, .founder, .company .wrap { grid-template-columns:1fr; }
  .cmod.rev .cmod-text { order:0; }
  .frag-grid, .voice-grid, .val-grid { grid-template-columns:1fr 1fr; }
  .price-grid { grid-template-columns:1fr 1fr; }
  .scene-stage { aspect-ratio:16/9; }
  .ctable th { width:160px; }
}
@media (max-width:680px){
  :root{ --pad:22px; --r-lg:28px; --r:18px; }
  .nav-links { display:none; }
  .header .btn.sm { display:none; }
  .burger { display:flex; }
  .frag-grid, .voice-grid, .val-grid, .price-grid, .gift-list { grid-template-columns:1fr; }
  .scene-tabs { grid-template-columns:1fr 1fr; }
  .scene-tab { padding:18px 14px; }
  .scene-stage { aspect-ratio:16/9; }
  .scene-cap { left:18px; bottom:18px; max-width:84%; }
  .scene-cap h4 { font-size:24px; }
  .scene-cap .se { margin-top:4px; }
  .scene-cap p { font-size:12.5px; margin-top:8px; line-height:1.7; }
  .hero h1 { font-size:clamp(40px,12vw,52px); line-height:1.05; }
  .hero .hero-sub { max-width:100%; }
  .hero-bg { background-image:
      linear-gradient(170deg, rgba(225,238,232,.12), rgba(168,200,190,.3)), url("images/hero-mobile.jpg"); transform:none; }
  body.loaded .hero-bg { transform:none; }
  .scroll-hint { display:none; }
  .ctable th { width:118px; font-size:11px; padding:16px 0; }
  .ctable td { font-size:13.5px; padding:16px 0; }
  .footer-top { grid-template-columns:1fr 1fr; gap:30px 20px; }
  .footer-pay { flex-direction:column; align-items:flex-start; }
  .section { padding:74px 0; }
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .reveal { opacity:1; transform:none; }
  .hero-bg { transform:none!important; }
}
