/* =========================================================
   ihinseiri LP — 案A: Editorial / Cream-Navy-Gold
   独自設計（水道LPとは別系統のレイアウト）
   ========================================================= */
:root{
  /* pa-sanki-ihinseiri.com 配色準拠 */
  --paper:#FFFFFF;
  --bg:#FFFFFF;
  --bg-soft:#F5F8F8;
  --bg-mint:#E8F1F1;
  --teal:#268383;
  --teal-deep:#1B6868;
  --teal-soft:#7FB6B6;
  --teal-tint:#D6E8E8;
  --gold:#C9A961;
  --gold-deep:#A88838;
  --gold-soft:#E8D9A8;
  --line:#E0E5E5;
  --line-2:#C8D2D2;
  --text:#1A1A1A;
  --text-soft:#4A5252;
  --text-mute:#8A8F8F;
  --cream:#FFFFFF;
  --cream-2:#F5F8F8;
  --navy:#268383;
  --navy-mid:#1B6868;
  --navy-soft:#7FB6B6;
  --shadow-1:0 2px 12px rgba(38,131,131,0.08);
  --shadow-2:0 12px 36px rgba(38,131,131,0.14);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP",sans-serif;
  font-weight:400;line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
.mincho{font-family:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold-deep)}
.container{max-width:1140px;margin:0 auto;padding:0 28px}

/* typography helpers */
.eyebrow-en{
  display:inline-block;font-family:"Cormorant Garamond",serif;
  letter-spacing:0.32em;font-size:13px;color:var(--gold-deep);font-weight:600;
}
.section-title{
  font-family:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif;font-weight:600;
  font-size:36px;letter-spacing:0.08em;color:var(--teal);
  line-height:1.5;margin-top:14px;
}
.section-title .accent{color:var(--gold-deep)}
.section-desc{
  font-size:14.5px;color:var(--text-soft);margin:18px auto 0;
  max-width:680px;line-height:2;
}
.section-head{text-align:center;margin-bottom:54px;position:relative}
.section-head:after{
  content:"";display:block;width:38px;height:1px;background:var(--gold);
  margin:24px auto 0;
}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity 1s ease, transform 1s ease}
.fade-up.in{opacity:1;transform:none}
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}.delay-4{transition-delay:.4s}

/* ===== pa-sanki style: top utility bar + nav ===== */
.topbar{
  background:#fff;border-bottom:1px solid var(--line);
  padding:0 24px;
}
.topbar-inner{
  max-width:1240px;margin:0 auto;min-height:64px;
  display:flex;align-items:stretch;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.topbar-left{display:flex;align-items:center;padding:8px 0}
.topbar-left{font-size:11.5px;color:var(--text-soft);letter-spacing:0.04em}
.topbar-right{display:flex;gap:0;align-items:stretch}
.topbar-right > a{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 20px;font-size:12.5px;font-weight:600;letter-spacing:0.06em;
  color:#fff;line-height:1.2;text-align:center;
}
.topbar-right .cta-tel{
  background:linear-gradient(180deg,#D4B36C 0%,var(--gold) 100%);
  font-family:"Hiragino Sans",sans-serif;
  flex-direction:column;padding:6px 22px;
}
.topbar-right .cta-tel b{
  display:block;font-family:"Cormorant Garamond",serif;font-size:22px;letter-spacing:0.04em;
}
.topbar-right .cta-tel small{font-size:10px;font-weight:500;letter-spacing:0.1em;opacity:0.9}
.topbar-right .cta-line{background:#06C755;color:#fff}
.topbar-right .cta-line:hover{background:#05A546}
.topbar-right .cta-form{background:var(--teal);color:#fff}
.topbar-right .cta-form:hover{background:var(--teal-deep)}

/* horizontal main nav */
.main-nav-wrap{
  background:#fff;border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.main-nav{
  max-width:1240px;margin:0 auto;
  display:flex;align-items:stretch;justify-content:flex-start;
  padding:0 24px;
}
.main-nav .brand-cell{
  display:flex;align-items:center;gap:12px;padding:14px 28px 14px 0;border-right:1px solid var(--line);
}
.main-nav .brand-cell .brand-mark{
  width:42px;height:42px;border-radius:50%;background:#fff;border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;color:var(--teal);
  font-family:"Hiragino Mincho ProN",serif;font-size:20px;font-weight:600;
}
.main-nav .brand-cell .brand-text{font-size:14px;font-weight:700;color:var(--teal);line-height:1.3;letter-spacing:0.05em}
.main-nav .brand-cell .brand-text small{display:block;font-size:10px;color:var(--text-mute);font-weight:500;margin-top:2px;letter-spacing:0.08em}
.main-nav ul{
  display:flex;align-items:stretch;list-style:none;flex:1;
}
.main-nav ul li{display:flex}
.main-nav ul li a{
  display:flex;align-items:center;padding:0 18px;
  font-size:13px;color:var(--text);font-weight:500;letter-spacing:0.04em;
  border-right:1px solid var(--line);
  transition:background .2s, color .2s;
}
.main-nav ul li a:hover{background:var(--bg-mint);color:var(--teal)}
.main-nav ul li.active a{color:var(--teal);font-weight:700}
.main-nav ul li.active a:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--gold);margin-right:8px}
@media (max-width:1100px){
  .main-nav ul{flex-wrap:wrap}
  .main-nav ul li a{padding:10px 14px;font-size:12px}
}

/* sample banner / trust bar */
.sample-banner{
  background:#1F1F1F;color:#fff;text-align:center;font-size:11.5px;
  padding:9px 16px;letter-spacing:0.06em;border-bottom:1px solid var(--gold);
}
.sample-banner b{color:var(--gold)}

.trust-bar{
  background:var(--bg-mint);
  border-bottom:1px solid var(--teal-tint);
  padding:14px 16px;
}
.trust-bar .inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
}
.trust-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--paper);border:1px solid var(--line-2);
  padding:6px 14px;
  color:var(--navy);font-weight:500;font-size:12px;letter-spacing:0.04em;
}
.trust-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}

/* header */
.header{
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;max-width:1240px;margin:0 auto;gap:18px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  width:46px;height:46px;border-radius:50%;
  background:var(--paper);border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);font-weight:600;font-size:22px;
  font-family:"Noto Serif JP","Hiragino Mincho ProN",serif;
}
.brand-name{font-weight:700;font-size:18px;color:var(--navy);line-height:1.25;letter-spacing:0.06em}
.brand-name small{
  display:block;font-size:10px;color:var(--gold-deep);font-weight:600;
  margin-top:4px;letter-spacing:0.22em;
  font-family:"Cormorant Garamond",serif;
}
.header-cta{display:flex;align-items:center;gap:18px}
.header-cta .reception{font-size:11px;color:var(--text-soft);text-align:right;line-height:1.6;letter-spacing:0.04em}
.header-cta .reception b{color:var(--gold-deep);font-size:12px}
.header-cta .tel{
  font-weight:700;color:var(--navy);font-size:24px;letter-spacing:0.05em;
  font-family:"Cormorant Garamond","Helvetica Neue",sans-serif;
}
.header-cta .tel:before{content:"☎ ";font-size:16px;color:var(--gold)}

/* HERO — pa-sanki style: centered headline, side staff circles, bottom badges */
.hero{
  background:radial-gradient(ellipse at 50% 25%, #BFE0E0 0%, var(--bg-mint) 32%, var(--bg-soft) 60%, var(--paper) 90%);
  position:relative;overflow:hidden;
  padding:32px 0 48px;
  border-top:6px solid var(--gold);
  border-bottom:6px solid var(--gold);
}
.hero:before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent 0%, var(--teal-soft) 50%, transparent 100%);z-index:0;
}
.hero-grid{display:none}
.hero-pa{
  position:relative;z-index:1;max-width:1200px;margin:0 auto;
  padding:48px 28px 32px;text-align:center;
  display:grid;grid-template-columns:200px 1fr 200px;gap:24px;align-items:center;
}
.hero-side{display:flex;flex-direction:column;align-items:center;gap:12px}
.hero-side.left{align-self:end}
.hero-side.right{align-self:start}
.circle-photo{
  width:160px;height:160px;border-radius:50%;overflow:hidden;
  border:4px solid #fff;box-shadow:var(--shadow-2);background:var(--bg-mint);
}
.circle-photo img{width:100%;height:100%;object-fit:cover}
.circle-photo.lg{width:180px;height:180px}
.circle-caption{font-size:11px;color:var(--text-soft);letter-spacing:0.08em}
.circle-caption b{display:block;font-family:"Hiragino Mincho ProN",serif;color:var(--teal);font-size:14px;margin-bottom:2px;letter-spacing:0.05em}

.hero-center{padding:28px 0}
.hero-eyebrow-pa{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Hiragino Mincho ProN",serif;color:var(--gold-deep);font-size:13px;letter-spacing:0.32em;
  margin-bottom:18px;
}
.hero-eyebrow-pa:before, .hero-eyebrow-pa:after{
  content:"";display:inline-block;width:30px;height:1px;background:var(--gold);
}
.hero-headline{
  font-family:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif;
  font-weight:600;font-size:88px;color:var(--teal);
  letter-spacing:0.14em;line-height:1.35;
  text-shadow:0 2px 0 #fff;
  margin-bottom:24px;
}
.hero-headline .of{font-size:64px;color:var(--teal-deep);font-weight:500;margin:0 4px}
.hero-headline .accent{color:var(--gold-deep)}
.hero-sub{
  font-family:"Hiragino Mincho ProN",serif;font-weight:400;
  font-size:18px;color:var(--text);letter-spacing:0.08em;line-height:2;
  margin-bottom:24px;
}

/* hero badges (3 circles) */
.hero-badges-row{
  position:relative;z-index:1;max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  padding:8px 28px 36px;
}
.hero-badge{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  background:transparent;border:none;padding:6px 10px;
}
.hero-badge .badge-circle{
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(180deg,#F5E5B8 0%,var(--gold) 60%, var(--gold-deep) 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:"Hiragino Mincho ProN",serif;font-size:17px;font-weight:700;line-height:1.4;
  margin-bottom:6px;letter-spacing:0.06em;
  box-shadow:0 6px 18px rgba(168,136,56,0.35), inset 0 -6px 12px rgba(168,136,56,0.45), inset 0 0 0 4px rgba(255,255,255,0.5);
  text-shadow:0 1px 1px rgba(0,0,0,0.15);
}
.hero-badge h3{display:none}
.hero-badge p{font-size:11px;color:var(--text-soft);line-height:1.7;max-width:200px;letter-spacing:0.04em}

@media (max-width:920px){
  .hero{padding:24px 0 36px}
  .hero-pa{grid-template-columns:1fr;padding:24px 16px}
  .hero-side{flex-direction:row;justify-content:center}
  .circle-photo{width:110px;height:110px}
  .hero-headline{font-size:40px}
  .hero-sub{font-size:15px}
  .hero-badges-row{grid-template-columns:1fr;gap:14px;padding:0 16px 24px}
}
.hero-eyebrow{
  font-family:"Cormorant Garamond",serif;
  letter-spacing:0.4em;font-size:13px;color:var(--gold-deep);font-weight:600;margin-bottom:22px;
}
.hero h1{
  font-family:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif;font-weight:600;
  font-size:58px;line-height:1.4;letter-spacing:0.1em;color:var(--teal);margin-bottom:28px;
  text-shadow:0 1px 0 rgba(255,255,255,0.6);
}
.hero h1 .accent{color:var(--gold-deep);position:relative}
.hero h1 .accent:after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--gold);
}
.hero .lead{font-size:15px;color:var(--text-soft);line-height:2.1;margin-bottom:30px;max-width:520px}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:20px;padding:18px 0;margin-bottom:30px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.hero-meta-item{display:flex;align-items:baseline;gap:6px;font-size:12px;color:var(--text-soft);letter-spacing:0.06em}
.hero-meta-item b{font-family:"Cormorant Garamond",serif;color:var(--navy);font-size:22px;font-weight:600;letter-spacing:0.02em}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--navy);color:#fff;
  padding:16px 30px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:0.06em;
  border:1px solid var(--navy);transition:all .25s ease;box-shadow:var(--shadow-1);
}
.btn-primary:hover{background:var(--navy-mid);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-2)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:var(--navy);
  padding:16px 28px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:0.06em;
  border:1px solid var(--gold);transition:all .25s ease;
}
.btn-secondary:hover{background:var(--gold);color:var(--paper)}

.hero-photo{position:relative;align-self:stretch}
.hero-photo .frame{
  position:relative;overflow:hidden;
  aspect-ratio:4/5;background:var(--cream-2);box-shadow:var(--shadow-2);
}
.hero-photo .frame:before{
  content:"";position:absolute;inset:14px;border:1px solid rgba(255,255,255,0.45);z-index:2;pointer-events:none;
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo .stamp{
  position:absolute;left:-22px;bottom:38px;
  background:var(--paper);border:1px solid var(--gold);padding:14px 22px;
  font-family:"Noto Serif JP",serif;font-size:13px;color:var(--navy);
  letter-spacing:0.08em;line-height:1.6;box-shadow:var(--shadow-1);
}
.hero-photo .stamp b{
  display:block;font-family:"Cormorant Garamond",serif;
  font-size:30px;color:var(--gold-deep);font-weight:700;letter-spacing:0.02em;
}
@media (max-width:920px){
  .hero{padding:42px 0 64px}
  .hero:before{display:none}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero h1{font-size:38px}
  .hero-photo .stamp{left:auto;right:14px;bottom:14px}
}

/* stats — minimal, light */
.stats{background:var(--paper);padding:54px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-row{
  max-width:1140px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat-cell{text-align:center;padding:14px 18px;border-right:1px solid var(--line)}
.stat-cell:last-child{border-right:0}
.stat-cell .num{
  font-family:"Cormorant Garamond",serif;
  font-size:54px;color:var(--navy);font-weight:600;line-height:1;
}
.stat-cell .num small{font-size:18px;color:var(--gold-deep);margin-left:4px;letter-spacing:0.02em;font-weight:400}
.stat-cell .lbl{font-size:13px;color:var(--text-soft);margin-top:14px;letter-spacing:0.08em}
.stat-cell .lbl-en{font-family:"Cormorant Garamond",serif;font-size:11px;color:var(--gold);margin-top:6px;letter-spacing:0.3em;text-transform:uppercase}
@media (max-width:780px){
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .stat-cell{border-right:0;border-bottom:1px solid var(--line);padding:24px 14px}
  .stat-cell:nth-last-child(-n+2){border-bottom:0}
}

/* generic section */
.sec{padding:104px 0;background:var(--paper)}
.sec.alt{background:var(--bg-soft)}
.sec.tight{padding:78px 0}

/* problem */
.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.problem-list{list-style:none}
.problem-list li{
  font-size:16px;color:var(--text);font-weight:500;
  padding:18px 0 18px 36px;border-bottom:1px solid var(--line);position:relative;letter-spacing:0.02em;
}
.problem-list li:before{content:"";position:absolute;left:0;top:24px;width:18px;height:1px;background:var(--gold)}
.problem-list li:last-child{border-bottom:0}
.problem-photo .frame{
  aspect-ratio:4/5;overflow:hidden;background:var(--cream-2);position:relative;box-shadow:var(--shadow-1);
}
.problem-photo .frame:before{content:"";position:absolute;inset:12px;border:1px solid rgba(255,255,255,0.45);z-index:2;pointer-events:none}
.problem-photo img{width:100%;height:100%;object-fit:cover}
@media (max-width:880px){.problem-grid{grid-template-columns:1fr;gap:36px}}

/* STAFF */
.staff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.staff-card{background:var(--paper);border:1px solid var(--line);transition:transform .35s ease, box-shadow .35s ease, border-color .35s}
.staff-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:var(--gold-soft)}
.staff-card .photo{aspect-ratio:1/1.15;overflow:hidden;background:var(--cream-2)}
.staff-card .photo img{width:100%;height:100%;object-fit:cover}
.staff-card .body{padding:22px 22px 26px}
.staff-card .pos{
  font-family:"Cormorant Garamond",serif;font-size:11px;color:var(--gold-deep);
  letter-spacing:0.32em;font-weight:600;margin-bottom:8px;text-transform:uppercase;
}
.staff-card h3{font-size:20px;color:var(--navy);margin-bottom:12px;letter-spacing:0.04em;font-weight:700}
.staff-card .qual{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.staff-card .qual span{font-size:10.5px;background:var(--cream);color:var(--navy);padding:4px 9px;border:1px solid var(--line-2);letter-spacing:0.02em}
.staff-card p{font-size:13px;color:var(--text-soft);line-height:1.85}
@media (max-width:980px){.staff-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.staff-grid{grid-template-columns:1fr}}

/* FLOW — vertical timeline */
.flow-timeline{max-width:880px;margin:0 auto;position:relative;padding-left:48px}
.flow-timeline:before{content:"";position:absolute;left:14px;top:14px;bottom:14px;width:1px;background:var(--line-2)}
.flow-item{position:relative;padding:22px 0;border-bottom:1px dashed var(--line)}
.flow-item:last-child{border-bottom:0}
.flow-item .num{
  position:absolute;left:-48px;top:22px;
  width:30px;height:30px;border-radius:50%;
  background:var(--paper);border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:"Cormorant Garamond",serif;font-size:13px;color:var(--gold-deep);font-weight:700;
}
.flow-item .step-en{font-family:"Cormorant Garamond",serif;font-size:11px;color:var(--gold-deep);letter-spacing:0.3em;font-weight:600}
.flow-item h4{font-size:19px;color:var(--navy);margin:6px 0 10px;letter-spacing:0.05em}
.flow-item p{font-size:14px;color:var(--text-soft);line-height:2}
@media (max-width:600px){
  .flow-timeline{padding-left:38px}
  .flow-item .num{left:-38px;width:24px;height:24px;font-size:11px}
}

/* CASES */
.cases-grid{display:grid;grid-template-columns:1fr;gap:40px}
.case-card{background:var(--paper);border:1px solid var(--line);display:grid;grid-template-columns:1.4fr 1fr}
.case-photos{display:grid;grid-template-columns:1fr 1fr}
.case-photos figure{position:relative;margin:0;background:var(--cream-2);aspect-ratio:4/3;overflow:hidden}
.case-photos figure img{width:100%;height:100%;object-fit:cover}
.case-photos figcaption{
  position:absolute;top:12px;left:12px;
  background:rgba(27,44,74,0.85);color:#fff;
  font-family:"Cormorant Garamond",serif;
  font-size:11px;padding:5px 12px;letter-spacing:0.32em;font-weight:600;
}
.case-photos figure.after figcaption{background:var(--gold);color:var(--paper)}
.case-info{padding:32px 32px;display:flex;flex-direction:column;justify-content:center}
.case-tag{
  display:inline-block;font-family:"Cormorant Garamond",serif;
  font-size:11px;color:var(--gold-deep);
  letter-spacing:0.3em;font-weight:600;align-self:flex-start;margin-bottom:14px;
}
.case-info h3{font-size:20px;color:var(--navy);margin-bottom:18px;line-height:1.6;letter-spacing:0.04em}
.case-info dl{display:grid;grid-template-columns:auto 1fr;gap:10px 18px;font-size:13.5px}
.case-info dt{color:var(--text-mute);font-weight:500;letter-spacing:0.04em}
.case-info dd{color:var(--text);font-weight:500}
.case-info dd.price{color:var(--gold-deep);font-size:18px;font-weight:700;font-family:"Cormorant Garamond",serif;letter-spacing:0.02em}
@media (max-width:880px){.case-card{grid-template-columns:1fr}}

/* PRICE — card based */
.price-pill{
  display:inline-block;background:var(--paper);border:1px solid var(--gold);
  padding:8px 22px;color:var(--gold-deep);font-size:13px;font-weight:600;letter-spacing:0.08em;margin-bottom:32px;
}
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1080px;margin:0 auto}
.price-card{
  background:var(--paper);border:1px solid var(--line);padding:32px 26px;
  display:flex;flex-direction:column;gap:14px;position:relative;
  transition:border-color .3s, transform .3s, box-shadow .3s;
}
.price-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow-2)}
.price-card .size{font-family:"Cormorant Garamond",serif;font-size:11px;color:var(--gold-deep);letter-spacing:0.32em;font-weight:600;text-transform:uppercase}
.price-card .label{font-size:21px;color:var(--navy);font-weight:700;letter-spacing:0.04em}
.price-card .meta{font-size:12.5px;color:var(--text-soft);letter-spacing:0.03em}
.price-card .yen{
  font-family:"Cormorant Garamond",serif;
  font-size:42px;color:var(--gold-deep);font-weight:600;letter-spacing:0.02em;
  line-height:1;border-top:1px solid var(--line);padding-top:18px;
}
.price-card .yen small{font-size:14px;color:var(--text);font-family:"Noto Sans JP",sans-serif;font-weight:400;margin-left:4px}
.price-note{text-align:center;font-size:12.5px;color:var(--text-mute);margin-top:32px;line-height:1.9}
@media (max-width:880px){.price-cards{grid-template-columns:1fr}}

/* INSURANCE BAND */
.insurance-band{
  background:var(--navy);color:#fff;padding:78px 24px;text-align:center;
  border-top:1px solid var(--gold);border-bottom:1px solid var(--gold);
}
.insurance-band .num{font-family:"Cormorant Garamond",serif;font-size:88px;color:var(--gold);font-weight:600;line-height:1;letter-spacing:0.02em}
.insurance-band .num small{font-size:22px;color:#fff;font-family:"Noto Sans JP",sans-serif;margin-left:8px;font-weight:400}
.insurance-band h2{font-size:22px;color:#fff;font-weight:600;letter-spacing:0.1em;margin-top:18px}
.insurance-band p{font-size:14px;color:rgba(255,255,255,0.78);max-width:620px;margin:18px auto 0;line-height:2}
.insurance-band .eyebrow-en{color:var(--gold-soft);margin-bottom:8px}

/* OPTIONS */
.options-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.option-card{
  background:var(--paper);
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:38px 26px;text-align:center;transition:background .3s;
}
.option-card:hover{background:var(--cream)}
.option-icon{
  width:56px;height:56px;border-radius:50%;
  background:var(--cream);border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);font-weight:600;font-size:22px;
  margin:0 auto 18px;
  font-family:"Noto Serif JP",serif;
}
.option-card h3{font-size:15px;color:var(--navy);margin-bottom:10px;letter-spacing:0.05em;font-weight:700}
.option-card p{font-size:12.5px;color:var(--text-soft);line-height:1.85}
@media (max-width:980px){.options-grid{grid-template-columns:repeat(2,1fr)}}

/* REASONS */
.reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.reason-cell{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:48px 32px;background:var(--paper);
  display:flex;flex-direction:column;gap:16px;
}
.reason-cell .num-en{font-family:"Cormorant Garamond",serif;font-size:13px;color:var(--gold-deep);letter-spacing:0.32em;font-weight:600}
.reason-cell h3{font-size:18px;color:var(--navy);font-weight:700;letter-spacing:0.06em;margin:0}
.reason-cell .big{font-family:"Cormorant Garamond",serif;font-size:48px;color:var(--gold-deep);font-weight:600;letter-spacing:0.02em;line-height:1}
.reason-cell .big small{font-size:18px;font-family:"Noto Sans JP",sans-serif;color:var(--text);margin-left:4px;font-weight:400}
.reason-cell p{font-size:13.5px;color:var(--text-soft);line-height:1.9}
@media (max-width:980px){.reasons-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.reasons-grid{grid-template-columns:1fr}}

/* VOICE */
.voices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.voice-card{background:var(--paper);border:1px solid var(--line);padding:32px 26px;position:relative}
.voice-card:before{
  content:"\201C";font-family:"Cormorant Garamond",serif;
  font-size:84px;color:var(--gold-soft);position:absolute;top:14px;left:18px;line-height:1;
}
.voice-card .stars{color:var(--gold);font-size:14px;letter-spacing:0.2em;margin-bottom:14px;position:relative;z-index:1}
.voice-card .text{font-size:13.5px;color:var(--text);line-height:2;position:relative;z-index:1}
.voice-card .meta{font-size:12px;color:var(--text-mute);margin-top:18px;letter-spacing:0.06em;position:relative;z-index:1;border-top:1px solid var(--line);padding-top:14px}
@media (max-width:880px){.voices-grid{grid-template-columns:1fr}}

/* CONSULT */
.consult-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.consult-card{background:var(--paper);border:1px solid var(--line);padding:30px 30px;position:relative}
.consult-card:before{content:"";position:absolute;left:0;top:30px;width:3px;height:32px;background:var(--gold)}
.consult-card h3{font-size:16px;color:var(--navy);margin-bottom:12px;letter-spacing:0.04em;padding-left:14px}
.consult-card p{font-size:13.5px;color:var(--text-soft);line-height:2;padding-left:14px}
.consult-card .note{font-size:11px;color:var(--text-mute);margin-top:10px;display:block;padding-left:14px}
@media (max-width:780px){.consult-grid{grid-template-columns:1fr}}

/* FAQ */
.faq{max-width:880px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:22px 0}
.faq summary{
  list-style:none;cursor:pointer;font-size:15.5px;color:var(--navy);font-weight:600;
  letter-spacing:0.04em;display:flex;align-items:flex-start;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:before{
  content:"Q";font-family:"Cormorant Garamond",serif;font-size:20px;color:var(--gold-deep);
  font-weight:700;flex-shrink:0;line-height:1;margin-top:2px;
}
.faq .a{font-size:14px;color:var(--text-soft);line-height:2;padding:18px 0 4px 38px;letter-spacing:0.02em}

/* CTA BAND */
.cta-band{background:var(--cream-2);padding:88px 28px;text-align:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band h2{font-size:32px;color:var(--navy);font-weight:700;letter-spacing:0.06em;line-height:1.5;margin-top:14px}
.cta-band h2 .accent{color:var(--gold-deep)}
.cta-band p{font-size:14.5px;color:var(--text-soft);max-width:560px;margin:18px auto 32px;line-height:2}
.cta-band .btn-tel-large{
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
  background:var(--paper);border:1.5px solid var(--gold);
  color:var(--navy);font-family:"Cormorant Garamond",serif;font-size:36px;font-weight:700;letter-spacing:0.04em;
  padding:24px 48px;
}
.cta-band .btn-tel-large small{font-family:"Noto Sans JP",sans-serif;font-size:11px;color:var(--gold-deep);letter-spacing:0.2em;font-weight:600}
.cta-band .reception-line{font-size:12.5px;color:var(--text-soft);margin-top:24px;letter-spacing:0.06em}

/* COMPANY */
.company-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px}
.company-grid dl{display:grid;grid-template-columns:140px 1fr;gap:18px 24px;font-size:13.5px}
.company-grid dt{color:var(--gold-deep);letter-spacing:0.1em;font-weight:600;font-size:12px;border-top:1px solid var(--line);padding-top:18px}
.company-grid dd{color:var(--text);line-height:1.9;border-top:1px solid var(--line);padding-top:18px}
.area-list h3{font-size:15px;color:var(--navy);margin-bottom:18px;letter-spacing:0.06em}
.area-list ul{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;list-style:none;font-size:13px}
.area-list li{background:var(--paper);border:1px solid var(--line);padding:8px 12px;text-align:center;color:var(--text);letter-spacing:0.04em}
@media (max-width:880px){
  .company-grid{grid-template-columns:1fr}
  .company-grid dl{grid-template-columns:100px 1fr}
}

/* footer */
.footer{background:var(--navy);color:#fff;text-align:center;padding:48px 24px 32px}
.footer p{font-size:14px;letter-spacing:0.06em}
.footer p+p{margin-top:8px;font-size:11.5px;color:rgba(255,255,255,0.62)}

/* sticky tel bar */
.tel-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:var(--navy);color:#fff;text-align:center;padding:12px 16px;
  display:none;border-top:1px solid var(--gold);
}
.tel-bar a{
  color:#fff;font-family:"Cormorant Garamond",serif;font-size:22px;font-weight:700;letter-spacing:0.04em;
  display:inline-flex;flex-direction:column;align-items:center;line-height:1.2;
}
.tel-bar a small{font-family:"Noto Sans JP",sans-serif;font-size:10px;color:var(--gold-soft);letter-spacing:0.16em;font-weight:500;margin-top:2px}
@media (max-width:780px){
  .tel-bar{display:block}
  body{padding-bottom:78px}
}

/* =========================================================
   MOBILE RESPONSIVE (<=768px / <=480px)
   ========================================================= */
@media (max-width:768px){
  .container{padding:0 18px}

  /* topbar: hide left tagline, stack CTAs */
  .topbar{padding:0}
  .topbar-inner{min-height:0;gap:0;flex-direction:column}
  .topbar-left{display:none}
  .topbar-right{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}
  .topbar-right > a{padding:10px 8px;font-size:11px;letter-spacing:0.02em}
  .topbar-right .cta-tel{
    grid-column:1 / -1;flex-direction:column;padding:8px 8px;gap:2px;
  }
  .topbar-right .cta-tel b{font-size:20px;letter-spacing:0.02em}
  .topbar-right .cta-tel small{font-size:10px}
  .topbar-right .cta-line, .topbar-right .cta-form{padding:12px 8px}
  .topbar-right .cta-line br, .topbar-right .cta-form br{display:none}

  /* trust bar — smaller badges */
  .trust-bar{padding:10px 12px}
  .trust-bar .inner{gap:6px}
  .trust-badge{font-size:10.5px;padding:4px 9px;letter-spacing:0.02em}

  /* main nav — horizontal scroll instead of wrap */
  .main-nav{padding:0;flex-direction:column;align-items:stretch}
  .main-nav .brand-cell{
    padding:10px 16px;border-right:0;border-bottom:1px solid var(--line);justify-content:center;
  }
  .main-nav .brand-cell .brand-mark{width:34px;height:34px;font-size:17px}
  .main-nav .brand-cell .brand-text{font-size:13px}
  .main-nav ul{
    flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .main-nav ul::-webkit-scrollbar{display:none}
  .main-nav ul li a{
    padding:11px 14px;font-size:12px;white-space:nowrap;border-right:1px solid var(--line);
  }

  /* sections — tighter padding & smaller titles */
  .sec{padding:56px 0}
  .sec.tight{padding:44px 0}
  .section-head{margin-bottom:36px}
  .section-head:after{margin-top:18px}
  .section-title{font-size:24px;letter-spacing:0.05em;line-height:1.5}
  .section-desc{font-size:13.5px;line-height:1.9}
  .eyebrow-en{font-size:11px;letter-spacing:0.24em}

  /* HERO — tighter & no overflow */
  .hero{padding:20px 0 28px;border-top-width:4px;border-bottom-width:4px}
  .hero-pa{padding:18px 14px 14px;gap:14px}
  .hero-side{flex-direction:row;justify-content:center;gap:14px}
  .circle-photo, .circle-photo.lg{width:90px;height:90px;border-width:3px}
  .circle-caption{font-size:10px}
  .circle-caption b{font-size:12px}
  .hero-eyebrow-pa{font-size:11px;letter-spacing:0.2em;margin-bottom:12px}
  .hero-eyebrow-pa:before, .hero-eyebrow-pa:after{width:18px}
  .hero-headline{
    font-size:32px;letter-spacing:0.06em;line-height:1.4;margin-bottom:14px;
  }
  .hero-headline .of{font-size:24px}
  .hero-sub{font-size:13.5px;letter-spacing:0.04em;line-height:1.9;margin-bottom:14px}
  .hero-badges-row{padding:0 14px 20px;gap:12px}
  .hero-badge{flex-direction:row;align-items:center;gap:14px;text-align:left}
  .hero-badge .badge-circle{width:80px;height:80px;font-size:13px;flex-shrink:0;margin-bottom:0}
  .hero-badge p{font-size:12px;max-width:none}

  /* stats */
  .stats{padding:36px 0}
  .stat-cell{padding:18px 10px}
  .stat-cell .num{font-size:38px}
  .stat-cell .num small{font-size:14px}
  .stat-cell .lbl{font-size:12px;margin-top:8px;letter-spacing:0.04em}
  .stat-cell .lbl-en{font-size:10px;letter-spacing:0.2em}

  /* problem */
  .problem-list li{font-size:14px;padding:14px 0 14px 26px}
  .problem-list li:before{top:20px;width:14px}

  /* staff */
  .staff-card .body{padding:18px 16px 20px}
  .staff-card h3{font-size:17px;margin-bottom:8px}

  /* flow */
  .flow-item{padding:18px 0}
  .flow-item h4{font-size:17px}
  .flow-item p{font-size:13px;line-height:1.85}

  /* cases */
  .cases-grid{gap:28px}
  .case-info{padding:22px 18px}
  .case-info h3{font-size:17px;margin-bottom:14px}
  .case-info dl{grid-template-columns:80px 1fr;gap:8px 12px;font-size:13px}
  .case-info dd.price{font-size:16px}
  .case-photos figcaption{font-size:10px;padding:4px 9px;letter-spacing:0.2em}

  /* price */
  .price-card{padding:24px 20px}
  .price-card .label{font-size:18px}
  .price-card .yen{font-size:34px}

  /* insurance band */
  .insurance-band{padding:56px 20px}
  .insurance-band .num{font-size:62px}
  .insurance-band .num small{font-size:18px}
  .insurance-band h2{font-size:18px;letter-spacing:0.06em}
  .insurance-band p{font-size:13px;line-height:1.9}

  /* options */
  .option-card{padding:26px 16px}
  .option-icon{width:46px;height:46px;font-size:18px;margin-bottom:12px}
  .option-card h3{font-size:14px}

  /* reasons */
  .reason-cell{padding:30px 22px;gap:12px}
  .reason-cell .big{font-size:38px}
  .reason-cell h3{font-size:16px}

  /* voice */
  .voice-card{padding:26px 22px}
  .voice-card:before{font-size:64px;top:8px;left:14px}

  /* consult */
  .consult-card{padding:24px 22px}
  .consult-card:before{top:24px}

  /* faq */
  .faq details{padding:18px 0}
  .faq summary{font-size:14px;gap:10px}
  .faq summary:before{font-size:17px}
  .faq .a{font-size:13px;padding:14px 0 4px 28px}

  /* cta band */
  .cta-band{padding:56px 18px}
  .cta-band h2{font-size:22px;letter-spacing:0.04em}
  .cta-band p{font-size:13.5px;margin:14px auto 22px}
  .cta-band .btn-tel-large{font-size:24px;padding:18px 24px;letter-spacing:0.02em;width:100%;max-width:340px}
  .cta-band .btn-tel-large small{font-size:10px;letter-spacing:0.14em}
  .cta-band .reception-line{font-size:11.5px;line-height:1.9}

  /* company */
  .company-grid{gap:32px}
  .company-grid dl{grid-template-columns:90px 1fr;gap:12px 14px;font-size:13px}
  .company-grid dt{padding-top:12px;font-size:11px}
  .company-grid dd{padding-top:12px}
  .area-list ul{grid-template-columns:repeat(2,1fr)}

  /* footer */
  .footer{padding:36px 18px 28px}
  .footer p{font-size:12.5px}

  /* sample banner */
  .sample-banner{font-size:10.5px;padding:8px 12px;line-height:1.6;letter-spacing:0.02em}

  /* sticky tel bar — already shown <=780, just tune */
  .tel-bar a{font-size:19px}
  .tel-bar a small{font-size:9.5px}
}

@media (max-width:420px){
  .hero-headline{font-size:26px;letter-spacing:0.04em}
  .hero-headline .of{font-size:20px}
  .section-title{font-size:21px}
  .hero-side{flex-direction:column;gap:6px}
  .hero-badge{flex-direction:column;gap:8px;text-align:center}
  .hero-badge p{font-size:11px}
  .stat-cell .num{font-size:32px}
  .reasons-grid{grid-template-columns:1fr}
  .cta-band .btn-tel-large{font-size:20px}
}
