*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue-900:#0f2442;
  --blue-800:#162d50;
  --blue-700:#1a3a6b;
  --blue-600:#1e56a0;
  --blue-500:#2563eb;
  --blue-400:#5b8dee;
  --blue-100:#e8f0fe;
  --blue-50:#f0f5ff;
  --orange:#e8841a;
  --orange-hover:#d4740f;
  --red:#c0392b;
  --green:#27ae60;
  --text:#2c2c2c;
  --text-light:#484848;
  --white:#fff;
  --gray-50:#f8f9fa;
  --shadow:0 4px 20px rgba(0,0,0,.07);
  --shadow-lg:0 12px 40px rgba(0,0,0,.10);
  --radius:12px;
  --heritage-title-desc-gap:18px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Noto Sans JP',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text);line-height:1.9;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.container{max-width:1080px;margin:0 auto;padding:0 20px}
.section{padding:90px 20px}
.section-label{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.8rem;
  letter-spacing:3px;text-transform:uppercase;color:var(--blue-500);
  text-align:center;margin-bottom:10px;
}
.section-title{
  text-align:center;font-size:1.95rem;font-weight:900;
  margin-bottom:16px;line-height:1.5;
}
.section-lead{text-align:center;color:var(--text-light);max-width:580px;margin:0 auto 56px;font-size:1.02rem}

/* btn */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 36px;border-radius:60px;font-weight:700;font-size:1rem;
  border:none;cursor:pointer;transition:all .3s;text-align:center;
}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 4px 16px rgba(232,132,26,.3)}
.btn-orange:hover{background:var(--orange-hover);transform:translateY(-2px);box-shadow:0 6px 24px rgba(232,132,26,.4)}
.btn-white{background:#fff;color:var(--blue-700);box-shadow:var(--shadow)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-blue{background:var(--blue-600);color:#fff;box-shadow:0 4px 16px rgba(30,86,160,.3)}
.btn-blue:hover{background:var(--blue-700);transform:translateY(-2px)}
.btn-lg{padding:18px 44px;font-size:1.1rem}
.btn-sm{padding:10px 22px;font-size:.85rem}
.btn-call{
  position:relative;
  border-radius:0;
  transform:skew(-15deg);
  padding-right:62px;
}
.btn-call::before,
.btn-call::after{
  content:"";
  position:absolute;
  right:10px;
  height:2px;
  background:#fff;
  transition:all .3s;
}
.btn-call::before{
  top:46%;
  width:30px;
}
.btn-call::after{
  top:56%;
  width:20px;
  right:18px;
}
.btn-call.btn-orange:hover{
  background:var(--orange-hover);
  transform:skew(0);
  box-shadow:0 3px 10px rgba(0,0,0,.15);
}
.btn-call:hover::before{right:-6px}
.btn-call:hover::after{right:0}

/* ========== HEADER ========== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255);backdrop-filter:blur(10px);
  box-shadow:0 1px 8px rgba(0,0,0,.05);
}
.header-inner{
  max-width:1200px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;padding:10px 20px;
}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem;color:var(--blue-700)}
.logo-mark{
  width:38px;height:38px;background:var(--blue-600);border-radius:8px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;
}
.logo-image{
  height:46px;
  width:auto;
  display:block;
}
.header-right{display:flex;align-items:center;gap:16px}
.header-phone{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.2rem;color:var(--blue-700);
  display:flex;align-items:center;gap:6px;
}
.header-phone-sub{font-family:'Noto Sans JP',sans-serif;font-size:.6rem;font-weight:500;color:var(--text-light);display:block}

/* ========== HERO ========== */
.hero{
  position:relative;min-height:100vh;
  background:#0d2341;overflow:hidden;padding-top:70px;
}
.hero-bg{
  display:none;
}
.hero-inner{
  position:relative;max-width:none;margin:0;width:100%;
  min-height:calc(100vh - 70px);
}
.hero-copy{
  position:absolute;inset:0 38% 0 0;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
  padding:72px 7vw 72px 3vw;
  background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue-700) 100%);
  clip-path:polygon(0 0,86% 0,100% 100%,0 100%);
  isolation:isolate;
}
.hero-map-overlay{
  position:absolute;
  right:-10%;
  bottom:-13%;
  width:60%;
  aspect-ratio:1 / 1;
  pointer-events:none;
  z-index:-1;
}
.hero-map-overlay::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("../images/kinki-map.png") right bottom/contain no-repeat;
  opacity:.50;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  align-self:flex-start;width:fit-content;
  background:#08182e;
  border:1px solid #ffffff;
  box-shadow:0 8px 22px rgba(4,12,24,.28),inset 0 1px 0 rgba(255,255,255,.2);
  backdrop-filter:blur(4px);
  padding:8px 12px;border-radius:60px;color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.35);
  letter-spacing:.02em;
  font-size:.9rem;font-weight:800;margin-bottom:24px;
}
.hero h1{
  color:#fff;font-size:clamp(3rem,5.8vw,6rem);
  font-weight:900;line-height:1.15;margin-bottom:20px;letter-spacing:.01em;
}
.hero h1 em{font-style:normal;color:var(--orange)}
.hero-sub{
  color:rgba(255,255,255,.92);
  font-size:clamp(1.1rem,2vw,1.55rem);
  margin-bottom:30px;line-height:1.8;font-weight:700;
}
.sp-500-break{display:none}
.sp-500-break-alert{display:none}
.sp-500-break-why{display:none}
.sp-500-break-cta{display:none}
.sp-500-break-price-lead{display:none}
.sp-500-break-price-example{display:none}
.sp-500-break-heritage{display:none}
.pc-break-heritage{display:inline}
.sp-400-break-hero{display:none}
.flow-break-701-900{display:none}
.flow-dot-701-900{display:inline}
.hero-sub-highlight{
  display:inline;
}
.hero-keypoints{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:10px;
}
.hero-keypoint{
  display:inline-block;
  font-size:clamp(1.45rem,3vw,2.35rem);
  font-weight:900;
  line-height:1.4;
  color:#fff;
  padding:1rem 3rem;
  transform:none;
  background-image:linear-gradient(to right,#1e56a0 0%,#4f86d8 100%);
  border:2px solid #ffffff;
  border-radius:0;
  box-shadow:0 10px 28px rgba(30,86,160,.35);
  letter-spacing:.01em;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-cta .btn{
  box-shadow:0 10px 24px rgba(30, 30, 30);
}
.hero-cta .btn:nth-child(2),
.hero-cta .btn:nth-child(3){
  box-shadow:5px 5px 0 rgba(17,47,86,.55),6px 12px 20px rgba(10,22,40,.28);
}
.hero-cta .btn:nth-child(2):hover,
.hero-cta .btn:nth-child(3):hover{
  transform:translateY(3px);
  box-shadow:0 3px 0 rgba(17,47,86,.12),0 6px 12px rgba(10,22,40,.16),inset 0 2px 0 rgba(255,255,255,.85);
}
.hero-cta .btn:nth-child(2):active,
.hero-cta .btn:nth-child(3):active{
  transform:translateY(4px);
  box-shadow:0 2px 0 rgba(17,47,86,.1),0 4px 8px rgba(10,22,40,.14),inset 0 2px 0 rgba(255,255,255,.9);
}
.hero-image{
  position:absolute;inset:0;min-height:100%;overflow:hidden;
  clip-path:polygon(62% 0,100% 0,100% 100%,46% 100%);
}
.hero-image img{width:100%;height:100%;object-fit:cover;object-position:center 0%}

/* ========== ALERT ========== */
.alert{
  position:relative;
  background:linear-gradient(135deg,#b82d2d 0%,#940000 100%);
  color:#fff;text-align:center;padding:64px 20px;
}
.alert::before,
.alert::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:16px;
  background:repeating-linear-gradient(-45deg,#e3d356 0 14px,#424242 14px 28px);
}
.alert::before{top:0}
.alert::after{bottom:0}
.alert h2{font-size:1.62rem;margin-bottom:12px;font-weight:900}
.alert p{font-size:1.02rem;opacity:.9;max-width:660px;margin:0 auto;line-height:2}
.alert p strong{
  font-size:1.20em;
  font-weight:900;
}

/* ========== PROBLEMS ========== */
.problems{background:var(--gray-50)}
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.problem-card{
  background:#fff;border-radius:var(--radius);padding:32px 24px;text-align:center;
  box-shadow:var(--shadow);transition:transform .3s;
}
.problem-card:hover{transform:translateY(-4px)}
.problem-icon{
  width:64px;height:64px;margin:0 auto 16px;
  background:var(--blue-50);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  padding:10px;
}
.problem-icon img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.problem-card h3{font-size:1.08rem;margin-bottom:10px;font-weight:700}
.problem-card p{font-size:.92rem;color:var(--text-light);line-height:1.8;text-align:left}

/* ========== FEATURES ========== */
.feature-row{
  display:grid;grid-template-columns:1fr 1fr;gap:52px;
  align-items:center;margin-bottom:72px;
}
.feature-row:last-child{margin-bottom:0}
.feature-row.rev{direction:rtl}
.feature-row.rev>*{direction:ltr}
.feature-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.feature-img img{width:100%;height:320px;object-fit:cover}
.feature-num{
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:3.2rem;
  color:var(--blue-100);line-height:1;margin-bottom:10px;
}
.feature-content h3{font-size:1.45rem;font-weight:900;margin-bottom:14px;color:var(--blue-700);line-height:1.5}
.feature-content p{color:var(--text-light);line-height:2;margin-bottom:14px;font-size:1rem}
.feature-tag{
  display:inline-block;background:var(--blue-50);padding:5px 14px;
  border-radius:60px;font-size:.85rem;font-weight:700;color:var(--blue-600);
}

/* ========== HERITAGE ========== */
.heritage{
  position:relative;
  isolation:isolate;
  background:var(--blue-900);
  color:#fff;
}
.heritage::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("../images/kenninji.jpg") center/cover no-repeat;
  opacity:.14;
  z-index:0;
  pointer-events:none;
}
.heritage > *{
  position:relative;
  z-index:1;
}
.heritage-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.heritage-card{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.4);
  border-radius:50%;
  aspect-ratio:1 / 1;
  padding:24px 20px;text-align:center;
  position:relative;
  overflow:hidden;
  transition:background .3s;
}
.heritage-card h4{
  font-size:1.52rem;
  font-weight:700;
  line-height:1.35;
  min-height:2.7em;
  margin:0;
  position:absolute;
  left:16px;
  right:16px;
  top:44%;
  transform:translateY(-50%);
  display:flex;
  align-items:center;
  justify-content:center;
}
.heritage-card p{
  font-size:.86rem;
  line-height:1.6;
  min-height:4em;
  margin:0;
  position:absolute;
  left:16px;
  right:16px;
  top:calc(44% + var(--heritage-title-desc-gap));
  opacity:.72;
}

/* ========== FLOW ========== */
.flow{background:var(--gray-50)}
.flow .container{max-width:1240px}
.flow-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0px;
}
.flow-step{
  --flow-cut:38px;
  --flow-head-top:26px;
  background:#fff;
  padding:32px 24px;
  text-align:center;
  position:relative;
  border:none;
  box-shadow:none;
  clip-path:polygon(0 0,calc(100% - var(--flow-cut)) 0,100% 50%,calc(100% - var(--flow-cut)) 100%,0 100%,var(--flow-cut) 50%);
}
.flow-step:not(:first-child){
  margin-left:-14px;
}
.flow-step:first-child{
  margin-left:0;
  clip-path:polygon(0 0,calc(100% - var(--flow-cut)) 0,100% 50%,calc(100% - var(--flow-cut)) 100%,0 100%);
}
.flow-step:nth-child(1){
  background:linear-gradient(180deg,#eff4ff 0%,#e4edfc 100%);
  z-index:1;
}
.flow-step:nth-child(2){
  background:linear-gradient(180deg,#dde9fb 0%,#cfdef7 100%);
  z-index:2;
}
.flow-step:nth-child(3){
  background:linear-gradient(180deg,#c8daf4 0%,#b9d0f1 100%);
  z-index:3;
}
.flow-step:nth-child(4){
  background:linear-gradient(180deg,#afc6eb 0%,#9fbbe6 100%);
  z-index:4;
}
.flow-step::after{
  display:none !important;
}
.flow-step-num{
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:2rem;
  color:var(--blue-700);
  line-height:1;
  margin-top:0;
  margin-bottom:12px;
}
.flow-step h3{font-size:1.14rem;font-weight:700;margin-bottom:10px}
.flow-step p{
  font-size:.9rem;
  color:var(--text-light);
  max-width:23ch;
  margin-left:auto;
  margin-right:auto;
  text-align:left;
}
.flow-step .badge-free{
  position:absolute;
  top:var(--flow-head-top);
  left:50%;
  transform:translateX(48px);
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--red);
  color:#fff;
  border-radius:50%;
  font-size:.78rem;
  font-weight:800;
  padding:0;
  margin:0;
  line-height:1;
}
.flow-arrow{display:none}

/* ========== PRICE ========== */
.price-box{
  max-width:640px;margin:0 auto;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  overflow:hidden;text-align:center;padding:48px 40px;
}
.price-main{
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:3rem;
  color:var(--blue-600);margin:16px 0 8px;
}
.price-main small{font-size:1.08rem;font-weight:500;color:var(--text-light)}
.price-example{
  background:var(--blue-50);border-radius:8px;padding:16px;margin:20px 0;
  font-size:.98rem;color:var(--text-light);
}
.price-note{text-align:center;margin-top:20px;margin-bottom:30px;font-size:.9rem;color:var(--text-light)}
.price-sim-card{
  max-width:720px;
  margin:0 auto 26px;
  background:#fff;
  border:1px solid #dbe6f7;
  border-radius:var(--radius);
  padding:24px;
  box-shadow:var(--shadow);
}
.price-sim-card h3{
  font-size:1.2rem;
  color:var(--blue-700);
  font-weight:900;
  margin-bottom:8px;
}
.price-sim-card p{
  font-size:.9rem;
  color:var(--text-light);
  margin-bottom:14px;
}
.price-sim-card .price-sim-result{
  margin:12px 0 0;
  font-size:.9rem;
  font-weight:500;
  line-height:1.45;
  color:var(--text-light);
}
.price-sim-result.sim-has-value{
  font-size:1rem;
  font-weight:700;
  color:var(--blue-700);
}
.price-sim-controls{
  display:grid;
  grid-template-columns:1fr 92px auto;
  gap:10px;
  align-items:center;
}
.price-sim-controls select,
.price-sim-controls input{
  height:42px;
  border:1px solid #cfdcf2;
  border-radius:8px;
  padding:0 12px;
  font-size:.95rem;
}
.price-sim-result .sim-amount{
  display:block;
  margin-top:4px;
  font-size:1.9rem;
  font-weight:900;
  line-height:1.2;
  color:var(--blue-700);
}

/* ========== AREA ========== */
.area{background:var(--blue-50)}
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
.area-card{
  background:#fff;border-radius:8px;padding:20px;box-shadow:var(--shadow);
}
.area-card h4{font-size:.98rem;font-weight:700;color:var(--blue-600);margin-bottom:8px}
.area-card p{font-size:.88rem;color:var(--text-light);line-height:1.8}

/* ========== VOICE ========== */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.voice-card{
  background:#fff;border-radius:var(--radius);padding:32px;
  box-shadow:var(--shadow);border-top:4px solid var(--blue-500);
}
.voice-stars{color:#f5a623;margin-bottom:12px;font-size:1rem;letter-spacing:2px}
.voice-text{font-size:.98rem;line-height:2;margin-bottom:18px}
.voice-author{display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid #eee}
.voice-avatar{
  width:42px;height:42px;border-radius:50%;background:var(--blue-50);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:var(--blue-600);font-size:1rem;
}
.voice-name{font-weight:700;font-size:.92rem}
.voice-meta{font-size:.8rem;color:var(--text-light)}

/* ========== FAQ ========== */
.faq{background:var(--gray-50)}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{background:#fff;border-radius:var(--radius);margin-bottom:14px;box-shadow:var(--shadow);overflow:hidden}
.faq-q{
  padding:22px 24px;cursor:pointer;display:flex;align-items:center;
  justify-content:space-between;font-weight:700;font-size:1.02rem;
}
.faq-q::before{
  content:'Q';flex-shrink:0;width:30px;height:30px;
  background:var(--blue-500);color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:.8rem;margin-right:14px;
}
.faq-q::after{content:'+';font-size:1.4rem;color:var(--text-light);transition:transform .3s;flex-shrink:0;margin-left:14px}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 24px 22px 68px;color:var(--text-light);line-height:2;font-size:.98rem}

/* ========== CTA ========== */
.cta{
  background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue-700) 100%);
  color:#fff;text-align:center;padding:72px 20px;
}
.cta h2{font-size:1.95rem;font-weight:900;margin-bottom:14px}
.cta p{opacity:.75;margin-bottom:36px;max-width:560px;margin-left:auto;margin-right:auto}
.cta .btn{
  display:flex;
  width:fit-content;
  margin:0 auto 14px;
}
.cta-phone{
  background:rgba(255,255,255,.08);border-radius:var(--radius);
  padding:24px 40px;display:block;width:fit-content;max-width:min(92vw,520px);margin:0 auto;backdrop-filter:blur(6px);
}
.cta-phone-num{
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:2rem;
  color:#fff;display:flex;align-items:center;gap:8px;justify-content:center;
}
.cta-phone-note{font-size:.86rem;opacity:.6;margin-top:6px}

/* ========== FOOTER ========== */
.footer{background:#0a1628;color:rgba(255,255,255,.5);padding:40px 20px;text-align:center;font-size:.88rem}

/* ========== FLOATING CTA ========== */
.floating{
  position:fixed;bottom:0;left:0;right:0;z-index:999;
  background:rgba(15,36,66,.96);backdrop-filter:blur(10px);
  padding:10px 20px;display:none;box-shadow:0 -4px 20px rgba(0,0,0,.12);
}
.floating-inner{
  max-width:600px;margin:0 auto;display:flex;align-items:center;
  justify-content:center;gap:12px;
}

/* ========== FADE ========== */
.fade{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade.visible{opacity:1;transform:translateY(0)}

/* ========== RESPONSIVE ========== */
@media(max-width:900px){
  :root{
    --mobile-floating-height:56px;
  }
  .hero{
    height:calc(var(--vh-initial, 100svh) - var(--mobile-floating-height));
    min-height:calc(var(--vh-initial, 100svh) - var(--mobile-floating-height));
  }
  .hero-inner{
    display:block;
    position:relative;
    isolation:isolate;
    height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
    min-height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
  }
  .hero-copy{
    position:relative;
    inset:auto;
    z-index:40;
    padding:44px 16px 22px;
    clip-path:none;
    height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
    min-height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
    justify-content:flex-start;
  }
  .hero-copy::before{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:100%;
    height:min(66%,380px);
    background:url("../images/FV.png") center 20%/cover no-repeat;
    clip-path:polygon(0 50%,100% 8%,100% 100%,0 100%);
    z-index:0;
    pointer-events:none;
  }
  .hero h1{
    width:100%;
    font-size:clamp(1.8rem,8.6vw,3.4rem) !important;
    line-height:1.04 !important;
    letter-spacing:0;
  }
  .hero-badge{
    background:#08182e;
    border-color:#ffffff;
  }
  .hero-keypoints{
    flex-wrap:nowrap;
    width:100%;
    gap:4px;
    justify-content:space-between;
  }
  .hero-keypoint{
    flex:1 1 0;
    min-width:0;
    text-align:center;
    white-space:nowrap;
    font-size:clamp(.96rem,3.8vw,1.3rem) !important;
    padding:12px 6px !important;
  }
  .hero-sub{
    position:relative;
    z-index:70;
    font-size:clamp(1.08rem,3.7vw,1.4rem);
    font-weight:800;
    line-height:1.75;
  }
  .hero-sub-highlight{
    display:inline;
    background:linear-gradient(transparent 36%,rgba(255, 179, 92, 0.62) 42%);
    box-decoration-break:clone;
    -webkit-box-decoration-break:clone;
    padding:0 .12em;
    color:#fff;
    text-shadow:0 2px 6px rgba(0,0,0,.58),0 1px 2px rgba(0,0,0,.45);
  }
  .hero .sp-500-break{display:inline}
  .hero-image{display:none}
  .hero-map-overlay{
    right:-12%;
    top:-18%;
    bottom:auto;
    width:72%;
    z-index:-1;
  }
  .hero-cta{
    position:relative;
    z-index:100 !important;
    justify-content:center;
    align-items:center;
    gap:10px;
    margin-top:auto;
    transform:translateY(-10px);
  }
  .hero-cta .btn{
    position:relative;
    z-index:101;
  }
  .hero-cta .btn:nth-child(2),
  .hero-cta .btn:nth-child(3){
    background:rgba(255,255,255,.84);
    padding:13px 18px;
    font-size:.92rem;
    box-shadow:4px 4px 0 rgba(17,47,86,.48),6px 10px 16px rgba(10,22,40,.24);
  }
  .hero-cta .btn:nth-child(2){order:1}
  .hero-cta .btn:nth-child(3){order:2}
  .hero-cta .btn:nth-child(1){order:3}
  .hero-cta .btn-call{display:none}
  .problem-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}
  .feature-row,.feature-row.rev{grid-template-columns:1fr;direction:ltr}
  .feature-content{order:1}
  .feature-img{order:2}
  .heritage-grid{
    grid-template-columns:repeat(2,clamp(180px,28vw,250px));
    justify-content:center;
    gap:16px;
  }
  .heritage-card{
    width:100%;
  }
  .flow-steps{grid-template-columns:1fr 1fr}
  .flow-arrow{display:none}
  .flow-step::after{display:none}
  .flow-step:nth-child(2n+1){margin-left:0}
  .flow-step:nth-child(2n){margin-left:-10px}
  .area-grid{grid-template-columns:1fr 1fr}
  .voice-grid{grid-template-columns:1fr}
  .header-phone{display:none}
  .floating{display:block !important}
  .section{padding:60px 16px}
  .price-box{padding:36px 24px}
}
@media(max-width:600px){
  .section-title{font-size:1.5rem}
  .flow-steps{grid-template-columns:1fr}
  .flow-step::after{display:none}
  .flow-step:not(:first-child){margin-left:0}
  .heritage-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
  }
  .area-grid{grid-template-columns:1fr}
  .btn-lg{padding:16px 28px;font-size:1rem}
}
@media(max-width:500px){
  .logo-image{
    height:30px;
  }
  .header-right .btn-call{
    justify-content:flex-end;
    padding-left:14px;
    padding-right:37px;
  }
  .header-right .btn-call::before{
    width:20px;
  }
  .header-right .btn-call::after{
    width:12px;
  }
  :root{
    --mobile-floating-height:56px;
  }
  .floating{
    display:block !important;
  }
  .hero{
    height:calc(var(--vh-initial, 100svh) - var(--mobile-floating-height));
    min-height:calc(var(--vh-initial, 100svh) - var(--mobile-floating-height));
  }
  .hero-inner{
    height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
    min-height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
  }
  .flow-steps{
    gap:0;
  }
  .flow-step{
    --flow-cut:30px;
    --flow-head-top:42px;
    margin-left:0;
    clip-path:polygon(0 0,50% var(--flow-cut),100% 0,100% calc(100% - var(--flow-cut)),50% 100%,0 calc(100% - var(--flow-cut)));
  }
  .flow-step:first-child{
    margin-left:0;
    clip-path:polygon(0 0,100% 0,100% calc(100% - var(--flow-cut)),50% 100%,0 calc(100% - var(--flow-cut)));
  }
  .flow-step:not(:first-child){
    margin-left:0;
    margin-top:-10px;
  }
  .sp-500-break-heritage{display:inline}
  .pc-break-heritage{display:none}
  .sp-500-break-price-lead{display:inline}
  .sp-500-break-price-example{display:inline}
  .sp-500-break-why{display:inline}
  .sp-500-break-cta{display:inline}
  .alert{
    padding:44px 16px;
  }
  .alert h2{
    font-size:1.28rem;
  }
  .alert p{
    font-size:.84rem;
    line-height:1.8;
  }
  .cta h2{
    font-size:1.64rem;
  }
  .feature-row,
  .feature-row.rev{
    gap:18px;
    margin-bottom:42px;
  }
  .feature-content{
    order:1;
  }
  .feature-img{
    order:2;
  }
  .hero-inner{
    position:relative;
    isolation:isolate;
  }
  .hero-copy{
    position:relative;
    z-index:40;
    padding:44px 16px 22px;
    clip-path:none;
    height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
    min-height:calc(var(--vh-initial, 100svh) - 70px - var(--mobile-floating-height));
    justify-content:flex-start;
  }
  .hero-copy::before{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:100%;
    height:min(66%,380px);
    background:url("../images/FV.png") center 20%/cover no-repeat;
    clip-path:polygon(0 50%,100% 8%,100% 100%,0 100%);
    z-index:0;
    pointer-events:none;
  }
  .hero h1{
    width:100% !important;
    font-size:clamp(1.88rem,8.8vw,3rem) !important;
    line-height:1.08 !important;
  }
  .hero-badge{
    background:#08182e;
    border-color:#ffffff;
  }
  .hero-keypoints{
    flex-wrap:nowrap;
    width:100%;
    gap:4px;
    justify-content:space-between;
  }
  .hero-keypoint{
    flex:1 1 0;
    text-align:center;
    white-space:nowrap;
    font-size:clamp(1.0rem,4.3vw,1.34rem) !important;
    padding:11px 4px !important;
  }
  .hero-map-overlay{
    right:-12%;
    top:-18%;
    bottom:auto;
    width:72%;
    z-index:-1;
  }
  .hero-sub{
    position:relative;
    z-index:70;
    font-size: clamp(.95rem,3.4vw,1.2rem) !important;
  }
  .hero-sub-highlight{
    display:inline;
    background:linear-gradient(transparent 42%,rgba(255, 179, 92, 0.62) 42%);
    box-decoration-break:clone;
    -webkit-box-decoration-break:clone;
    padding:0 .14em;
    color:#fff;
    text-shadow:0 2px 6px rgba(0,0,0,.62),0 1px 2px rgba(0,0,0,.48);
  }
  .sp-500-break{display:inline}
  .sp-500-break-alert{display:inline}
  .hero-image{display:none}
  .hero-cta{
    position:relative;
    z-index:100 !important;
    justify-content:center;
    align-items:center;
    gap:10px;
    margin-top:auto;
    transform:translateY(-10px);
  }
  .hero-cta .btn{
    position:relative;
    z-index:101;
  }
  .hero-cta .btn:nth-child(2),
  .hero-cta .btn:nth-child(3){
    background:rgba(255,255,255,.84);
    padding:13px 18px;
    font-size:.92rem;
    box-shadow:4px 4px 0 rgba(17,47,86,.48),6px 10px 16px rgba(10,22,40,.24);
  }
  .hero-cta .btn-call::before{
    right:-10px;
  }
  .hero-cta .btn-call::after{
    right:-2px;
  }
  .hero-cta .btn-call:hover::before{
    right:-16px;
  }
  .hero-cta .btn-call:hover::after{
    right:-8px;
  }
  .cta .btn-call{
    padding-left:34px;
    padding-right:34px;
  }
  .cta .btn-call::before{
    right:-12px;
  }
  .cta .btn-call::after{
    right:-4px;
  }
  .cta .btn-call:hover::before{
    right:-18px;
  }
  .cta .btn-call:hover::after{
    right:-10px;
  }
  .hero-cta .btn:nth-child(2){
    order:1;
  }
  .hero-cta .btn:nth-child(3){
    order:2;
  }
  .hero-cta .btn:nth-child(1){
    order:3;
  }
  .hero-cta .btn-call{
    display:none;
  }
  .heritage-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }
  .heritage-card{
    width:100%;
    margin:0 auto;
    padding:14px 10px;
  }
  .heritage-card h4{
    font-size:1.16rem;
    min-height:2.4em;
    top:42%;
  }
  .heritage-card p{
    font-size:.8rem;
    min-height:3.8em;
    top:calc(42% + var(--heritage-title-desc-gap));
  }
  .problems .section-title{
    margin-bottom:10px;
  }
  .problem-grid{
    gap:12px;
  }
  .problem-card{
    padding:22px 16px;
  }
  .flow-step{
    padding:46px 14px calc(10px + var(--flow-cut));
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
  }
  .flow-step-num{
    line-height:1;
    margin-bottom:1px;
    margin-top:0;
  }
  .flow-step h3{
    margin-top:0;
    margin-bottom:4px;
  }
  .flow-step p{
    font-size:1rem;
    line-height:1.65;
    max-width:38ch;
    width:92%;
    margin:0 auto;
    text-align:left;
  }
  .flow-step .badge-free{
    top:var(--flow-head-top);
    transform:translateX(94px);
    width:40px;
    height:40px;
  }
  .price-detail-note{
    text-align:left;
  }
  .price-sim-card{
    padding:18px 14px;
  }
  .price-sim-controls{
    grid-template-columns:1fr;
  }
  .price-sim-controls .btn{
    width:100%;
  }
  .price-note{
    text-align:left;
    padding-left:1.4em;
    text-indent:-1.4em;
  }
}

@media(min-width:501px){
  .hero h1{
    font-size:clamp(2.1rem,4.6vw,4.6rem);
    line-height:1.12;
  }
  .hero-keypoints{
    width:100%;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:clamp(6px,.8vw,12px);
  }
  .hero-keypoint{
    min-width:0;
    text-align:center;
    white-space:nowrap;
    font-size:clamp(1rem,1.75vw,1.6rem);
    padding:clamp(8px,1vw,14px) clamp(10px,1.1vw,18px);
  }
  .hero-cta .btn:first-child{
    margin-right:12px;
  }
  .hero-cta .btn{
    box-shadow:5px 5px 0 rgba(255, 164, 60, 0.55);
  }
  .hero-cta .btn:nth-child(2),
  .hero-cta .btn:nth-child(3){
    box-shadow:5px 5px 0 rgba(255, 255, 255, 0.55);
  }
}

@media(min-width:501px) and (max-width:900px){
  .hero-copy::before{
    height:56% !important;
    max-height:none !important;
  }
  .hero-cta{
    transform:translateY(-20px);
  }
}

@media(min-width:901px) and (max-width:1440px){
  .hero-cta{
    display:grid;
    grid-template-columns:repeat(2,max-content);
    justify-content:center;
    column-gap:14px;
    row-gap:24px;
    margin-left:auto;
    margin-right:auto;
    width:fit-content;
  }
  .hero-cta .btn:nth-child(1){
    grid-column:1 / -1;
    justify-self:center;
    margin-top:-8px;
  }
  .hero-sub{
    font-size:clamp(1.08rem,1.8vw,5rem) !important;
    line-height:1.7;
  }
  .hero .sp-500-break{
    display:none !important;
  }
  .hero-sub .hero-sub-highlight:nth-of-type(2),
  .hero-sub .hero-sub-highlight:nth-of-type(3){
    white-space:nowrap;
  }
}

@media(min-width:501px) and (max-width:800px){
  .flow-steps{
    grid-template-columns:1fr;
    gap:0;
  }
  .flow-arrow{display:none}
  .flow-step{
    --flow-cut:30px;
    --flow-head-top:42px;
    margin-left:0;
    clip-path:polygon(0 0,50% var(--flow-cut),100% 0,100% calc(100% - var(--flow-cut)),50% 100%,0 calc(100% - var(--flow-cut)));
  }
  .flow-step:first-child{
    margin-left:0;
    clip-path:polygon(0 0,100% 0,100% calc(100% - var(--flow-cut)),50% 100%,0 calc(100% - var(--flow-cut)));
  }
  .flow-step:not(:first-child){
    margin-left:0;
    margin-top:-10px;
  }
  .flow-step:nth-child(2n){
    margin-left:0;
  }
  .flow-step{
    padding:58px 16px calc(14px + var(--flow-cut));
  }
  .flow-step-num{
    margin-top:8px;
    margin-bottom:4px;
  }
  .flow-step p{
    width:72%;
    max-width:none;
    margin-left:auto;
    margin-right:auto;
    text-align:left;
  }
  .flow-step .badge-free{
    position:absolute;
    transform:none;
    top:var(--flow-head-top);
    right:60px;
    left:auto;
    margin:0;
    width:46px;
    height:46px;
  }
}

@media(min-width:801px) and (max-width:1100px){
  .flow-steps{
    grid-template-columns:repeat(4,1fr);
    gap:0;
  }
  .flow-step{
    --flow-cut:38px;
    --flow-head-top:26px;
  }
  .flow-step:not(:first-child){
    margin-left:-14px;
    margin-top:0;
  }
  .flow-step:nth-child(2n),
  .flow-step:nth-child(2n+1){
    margin-left:0;
  }
  .flow-step:not(:first-child){
    margin-left:-14px;
  }
  .flow-step{
    padding:34px 8px 30px 24px;
  }
  .flow-step-num{
    padding-left:0;
    margin-left:0;
    text-align:center;
    align-self:center;
  }
  .flow-step h3{
    padding-left:0;
    min-height:3.1em;
    height:3.1em;
    display:flex;
    align-items:flex-start;
    justify-content:center;
    text-align:center;
    width:100%;
    margin-bottom:18px;
  }
  .flow-step p{
    width:100%;
    max-width:none;
    min-height:4.8em;
    margin-top:0;
  }
  .flow-step:nth-child(1) p{
    width:96%;
    padding-left:2px;
  }
  .flow-step:nth-child(n+2) p{
    width:88%;
    padding-left:10px;
  }
  .flow-step .badge-free{
    position:static;
    transform:none;
    margin:12px auto 0;
  }
  .flow-break-701-900{display:inline}
  .flow-dot-701-900{display:none}
}

@media(max-width:400px){
  .logo-image{
    height:22px;
  }
  .hero h1{
        font-size:clamp(1.9rem,4.4vw,4.8rem)!important;
        line-height:1.12;
  }
  .hero-keypoint{
    font-size:clamp(0.5rem,4.2vw,1.34rem) !important;
  }

  .sp-400-break-hero{display:inline}
  .hero-map-overlay{
    top:-13%;
  }
  .section-label{font-size:.72rem}
  .section-title{font-size:1.36rem}
  .section-lead{font-size:.92rem}

  .alert h2{font-size:1.16rem}
  .alert p{font-size:.8rem;line-height:1.72}
  .alert p strong{font-size:.86rem;line-height:1.72}


  .problem-card h3{font-size:1rem}
  .problem-card p{font-size:.82rem}

  .feature-num{font-size:2.4rem}
  .feature-content h3{font-size:1.18rem}
  .feature-content p{font-size:.9rem}
  .feature-tag{font-size:.76rem}

  .heritage-card h4{
    font-size:1.02rem;
    top:41%;
  }
  .heritage-card p{
    font-size:.65rem;
    top:calc(41% + var(--heritage-title-desc-gap) - 3px);
  }

  .flow-step-num{font-size:1.7rem}
  .flow-step h3{font-size:.92rem}
  .flow-step p{font-size:.8rem}
  .flow-step .badge-free{
    font-size:.7rem;
    width:36px;
    height:36px;
    transform:translateX(78px);
  }

  .price-main{font-size:2.4rem}
  .price-main small{font-size:.94rem}
  .price-example{font-size:.86rem}
  .price-note{font-size:.82rem}

  .area-card h4{font-size:.9rem}
  .area-card p{font-size:.8rem}

  .voice-text{font-size:.9rem}
  .voice-name{font-size:.86rem}
  .voice-meta{font-size:.74rem}

  .faq-q{font-size:.94rem}
  .faq-a-inner{font-size:.88rem}

  .cta h2{font-size:1.46rem}
  .cta p{font-size:.9rem}
  .cta-phone-note{font-size:.78rem}

  .footer{font-size:.8rem}
}

