*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;background:#faf9f6;color:#2d2a24;line-height:1.8;font-size:18px}
:root{
  --cream:#faf9f6;--warm-white:#f7f5f0;
  --bark:#8b6f47;--bark-light:#c9a97a;--bark-dark:#5c4730;
  --moss:#4e6b4a;--moss-light:#a8c4a2;--moss-pale:#eef5ed;
  --soil:#2d2a24;--stone:#6b665e;--fog:#e8e4dc;--fog-mid:#d4cfc5;
  --gold:#c9963a;--gold-pale:#fdf6e8;
  --serif:'Noto Serif JP',serif;--sans:'Noto Sans JP',sans-serif;
}
#root{width:100%}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in   {animation:fadeUp .7s ease both}
.fade-in-d1{animation:fadeUp .7s .12s ease both}
.fade-in-d2{animation:fadeUp .7s .24s ease both}
.fade-in-d3{animation:fadeUp .7s .36s ease both}
.fade-in-d4{animation:fadeUp .7s .48s ease both}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(250,249,246,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--fog);height:60px;display:flex;align-items:center;padding:0 1.5rem;gap:1rem}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;flex:1;min-width:0}
.nav-badge{background:var(--moss);color:white;font-size:10px;font-weight:700;letter-spacing:.08em;padding:.3rem .6rem;border-radius:3px;white-space:nowrap;flex-shrink:0}
.nav-name{font-size:14px;color:var(--soil);font-weight:500;line-height:1.3}
.nav-name small{display:block;font-size:11px;color:var(--stone);font-weight:400}
.nav-cta{background:var(--gold);color:white;border:none;border-radius:4px;padding:.45rem 1.1rem;font-size:12px;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background .2s}
.nav-cta:hover{background:#b5832e}

/* Shared */
section{padding:5.5rem 1.5rem}
.container{max-width:900px;margin:0 auto}
.section-eyebrow{font-size:12px;letter-spacing:.2em;color:var(--bark);text-transform:uppercase;margin-bottom:.9rem;display:flex;align-items:center;gap:.6rem}
.section-eyebrow::before{content:'';width:20px;height:1px;background:var(--bark);display:block}
h2.sh{font-family:var(--serif);font-size:clamp(1.75rem,4vw,2.6rem);font-weight:400;line-height:1.55;color:var(--soil);margin-bottom:1.2rem}
.lead{font-size:17px;color:var(--stone);line-height:2;max-width:640px}

/* HERO */
.hero{min-height:100vh;background:#fff;display:flex;align-items:center;padding:7rem 1.5rem 5rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 20% 80%,rgba(232,220,200,.35) 0%,transparent 70%);pointer-events:none}
.hero-layout{position:relative;z-index:1;display:grid;grid-template-columns:1fr minmax(280px,42%);gap:3rem;align-items:center;width:100%;max-width:1080px;margin:0 auto}
.hero-inner{max-width:580px}
.hero-art{display:flex;align-items:center;justify-content:center}
.hero-art-img{
  width:min(460px,100%);height:min(460px,42vw);
  background-image:url('assets/hero-illustration.jpg');
  background-size:contain;background-repeat:no-repeat;background-position:center;
  mix-blend-mode:multiply;opacity:.92;
  animation:fadeUp 1s .2s ease both;
}
.hero-kicker{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--bark-light);color:var(--bark-dark);font-size:11px;letter-spacing:.12em;padding:.3rem .8rem;border-radius:2px;margin-bottom:1.8rem}
h1.hero-title{font-family:var(--serif);font-size:clamp(2.5rem,6.5vw,4.5rem);font-weight:400;line-height:1.35;color:var(--soil);margin-bottom:.5rem}
.hero-tagline{font-family:var(--serif);font-size:clamp(1.15rem,2.4vw,1.5rem);color:var(--moss);font-weight:400;line-height:1.6;margin-bottom:1.5rem;border-left:3px solid var(--moss-light);padding-left:1rem}
.hero-desc{font-size:17px;color:var(--stone);max-width:520px;line-height:2;margin-bottom:2.5rem}
.hero-price-box{display:inline-flex;align-items:flex-start;flex-wrap:wrap;gap:1.2rem 2rem;background:white;border:1px solid var(--fog);border-radius:8px;padding:1.4rem 1.8rem;margin-bottom:2rem;box-shadow:0 4px 24px rgba(0,0,0,.07)}
.price-label{font-size:13px;letter-spacing:.1em;color:var(--stone);margin-bottom:3px}
.price-original{font-size:14px;color:var(--stone);text-decoration:line-through;margin-bottom:2px}
.price-special{font-family:var(--serif);font-size:2.8rem;font-weight:600;color:var(--gold);line-height:1}
.price-tax{font-size:11px;color:var(--stone);margin-left:3px}
.price-tag{background:var(--gold);color:white;font-size:10px;font-weight:700;letter-spacing:.05em;padding:.25rem .65rem;border-radius:3px}
.price-includes{list-style:none}
.price-includes li{font-size:14px;color:var(--stone);padding:1px 0}
.price-includes li::before{content:'✓ ';color:var(--moss);font-weight:700}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem}
.btn-gold{background:var(--gold);color:white;border:none;border-radius:5px;padding:1.1rem 2rem;font-size:17px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:background .2s,transform .15s;font-family:var(--sans)}
.btn-gold:hover{background:#b5832e;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--soil);border:1.5px solid var(--fog-mid);border-radius:5px;padding:1.1rem 1.7rem;font-size:16px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:border-color .2s;font-family:var(--sans)}
.btn-outline:hover{border-color:var(--bark-light);color:var(--bark-dark)}
@media(max-width:800px){
  .hero-layout{grid-template-columns:1fr}
  .hero-art{order:-1}
  .hero-art-img{width:260px;height:260px;margin:0 auto}
}

/* CONCEPT */
.concept{background:var(--cream)}
.concept-quote{font-family:var(--serif);font-size:clamp(1rem,2.2vw,1.5rem);font-weight:300;color:var(--soil);line-height:1.9;margin-bottom:2rem;padding:2rem 2.5rem;background:white;border:1px solid var(--fog);border-left:4px solid var(--moss);border-radius:0 8px 8px 0;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.concept-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.2rem;margin-top:2.5rem}
.concept-card{background:white;border:1px solid var(--fog);border-radius:8px;padding:1.6rem 1.4rem;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.concept-icon{display:block;width:52px;height:52px;margin-bottom:1.1rem}
.concept-icon svg{width:52px;height:52px}
.concept-card h3{font-size:15px;font-weight:700;color:var(--soil);margin-bottom:.4rem}
.concept-card p{font-size:14px;color:var(--stone);line-height:1.8}

/* FOR WHO */
.forwho{background:#2a271f}
.forwho .section-eyebrow{color:var(--bark-light)}
.forwho .section-eyebrow::before{background:var(--bark-light)}
.forwho h2.sh{color:#f0ece3}
.forwho-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);border-radius:8px;overflow:hidden;margin-top:2.8rem}
.forwho-card{background:rgba(255,255,255,.03);padding:1.8rem 1.5rem;transition:background .2s}
.forwho-card:hover{background:rgba(255,255,255,.07)}
.forwho-num{font-family:var(--serif);font-size:2.2rem;font-weight:300;color:var(--bark-light);opacity:.35;line-height:1;margin-bottom:.7rem}
.forwho-card h3{font-size:16px;font-weight:500;color:#f0ece3;margin-bottom:.4rem;line-height:1.6}
.forwho-card p{font-size:13px;color:rgba(232,228,220,.55);line-height:1.8}

/* METHODS */
.methods{background:var(--warm-white)}
.method-intro{font-size:15px;color:var(--stone);line-height:2;margin-bottom:2.5rem;max-width:680px}
.method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.2rem}
.method-card{background:white;border:1px solid var(--fog);border-radius:10px;padding:2rem 1.6rem;box-shadow:0 2px 12px rgba(0,0,0,.04);position:relative;overflow:hidden}
.method-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.method-card.aw::before{background:linear-gradient(90deg,#5a8f9a,#3d6b7a)}
.method-card.ph::before{background:linear-gradient(90deg,#8b6f47,#c9963a)}
.method-card.heat::before{background:linear-gradient(90deg,#7a4e3a,#b5642e)}
.method-num{font-family:var(--serif);font-size:.85rem;letter-spacing:.15em;color:var(--stone);margin-bottom:.6rem}
.method-card h3{font-size:15px;font-weight:700;color:var(--soil);margin-bottom:.5rem}
.method-tag{display:inline-block;font-size:11px;font-weight:700;padding:.2rem .6rem;border-radius:3px;margin-bottom:.8rem}
.method-card.aw .method-tag{background:#e4f0f2;color:#3d6b7a}
.method-card.ph .method-tag{background:var(--gold-pale);color:var(--bark-dark)}
.method-card.heat .method-tag{background:#faeae4;color:#7a4e3a}
.method-card p{font-size:14px;color:var(--stone);line-height:1.85;margin-bottom:.8rem}
.method-examples{font-size:13px;color:var(--moss);background:var(--moss-pale);padding:.5rem .75rem;border-radius:4px;line-height:1.7}
.method-note{margin-top:1.5rem;padding:1rem 1.25rem;background:white;border:1px solid var(--fog);border-radius:8px;font-size:15px;color:var(--stone);line-height:1.9}

/* SCOPE */
.scope{background:var(--cream)}
.scope-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:2.8rem}
.scope-card{background:white;border:1px solid var(--fog);border-radius:8px;padding:1.5rem 1.3rem;box-shadow:0 1px 8px rgba(0,0,0,.04);transition:transform .2s,box-shadow .2s}
.scope-card:hover{transform:translateY(-2px);box-shadow:0 4px 18px rgba(0,0,0,.08)}
.scope-num{font-family:var(--serif);font-size:.75rem;color:var(--bark-light);letter-spacing:.12em;margin-bottom:.4rem}
.scope-card h3{font-size:15px;font-weight:700;color:var(--soil);margin-bottom:.4rem}
.scope-card p{font-size:13px;color:var(--stone);line-height:1.8}

/* FORMAT */
.format{background:var(--warm-white)}
.format-box{background:white;border:1px solid var(--fog);border-radius:10px;overflow:hidden;margin-top:2.8rem;box-shadow:0 2px 14px rgba(0,0,0,.05)}
.format-row{display:grid;grid-template-columns:150px 1fr;border-bottom:1px solid var(--fog)}
.format-row:last-child{border-bottom:none}
.format-key{background:var(--warm-white);padding:1.1rem 1.3rem;font-size:14px;font-weight:500;color:var(--stone);display:flex;align-items:center;border-right:1px solid var(--fog)}
.format-val{padding:1.1rem 1.3rem;font-size:15px;color:var(--soil);line-height:1.7;display:flex;align-items:center}

/* PRICING */
.pricing{background:var(--warm-white)}
.price-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.2rem;margin-top:2.8rem}
.price-card{background:white;border:1px solid var(--fog);border-radius:10px;padding:2rem 1.8rem;box-shadow:0 2px 12px rgba(0,0,0,.04);position:relative}
.price-card.featured{border:2px solid var(--gold);box-shadow:0 4px 24px rgba(201,150,58,.15)}
.featured-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--gold);color:white;font-size:10px;font-weight:700;padding:.25rem 1rem;border-radius:0 0 6px 6px;white-space:nowrap}
.pc-label{font-size:12px;letter-spacing:.1em;color:var(--stone);margin-bottom:.4rem}
.pc-title{font-size:17px;font-weight:700;color:var(--soil);margin-bottom:.9rem}
.pc-original{font-size:12px;color:var(--stone);text-decoration:line-through;margin-bottom:2px}
.pc-price{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:2px}
.pc-tax{font-size:11px;color:var(--stone)}
.pc-divider{border:none;border-top:1px solid var(--fog);margin:1.2rem 0}
.pc-includes{list-style:none}
.pc-includes li{font-size:15px;color:var(--soil);padding:.4rem 0;display:flex;align-items:flex-start;gap:.55rem;border-bottom:1px solid var(--fog)}
.pc-includes li:last-child{border-bottom:none}
.pc-includes .check{color:var(--moss);font-weight:700;flex-shrink:0}
.pc-btn{display:block;width:100%;margin-top:1.4rem;background:var(--gold);color:white;border:none;border-radius:5px;padding:.9rem;font-size:16px;font-weight:700;cursor:pointer;text-decoration:none;text-align:center;transition:background .2s;font-family:var(--sans)}
.pc-btn:hover{background:#b5832e}
.pc-btn.muted{background:transparent;color:var(--moss);border:1.5px solid var(--moss-light)}
.pc-btn.muted:hover{background:var(--moss-pale)}
.price-note{margin-top:1.5rem;padding:1rem 1.25rem;background:var(--gold-pale);border-radius:6px;font-size:14px;color:var(--bark-dark);line-height:1.9}

/* FLOW */
.flow{background:var(--cream)}
.flow-track{display:grid;grid-template-columns:1fr 28px 1fr 28px 1fr 28px 1fr 28px 1fr;align-items:start;margin-top:3rem}
.flow-card{background:white;border:1px solid var(--fog);border-radius:10px;padding:1.8rem 1.2rem 1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.05);position:relative;transition:box-shadow .2s,transform .2s}
.flow-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.09);transform:translateY(-2px)}
.flow-num{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:28px;height:28px;background:var(--moss);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.85rem;box-shadow:0 2px 8px rgba(78,107,74,.35)}
.flow-card.last .flow-num{background:var(--gold);box-shadow:0 2px 8px rgba(201,150,58,.4)}
.flow-card.last{border-color:var(--gold);box-shadow:0 2px 16px rgba(201,150,58,.12)}
.flow-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--moss-pale);border-radius:8px;margin:.8rem auto .9rem}
.flow-card.last .flow-icon{background:var(--gold-pale)}
.flow-card h3{font-size:14px;font-weight:700;color:var(--soil);text-align:center;line-height:1.5;margin-bottom:.5rem}
.flow-card p{font-size:13px;color:var(--stone);line-height:1.75;text-align:center}
.flow-arrow{display:flex;align-items:center;justify-content:center;padding-top:2.4rem}
@media(max-width:780px){
  .flow-track{grid-template-columns:1fr 1fr;gap:2rem 1rem}
  .flow-arrow{display:none}
}
@media(max-width:400px){.flow-track{grid-template-columns:1fr}}

/* TRUST */
.trust{background:var(--warm-white)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.1rem;margin-top:2.8rem}
.trust-card{background:white;border:1px solid var(--fog);border-radius:8px;padding:1.6rem 1.4rem;box-shadow:0 1px 8px rgba(0,0,0,.04)}
.trust-icon{display:block;width:52px;height:52px;margin-bottom:1rem}.trust-icon svg{width:52px;height:52px}
.trust-card h3{font-size:15px;font-weight:700;color:var(--soil);margin-bottom:.4rem}
.trust-card p{font-size:14px;color:var(--stone);line-height:1.8}

/* FAQ */
.faq{background:var(--cream)}
.faq-list{margin-top:2.5rem;max-width:700px}
.faq-item{border-bottom:1px solid var(--fog)}
.faq-q{display:flex;justify-content:space-between;align-items:flex-start;padding:1.3rem 0;cursor:pointer;gap:1rem}
.faq-q-text{font-size:16px;font-weight:500;color:var(--soil);line-height:1.6}
.faq-toggle{color:var(--bark-light);font-size:22px;flex-shrink:0;line-height:1}
.faq-a{font-size:15px;color:var(--stone);line-height:1.9;padding-bottom:1.3rem}

/* CTA BANNER */
.cta-banner{background:linear-gradient(135deg,#2a271f 0%,#3d3828 100%);padding:5rem 1.5rem;text-align:center}
.cta-banner h2{font-family:var(--serif);font-size:clamp(1.4rem,3.5vw,2rem);font-weight:400;color:#f0ece3;margin-bottom:.7rem;line-height:1.55}
.cta-banner .sub{font-size:16px;color:rgba(232,228,220,.6);margin-bottom:1.8rem}
.price-highlight{font-family:var(--serif);font-size:clamp(2rem,5vw,3rem);color:var(--gold);display:block;margin-bottom:.2rem}
.price-sub{font-size:14px;color:rgba(232,228,220,.5);margin-bottom:2rem;display:block}

/* FOOTER */
footer{background:#1b1a16;color:rgba(232,228,220,.5);padding:3.5rem 1.5rem 2rem}
.footer-inner{max-width:900px;margin:0 auto;display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:space-between}
.footer-org h3{font-family:var(--serif);font-size:1rem;font-weight:400;color:#e8e4dc;margin-bottom:.5rem}
.footer-org p{font-size:13px;line-height:1.9}
.footer-links h4{font-size:13px;color:#e8e4dc;margin-bottom:.75rem;letter-spacing:.05em}
.footer-links ul{list-style:none}
.footer-links li{margin-bottom:.4rem}
.footer-links a{font-size:13px;color:rgba(232,228,220,.5);text-decoration:none}
.footer-links a:hover{color:var(--bark-light)}
.footer-bottom{max-width:900px;margin:2.5rem auto 0;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.07);font-size:10px;color:rgba(232,228,220,.28);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

@media(max-width:600px){
  section{padding:4rem 1.2rem}
  .format-row{grid-template-columns:1fr}
  .format-key{border-right:none;border-bottom:1px solid var(--fog)}
  nav{padding:0 1rem}
}

/* ── PARALLAX PHOTO PANELS ─────────────────────────── */
.parallax-panel {
  height: 72vh;
  min-height: 440px;
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  overflow: hidden;
}
.parallax-panel::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(10,8,4,0.22) 0%,
    rgba(10,8,4,0.52) 50%,
    rgba(10,8,4,0.28) 100%
  );
}
.parallax-caption {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, calc(-50% + 14px));
  z-index: 1;
  text-align: center;
  color: rgba(255,255,255,0.96);
  font-family: var(--serif);
  font-size: clamp(1.6rem, 4vw, 3rem);
  font-weight: 300;
  letter-spacing: 0.18em;
  line-height: 1.7;
  white-space: nowrap;
  text-shadow: 0 2px 32px rgba(0,0,0,0.55);
  opacity: 0;
  pointer-events: none;
}
@keyframes captionFade {
  0%   { opacity: 0; transform: translate(-50%, calc(-50% + 18px)); }
  28%  { opacity: 1; transform: translate(-50%, -50%); }
  62%  { opacity: 1; transform: translate(-50%, -50%); }
  100% { opacity: 0; transform: translate(-50%, calc(-50% - 12px)); }
}
.parallax-caption.in-view {
  animation: captionFade 4.2s cubic-bezier(0.35, 0, 0.25, 1) forwards;
}
@media (max-width: 768px) {
  .parallax-panel {
    background-attachment: scroll;
    height: 56vw;
    min-height: 300px;
  }
  .parallax-caption {
    font-size: clamp(1.15rem, 5vw, 1.8rem);
    white-space: normal;
    width: 88%;
    letter-spacing: 0.1em;
  }
}
