:root{
  --navy:#0F2347;
  --navy-mid:#1B3A6B;
  --navy-dark:#08152C;
  --aqua:#3DA5D9;
  --aqua-light:#E6F2FA;
  --gold:#D4A24C;
  --gold-dark:#B8893F;
  --gold-light:#F5E5B5;
  --orange:#F39200;
  --orange-dark:#D87C00;
  --bg:#FFFFFF;
  --bg-alt:#F7F4EE;
  --bg-dark:#0A1628;
  --text:#1a1a1a;
  --text-soft:#555;
  --text-mute:#888;
  --line:#E2E8EC;
  --gold-grad:linear-gradient(135deg,#E8C885 0%,#D4A24C 50%,#A07932 100%);
  --navy-grad:linear-gradient(135deg,#1B3A6B 0%,#0F2347 60%,#08152C 100%);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif;
  color:var(--text);line-height:1.85;background:var(--bg);
  -webkit-font-smoothing:antialiased;
  padding-bottom:64px;
  overflow-x:hidden;
}
.sans{font-family:"Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","Noto Sans JP",sans-serif}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-decoration:none}
.container{max-width:1140px;margin:0 auto;padding:0 24px;position:relative}

/* fade-up animation */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .9s ease, transform .9s ease}
.fade-up.in{opacity:1;transform:none}
.delay-1{transition-delay:.12s}.delay-2{transition-delay:.24s}.delay-3{transition-delay:.36s}.delay-4{transition-delay:.48s}

/* sample banner */
.sample-banner{
  background:#0A0A0A;color:#fff;text-align:center;font-size:12px;
  padding:8px 16px;letter-spacing:0.05em;
  border-bottom:1px solid var(--gold);
}
.sample-banner b{color:var(--gold)}

/* header */
.header{background:rgba(255,255,255,0.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(212,162,76,0.3);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:1200px;margin:0 auto;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  width:52px;height:52px;border-radius:50%;
  background:var(--navy-grad);
  display:flex;align-items:center;justify-content:center;color:var(--gold);font-weight:700;font-size:22px;
  box-shadow:0 6px 18px rgba(15,35,71,0.35), inset 0 0 0 2px var(--gold);
  font-family:"Hiragino Mincho ProN",serif;
}
.brand-name{font-weight:700;font-size:20px;color:var(--navy);line-height:1.2;letter-spacing:0.05em}
.brand-name small{display:block;font-size:11px;color:var(--gold-dark);font-weight:600;margin-top:4px;letter-spacing:0.15em}
.header-cta{display:flex;align-items:center;gap:18px}
.header-cta .reception{font-size:12px;color:var(--text-soft);text-align:right;font-family:"Hiragino Sans",sans-serif}
.header-cta .reception b{color:var(--orange-dark);font-size:13px}
.header-cta .tel{font-weight:800;color:var(--navy);font-size:26px;letter-spacing:0.04em;font-family:"Helvetica Neue","Arial",sans-serif}
.header-cta .tel:before{content:"📞 ";font-size:18px;filter:saturate(0.5)}

/* HERO */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;background:#000}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:0.55;transform:scale(1.05)}
.hero-bg:before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(8,21,44,0.92) 0%,rgba(15,35,71,0.7) 50%,rgba(8,21,44,0.55) 100%);
  z-index:1;
}
.hero-bg:after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 80% 20%,rgba(212,162,76,0.25) 0%,transparent 50%);
  z-index:2;
}
.hero-grid{position:relative;z-index:3;max-width:1200px;margin:0 auto;padding:80px 24px;width:100%;display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;color:var(--gold);
  font-family:"Helvetica Neue",sans-serif;font-size:13px;font-weight:700;letter-spacing:0.4em;
  text-transform:uppercase;margin-bottom:24px;
}
.hero-eyebrow:before{content:"";width:48px;height:1px;background:var(--gold)}
.hero h1{font-size:64px;line-height:1.3;color:#fff;font-weight:700;letter-spacing:0.02em;text-shadow:0 4px 24px rgba(0,0,0,0.4)}
.hero h1 .accent{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;
}
.hero .lead{margin-top:28px;color:rgba(255,255,255,0.88);font-size:17px;line-height:2;max-width:540px;font-family:"Hiragino Sans",sans-serif;font-weight:300}
.hero-badges{display:flex;gap:10px;margin-top:32px;flex-wrap:wrap}
.hero-badges .badge{
  background:rgba(255,255,255,0.06);border:1px solid rgba(212,162,76,0.6);color:var(--gold-light);
  font-family:"Hiragino Sans",sans-serif;
  font-size:13px;font-weight:700;padding:8px 16px;border-radius:999px;
  backdrop-filter:blur(10px);letter-spacing:0.05em;
}
.hero-badges .badge.solid{background:var(--gold-grad);border-color:transparent;color:var(--navy-dark);box-shadow:0 4px 16px rgba(212,162,76,0.4)}
.hero-actions{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.btn-tel{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--gold-grad);
  color:var(--navy-dark);
  font-weight:800;font-size:24px;padding:20px 32px;border-radius:10px;
  box-shadow:0 12px 30px rgba(212,162,76,0.5),0 0 0 1px rgba(255,255,255,0.2) inset;
  transition:transform .25s, box-shadow .25s;
  font-family:"Helvetica Neue","Arial",sans-serif;letter-spacing:0.02em;
  position:relative;overflow:hidden;
}
.btn-tel:before{
  content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,0.5),transparent);
  transition:left .8s;
}
.btn-tel:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(212,162,76,0.6)}
.btn-tel:hover:before{left:100%}
.btn-tel small{display:block;font-size:11px;font-weight:600;opacity:0.85;font-family:"Hiragino Sans",sans-serif;letter-spacing:0.05em}
.btn-form{
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.4);
  font-weight:600;padding:18px 28px;border-radius:10px;font-size:15px;
  font-family:"Hiragino Sans",sans-serif;
  transition:background .25s, border-color .25s;
}
.btn-form:hover{background:rgba(255,255,255,0.08);border-color:var(--gold)}
.hero-image{position:relative}
.hero-image .frame{
  border-radius:16px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,0.6),0 0 0 1px rgba(212,162,76,0.4);
  position:relative;
}
.hero-image .frame:after{
  content:"";position:absolute;inset:0;border-radius:16px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.15);
  pointer-events:none;
}
.hero-image .frame img{display:block;width:100%}
.hero-image .stamp{
  position:absolute;right:-18px;top:-18px;
  background:var(--gold-grad);color:var(--navy-dark);
  width:130px;height:130px;border-radius:50%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;font-weight:800;font-size:13px;line-height:1.3;
  box-shadow:0 14px 36px rgba(212,162,76,0.6),inset 0 0 0 2px rgba(255,255,255,0.4);
  transform:rotate(-8deg);text-align:center;letter-spacing:0.05em;
  font-family:"Hiragino Sans",sans-serif;
}
.hero-image .stamp b{font-size:34px;display:block;margin:2px 0;font-family:"Helvetica Neue",sans-serif;letter-spacing:0.02em}
.hero-image .stamp small{font-size:10px;font-weight:600}
.hero-scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.6);font-size:11px;letter-spacing:0.3em;z-index:3;font-family:"Helvetica Neue",sans-serif}
.hero-scroll:after{content:"";display:block;width:1px;height:36px;background:rgba(255,255,255,0.4);margin:8px auto 0;animation:scrolldot 2s ease-in-out infinite}
@keyframes scrolldot{0%,100%{transform:scaleY(0.4);transform-origin:top}50%{transform:scaleY(1)}}

/* big stats band */
.stats-band{
  background:var(--navy-grad);color:#fff;padding:64px 24px;position:relative;overflow:hidden;
}
.stats-band:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0,rgba(212,162,76,0.15) 0%,transparent 60%);
}
.stats-grid{position:relative;z-index:1;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{font-family:"Helvetica Neue","Arial",sans-serif;font-weight:200;font-size:64px;line-height:1;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-0.02em}
.stat .num small{font-size:24px;margin-left:4px;font-weight:300;color:var(--gold-light);background:none;-webkit-text-fill-color:var(--gold-light)}
.stat .label{margin-top:14px;font-family:"Hiragino Sans",sans-serif;font-size:13px;color:rgba(255,255,255,0.85);letter-spacing:0.15em}
.stat .label-en{font-family:"Helvetica Neue",sans-serif;font-size:10px;color:var(--gold);letter-spacing:0.3em;margin-top:4px}

/* section common */
.sec{padding:110px 0;position:relative}
.sec.alt{background:var(--bg-alt)}
.sec-head{text-align:center;margin-bottom:64px;position:relative}
.sec-head .eyebrow{font-family:"Helvetica Neue",sans-serif;color:var(--gold-dark);font-size:12px;font-weight:700;letter-spacing:0.4em;text-transform:uppercase;display:inline-block}
.sec-head .eyebrow:before,.sec-head .eyebrow:after{content:"";display:inline-block;width:32px;height:1px;background:var(--gold);vertical-align:middle;margin:0 14px}
.sec-head h2{font-size:40px;font-weight:700;color:var(--navy);margin-top:18px;line-height:1.5;letter-spacing:0.02em}
.sec-head h2 .accent{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.sec-head .desc{color:var(--text-soft);margin-top:18px;font-size:15px;font-family:"Hiragino Sans",sans-serif}
.sec-head .bg-en{
  position:absolute;top:-30px;left:50%;transform:translateX(-50%);
  font-family:"Helvetica Neue","Arial",sans-serif;font-size:140px;font-weight:800;
  color:transparent;-webkit-text-stroke:1px rgba(15,35,71,0.06);letter-spacing:0.05em;
  white-space:nowrap;z-index:0;pointer-events:none;
}
.sec-head>*{position:relative;z-index:1}

/* problem checklist */
.problem{display:grid;grid-template-columns:1fr 1.05fr;gap:50px;align-items:center}
.problem-list{display:flex;flex-direction:column;gap:14px;font-family:"Hiragino Sans",sans-serif}
.problem-list li{
  list-style:none;background:#fff;
  border:1px solid var(--line);
  border-left:3px solid var(--gold);
  padding:20px 24px;font-size:16px;font-weight:600;
  display:flex;align-items:center;gap:14px;
  border-radius:6px;transition:transform .25s, box-shadow .25s;
  box-shadow:0 2px 12px rgba(15,35,71,0.04);
}
.problem-list li:hover{transform:translateX(4px);box-shadow:0 8px 24px rgba(212,162,76,0.18)}
.problem-list li:before{
  content:"✓";color:#fff;font-weight:900;font-size:16px;
  width:28px;height:28px;
  background:var(--gold-grad);
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 4px 10px rgba(212,162,76,0.4);
}
.problem-image .frame{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 30px 60px rgba(15,35,71,0.18);transform:perspective(1000px) rotateY(-3deg)}
.problem-image .frame:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(212,162,76,0.15));pointer-events:none}

/* price table */
.price-frame{
  background:#fff;border-radius:18px;
  box-shadow:0 30px 80px rgba(15,35,71,0.12),0 0 0 1px rgba(212,162,76,0.25);
  overflow:hidden;position:relative;
}
.price-frame:before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gold-grad);
}
.price-intro{text-align:center;margin-bottom:36px}
.price-intro .price-pill{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--navy);color:var(--gold);
  font-family:"Hiragino Sans",sans-serif;
  font-weight:700;padding:10px 28px;border-radius:999px;font-size:14px;letter-spacing:0.15em;
  border:1px solid var(--gold);
  box-shadow:0 8px 24px rgba(15,35,71,0.2);
}
.price-intro .price-pill:before{content:"●";color:var(--gold);font-size:8px}
.price-table table{width:100%;border-collapse:collapse}
.price-table th,.price-table td{padding:22px 28px;text-align:left;border-bottom:1px solid var(--line);font-family:"Hiragino Sans",sans-serif}
.price-table thead th{
  background:var(--navy-grad);color:var(--gold-light);
  font-weight:700;font-size:13px;letter-spacing:0.2em;
  text-transform:uppercase;
}
.price-table tbody tr{transition:background .2s}
.price-table tbody tr:hover{background:#FCF8EE}
.price-table tbody tr:last-child td{border-bottom:none}
.price-table .item{font-weight:700;color:var(--navy);font-size:16px;font-family:"Hiragino Mincho ProN",serif}
.price-table .place{color:var(--text-soft);font-size:14px}
.price-table .price{font-family:"Helvetica Neue","Arial",sans-serif;font-weight:300;color:var(--navy);font-size:28px;white-space:nowrap;text-align:right;letter-spacing:0.01em}
.price-table .price b{font-weight:700;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.price-table .price small{font-size:11px;color:var(--text-mute);font-weight:500;display:block;margin-top:4px;letter-spacing:0.05em}
.price-note{margin-top:20px;font-size:13px;color:var(--text-soft);text-align:center;font-family:"Hiragino Sans",sans-serif}

/* services */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.service-card{
  background:#fff;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 12px 28px rgba(15,35,71,0.06);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s;
  position:relative;
}
.service-card:before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gold-grad);transform:scaleX(0);transform-origin:left;transition:transform .4s;
  z-index:2;
}
.service-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(15,35,71,0.18)}
.service-card:hover:before{transform:scaleX(1)}
.service-card .photo{aspect-ratio:3/2;overflow:hidden;position:relative}
.service-card .photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.service-card:hover .photo img{transform:scale(1.08)}
.service-card .photo:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 70%,rgba(8,21,44,0.4));pointer-events:none}
.service-card .body{padding:24px}
.service-card .num-tag{font-family:"Helvetica Neue",sans-serif;font-size:11px;color:var(--gold-dark);font-weight:700;letter-spacing:0.3em;margin-bottom:8px}
.service-card h3{color:var(--navy);font-size:20px;margin-bottom:10px;font-family:"Hiragino Mincho ProN",serif}
.service-card p{color:var(--text-soft);font-size:14px;line-height:1.85;font-family:"Hiragino Sans",sans-serif}

/* reasons */
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.reason-card{
  background:#fff;border-radius:14px;padding:40px 28px;
  border:1px solid var(--line);text-align:center;
  position:relative;overflow:hidden;
  transition:transform .3s, box-shadow .3s;
  box-shadow:0 8px 20px rgba(15,35,71,0.04);
}
.reason-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(15,35,71,0.14)}
.reason-card .reason-num{
  position:absolute;top:14px;right:18px;
  font-family:"Helvetica Neue",sans-serif;font-size:56px;font-weight:200;
  color:transparent;-webkit-text-stroke:1px rgba(212,162,76,0.4);letter-spacing:-0.04em;
  line-height:1;
}
.reason-card h3{color:var(--navy);font-size:18px;margin-bottom:8px;font-family:"Hiragino Sans",sans-serif;font-weight:700}
.reason-card .big{
  display:block;font-size:48px;font-weight:200;margin:12px 0;
  font-family:"Helvetica Neue","Arial",sans-serif;letter-spacing:-0.02em;line-height:1;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.reason-card .big small{font-size:18px;background:none;-webkit-text-fill-color:var(--gold-dark);margin-left:2px}
.reason-card p{color:var(--text-soft);font-size:14px;line-height:1.85;font-family:"Hiragino Sans",sans-serif;margin-top:8px}

/* flow */
.flow{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative}
.flow:before{
  content:"";position:absolute;top:60px;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold) 10%,var(--gold) 90%,transparent);
  opacity:0.5;
}
.flow-step{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:60px 18px 28px;text-align:center;position:relative;
  box-shadow:0 8px 20px rgba(15,35,71,0.04);
  font-family:"Hiragino Sans",sans-serif;
}
.flow-step .step-num{
  position:absolute;top:-2px;left:50%;transform:translate(-50%,-50%);
  background:var(--navy-grad);color:var(--gold);
  font-weight:700;font-size:11px;letter-spacing:0.3em;
  padding:8px 18px;border-radius:999px;
  border:1px solid var(--gold);
  box-shadow:0 6px 16px rgba(15,35,71,0.25);
  font-family:"Helvetica Neue",sans-serif;
}
.flow-step .icon-circle{
  width:54px;height:54px;border-radius:50%;
  background:var(--gold-grad);color:var(--navy-dark);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;font-weight:700;font-size:22px;
  box-shadow:0 8px 20px rgba(212,162,76,0.35);
  font-family:"Hiragino Mincho ProN",serif;
}
.flow-step h4{color:var(--navy);margin-bottom:10px;font-size:17px;font-weight:700}
.flow-step p{color:var(--text-soft);font-size:13px;line-height:1.75}

/* voice */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.voice-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:36px 30px;position:relative;
  box-shadow:0 8px 24px rgba(15,35,71,0.05);
  transition:transform .3s, box-shadow .3s;
}
.voice-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px rgba(15,35,71,0.12)}
.voice-card:before{
  content:"\201C";position:absolute;top:-22px;left:24px;
  font-size:96px;color:var(--gold);line-height:1;
  font-family:Georgia,serif;
  text-shadow:0 4px 12px rgba(212,162,76,0.3);
}
.voice-card .stars{color:var(--gold);font-size:18px;margin-bottom:12px;letter-spacing:3px}
.voice-card .voice-text{color:var(--text);font-size:15px;line-height:2;margin-bottom:20px;font-family:"Hiragino Mincho ProN",serif}
.voice-card .voice-meta{font-size:13px;color:var(--text-mute);border-top:1px solid var(--line);padding-top:16px;font-family:"Hiragino Sans",sans-serif;letter-spacing:0.05em}

/* faq */
.faq{max-width:860px;margin:0 auto;font-family:"Hiragino Sans",sans-serif}
.faq details{
  background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:14px;overflow:hidden;
  box-shadow:0 4px 14px rgba(15,35,71,0.04);
  transition:box-shadow .25s;
}
.faq details[open]{box-shadow:0 12px 32px rgba(15,35,71,0.1);border-color:var(--gold)}
.faq summary{padding:22px 28px;cursor:pointer;font-weight:700;color:var(--navy);font-size:16px;list-style:none;position:relative;padding-right:54px;padding-left:60px}
.faq summary:before{
  content:"Q";position:absolute;left:22px;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border-radius:50%;
  background:var(--gold-grad);color:var(--navy-dark);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:"Helvetica Neue",sans-serif;font-weight:800;font-size:14px;
}
.faq summary:after{content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:24px;color:var(--gold);font-weight:300;transition:transform .3s}
.faq details[open] summary:after{content:"−";transform:translateY(-50%) rotate(180deg)}
.faq .a{padding:0 28px 22px 60px;color:var(--text-soft);line-height:1.95;position:relative}
.faq .a:before{
  content:"A";position:absolute;left:22px;top:0;
  width:30px;height:30px;border-radius:50%;
  background:var(--navy);color:var(--gold);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:"Helvetica Neue",sans-serif;font-weight:800;font-size:14px;
}

/* CTA band */
.cta-band{
  background:var(--navy-grad);color:#fff;text-align:center;padding:90px 24px;
  position:relative;overflow:hidden;
}
.cta-band:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(212,162,76,0.2) 0%,transparent 60%),
             radial-gradient(circle at 70% 70%,rgba(61,165,217,0.12) 0%,transparent 60%);
}
.cta-band:after{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);
  opacity:0.6;
}
.cta-band>*{position:relative;z-index:1}
.cta-band .eyebrow{font-family:"Helvetica Neue",sans-serif;color:var(--gold);font-size:12px;font-weight:700;letter-spacing:0.4em;text-transform:uppercase;margin-bottom:20px;display:inline-block}
.cta-band h2{font-size:38px;margin-bottom:18px;line-height:1.5;letter-spacing:0.02em}
.cta-band h2 .accent{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta-band p{opacity:0.92;margin-bottom:34px;font-size:16px;font-family:"Hiragino Sans",sans-serif;font-weight:300;line-height:2}
.cta-band .btn-tel{font-size:30px;padding:24px 44px}
.cta-band .reception-line{margin-top:22px;font-size:13px;opacity:0.85;letter-spacing:0.1em;font-family:"Hiragino Sans",sans-serif}

/* company info */
.company{display:grid;grid-template-columns:1fr 1fr;gap:40px;font-family:"Hiragino Sans",sans-serif}
.company dl{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:grid;grid-template-columns:160px 1fr;
  box-shadow:0 8px 24px rgba(15,35,71,0.05);
}
.company dt,.company dd{padding:18px 22px;border-bottom:1px solid var(--line);font-size:14px}
.company dt{background:var(--bg-alt);font-weight:700;color:var(--navy);letter-spacing:0.05em}
.company dd{color:var(--text-soft)}
.company dt:nth-last-of-type(1),.company dd:nth-last-of-type(1){border-bottom:none}
.area-list{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px;
  box-shadow:0 8px 24px rgba(15,35,71,0.05);
}
.area-list h3{color:var(--navy);margin-bottom:16px;font-size:18px;font-family:"Hiragino Mincho ProN",serif}
.area-list ul{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;list-style:none}
.area-list li{
  font-size:14px;color:var(--navy);
  background:linear-gradient(135deg,#FCF8EE 0%,#F5E5B5 100%);
  padding:8px 12px;border-radius:6px;text-align:center;font-weight:600;
  border:1px solid rgba(212,162,76,0.3);
}

/* footer */
.footer{
  background:var(--bg-dark);color:#aaa;text-align:center;padding:40px 24px;font-size:13px;
  border-top:1px solid rgba(212,162,76,0.2);font-family:"Hiragino Sans",sans-serif;
}
.footer b{color:var(--gold);font-family:"Hiragino Mincho ProN",serif;font-size:16px;letter-spacing:0.1em}

/* sticky bottom call bar */
.tel-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:var(--gold-grad);
  box-shadow:0 -6px 24px rgba(0,0,0,0.25);
}
.tel-bar a{
  display:flex;align-items:center;justify-content:center;gap:10px;color:var(--navy-dark);
  padding:16px;font-weight:800;font-size:18px;font-family:"Hiragino Sans",sans-serif;
}
.tel-bar small{display:block;font-size:11px;opacity:0.85;font-weight:600}

/* responsive */
@media (max-width:980px){
  .hero h1{font-size:42px}
  .sec-head h2{font-size:30px}
  .sec-head .bg-en{font-size:90px}
}
@media (max-width:880px){
  .hero{min-height:auto}
  .hero-grid{grid-template-columns:1fr;gap:40px;padding:60px 24px}
  .hero h1{font-size:34px}
  .hero-image{max-width:480px;margin:0 auto}
  .hero-image .stamp{width:96px;height:96px;font-size:11px;right:auto;left:-8px;top:-8px}
  .hero-image .stamp b{font-size:24px}
  .hero-scroll{display:none}
  .header-cta .reception{display:none}
  .header-cta .tel{font-size:20px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:36px 16px}
  .stat .num{font-size:48px}
  .problem{grid-template-columns:1fr;gap:30px}
  .problem-image .frame{transform:none}
  .services{grid-template-columns:repeat(2,1fr)}
  .reasons{grid-template-columns:1fr}
  .flow{grid-template-columns:1fr 1fr}
  .flow:before{display:none}
  .voices{grid-template-columns:1fr}
  .company{grid-template-columns:1fr}
  .area-list ul{grid-template-columns:repeat(2,1fr)}
  .sec{padding:70px 0}
  .sec-head{margin-bottom:48px}
  .sec-head h2{font-size:24px}
  .sec-head .bg-en{font-size:60px;top:-10px}
  .price-table th,.price-table td{padding:14px 16px;font-size:13px}
  .price-table .price{font-size:20px}
  .price-table .item{font-size:14px}
  .cta-band h2{font-size:26px}
  .cta-band .btn-tel{font-size:22px;padding:18px 28px}
  .tel-bar{display:block}
  body{padding-bottom:64px}
  .header{position:static}
  .btn-tel{font-size:20px;padding:16px 24px}
}
@media (max-width:480px){
  .services{grid-template-columns:1fr}
  .flow{grid-template-columns:1fr}
  .hero h1{font-size:28px}
  .hero-eyebrow{font-size:11px;letter-spacing:0.3em}
  .price-table thead{display:none}
  .price-table tr{display:block;border-bottom:1px solid var(--line);padding:14px 0}
  .price-table tr:last-child{border-bottom:none}
  .price-table td{display:block;border:none;padding:4px 16px;text-align:left}
  .price-table .price{text-align:left;font-size:24px}
  .company dl{grid-template-columns:100px 1fr}
}
