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

:root{
  --cream:    #FAF7F2;
  --cream-d:  #F2EDE4;
  --forest:   #2A5C45;
  --forest-l: #3A7A5E;
  --sage:     #86BDA4;
  --sage-l:   #C6DFD5;
  --amber:    #E8834A;
  --ink:      #1E2E27;
  --mid:      #5A6E65;
  --border:   rgba(42,92,69,0.12);
  --white:    #FFFFFF;
  --f-disp: 'Zen Maru Gothic','Noto Sans JP',sans-serif;
  --f-body: 'Noto Sans JP','Zen Maru Gothic',sans-serif;
  --r-sm:  10px;
  --r-md:  18px;
  --r-lg:  28px;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  background:var(--cream);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.7;
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(250,247,242,0.92);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  height:60px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;
}
.nav-logo{
  font-family:var(--f-disp);
  font-size:17px;font-weight:700;color:var(--forest);
  display:flex;align-items:center;gap:8px;
  text-decoration:none;
}
.nav-logo-mark{
  width:32px;height:32px;border-radius:8px;
  background:transparent;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  padding:2px;
}
.nav-logo-img{width:100%;height:100%;object-fit:contain;}
.nav-cta{
  background:var(--amber);color:var(--white);
  font-family:var(--f-disp);
  font-size:13px;font-weight:700;
  padding:9px 20px;border-radius:980px;
  text-decoration:none;
  box-shadow:0 2px 12px rgba(232,131,74,0.32);
  transition:background 0.18s,transform 0.15s,box-shadow 0.15s;
}
.nav-cta:hover{background:#d9703a;transform:translateY(-1px);box-shadow:0 5px 18px rgba(232,131,74,0.38)}

/* HERO */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:110px 24px 80px;
  background:var(--cream);
  position:relative;overflow:hidden;
}
.ring{
  position:absolute;border-radius:50%;
  border:1px solid var(--sage-l);
  pointer-events:none;z-index:0;
  animation:ringPulse 8s ease-in-out infinite;
}
.ring-1{width:480px;height:480px;top:50%;left:50%;transform:translate(-50%,-50%)}
.ring-2{width:680px;height:680px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:2s}
.ring-3{width:900px;height:900px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:4s}
@keyframes ringPulse{
  0%,100%{opacity:0.6;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:0.3;transform:translate(-50%,-50%) scale(1.03)}
}
.hero-inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.hero-kicker{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--sage-l);color:var(--forest);
  font-family:var(--f-disp);
  font-size:13px;font-weight:700;
  padding:6px 16px;border-radius:980px;
  margin-bottom:28px;
  opacity:0;animation:fadeUp .7s .1s cubic-bezier(.22,1,.36,1) forwards;
}
.kicker-dot{width:6px;height:6px;border-radius:50%;background:var(--forest)}
.hero-logo-wrap{
  width:72px;height:72px;margin:0 auto 20px;
  opacity:0;animation:fadeUp .7s 0s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-logo-img{width:100%;height:100%;object-fit:contain;}
.hero-title{
  font-family:var(--f-disp);
  font-size:clamp(32px,5.2vw,54px);
  font-weight:700;line-height:1.3;
  color:var(--ink);margin-bottom:24px;
  opacity:0;animation:fadeUp .7s .2s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-title .hl{
  background:linear-gradient(0deg,rgba(134,189,164,.35) 0%,rgba(134,189,164,.35) 100%);
  border-radius:4px;padding:0 4px;
}
.hero-body{
  font-size:17px;font-weight:400;line-height:1.85;
  color:var(--mid);max-width:560px;margin:0 auto 20px;
  opacity:0;animation:fadeUp .7s .3s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-honest{
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--r-md);
  padding:14px 20px;
  font-size:14px;color:var(--mid);line-height:1.7;
  display:inline-block;max-width:520px;margin:0 auto 36px;
  opacity:0;animation:fadeUp .7s .38s cubic-bezier(.22,1,.36,1) forwards;
  box-shadow:0 2px 12px rgba(42,92,69,0.07);
}
.hero-honest strong{color:var(--forest);font-weight:700}
.hero-ctas{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:20px;
  opacity:0;animation:fadeUp .7s .45s cubic-bezier(.22,1,.36,1) forwards;
}
.btn-primary{
  background:var(--amber);color:var(--white);
  font-family:var(--f-disp);
  font-size:16px;font-weight:700;
  padding:14px 32px;border-radius:980px;
  text-decoration:none;display:inline-block;
  box-shadow:0 4px 18px rgba(232,131,74,0.35);
  transition:background .18s,transform .15s,box-shadow .15s;
}
.btn-primary:hover{background:#d9703a;transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,131,74,0.42)}
.btn-secondary{
  background:var(--white);color:var(--forest);
  font-family:var(--f-disp);
  font-size:15px;font-weight:700;
  padding:13px 26px;border-radius:980px;
  border:2px solid var(--sage);
  text-decoration:none;display:inline-block;
  transition:border-color .18s,background .18s;
}
.btn-secondary:hover{border-color:var(--forest);background:rgba(42,92,69,0.04)}
.hero-meta{
  font-size:13px;color:var(--sage);
  display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;
  opacity:0;animation:fadeUp .7s .52s ease forwards;
}
.meta-sep{opacity:0.4}
.hero-chips{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:48px;
  opacity:0;animation:fadeUp .7s .6s ease forwards;
}
.chip{
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--r-md);
  padding:12px 18px;
  font-family:var(--f-disp);
  font-size:13px;font-weight:700;color:var(--ink);
  display:flex;align-items:center;gap:10px;
  box-shadow:0 2px 14px rgba(42,92,69,0.07);
  animation:chipFloat 4s ease-in-out infinite;
}
.chip:nth-child(2){animation-delay:.6s}
.chip:nth-child(3){animation-delay:1.2s}
.chip:nth-child(4){animation-delay:1.8s}
.chip:nth-child(5){animation-delay:2.4s}
.chip-icon{
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;
}
@keyframes chipFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-5px)}
}

/* SHARED */
section{padding:96px 24px}
.sec-inner{max-width:960px;margin:0 auto}
.label{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--sage-l);color:var(--forest);
  font-family:var(--f-disp);
  font-size:12px;font-weight:700;letter-spacing:.06em;
  padding:5px 14px;border-radius:980px;margin-bottom:16px;
  text-transform:uppercase;
}
h2{
  font-family:var(--f-disp);
  font-size:clamp(26px,4vw,38px);
  font-weight:700;line-height:1.35;
  color:var(--ink);margin-bottom:12px;
}
.sub-copy{
  font-size:16px;color:var(--mid);line-height:1.8;
  max-width:580px;margin-bottom:48px;
}

/* PAIN */
.pain{background:var(--white)}
.pain-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:12px;margin-bottom:40px;
}
.pain-card{
  background:var(--cream);
  border-radius:var(--r-md);
  padding:20px 22px;
  display:flex;align-items:flex-start;gap:14px;
  border:1.5px solid transparent;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.pain-card:hover{
  border-color:var(--sage);transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(42,92,69,0.09);
}
.pain-check{
  width:22px;height:22px;border-radius:6px;
  border:2px solid var(--sage);flex-shrink:0;margin-top:2px;
  background:var(--white);
}
.pain-text{font-size:14px;color:var(--mid);line-height:1.7}
.pain-close{
  background:linear-gradient(135deg,var(--forest) 0%,var(--forest-l) 100%);
  border-radius:var(--r-lg);padding:36px 40px;
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
}
.pain-close-icon{
  width:56px;height:56px;border-radius:16px;
  background:rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;flex-shrink:0;
}
.pain-close-text{flex:1;min-width:200px}
.pain-close-text p{
  font-family:var(--f-disp);
  font-size:17px;font-weight:700;color:var(--white);line-height:1.65;
}
.pain-close-text span{color:var(--sage-l)}

/* WHAT */
.what{background:var(--cream)}
.honest-pill{
  background:var(--white);
  border:1.5px solid var(--sage);
  border-radius:var(--r-md);
  padding:14px 20px;
  font-size:14px;color:var(--mid);line-height:1.7;
  display:inline-block;margin-bottom:40px;
  box-shadow:0 2px 10px rgba(42,92,69,0.07);
}
.honest-pill strong{color:var(--forest)}
.obs-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;margin-bottom:48px;
}
.obs-card{
  border-radius:var(--r-md);
  padding:24px 18px;
  background:var(--white);
  border:1.5px solid var(--border);
  transition:transform .22s,box-shadow .22s,border-color .22s;
  cursor:default;
}
.obs-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(42,92,69,0.12);border-color:var(--sage)}
.obs-accent{
  width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;margin-bottom:14px;
}
.obs-card-1 .obs-accent{background:#FEF3E2}
.obs-card-2 .obs-accent{background:#E8F5F1}
.obs-card-3 .obs-accent{background:#EDE8FE}
.obs-card-4 .obs-accent{background:#E2F0FB}
.obs-card-5 .obs-accent{background:#E8F5E9}
.obs-n{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--sage);display:block;margin-bottom:6px}
.obs-t{font-family:var(--f-disp);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:8px;line-height:1.3}
.obs-q{font-size:12px;color:var(--mid);line-height:1.6}
.specs-strip{
  display:flex;gap:1px;
  background:var(--border);
  border-radius:var(--r-md);overflow:hidden;
}
.spec-block{
  flex:1;background:var(--white);
  padding:20px 16px;text-align:center;
}
.spec-val{
  font-family:var(--f-disp);
  font-size:28px;font-weight:700;color:var(--forest);line-height:1;
}
.spec-lbl{font-size:12px;color:var(--mid);margin-top:6px}

/* OUTPUT */
.output{background:var(--white)}
.output-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(256px,1fr));
  gap:16px;margin-bottom:32px;
}
.out-card{
  background:var(--cream);
  border-radius:var(--r-lg);padding:32px 28px;
  border:1.5px solid var(--border);
  position:relative;overflow:hidden;
  transition:transform .2s,box-shadow .2s;
}
.out-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(42,92,69,0.1)}
.out-stripe{position:absolute;top:0;left:0;right:0;height:4px}
.out-card:nth-child(1) .out-stripe{background:var(--amber)}
.out-card:nth-child(2) .out-stripe{background:var(--sage)}
.out-card:nth-child(3) .out-stripe{background:var(--forest)}
.out-n{font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--mid);display:block;margin-bottom:12px}
.out-t{font-family:var(--f-disp);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:10px;line-height:1.3}
.out-d{font-size:13px;color:var(--mid);line-height:1.75}
.consult-card{
  background:var(--forest);
  border-radius:var(--r-lg);padding:36px 40px;
  display:flex;align-items:center;gap:32px;flex-wrap:wrap;
}
.consult-card-body{flex:1;min-width:200px}
.consult-card-body strong{
  font-family:var(--f-disp);
  font-size:18px;font-weight:700;color:var(--white);display:block;margin-bottom:10px;
}
.consult-card-body p{font-size:14px;color:rgba(255,255,255,0.65);line-height:1.75}
.consult-card-body .note{font-size:12px;color:rgba(255,255,255,0.4);margin-top:8px}
.btn-consult{
  background:var(--white);color:var(--forest);
  font-family:var(--f-disp);
  font-size:14px;font-weight:700;
  padding:13px 26px;border-radius:980px;
  text-decoration:none;white-space:nowrap;
  transition:background .18s,transform .15s;flex-shrink:0;
}
.btn-consult:hover{background:var(--sage-l);transform:scale(1.03)}

/* TRUST */
.trust{background:var(--cream)}
.trust-body{
  font-size:17px;line-height:1.9;color:var(--mid);
  max-width:620px;margin-bottom:48px;
}
.trust-body em{color:var(--forest);font-style:normal;font-weight:700}
.trust-list{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:12px;
}
.trust-item{
  background:var(--white);border-radius:var(--r-md);
  padding:20px 22px;
  display:flex;align-items:flex-start;gap:14px;
  border:1.5px solid var(--border);
}
.trust-icon{
  width:36px;height:36px;border-radius:10px;
  background:var(--sage-l);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;
}
.trust-item-body strong{
  font-family:var(--f-disp);
  font-size:14px;font-weight:700;color:var(--ink);display:block;margin-bottom:4px;
}
.trust-item-body p{font-size:13px;color:var(--mid);line-height:1.6}

/* FAQ */
.faq{background:var(--white)}
.faq-list{max-width:720px;display:grid;gap:8px}
.faq-item{
  background:var(--cream);
  border-radius:var(--r-md);
  border:1.5px solid var(--border);
  overflow:hidden;
  transition:border-color .2s;
}
.faq-item.open{border-color:var(--sage)}
.faq-q{
  width:100%;background:none;border:none;
  padding:22px 24px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:var(--f-disp);font-size:15px;font-weight:700;
  color:var(--ink);text-align:left;
}
.faq-q:hover{background:rgba(134,189,164,0.08)}
.faq-badge{
  width:24px;height:24px;border-radius:6px;
  background:var(--white);border:1.5px solid var(--sage);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;line-height:1;color:var(--forest);
  flex-shrink:0;transition:background .2s,transform .25s;
}
.faq-item.open .faq-badge{background:var(--forest);border-color:var(--forest);color:#fff;transform:rotate(45deg)}
.faq-a{
  font-size:14px;color:var(--mid);line-height:1.8;
  padding:0 24px 22px;display:none;
  border-top:1px solid var(--border);padding-top:18px;
}
.faq-item.open .faq-a{display:block}

/* FINAL CTA */
.final{
  background:var(--forest);
  padding:120px 24px;text-align:center;
  position:relative;overflow:hidden;
}
.final::before{
  content:'';
  position:absolute;top:-40%;left:-10%;width:120%;height:200%;
  background:
    radial-gradient(ellipse 50% 40% at 20% 50%,rgba(134,189,164,0.18),transparent),
    radial-gradient(ellipse 50% 40% at 80% 50%,rgba(255,255,255,0.06),transparent);
  pointer-events:none;
}
.final-inner{position:relative;z-index:1}
.final-title{
  font-family:var(--f-disp);
  font-size:clamp(28px,4.5vw,48px);
  font-weight:700;line-height:1.35;color:var(--white);
  max-width:680px;margin:0 auto 20px;
}
.final-sub{
  font-size:17px;color:rgba(255,255,255,0.65);
  max-width:480px;margin:0 auto 44px;line-height:1.8;
}
.btn-final{
  display:inline-block;
  background:var(--amber);color:var(--white);
  font-family:var(--f-disp);font-size:17px;font-weight:700;
  padding:16px 40px;border-radius:980px;
  text-decoration:none;
  box-shadow:0 6px 24px rgba(0,0,0,0.25);
  transition:background .18s,transform .15s,box-shadow .15s;
}
.btn-final:hover{background:#d9703a;transform:translateY(-2px);box-shadow:0 10px 32px rgba(0,0,0,0.3)}
.final-micro{
  margin-top:22px;font-size:12px;
  color:rgba(255,255,255,0.35);line-height:2;
}
.final-trust-row{
  display:flex;gap:20px;justify-content:center;flex-wrap:wrap;
  margin-top:40px;
}
.final-trust-item{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:rgba(255,255,255,0.55);
}
.final-trust-icon{
  width:20px;height:20px;border-radius:50%;
  background:rgba(134,189,164,0.3);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;flex-shrink:0;
}

/* FOOTER */
footer{
  background:#1A2E25;padding:36px 24px;text-align:center;
}
.footer-links{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-bottom:14px}
.footer-links a{font-size:12px;color:rgba(255,255,255,0.38);text-decoration:none}
.footer-links a:hover{color:rgba(255,255,255,0.65)}
.footer-copy{font-size:11px;color:rgba(255,255,255,0.2)}

/* ANIMATIONS */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:760px){.obs-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){
  .hero-ctas{flex-direction:column;align-items:center}
  .pain-close,.consult-card{padding:28px 24px}
  .specs-strip{flex-direction:column;gap:1px}
  .obs-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:400px){
  .obs-grid{grid-template-columns:1fr}
  nav{padding:8px 12px 8px 16px}
}
