/* =========================================================
   夢鍼灸院  ─  不妊鍼灸専門サイト
   Design System
   ========================================================= */
:root{
  --cream:#fdf6f9;
  --cream-2:#fbe9f1;
  --cream-3:#f6d6e3;
  --ink:#5b4651;
  --ink-soft:#937c88;
  --rose:#e58aaa;
  --rose-deep:#cf6e90;
  --rose-light:#fad6e4;
  --green:#bd7d9e;
  --green-deep:#8e5773;
  --gold:#dba6b6;
  --line:#06c755;
  --white:#ffffff;
  --shadow-sm:0 4px 16px rgba(90,70,55,.08);
  --shadow:0 14px 40px rgba(90,70,55,.12);
  --shadow-lg:0 30px 70px rgba(90,70,55,.18);
  --radius:18px;
  --radius-lg:28px;
  --maxw:1140px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Shippori Mincho","Noto Serif JP",serif;
  --sans:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  --en:"Cormorant Garamond",serif;
  --num:"Outfit","Zen Kaku Gothic New",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.9;
  font-size:16px;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:.3s var(--ease)}
ul{list-style:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:880px}

/* ---------- Typography helpers ---------- */
.en-label{
  font-family:var(--en);
  font-size:.95rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--rose);
  font-weight:600;
  display:block;
}
.sec-head{text-align:center;margin-bottom:54px}
.sec-head .en-label{margin-bottom:10px}
.sec-head h2{
  font-family:var(--serif);
  font-size:clamp(1.7rem,4vw,2.5rem);
  font-weight:600;
  line-height:1.5;
  letter-spacing:.04em;
}
.sec-head h2 b{color:var(--rose-deep);font-weight:600}
.sec-head p{margin-top:18px;color:var(--ink-soft);font-size:1rem}
.accent{color:var(--rose-deep)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--sans);font-weight:700;font-size:1rem;letter-spacing:.06em;
  padding:16px 38px;border-radius:999px;cursor:pointer;border:none;
  transition:.35s var(--ease);position:relative;
}
.btn-primary{background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;box-shadow:0 12px 28px rgba(168,106,91,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(168,106,91,.45)}
.btn-line{background:var(--line);color:#fff;box-shadow:0 12px 28px rgba(6,199,85,.3)}
.btn-line:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(6,199,85,.4)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--cream-3)}
.btn-ghost:hover{border-color:var(--rose);color:var(--rose-deep)}
.btn-lg{padding:20px 54px;font-size:1.08rem}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  transition:.4s var(--ease);
  background:transparent;
}
.site-header.scrolled{background:rgba(253,246,249,.93);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:84px;max-width:1260px;margin:0 auto;padding:0 28px}
.logo{display:flex;align-items:center;gap:12px;line-height:1.2}
.logo .mark{width:60px;height:60px;flex:0 0 60px;object-fit:contain}
.logo .txt{font-family:var(--serif);font-weight:700;font-size:1.45rem;letter-spacing:.08em;color:var(--ink)}
.logo .sub{display:block;font-family:var(--en);font-size:.62rem;letter-spacing:.3em;color:var(--rose);font-weight:600;margin-top:2px}
.site-header.scrolled .logo .txt,.site-header.scrolled .nav a{color:var(--ink)}
.main-nav ul{display:flex;align-items:center;gap:30px}
.main-nav a{font-size:.92rem;font-weight:500;letter-spacing:.06em;position:relative;padding:6px 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--rose);transition:.3s var(--ease)}
.main-nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:14px}
.header-tel{text-align:right;line-height:1.2}
.header-tel .num{font-family:var(--num);font-size:1.4rem;font-weight:700;color:var(--rose-deep);letter-spacing:.04em;display:flex;align-items:center;gap:6px}
.header-tel small{font-size:.7rem;color:var(--ink-soft);letter-spacing:.1em}
.nav-toggle{display:none;flex-direction:column;gap:6px;width:30px;height:24px;background:none;border:none;cursor:pointer;z-index:1100}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--ink);transition:.3s var(--ease);transform-origin:center}
.nav-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile drawer */
.mobile-drawer{position:fixed;inset:0;z-index:1050;background:var(--cream);transform:translateX(100%);transition:.45s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:40px;opacity:0;visibility:hidden}
.mobile-drawer.open{transform:none;opacity:1;visibility:visible}
.mobile-drawer ul{display:flex;flex-direction:column;gap:6px}
.mobile-drawer a{font-family:var(--serif);font-size:1.3rem;padding:14px 0;border-bottom:1px solid var(--cream-3);display:flex;align-items:center;justify-content:space-between}
.mobile-drawer a .en{font-family:var(--en);font-size:.8rem;color:var(--rose);letter-spacing:.15em}
.mobile-drawer .drawer-cta{display:flex;flex-direction:column;gap:12px;margin-top:30px}
.mobile-drawer .drawer-tel{text-align:center;font-family:var(--num);font-size:1.8rem;font-weight:700;color:var(--rose-deep);margin-top:24px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:slowzoom 18s ease-in-out infinite alternate}
@keyframes slowzoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(253,246,249,.96) 0%,rgba(253,246,249,.86) 38%,rgba(253,242,247,.4) 70%,rgba(253,242,247,.12) 100%)}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:120px 24px 80px;width:100%}
.hero-content{max-width:620px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--rose-deep);font-weight:700;font-size:.82rem;letter-spacing:.1em;padding:9px 20px;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:28px}
.hero-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--rose)}
.hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(2.1rem,5.6vw,3.6rem);line-height:1.45;letter-spacing:.03em;margin-bottom:26px}
.hero h1 .hl{position:relative;color:var(--rose-deep);white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-2%;bottom:6%;width:104%;height:30%;background:var(--rose-light);z-index:-1;border-radius:4px}
.hero p.lead{font-size:1.08rem;color:var(--ink-soft);margin-bottom:38px;font-weight:500}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;margin-top:50px}
.hero-stats .stat .n{font-family:var(--num);font-size:2.6rem;font-weight:700;color:var(--rose-deep);line-height:1}
.hero-stats .stat .n small{font-size:1.1rem}
.hero-stats .stat .l{font-size:.78rem;color:var(--ink-soft);letter-spacing:.08em;margin-top:4px}
.hero-stats .divider{width:1px;background:var(--cream-3)}
.scroll-ind{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);writing-mode:vertical-rl;font-family:var(--en);font-size:.7rem;letter-spacing:.3em;color:var(--ink-soft);display:flex;align-items:center;gap:14px}
.scroll-ind::after{content:"";width:1px;height:46px;background:var(--rose);animation:scrolldot 2s infinite}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Section base ---------- */
section{position:relative}
.sec{padding:110px 0}
.sec-cream{background:var(--cream-2)}
.sec-rose{background:linear-gradient(160deg,#fdeaf2,#f8d6e6)}
.sec-green{background:var(--green-deep);color:#fff}
.sec-green .sec-head h2,.sec-green .en-label{color:#fff}
.sec-green .en-label{color:#f8d9e6}

/* ---------- Worry checklist ---------- */
.worry{background:var(--cream);}
.worry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:46px}
.worry-card{background:#fff;border-radius:var(--radius);padding:26px 24px;display:flex;gap:14px;align-items:flex-start;box-shadow:var(--shadow-sm);border:1px solid #f0e6da;transition:.35s var(--ease)}
.worry-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.worry-card .ic{flex:0 0 30px;color:var(--rose)}
.worry-card p{font-size:.98rem;font-weight:500;line-height:1.7}
.worry-cta{text-align:center;font-family:var(--serif);font-size:1.25rem;line-height:1.8}
.worry-cta b{color:var(--rose-deep)}

/* ---------- Reasons ---------- */
.reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.reason-card{background:#fff;border-radius:var(--radius-lg);padding:42px 30px;text-align:center;box-shadow:var(--shadow-sm);transition:.4s var(--ease);position:relative;overflow:hidden}
.reason-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background:linear-gradient(90deg,var(--rose),var(--gold));transform:scaleX(0);transform-origin:left;transition:.4s var(--ease)}
.reason-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.reason-card:hover::before{transform:scaleX(1)}
.reason-num{font-family:var(--en);font-size:.85rem;letter-spacing:.2em;color:var(--gold);font-weight:600}
.reason-ic{width:74px;height:74px;margin:14px auto 22px;border-radius:50%;background:var(--cream-2);display:flex;align-items:center;justify-content:center;color:var(--rose-deep)}
.reason-ic svg{width:38px;height:38px}
.reason-card h3{font-family:var(--serif);font-size:1.2rem;font-weight:600;margin-bottom:12px;letter-spacing:.03em}
.reason-card p{font-size:.92rem;color:var(--ink-soft);line-height:1.85}

/* ---------- Effects (green section) ---------- */
.effects-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:10px}
.effect{background:rgba(255,255,255,.09);border:2px solid rgba(255,255,255,.55);border-radius:var(--radius);padding:30px 18px;text-align:center;transition:.35s var(--ease)}
.effect:hover{background:rgba(255,255,255,.16);border-color:#fff;transform:translateY(-5px)}
.effect .ic{width:54px;height:54px;margin:0 auto 16px;color:#f8d9e6}
.effect h4{font-family:var(--serif);font-size:1.05rem;margin-bottom:10px;font-weight:600}
.effect p{font-size:.82rem;color:rgba(255,255,255,.78);line-height:1.7}
.effects-note{text-align:center;margin-top:40px;font-size:.95rem;color:rgba(255,255,255,.85)}

/* ---------- Flow steps ---------- */
.flow-list{max-width:840px;margin:0 auto;position:relative}
.flow-list::before{content:"";position:absolute;left:35px;top:30px;bottom:30px;width:2px;background:linear-gradient(var(--rose-light),var(--cream-3))}
.flow-step{display:flex;gap:28px;margin-bottom:34px;position:relative}
.flow-step:last-child{margin-bottom:0}
.flow-step .no{flex:0 0 72px;height:72px;border-radius:50%;background:#fff;border:2px solid var(--rose-light);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);z-index:1}
.flow-step .no small{font-family:var(--en);font-size:.6rem;letter-spacing:.2em;color:var(--rose)}
.flow-step .no b{font-family:var(--num);font-size:1.7rem;color:var(--rose-deep);line-height:1}
.flow-body{background:#fff;border-radius:var(--radius);padding:26px 30px;box-shadow:var(--shadow-sm);flex:1;transition:.35s var(--ease)}
.flow-step:hover .flow-body{box-shadow:var(--shadow);transform:translateX(4px)}
.flow-body h3{font-family:var(--serif);font-size:1.22rem;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:10px}
.flow-body h3 .tic{color:var(--rose);width:24px;height:24px;flex:0 0 24px}
.flow-body p{font-size:.94rem;color:var(--ink-soft);line-height:1.85}
.flow-body ul.bullet{margin-top:12px}
.flow-body ul.bullet li{position:relative;padding-left:20px;font-size:.9rem;color:var(--ink-soft);margin-bottom:4px}
.flow-body ul.bullet li::before{content:"";position:absolute;left:0;top:.7em;width:7px;height:7px;border-radius:50%;background:var(--rose-light)}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:900px;margin:0 auto}
.price-card{background:#fff;border-radius:var(--radius-lg);padding:46px 40px;box-shadow:var(--shadow);position:relative;transition:.4s var(--ease);border:1px solid #f0e6da}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.price-card.feature{border:2px solid var(--rose)}
.price-badge{position:absolute;top:-14px;left:40px;background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;font-size:.78rem;font-weight:700;letter-spacing:.08em;padding:6px 18px;border-radius:999px;box-shadow:var(--shadow-sm)}
.price-card h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin-bottom:6px}
.price-card .dur{font-size:.85rem;color:var(--ink-soft);letter-spacing:.08em}
.price-card .amount{font-family:var(--num);font-size:3.1rem;font-weight:700;color:var(--rose-deep);line-height:1.1;margin:16px 0 4px}
.price-card .amount small{font-size:1.1rem;color:var(--ink)}
.price-card .amount .yen{font-size:1.4rem}
.price-card .note{font-size:.8rem;color:var(--ink-soft);margin-bottom:22px}
.price-card ul.inc li{position:relative;padding-left:30px;font-size:.95rem;margin-bottom:12px}
.price-card ul.inc li::before{content:"";background-size:13px 13px;position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:var(--cream-2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24'%3E%3Cellipse cx='12.0' cy='6.0' rx='2.6' ry='5' transform='rotate(0 12.0 6.0)' fill='%23e58aaa'/%3E%3Cellipse cx='17.7' cy='10.1' rx='2.6' ry='5' transform='rotate(72 17.7 10.1)' fill='%23e58aaa'/%3E%3Cellipse cx='15.5' cy='16.9' rx='2.6' ry='5' transform='rotate(144 15.5 16.9)' fill='%23e58aaa'/%3E%3Cellipse cx='8.5' cy='16.9' rx='2.6' ry='5' transform='rotate(216 8.5 16.9)' fill='%23e58aaa'/%3E%3Cellipse cx='6.3' cy='10.1' rx='2.6' ry='5' transform='rotate(288 6.3 10.1)' fill='%23e58aaa'/%3E%3Ccircle cx='12' cy='12' r='2.8' fill='%23cf6e90'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.price-foot{text-align:center;margin-top:34px;font-size:.9rem;color:var(--ink-soft)}

/* ---------- Campaign ---------- */
.campaign{background:linear-gradient(135deg,var(--rose),var(--green-deep));color:#fff;border-radius:var(--radius-lg);padding:52px 50px;display:flex;align-items:center;gap:50px;box-shadow:var(--shadow-lg);overflow:hidden;position:relative}
.campaign::before{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.08)}
.campaign::after{content:"";position:absolute;left:-40px;bottom:-70px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.06)}
.campaign-l{flex:0 0 auto;text-align:center;position:relative}
.campaign-l .ribbon{font-family:var(--serif);font-size:1.1rem;letter-spacing:.1em;margin-bottom:8px}
.campaign-l .limited{display:inline-block;border:1px solid rgba(255,255,255,.5);border-radius:999px;font-size:.75rem;padding:4px 16px;letter-spacing:.1em}
.campaign-r{flex:1;position:relative}
.campaign-r h3{font-family:var(--serif);font-size:1.7rem;font-weight:600;margin-bottom:14px;line-height:1.5}
.campaign-price{display:flex;align-items:baseline;gap:16px;margin-bottom:8px}
.campaign-price .old{font-family:var(--num);font-size:1.5rem;text-decoration:line-through;opacity:.6}
.campaign-price .new{font-family:var(--num);font-size:3.4rem;font-weight:700;line-height:1}
.campaign-price .new small{font-size:1.3rem}
.campaign-r .cond{font-size:.85rem;opacity:.85;line-height:1.8}

/* ---------- Evidence ---------- */
.evidence-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:960px;margin:40px auto 0}
.ev-card{background:#fff;border-radius:var(--radius);padding:36px 34px;box-shadow:var(--shadow-sm);border-left:4px solid var(--gold)}
.ev-card .yr{font-family:var(--num);font-size:1.6rem;font-weight:700;color:var(--gold);letter-spacing:.04em}
.ev-card .src{font-size:.8rem;color:var(--ink-soft);letter-spacing:.1em;margin-bottom:14px}
.ev-card p{font-size:.94rem;color:var(--ink-soft);line-height:1.9}
.ev-card .hl{color:var(--rose-deep);font-weight:700}
.ev-lead{text-align:center;font-family:var(--serif);font-size:clamp(1.3rem,3vw,1.8rem);line-height:1.7;max-width:760px;margin:0 auto}
.ev-lead b{color:var(--rose-deep)}

/* ---------- Testimonials ---------- */
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.voice-card{background:#fff;border-radius:var(--radius);padding:34px 34px 30px;box-shadow:var(--shadow-sm);transition:.4s var(--ease);position:relative}
.voice-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.voice-card .quote{font-family:var(--serif);font-size:3rem;line-height:1;color:var(--rose-light);position:absolute;top:18px;right:26px}
.voice-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.voice-tags span{font-size:.72rem;background:var(--cream-2);color:var(--rose-deep);padding:4px 12px;border-radius:999px;font-weight:600;letter-spacing:.04em}
.voice-card h3{font-family:var(--serif);font-size:1.12rem;font-weight:600;line-height:1.6;margin-bottom:14px}
.voice-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.85}
.voice-card .who{margin-top:18px;font-size:.85rem;color:var(--rose-deep);font-weight:600;display:flex;align-items:center;gap:8px}
.voice-card .who::before{content:"";width:24px;height:1px;background:var(--rose)}

/* ---------- Doctor ---------- */
.doctor{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.doctor-photo{position:relative}
.doctor-photo img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/5;object-fit:cover}
.doctor-photo .frame{position:absolute;inset:18px -18px -18px 18px;border:1.5px solid var(--rose);border-radius:var(--radius-lg);z-index:-1}
.doctor-body .en-label{margin-bottom:12px}
.doctor-body h2{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:600;line-height:1.55;margin-bottom:8px}
.doctor-name{font-size:1rem;color:var(--ink-soft);margin-bottom:24px;letter-spacing:.06em}
.doctor-name b{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-left:8px}
.doctor-body p{font-size:.96rem;color:var(--ink-soft);line-height:2;margin-bottom:16px}
.doctor-sign{font-family:var(--serif);font-size:1.15rem;color:var(--rose-deep);margin-top:20px}

/* ---------- Access / Map ---------- */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.access-info dl>div{display:grid;grid-template-columns:120px 1fr;border-top:1px solid var(--cream-3)}
.access-info dl>div:last-child{border-bottom:1px solid var(--cream-3)}
.access-info dt{font-weight:700;padding:18px 16px 18px 0;color:var(--rose-deep);font-size:.92rem}
.access-info dd{padding:18px 0;font-size:.96rem}
@media(max-width:768px){.access-info dl>div{grid-template-columns:96px 1fr}}
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.map-wrap iframe{width:100%;height:100%;border:0}
.route-steps{counter-reset:r;margin-top:8px}
.route-steps li{counter-increment:r;position:relative;padding-left:38px;margin-bottom:14px;font-size:.92rem;color:var(--ink-soft)}
.route-steps li::before{content:counter(r);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:50%;background:var(--rose);color:#fff;font-family:var(--num);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center}

/* ---------- LINE CTA ---------- */
.line-cta{display:grid;grid-template-columns:1.4fr .6fr;gap:46px;align-items:center;background:#fff;border-radius:var(--radius-lg);padding:50px 54px;box-shadow:var(--shadow);border:1px solid #eadfd0}
.line-cta .lc-body .badge{display:inline-flex;align-items:center;gap:8px;background:var(--line);color:#fff;font-weight:700;font-size:.82rem;padding:7px 18px;border-radius:999px;margin-bottom:18px;letter-spacing:.06em}
.line-cta h3{font-family:var(--serif);font-size:1.7rem;font-weight:600;line-height:1.55;margin-bottom:14px}
.line-cta p{color:var(--ink-soft);font-size:.96rem;margin-bottom:26px}
.line-cta .qr{text-align:center}
.line-cta .qr img{width:160px;height:160px;border:8px solid #fff;border-radius:14px;box-shadow:var(--shadow-sm);margin:0 auto 10px}
.line-cta .qr small{font-size:.8rem;color:var(--ink-soft);letter-spacing:.06em}

/* ---------- Contact form ---------- */
.contact-card{background:#fff;border-radius:var(--radius-lg);padding:54px 56px;box-shadow:var(--shadow);max-width:820px;margin:0 auto}
.form-row{margin-bottom:24px}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:20px}
label{display:block;font-weight:700;font-size:.9rem;margin-bottom:8px}
label .req{color:#fff;background:var(--rose);font-size:.66rem;padding:2px 8px;border-radius:4px;margin-left:8px;letter-spacing:.06em}
label .opt{color:var(--ink-soft);background:var(--cream-2);font-size:.66rem;padding:2px 8px;border-radius:4px;margin-left:8px}
input,select,textarea{width:100%;font-family:var(--sans);font-size:1rem;padding:14px 16px;border:1.5px solid var(--cream-3);border-radius:12px;background:var(--cream);transition:.3s var(--ease);color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--rose);background:#fff;box-shadow:0 0 0 4px rgba(192,132,117,.12)}
textarea{resize:vertical;min-height:130px}
.form-note{font-size:.82rem;color:var(--ink-soft);background:var(--cream-2);padding:16px 20px;border-radius:12px;margin-bottom:24px;line-height:1.8}
.check-line{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;margin-bottom:24px}
.check-line input{width:auto;margin-top:5px}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;text-align:center;padding:80px 24px}
.cta-band .en-label{color:#f8d9e6}
.cta-band h2{font-family:var(--serif);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:600;line-height:1.6;margin:12px 0 14px}
.cta-band p{opacity:.9;margin-bottom:36px}
.cta-band .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-band .tel-big{font-family:var(--num);font-size:2.6rem;font-weight:700;letter-spacing:.04em;margin-top:30px;display:block}
.cta-band .tel-big small{display:block;font-family:var(--sans);font-size:.8rem;opacity:.85;letter-spacing:.1em}

/* ---------- Footer ---------- */
.site-footer{background:#46303b;color:#d9c6d0;padding:70px 0 30px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .logo .txt{color:#fff}
.footer-brand p{font-size:.86rem;margin-top:18px;line-height:1.9;opacity:.8}
.footer-col h4{font-family:var(--serif);font-size:1rem;color:#fff;margin-bottom:18px;letter-spacing:.06em}
.footer-col ul li{margin-bottom:11px}
.footer-col a{font-size:.88rem;opacity:.8}
.footer-col a:hover{opacity:1;color:var(--rose-light)}
.footer-contact p{font-size:.88rem;margin-bottom:10px;opacity:.85;display:flex;gap:10px}
.footer-contact .ic{flex:0 0 18px;opacity:.7}
.footer-bottom{text-align:center;padding-top:26px;font-size:.78rem;opacity:.6;font-family:var(--en);letter-spacing:.08em}
.footer-sns{display:flex;gap:14px;margin-top:18px}
.footer-sns a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:.3s var(--ease)}
.footer-sns a:hover{background:var(--rose)}

/* ---------- Floating mobile CTA ---------- */
.mobile-bar{position:fixed;bottom:0;left:0;width:100%;z-index:900;display:none;grid-template-columns:1fr 1fr 1fr;box-shadow:0 -6px 24px rgba(0,0,0,.14)}
.mobile-bar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:11px 4px;font-size:.72rem;font-weight:700;color:#fff;letter-spacing:.04em}
.mobile-bar .m-tel{background:var(--rose-deep)}
.mobile-bar .m-line{background:var(--line)}
.mobile-bar .m-rsv{background:var(--green)}
.mobile-bar svg{width:22px;height:22px}

/* ---------- Page hero (sub pages) ---------- */
.page-hero{padding:160px 0 70px;text-align:center;background:linear-gradient(160deg,var(--cream-2),var(--cream-3));position:relative;overflow:hidden}
.page-hero .en-label{margin-bottom:10px}
.page-hero h1{font-family:var(--serif);font-size:clamp(1.9rem,4.5vw,2.8rem);font-weight:600;letter-spacing:.05em}
.breadcrumb{font-size:.78rem;color:var(--ink-soft);margin-top:16px;font-family:var(--en);letter-spacing:.1em}
.breadcrumb a:hover{color:var(--rose-deep)}

/* ---------- FAQ accordion ---------- */
.faq-list{max-width:840px;margin:0 auto}
.faq-item{background:#fff;border-radius:var(--radius);margin-bottom:16px;box-shadow:var(--shadow-sm);overflow:hidden}
.faq-q{display:flex;align-items:center;gap:16px;padding:24px 28px;cursor:pointer;font-weight:700;font-size:1.02rem}
.faq-q .qi{flex:0 0 32px;height:32px;border-radius:50%;background:var(--cream-2);color:var(--rose-deep);font-family:var(--en);font-weight:700;display:flex;align-items:center;justify-content:center}
.faq-q .arrow{margin-left:auto;flex:0 0 auto;transition:.35s var(--ease);color:var(--rose)}
.faq-item.open .faq-q .arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 28px 26px 76px;color:var(--ink-soft);font-size:.95rem;line-height:1.9}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:.9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}
.reveal.d4{transition-delay:.4s}.reveal.d5{transition-delay:.5s}

/* ---------- Intro band ---------- */
.intro{text-align:center;max-width:780px;margin:0 auto}
.intro .en-label{margin-bottom:14px}
.intro h2{font-family:var(--serif);font-size:clamp(1.5rem,3.6vw,2.1rem);font-weight:600;line-height:1.7;margin-bottom:24px}
.intro p{color:var(--ink-soft);line-height:2.05}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .main-nav,.header-tel{display:none}
  .header-cta .btn{display:none}
  .nav-toggle{display:flex}
  .effects-grid{grid-template-columns:repeat(3,1fr)}
  .worry-grid{grid-template-columns:repeat(2,1fr)}
  .reasons-grid{grid-template-columns:repeat(2,1fr)}
  .doctor{grid-template-columns:1fr;gap:40px}
  .doctor-photo{max-width:420px;margin:0 auto}
}
@media(max-width:768px){
  body{font-size:15px}
  .sec{padding:74px 0}
  .header-inner{height:70px;padding:0 18px}
  .logo .txt{font-size:1.2rem}
  .logo .mark{width:50px;height:50px;flex:0 0 50px}
  .hero-inner{padding:120px 22px 110px}
  .hero-stats{gap:22px;margin-top:36px}
  .hero-stats .stat .n{font-size:2rem}
  .reasons-grid,.price-grid,.evidence-grid,.voice-grid,.effects-grid,.worry-grid{grid-template-columns:1fr}
  .access-grid,.line-cta,.campaign{grid-template-columns:1fr}
  .campaign{padding:40px 28px;gap:30px;text-align:center}
  .campaign-price{justify-content:center}
  .line-cta{padding:38px 28px}
  .line-cta .qr img{width:180px;height:180px}
  .contact-card{padding:34px 22px}
  .form-row.two{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:32px}
  .flow-list::before{left:26px}
  .flow-step .no{flex:0 0 54px;height:54px}
  .flow-step .no b{font-size:1.3rem}
  .flow-step{gap:18px}
  .flow-body{padding:22px 22px}
  .mobile-bar{display:grid}
  .site-footer{padding-bottom:90px}
  .scroll-ind{display:none}
  .page-hero{padding:120px 0 54px}
  .faq-a-inner{padding-left:28px}
  .cta-band .tel-big{font-size:2rem}
}

/* ===== Soft pink base + partial floral accents ===== */
:root{--sprig:url("data:image/svg+xml,%3Csvg%20xmlns=%27http://www.w3.org/2000/svg%27%20width=%27240%27%20height=%27240%27%20viewBox=%270%200%20240%20240%27%3E%3Cpath%20d=%27M28,214%20C74,176%2086,120%20138,92%20C176,72%20192,52%20212,30%27%20stroke=%27%23d597b2%27%20stroke-width=%272.4%27%20fill=%27none%27%20stroke-linecap=%27round%27/%3E%3Cg%20transform=%27translate(70%20176)%20rotate(40)%20scale(1.5)%27%3E%3Cpath%20d=%27M0,0%20C8,-9%208,-22%200,-30%20C-8,-22%20-8,-9%200,0%20Z%27%20fill=%27%23eec6d8%27/%3E%3Cpath%20d=%27M0,-3%20L0,-26%27%20stroke=%27%23d597b2%27%20stroke-width=%271%27%20fill=%27none%27/%3E%3C/g%3E%3Cg%20transform=%27translate(96%20150)%20rotate(-150)%20scale(1.3)%27%3E%3Cpath%20d=%27M0,0%20C8,-9%208,-22%200,-30%20C-8,-22%20-8,-9%200,0%20Z%27%20fill=%27%23eec6d8%27/%3E%3Cpath%20d=%27M0,-3%20L0,-26%27%20stroke=%27%23d597b2%27%20stroke-width=%271%27%20fill=%27none%27/%3E%3C/g%3E%3Cg%20transform=%27translate(120%20118)%20rotate(55)%20scale(1.6)%27%3E%3Cpath%20d=%27M0,0%20C8,-9%208,-22%200,-30%20C-8,-22%20-8,-9%200,0%20Z%27%20fill=%27%23eec6d8%27/%3E%3Cpath%20d=%27M0,-3%20L0,-26%27%20stroke=%27%23d597b2%27%20stroke-width=%271%27%20fill=%27none%27/%3E%3C/g%3E%3Cg%20transform=%27translate(150%2096)%20rotate(-150)%20scale(1.2)%27%3E%3Cpath%20d=%27M0,0%20C8,-9%208,-22%200,-30%20C-8,-22%20-8,-9%200,0%20Z%27%20fill=%27%23eec6d8%27/%3E%3Cpath%20d=%27M0,-3%20L0,-26%27%20stroke=%27%23d597b2%27%20stroke-width=%271%27%20fill=%27none%27/%3E%3C/g%3E%3Cg%20transform=%27translate(182%2058)%20rotate(60)%20scale(1.3)%27%3E%3Cpath%20d=%27M0,0%20C8,-9%208,-22%200,-30%20C-8,-22%20-8,-9%200,0%20Z%27%20fill=%27%23eec6d8%27/%3E%3Cpath%20d=%27M0,-3%20L0,-26%27%20stroke=%27%23d597b2%27%20stroke-width=%271%27%20fill=%27none%27/%3E%3C/g%3E%3Cellipse%20cx=%27212.0%27%20cy=%2713.9%27%20rx=%278.4%27%20ry=%2714.0%27%20transform=%27rotate(0%20212.0%2013.9)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27227.3%27%20cy=%2725.0%27%20rx=%278.4%27%20ry=%2714.0%27%20transform=%27rotate(72%20227.3%2025.0)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27221.5%27%20cy=%2743.0%27%20rx=%278.4%27%20ry=%2714.0%27%20transform=%27rotate(144%20221.5%2043.0)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27202.5%27%20cy=%2743.0%27%20rx=%278.4%27%20ry=%2714.0%27%20transform=%27rotate(216%20202.5%2043.0)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27196.7%27%20cy=%2725.0%27%20rx=%278.4%27%20ry=%2714.0%27%20transform=%27rotate(288%20196.7%2025.0)%27%20fill=%27%23f2bcd4%27/%3E%3Ccircle%20cx=%27212%27%20cy=%2730%27%20r=%277.0%27%20fill=%27%23e7a3c4%27/%3E%3Cellipse%20cx=%27132.0%27%20cy=%2778.2%27%20rx=%277.2%27%20ry=%2712.0%27%20transform=%27rotate(0%20132.0%2078.2)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27145.1%27%20cy=%2787.7%27%20rx=%277.2%27%20ry=%2712.0%27%20transform=%27rotate(72%20145.1%2087.7)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27140.1%27%20cy=%27103.2%27%20rx=%277.2%27%20ry=%2712.0%27%20transform=%27rotate(144%20140.1%20103.2)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27123.9%27%20cy=%27103.2%27%20rx=%277.2%27%20ry=%2712.0%27%20transform=%27rotate(216%20123.9%20103.2)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%27118.9%27%20cy=%2787.7%27%20rx=%277.2%27%20ry=%2712.0%27%20transform=%27rotate(288%20118.9%2087.7)%27%20fill=%27%23f2bcd4%27/%3E%3Ccircle%20cx=%27132%27%20cy=%2792%27%20r=%276.0%27%20fill=%27%23e7a3c4%27/%3E%3Cellipse%20cx=%2760.0%27%20cy=%27185.7%27%20rx=%275.4%27%20ry=%279.0%27%20transform=%27rotate(0%2060.0%20185.7)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%2769.8%27%20cy=%27192.8%27%20rx=%275.4%27%20ry=%279.0%27%20transform=%27rotate(72%2069.8%20192.8)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%2766.1%27%20cy=%27204.4%27%20rx=%275.4%27%20ry=%279.0%27%20transform=%27rotate(144%2066.1%20204.4)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%2753.9%27%20cy=%27204.4%27%20rx=%275.4%27%20ry=%279.0%27%20transform=%27rotate(216%2053.9%20204.4)%27%20fill=%27%23f2bcd4%27/%3E%3Cellipse%20cx=%2750.2%27%20cy=%27192.8%27%20rx=%275.4%27%20ry=%279.0%27%20transform=%27rotate(288%2050.2%20192.8)%27%20fill=%27%23f2bcd4%27/%3E%3Ccircle%20cx=%2760%27%20cy=%27196%27%20r=%274.5%27%20fill=%27%23e7a3c4%27/%3E%3C/svg%3E")}
body{background-color:var(--cream)}
.sec-cream{background-color:var(--cream-2)}
.hero-inner{position:relative;z-index:2}
/* floral used sparingly as corner accents only */
.page-hero{position:relative}
.page-hero::after{content:"";position:absolute;top:46px;right:-26px;width:220px;height:220px;
  background:var(--sprig) no-repeat center/contain;opacity:.5;pointer-events:none}
.page-hero::before{content:"";position:absolute;bottom:-30px;left:-30px;width:170px;height:170px;
  background:var(--sprig) no-repeat center/contain;opacity:.3;transform:scaleX(-1) rotate(12deg);pointer-events:none}
.page-hero .wrap{position:relative;z-index:2}
.sec-rose{position:relative;overflow:hidden}
.sec-rose::before{content:"";position:absolute;top:-34px;left:-36px;width:200px;height:200px;
  background:var(--sprig) no-repeat center/contain;opacity:.4;transform:scaleX(-1);pointer-events:none}
.sec-rose .wrap{position:relative;z-index:2}
@media(max-width:768px){
  .page-hero::after{width:130px;height:130px;opacity:.4}
  .page-hero::before,.sec-rose::before{width:120px;height:120px;opacity:.3}
}

/* ===== Clinic gallery ===== */
.clinic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.clinic-grid figure{margin:0;text-align:center}
.clinic-grid img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.clinic-grid figcaption{margin-top:12px;font-size:.88rem;color:var(--ink-soft);font-family:var(--serif)}
@media(max-width:768px){.clinic-grid{grid-template-columns:1fr;gap:18px;max-width:360px;margin:0 auto}}

/* ===== 3 course layout ===== */
.price-grid.course3{grid-template-columns:repeat(3,1fr);max-width:1080px;align-items:stretch}
.price-grid.course3 .price-card{padding:42px 30px;border:2px solid var(--rose-light)}
.price-grid.course3 .price-card.feature{border:2px solid var(--rose)}
.price-card .csub{display:block;font-size:1.05rem;margin-top:2px}
.price-card .amount small{font-size:1rem;color:var(--ink-soft)}
.price-grid.course3 .amount{font-size:2.5rem;white-space:nowrap}
.price-grid.course3 .amount small{white-space:nowrap}
.price-card .cdesc{font-size:.86rem;color:var(--ink-soft);line-height:1.8;margin:4px 0 18px;min-height:3.6em}
.price-badge.alt{background:linear-gradient(135deg,var(--gold),var(--rose))}
.course-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1000px;margin:56px auto 0}
.course-gallery figure{margin:0}
.course-gallery img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid #f0dbe6}
@media(max-width:900px){
  .price-grid.course3{grid-template-columns:1fr;max-width:480px}
  .price-card .cdesc{min-height:0}
}
@media(max-width:768px){
  .course-gallery{grid-template-columns:1fr;max-width:360px;gap:18px}
}

/* ===== Instagram section ===== */
.insta-handle{display:inline-block;font-family:var(--num);font-weight:700;font-size:1.35rem;color:var(--rose-deep);margin:4px 0;letter-spacing:.04em}
.insta-handle:hover{opacity:.8}
.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.insta-grid a{position:relative;display:block;aspect-ratio:1/1;overflow:hidden;border-radius:14px;box-shadow:var(--shadow-sm)}
.insta-grid img{width:100%;height:100%;object-fit:cover;transition:.45s var(--ease)}
.insta-grid a:hover img{transform:scale(1.07)}
.insta-grid .ig-ov{position:absolute;inset:0;background:rgba(207,110,144,0);transition:.35s var(--ease);display:flex;align-items:center;justify-content:center}
.insta-grid a:hover .ig-ov{background:rgba(207,110,144,.28)}
.insta-grid .ig-ov::after{content:"";width:30px;height:30px;background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='1.8'%3E%3Crect x='3' y='3' width='18' height='18' rx='5'/%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Ccircle cx='17.5' cy='6.5' r='1' fill='%23fff' stroke='none'/%3E%3C/svg%3E");opacity:0;transform:scale(.6);transition:.35s var(--ease)}
.insta-grid a:hover .ig-ov::after{opacity:1;transform:scale(1)}
.btn-insta{background:linear-gradient(135deg,#feda75,#fa7e1e 28%,#d62976 60%,#962fbf 85%,#4f5bd5);color:#fff;box-shadow:0 12px 28px rgba(214,41,118,.3)}
.btn-insta:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(214,41,118,.42)}
@media(max-width:900px){.insta-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.insta-grid{grid-template-columns:repeat(2,1fr);gap:10px}}
