:root{
    /* ヒーロー背景: 画像内の上余白を減らしたい時は px を大きく（上にずらして切る） */
    --jres-hero-bg-y: -2rem;
    --home-hero-bg-y: -10rem;
    --home-hero-card-shift-x: 123px;
    --home-hero-card-shift-y: 92px;
    --home-hero-pest-shift-x: 172px;
    --home-hero-pest-shift-y: 41px;
    --home-hero-image: url("../jres-hero.webp");
    --ink:#0b1f3a;           /* deep navy */
    --ink-2:#1a3560;
    --ink-3:#45597a;
    --line:#dfe5ee;
    --line-2:#eef1f6;
    --bg:#f5f7fa;
    --bg-card:#ffffff;
    --brand:#1e55a8;         /* primary navy-blue */
    --brand-2:#14407f;
    --brand-soft:#e7eef9;
    --accent:#e85427;        /* warm CTA */
    --accent-2:#c6401a;
    --warn:#f2b134;
    --ok:#2aa97a;
    --shadow-sm: 0 1px 2px rgba(11,31,58,.06), 0 1px 3px rgba(11,31,58,.05);
    --shadow-md: 0 4px 14px rgba(11,31,58,.08), 0 2px 6px rgba(11,31,58,.05);
    --shadow-lg: 0 20px 50px rgba(11,31,58,.12), 0 6px 18px rgba(11,31,58,.06);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:"Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Sans", sans-serif;
    color:var(--ink);
    background:#fff;
    line-height:1.7;
    -webkit-font-smoothing:antialiased;
    font-feature-settings:"palt";
  }
  .serif{font-family:"Noto Serif JP", serif; letter-spacing:.02em}
  .mono{font-family:"JetBrains Mono", monospace}
  a{color:inherit; text-decoration:none}
  button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit}
  img{max-width:100%}
  .container{max-width:1200px; margin:0 auto; padding:0 24px}
  .container-wide{max-width:1320px; margin:0 auto; padding:0 24px}
  #app{ margin:0; padding:0; }

  /* Hero: 通常はベタ塗り。背景写真は .pest-top-hero と .home-hero のみ */
  .hero{
    position:relative;
    overflow:hidden;
    padding:0 0 48px;
    margin:0;
    border-bottom:1px solid var(--line);
    background: linear-gradient(180deg, #f7f9fc 0%, #fff 100%);
  }
  .pest-top-hero::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:0;
    pointer-events:none;
    background:
      linear-gradient(180deg, rgba(30,85,168,0.12) 0%, rgba(30,85,168,0.08) 55%, rgba(30,85,168,0.06) 100%),
      linear-gradient(180deg, rgba(255,255,255,0.4) 0%, rgba(255,255,255,0.72) 40%, rgba(255,255,255,0.98) 100%),
      radial-gradient(1200px 600px at 85% -10%, rgba(233,241,251,0.55) 0%, transparent 60%),
      url("../top-background.webp") center var(--jres-hero-bg-y) / cover no-repeat;
  }
  .pest-top-hero .container-wide{
    position:relative; z-index:1;
    padding-top:12px;
  }
  /* ----- トップ専用・キャプチャ風フル幅ヒーロー ----- */
  .home-hero{
    position:relative;
    margin:0;
    padding:0 0 28px;
    min-height:min(72vh, 720px);
    border-bottom:1px solid var(--line);
    overflow:hidden;
  }
  .home-hero::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:0;
    background: var(--home-hero-image) center var(--home-hero-bg-y) / cover no-repeat;
  }
  .home-hero::after{
    content:"";
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background:
      linear-gradient(180deg, rgba(255,255,255,0.15) 0%, rgba(255,255,255,0.5) 45%, rgba(255,255,255,0.88) 100%),
      linear-gradient(90deg, rgba(255,255,255,0.35) 0%, transparent 55%);
  }
  .home-hero__wrap{
    position:relative; z-index:1;
    min-height:min(68vh, 680px);
    display:flex;
    flex-direction:column;
    padding-top:8px;
    padding-bottom:8px;
  }
  .home-hero__anchor{
    position:relative;
    top:-10px;
    height:0;
  }
  .home-hero__head{
    text-align:center;
    padding:20px 12px 12px;
    flex:0 0 auto;
  }
  .home-hero__h1{
    margin:0;
    font-size:clamp(24px, 4.2vw, 40px);
    font-weight:900;
    line-height:1.25;
    letter-spacing:-.02em;
    color:var(--ink);
    text-shadow:
      0 0 1px #fff, 0 0 2px #fff, 0 0 8px rgba(255,255,255,.95),
      0 0 16px rgba(255,255,255,.8);
  }
  .home-hero__sub{
    margin:10px auto 0;
    max-width:38ch;
    font-size:clamp(13px, 1.8vw, 15px);
    font-weight:800;
    line-height:1.6;
    color:var(--ink-2);
    text-shadow: 0 0 2px #fff, 0 0 10px rgba(255,255,255,.9);
  }
  /* Push the cards closer to center (less bottom-heavy) */
  .home-hero__card-spacer{ flex:0 0 clamp(44px, 10vh, 92px); min-height:20px; }
  .home-hero__lower{
    display:grid;
    grid-template-columns: minmax(0, 520px) minmax(0, 420px);
    gap:16px;
    align-items:end;
    position:relative;
  }
  @media (max-width: 900px){
    .home-hero__wrap{
      min-height:auto;
      padding-top:0;
      padding-bottom:12px;
    }
    .home-hero__head{
      padding:14px 12px 8px;
    }
    .home-hero__lower{
      grid-template-columns: 1fr;
      align-items:stretch;
      transform:none;
      align-self:stretch;
      justify-items:center;
      gap:14px;
      padding-left:16px;
      padding-right:16px;
    }
    .home-hero__card,
    .home-hero__pestpanel{
      width:100%;
      max-width:520px;
      margin-left:auto;
      margin-right:auto;
      transform:none !important;
    }
    .home-hero__card{ transform:none; padding:18px 14px 12px; }
    .home-hero__pestpanel{ transform:none; padding:14px 14px 12px; }
    .home-hero__card-spacer{ display:none; }
  }
  .home-hero__card{
    width:100%;
    max-width:100%;
    background:rgba(255,255,255,.97);
    border:1px solid var(--line);
    border-radius:20px;
    box-shadow:var(--shadow-lg);
    padding:28px 20px 16px;
    position:relative;
    margin-top:0;
    transform: translate(var(--home-hero-card-shift-x), var(--home-hero-card-shift-y));
  }
  .home-hero__grid2{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-top:0;
  }
  @media (max-width: 520px){
    .home-hero__grid2{ grid-template-columns:1fr; }
  }
  .home-hero__ql{
    display:flex; align-items:center; gap:10px;
    min-height:52px; padding:10px 12px;
    border-radius:12px;
    border:1px solid var(--line);
    background:#fff;
    text-decoration:none; color:var(--ink);
    font-size:13px; font-weight:700;
    line-height:1.35;
    transition:border-color .15s, background .15s, box-shadow .15s;
  }
  .home-hero__ql:hover{
    border-color:var(--brand);
    background:var(--brand-soft);
    box-shadow:var(--shadow-sm);
  }
  .home-hero__ql-ico{
    flex:0 0 36px; width:36px; height:36px;
    border-radius:8px; background:var(--brand-soft); color:var(--brand);
    display:grid; place-items:center;
  }
  .home-hero__ql-ico svg{ display:block; }
  .home-hero__card-foot{
    display:flex; align-items:center; justify-content:space-between;
    gap:10px; flex-wrap:wrap;
    margin-top:12px; padding-top:10px;
    border-top:1px dashed var(--line);
    font-size:12px; font-weight:600;
  }
  .home-hero__card-foot a{
    color:var(--brand);
    text-decoration:underline; text-underline-offset:2px;
  }
  .home-hero__card-foot a:hover{ color:var(--brand-2) }
  .home-hero__pestpanel{
    width:100%;
    background:rgba(255,255,255,.92);
    border:1px solid var(--line);
    border-radius:20px;
    box-shadow:var(--shadow-lg);
    padding:18px 18px 16px;
    position:relative;
    transform: translate(var(--home-hero-pest-shift-x), var(--home-hero-pest-shift-y));
  }
  .home-hero__pests-t{
    font-size:12px; font-weight:900; color:var(--ink-2);
    margin:0 0 10px;
    letter-spacing:.04em;
  }
  .home-pest-choices{ margin:0; }
  .hero-kicker{
    display:inline-flex; align-items:center; gap:8px;
    background:var(--brand-soft); color:var(--brand-2);
    padding:6px 12px; border-radius:999px;
    font-size:12px; font-weight:700; letter-spacing:.05em;
  }
  .hero-kicker .dot{width:6px; height:6px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(232,84,39,.18)}
  .hero-title{
    font-size:40px; line-height:1.3; font-weight:900; margin:14px 0 10px;
    letter-spacing:-.01em;
  }
  .hero-title .hl{
    background:linear-gradient(transparent 65%, #ffe27a 65%);
    padding:0 2px;
  }
  .hero-sub{color:var(--ink-3); font-size:15px; max-width:60ch}

  .hero-stats{
    display:flex; gap:26px; margin-top:22px; flex-wrap:wrap;
  }
  .hero-stat{display:flex; align-items:baseline; gap:8px}
  .hero-stat .num{
    font-family:"Noto Serif JP", serif; font-weight:900;
    font-size:26px; color:var(--brand);
  }
  .hero-stat .lbl{font-size:12px; color:var(--ink-3); font-weight:500}

  .hero-grid{
    margin-top:0;
    display:grid;
    grid-template-columns: minmax(0, 3fr) minmax(0, 1fr);
    gap:24px;
    align-items:stretch;
  }
  @media (max-width:1000px){
    .hero-grid{grid-template-columns:1fr}
    .hero-title{font-size:30px}
  }
  .home-pest-title{
    font-size:clamp(22px, 4.2vw, 30px);
    font-weight:900;
    margin:0 0 8px;
    letter-spacing:-.01em;
  }
  .home-pest-lead{color:var(--ink-3); font-size:15px; max-width:56ch; margin:0 0 20px}
  .home-pest-choices{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap:14px;
  }
  @media (max-width: 820px){
    .home-pest-choices{grid-template-columns:1fr; gap:10px}
  }
  .home-pest-card{
    display:block;
    padding:18px 20px;
    border-radius:14px;
    border:1px solid var(--line);
    background:var(--bg-card);
    box-shadow:var(--shadow-sm);
    text-decoration:none;
    color:var(--ink);
    font-weight:800;
    font-size:15px;
    transition: border-color .15s, box-shadow .15s;
  }
  .home-pest-card:hover{
    border-color:var(--brand);
    box-shadow:var(--shadow-md);
  }
  .home-pest-card.is-disabled{
    color:var(--ink-3);
    opacity:.55;
    pointer-events:none;
    box-shadow:none;
  }
  .home-pest-card.is-disabled:hover{
    border-color:var(--line);
    box-shadow:none;
  }
  .home-pest-card__sub{
    display:block;
    margin-top:6px;
    font-size:12px;
    color:var(--ink-3);
    font-weight:500;
  }
  .pest-side__block{margin-bottom:18px}
  .pest-side__block:last-child{margin-bottom:0; padding-top:4px; border-top:1px dashed var(--line)}
  .pest-side__h{
    font-size:12px; font-weight:800; color:var(--ink-2);
    margin:0 0 8px; letter-spacing:.04em;
  }
  .pest-side__pests{display:flex; flex-direction:column; gap:8px}
  .pest-side__pest-link{
    display:block;
    padding:12px 14px;
    border-radius:10px;
    border:1px solid var(--line);
    background:var(--bg);
    text-decoration:none;
    color:var(--ink);
    font-weight:700;
    font-size:14px;
  }
  .pest-side__pest-link:hover{border-color:var(--brand); background:var(--brand-soft)}
  .pest-side__pest-link.is-disabled{
    color:var(--ink-3);
    opacity:.55;
    pointer-events:none;
    background:var(--bg);
  }
  /* スマホ: 地図下にサイド欄 */
  @media (max-width: 820px){
    .pest-top-hero .container-wide{padding-left:0;padding-right:0;}
    .map-panel .panel-head{display:none;}
    .map-panel .map-legend{display:none;}
    .map-panel{
      border-radius:0;
      border:0;
      border-bottom:1px solid var(--line);
      box-shadow:none;
      padding:0;
      overflow:visible;
      background:#fff;
    }
    .map-panel::before{display:none;}
  }

  /* Map panel */
  .map-panel{
    background:#fff; border:1px solid var(--line);
    border-radius:16px; padding:22px; box-shadow:var(--shadow-md);
    position:relative; overflow:hidden;
  }
  .map-panel::before{
    content:""; position:absolute; inset:0;
    background:
      radial-gradient(circle at 10% 0%, rgba(30,85,168,.05), transparent 40%);
    pointer-events:none;
  }
  .panel-head{
    display:flex; align-items:center; justify-content:space-between; margin-bottom:14px;
  }
  .panel-title{
    display:flex; align-items:center; gap:10px;
    font-size:15px; font-weight:700;
  }
  .panel-title .ico{
    width:28px; height:28px; border-radius:8px;
    background:var(--brand-soft); color:var(--brand);
    display:grid; place-items:center;
  }
  .panel-hint{font-size:12px; color:var(--ink-3)}

  .map-wrap{
    position:relative;
    background:
      linear-gradient(180deg, #f7faff 0%, #eef3fb 100%);
    border:1px solid #cfd9e8;
    border-radius:12px;
    padding:16px;
    overflow:hidden;
    aspect-ratio: 16 / 9;
    /* for responsive region cards */
    container-type:inline-size;
  }
  .map-corner-label{
    position:absolute;
    top:12px;
    left:12px;
    z-index:2;
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:6px 4px;
    font-weight:900;
    font-size:16px;
    color:var(--ink);
    text-shadow:
      0 0 2px rgba(255,255,255,.95),
      0 0 10px rgba(255,255,255,.8);
    pointer-events:none;
  }
  .map-corner-label .ico{
    width:32px; height:32px;
    border-radius:10px;
    background:transparent;
    color:var(--brand);
    display:grid;
    place-items:center;
  }
  .map-bg{
    position:absolute; inset:0;
    display:grid; place-items:center;
    pointer-events:auto;
    opacity:.9;
    transform-origin:center center;
    transition: transform .05s linear;
    user-select:none;
  }
  .map-bg img{
    width:110%; height:110%; object-fit:contain;
    filter:saturate(.85);
  }
  .map-overlay{
    position:absolute; inset:0;
    z-index:1;
  }

  /* Floating region cards over the map image */
  .region-card{
    position:absolute;
    background:rgba(255,255,255,.96);
    border:1px solid var(--line);
    border-radius:8px;
    padding:clamp(4px, 1.2cqw, 6px) clamp(6px, 1.6cqw, 8px) clamp(5px, 1.3cqw, 7px);
    box-shadow: 0 2px 8px rgba(11,31,58,.08);
    backdrop-filter:saturate(140%) blur(3px);
    min-width:clamp(74px, 16cqw, 92px);
  }
  .region-card .rc-head{
    font-size:clamp(8px, 1.8cqw, 9.5px); font-weight:800; letter-spacing:.06em;
    color:#fff; background:var(--brand);
    padding:2px 6px; border-radius:3px; display:inline-block;
    margin-bottom:5px;
  }
  .region-card .rc-prefs{
    display:grid; grid-template-columns:repeat(2, 1fr); gap:2px;
  }
  .region-card.wide .rc-prefs{grid-template-columns:repeat(2, 1fr)}
  .pref-chip{
    font-size:clamp(8.5px, 2.0cqw, 10px); font-weight:700;
    color:var(--ink-2);
    padding:clamp(2px, .8cqw, 3px) clamp(3px, 1.2cqw, 4px); border-radius:3px;
    text-align:center;
    cursor:pointer;
    border:1px solid transparent;
    transition:all .12s ease;
    line-height:1.2;
    background:#fff;
  }
  /* When the map is narrow, gently tighten region cards */
  @container (max-width: 520px){
    .region-card{min-width:68px}
    .region-card .rc-head{margin-bottom:4px}
    .pref-chip{border-radius:4px}
  }
  @container (max-width: 420px){
    .region-card{min-width:62px}
  }
  .pref-chip:hover{
    background:var(--brand); color:#fff;
  }
  .pref-chip.active{
    background:var(--accent); color:#fff;
  }
  .region-connector{
    position:absolute;
    height:1px; background:var(--brand); opacity:.5;
    transform-origin:left center;
    z-index:0;
  }
  .region-connector::after{
    content:""; position:absolute; right:-3px; top:-2px;
    width:5px; height:5px; border-radius:50%; background:var(--brand);
  }

  .map-legend{
    display:flex; gap:14px; margin-top:10px; font-size:12px; color:var(--ink-3);
    flex-wrap:wrap;
  }
  .legend-sw{display:inline-flex; align-items:center; gap:6px}
  .legend-sw .sw{width:12px; height:12px; border-radius:3px; border:1px solid #c7d2e2; background:#fff}
  .legend-sw .sw.b{background:var(--brand); border-color:var(--brand-2)}
  .legend-sw .sw.a{background:var(--accent); border-color:var(--accent-2)}

  /* Right side: pest genre selector */
  .genre-panel{
    background:#fff; border:1px solid var(--line);
    border-radius:16px; padding:22px; box-shadow:var(--shadow-md);
    display:flex; flex-direction:column;
  }
  .genre-search{
    display:flex; gap:8px; margin-bottom:14px;
  }
  .genre-search input{
    flex:1; border:1px solid var(--line);
    background:var(--bg); border-radius:10px;
    padding:12px 14px; font-size:14px; font-family:inherit;
    color:var(--ink);
  }
  .genre-search input:focus{outline:2px solid var(--brand-soft); border-color:var(--brand)}
  .genre-search button{
    width:46px; border-radius:10px; background:var(--ink);
    color:#fff; display:grid; place-items:center;
  }
  .genre-head{font-size:12px; color:var(--ink-3); font-weight:700; letter-spacing:.08em; margin:10px 0 8px}
  .pest-side__block{
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .pest-side__h{
    color:var(--ink);
    font-size:13px;
    font-weight:900;
    line-height:1.5;
  }
  .pest-side__sub{
    color:var(--ink-3);
    font-size:12px;
    line-height:1.7;
    margin:0;
  }
  .pest-side__divider{
    display:flex;
    align-items:center;
    gap:10px;
    color:var(--ink-3);
    font-size:11px;
    font-weight:900;
    letter-spacing:.08em;
    margin:4px 0;
  }
  .pest-side__divider::before,.pest-side__divider::after{
    content:"";
    flex:1;
    height:1px;
    background:var(--line);
  }
  .pest-side__geo{
    display:flex;
    flex-direction:column;
    gap:8px;
    padding:14px;
    border:1px solid var(--line);
    border-radius:14px;
    background:#f7faff;
  }
  .pest-side__geo-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    width:100%;
    border:1px solid rgba(30,85,168,.28);
    border-radius:10px;
    padding:12px 14px;
    background:#fff;
    color:var(--brand-2);
    font-size:13px;
    font-weight:900;
    box-shadow:0 6px 16px -14px rgba(11,31,58,.45);
    transition:background .15s, border-color .15s, transform .15s;
  }
  .pest-side__geo-btn:hover{
    background:var(--brand-soft);
    border-color:rgba(30,85,168,.42);
    transform:translateY(-1px);
  }
  .pest-side__geo-btn:disabled{opacity:.7; cursor:not-allowed;}
  .pest-side__geo-btn svg{
    flex:0 0 auto;
  }
  .pest-side__note{
    margin-top:auto;
    padding-top:12px;
    border-top:1px dashed var(--line);
    color:var(--ink-3);
    font-size:11.5px;
    line-height:1.7;
  }

  .genre-grid{
    display:flex; flex-direction:column; gap:6px;
    margin-bottom:12px;
  }
  .genre-card{
    border:1px solid var(--line); border-radius:10px;
    background:#fff;
    padding:10px 12px;
    display:flex; align-items:center; justify-content:space-between; gap:8px;
    text-align:left;
    transition:all .15s ease;
    position:relative;
  }
  .genre-card:hover{
    border-color:var(--brand); box-shadow:var(--shadow-sm);
  }
  .genre-card.active{
    border-color:var(--brand); background:var(--brand-soft);
  }
  .genre-card .nm{font-size:13px; font-weight:700; line-height:1.3; display:flex; align-items:center; gap:8px}
  .genre-card .nm::before{
    content:""; width:6px; height:6px; border-radius:50%;
    background:var(--brand); opacity:.3;
  }
  .genre-card.active .nm::before{opacity:1}
  .genre-card .pr{
    font-size:11px; color:var(--ink-3);
    font-family:"JetBrains Mono", monospace; letter-spacing:.02em;
  }
  .genre-card .pr b{color:var(--ink); font-weight:700}

  .urgent-row{
    display:flex; gap:10px; margin-top:auto; padding-top:14px;
    border-top:1px dashed var(--line);
  }
  .urgent-btn{
    flex:1; background:var(--brand); color:#fff;
    border-radius:10px; padding:14px; font-weight:700; font-size:14px;
    display:flex; align-items:center; justify-content:center; gap:8px;
    transition:background .15s;
  }
  .urgent-btn:hover{background:var(--brand-2)}

  @media (max-width:600px){
    .genre-grid{grid-template-columns:repeat(2,1fr)}
  }

  /* Generic section */
  section{padding:72px 0; border-bottom:1px solid var(--line-2)}
  .sec-kicker{
    font-size:12px; font-weight:700; letter-spacing:.25em;
    color:var(--brand); text-transform:uppercase;
  }
  .sec-title{
    font-size:32px; font-weight:900; letter-spacing:-.01em;
    margin:8px 0 8px;
  }
  .sec-sub{color:var(--ink-3); font-size:15px}
  .sec-head{text-align:center; margin-bottom:40px}
  .sec-head.left{text-align:left}
  @media (max-width: 600px){
    section{padding:52px 0;}
    .sec-head{margin-bottom:28px;}
    .sec-kicker{font-size:11px; letter-spacing:.18em;}
    .sec-title{
      font-size:clamp(22px, 6.4vw, 26px);
      line-height:1.45;
      letter-spacing:-.025em;
      text-wrap:balance;
    }
    .sec-sub{
      font-size:14px;
      line-height:1.85;
      text-wrap:pretty;
    }
  }

  /* Simulator */
  .sim{
    background:linear-gradient(180deg, #0b1f3a 0%, #13315c 100%);
    color:#fff;
    border-bottom-color:#13315c;
  }
  .sim .sec-title{color:#fff}
  .sim .sec-kicker{color:#9ec1ef}
  .sim .sec-sub{color:#b9c4d9}

  .sim-card{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.12);
    border-radius:18px;
    padding:28px;
    backdrop-filter:blur(6px);
    display:grid; grid-template-columns: 1.2fr 1fr; gap:28px;
  }
  @media (max-width:900px){ .sim-card{grid-template-columns:1fr} }

  .sim-field{margin-bottom:18px}
  .sim-label{
    display:flex; justify-content:space-between; align-items:center;
    font-size:12px; letter-spacing:.08em; color:#b9c4d9;
    font-weight:700; margin-bottom:8px;
  }
  .sim-label span.v{color:#fff; font-family:"JetBrains Mono", monospace}
  .chips{display:flex; gap:8px; flex-wrap:wrap}
  .chip{
    padding:10px 14px; border-radius:10px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.14);
    color:#dbe4f2; font-size:13px; font-weight:700;
    display:inline-flex; align-items:center; gap:8px;
    transition:all .15s;
  }
  .chip:hover{background:rgba(255,255,255,.1)}
  .chip.active{
    background:#fff; color:var(--ink); border-color:#fff;
  }
  .chip.big{padding:14px 16px; font-size:14px}

  /* Step-based diagnostic */
  .diag{
    display:grid;
    grid-template-columns:1fr;
    gap:16px;
    max-width:760px;
    margin:0 auto;
  }
  @media (max-width: 600px){
    .diag{gap:14px;}
    .diag-steps .diag-step-label{display:none;}
  }
  .diag-steps{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.12);
    border-radius:18px;
    padding:28px;
  }
  .diag-progress{
    display:flex; gap:6px; margin-bottom:22px;
  }
  .diag-progress .seg{
    flex:1; height:4px; border-radius:999px;
    background:rgba(255,255,255,.1);
    transition:background .3s;
  }
  .diag-progress .seg.on{background:#fff}
  .diag-step-label{
    font-size:11px; letter-spacing:.2em; color:#9ec1ef; font-weight:700;
    margin-bottom:10px;
  }
  .diag-q{
    font-size:22px; font-weight:900; color:#fff;
    margin-bottom:20px; letter-spacing:-.005em;
  }
  .diag-opts{display:grid; grid-template-columns: 1fr 1fr; gap:8px}
  .diag-opts.one{grid-template-columns:1fr}
  .diag-opt{
    display:flex; align-items:center; justify-content:space-between; gap:12px;
    padding:14px 16px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.14);
    border-radius:10px;
    color:#dbe4f2; font-weight:700; font-size:14px;
    text-align:left;
    transition:all .15s;
    width:100%;
  }
  .diag-opt:hover{background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.3)}
  .diag-opt.active{background:#fff; color:var(--ink); border-color:#fff}
  .diag-opt .meta{
    font-size:11px; font-weight:500; color:#b9c4d9;
    font-family:"JetBrains Mono", monospace;
  }
  .diag-opt.active .meta{color:var(--ink-3)}
  .diag-nav{
    display:flex; justify-content:space-between; align-items:center;
    margin-top:24px;
  }
  .diag-back{
    font-size:13px; color:#9ec1ef; font-weight:700;
    display:inline-flex; align-items:center; gap:6px;
  }
  .diag-back:disabled{opacity:.3; cursor:not-allowed}
  .diag-submit{
    background:var(--brand); color:#fff; font-weight:800;
    padding:12px 22px; border-radius:999px; font-size:14px;
    display:inline-flex; align-items:center; gap:8px;
  }
  .diag-submit:hover{background:#fff; color:var(--ink)}

  /* Slider card */
  .diag-slider{
    background:rgba(0,0,0,.15); border-radius:12px; padding:18px 20px;
    margin-bottom:16px;
  }
  .diag-slider-val{
    font-family:"Noto Serif JP", serif; font-weight:900; font-size:36px;
    color:#fff; line-height:1; margin-bottom:14px;
  }
  .diag-slider-val small{font-size:14px; color:#9ec1ef; font-family:"Noto Sans JP", sans-serif; font-weight:500; margin-left:6px}
  .sim-range{
    width:100%; -webkit-appearance:none; appearance:none;
    height:6px; border-radius:999px; background:rgba(255,255,255,.14);
    outline:none;
  }
  .sim-range::-webkit-slider-thumb{
    -webkit-appearance:none; appearance:none;
    width:22px; height:22px; border-radius:50%;
    background:#fff; border:3px solid var(--brand);
    box-shadow:0 2px 8px rgba(0,0,0,.3); cursor:pointer;
  }

  .sim-result{
    background:#fff; color:var(--ink);
    border-radius:14px; padding:28px;
    display:flex; flex-direction:column;
    position:relative;
  }
  .sim-result[hidden]{display:none !important;}
  .sim-result-label{font-size:12px; color:var(--ink-3); font-weight:700; letter-spacing:.1em}
  .sim-price{
    font-family:"Noto Serif JP", serif;
    font-weight:900; font-size:56px; line-height:1.1;
    letter-spacing:-.02em; color:var(--ink);
    margin:6px 0;
    display:flex; align-items:baseline; gap:4px;
  }
  .sim-price .unit{font-size:18px; font-weight:700; color:var(--ink-3); font-family:"Noto Sans JP", sans-serif}
  .sim-price .sep{font-size:22px; color:var(--ink-3); font-weight:700; margin:0 4px}
  .sim-bar{
    height:8px; background:var(--bg); border-radius:999px; overflow:hidden;
    margin:14px 0 10px;
  }
  .sim-bar .fill{
    height:100%;
    background:var(--brand);
    border-radius:999px;
    transition:width .4s cubic-bezier(.2,.7,.2,1);
  }
  .sim-breakdown{
    display:grid; grid-template-columns:1fr 1fr; gap:6px 14px;
    font-size:12px; color:var(--ink-3); margin-top:6px;
  }
  .sim-breakdown div{display:flex; justify-content:space-between}
  .sim-breakdown b{color:var(--ink); font-family:"JetBrains Mono", monospace}
  .sim-note{
    margin-top:auto; padding-top:14px;
    font-size:11px; color:var(--ink-3);
    border-top:1px dashed var(--line);
  }
  @media (max-width: 520px){
    .sim-result{ padding:18px 16px; }
    .sim-price{
      font-size:clamp(28px, 10vw, 42px);
      flex-wrap:wrap;
      word-break:break-word;
      overflow-wrap:anywhere;
    }
    .sim-price .unit{font-size:14px}
    .sim-price .sep{font-size:16px; margin:0 2px}
    .sim-breakdown{ grid-template-columns:1fr; }
  }

  /* Pain points */
  .pain-grid{
    display:grid; grid-template-columns:repeat(3, 1fr); gap:20px;
  }
  @media (max-width:820px){ .pain-grid{grid-template-columns:1fr} }
  .pain-card{
    background:#fff;
    border:1px solid var(--line);
    border-radius:14px;
    padding:28px 24px;
    position:relative;
  }
  .pain-n{
    position:absolute; top:-14px; left:20px;
    font-family:"Noto Serif JP", serif; font-weight:900;
    background:var(--ink); color:#fff;
    padding:2px 10px; border-radius:6px;
    font-size:12px; letter-spacing:.1em;
  }
  .pain-quote{
    font-size:18px; font-weight:700; line-height:1.6;
    margin:8px 0 10px;
  }
  .pain-desc{font-size:13px; color:var(--ink-3)}
  .pain-card .ico-big{
    font-size:36px; margin-bottom:6px; display:block;
  }

  /* Solution */
  .sol{background:var(--bg)}
  .sol-grid{
    display:grid; grid-template-columns:repeat(3, 1fr); gap:20px;
  }
  @media (max-width:820px){ .sol-grid{grid-template-columns:1fr} }
  .sol-card{
    background:#fff; border:1px solid var(--line);
    border-radius:14px; padding:28px; position:relative;
    display:flex; flex-direction:column; gap:10px;
  }
  .sol-n{
    font-family:"Noto Serif JP", serif; font-weight:900;
    color:var(--brand); font-size:14px; letter-spacing:.1em;
  }
  .sol-title{font-size:20px; font-weight:900}
  .sol-desc{font-size:14px; color:var(--ink-3)}
  .sol-vis{
    height:132px; border-radius:10px;
    background:
      repeating-linear-gradient(135deg, #f2f5fa 0 8px, #ffffff 8px 16px);
    border:1px solid var(--line);
    display:grid; place-items:center;
    font-family:"JetBrains Mono", monospace;
    font-size:11px; color:var(--ink-3);
    margin-bottom:6px;
  }
  .sol-vis strong{font-family:"Noto Sans JP", sans-serif; font-size:12px; color:var(--ink-2); font-weight:900}
  .sol-vis .mini{
    width:100%; height:100%;
    display:grid;
    grid-template-columns: 1.2fr .8fr;
    gap:10px;
    padding:12px;
  }
  .sol-vis .mini .pane{
    border:1px solid var(--line);
    border-radius:10px;
    background:#fff;
    overflow:hidden;
  }
  .sol-vis .mini .map{
    background:
      radial-gradient(circle at 22% 35%, rgba(30,85,168,.14), transparent 50%),
      radial-gradient(circle at 62% 58%, rgba(30,85,168,.12), transparent 55%),
      linear-gradient(180deg, #fff, #f6f9ff);
    position:relative;
  }
  .sol-vis .mini .pin{
    position:absolute;
    width:8px; height:8px; border-radius:50%;
    background:var(--brand);
    box-shadow:0 0 0 4px rgba(30,85,168,.18);
  }
  .sol-vis .mini .list{
    padding:10px;
    display:grid;
    gap:8px;
  }
  .sol-vis .mini .bar{
    height:10px;
    border-radius:999px;
    background:linear-gradient(90deg, rgba(30,85,168,.25), rgba(30,85,168,.12));
  }
  .sol-vis .mini .bar:nth-child(2){width:92%}
  .sol-vis .mini .bar:nth-child(3){width:72%}
  .sol-vis .mini .bar:nth-child(4){width:84%}
  .sol-vis .mini.sim{
    grid-template-columns: 1fr;
  }
  .sol-vis .mini.sim .pane{
    background:linear-gradient(180deg, #fff, #f7faff);
  }
  .sol-vis .mini.sim .sim-top{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:10px 12px;
    border-bottom:1px solid var(--line);
  }
  .sol-vis .mini.sim .chip{
    height:22px;
    padding:0 10px;
    border-radius:999px;
    border:1px solid rgba(30,85,168,.25);
    background:rgba(30,85,168,.08);
    color:var(--brand);
    font-weight:900;
    font-size:11px;
    display:inline-flex;
    align-items:center;
  }
  .sol-vis .mini.sim .dots{display:flex; gap:4px}
  .sol-vis .mini.sim .dot{
    width:8px; height:8px; border-radius:50%;
    background:rgba(30,85,168,.18);
  }
  .sol-vis .mini.sim .sim-body{
    padding:10px 12px;
    display:grid;
    gap:8px;
  }
  .sol-vis .mini.sim .row{
    display:grid;
    grid-template-columns: 64px 1fr;
    gap:10px;
    align-items:center;
  }
  .sol-vis .mini.sim .lbl{
    font-size:10px;
    color:var(--ink-3);
    font-weight:900;
    font-family:"JetBrains Mono", monospace;
  }
  .sol-vis .mini.sim .line{
    height:10px; border-radius:999px;
    background:rgba(11,31,58,.06);
    overflow:hidden;
  }
  .sol-vis .mini.sim .line > i{
    display:block; height:100%;
    width:70%;
    background:linear-gradient(90deg, rgba(30,85,168,.35), rgba(30,85,168,.16));
    border-radius:999px;
  }
  .sol-vis .mini.sim .row:nth-child(2) .line > i{width:82%}
  .sol-vis .mini.sim .row:nth-child(3) .line > i{width:58%}
  .sol-vis .mini.sim .price{
    margin-top:6px;
    padding:10px 12px;
    border-radius:12px;
    border:1px solid rgba(30,85,168,.18);
    background:#fff;
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    gap:10px;
  }
  .sol-vis .mini.sim .price .k{
    font-size:10px; color:var(--ink-3); font-weight:900; letter-spacing:.08em;
  }
  .sol-vis .mini.sim .price .v{
    font-family:"Noto Serif JP", serif;
    font-weight:900;
    font-size:16px;
    color:var(--ink);
    white-space:nowrap;
  }

  .sol-vis .mini.proof{
    grid-template-columns: 1fr;
  }
  .sol-vis .mini.proof .flow{
    padding:10px 12px;
    display:grid;
    gap:8px;
  }
  .sol-vis .mini.proof .step{
    display:grid;
    grid-template-columns: 24px 1fr;
    gap:10px;
    align-items:center;
  }
  .sol-vis .mini.proof .badge{
    width:24px; height:24px; border-radius:8px;
    background:rgba(30,85,168,.10);
    border:1px solid rgba(30,85,168,.20);
    color:var(--brand);
    font-weight:900;
    font-family:"JetBrains Mono", monospace;
    font-size:11px;
    display:grid;
    place-items:center;
  }
  .sol-vis .mini.proof .txt{
    height:10px;
    border-radius:999px;
    background:rgba(11,31,58,.06);
  }
  .sol-vis .mini.proof .txt.w2{width:80%}
  .sol-vis .mini.proof .txt.w3{width:65%}
  .sol-vis .mini.proof .cite{
    margin-top:2px;
    padding:10px 12px;
    border-top:1px solid var(--line);
    display:grid;
    gap:8px;
  }
  .sol-vis .mini.proof .cite .pill{
    height:18px;
    width:60%;
    border-radius:999px;
    background:rgba(30,85,168,.08);
    border:1px solid rgba(30,85,168,.18);
  }

  /* FAQ */
  .faq{background:#fff; border-bottom:1px solid var(--line)}
  .faq-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
  @media (max-width: 820px){ .faq-grid{grid-template-columns:1fr} }
  details.faq-item{
    border:1px solid var(--line);
    border-radius:14px;
    padding:14px 16px;
    background:var(--bg);
  }
  details.faq-item summary{
    cursor:pointer;
    list-style:none;
    display:flex;
    align-items:flex-start;
    gap:12px;
    font-weight:900;
    color:var(--ink);
  }
  details.faq-item summary::-webkit-details-marker{display:none;}
  .faq-q{
    width:26px; height:26px; border-radius:8px;
    background:var(--brand-soft);
    color:var(--brand);
    display:grid; place-items:center;
    flex:0 0 auto;
    font-family:"JetBrains Mono", monospace;
    font-size:12px;
  }
  .faq-a{margin-top:10px; color:var(--ink-2); font-size:14px; line-height:1.7}
  .faq-a b{color:var(--ink)}

  /* Articles */
  .art-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:24px; gap:16px; flex-wrap:wrap}
  .art-scroll{
    display:grid; grid-auto-flow:column;
    grid-auto-columns: minmax(280px, 320px);
    gap:18px;
    overflow-x:auto;
    padding-bottom:14px;
    scroll-snap-type:x mandatory;
    scrollbar-width:thin;
  }
  .art-card{
    background:#fff; border:1px solid var(--line);
    border-radius:14px; overflow:hidden;
    scroll-snap-align:start;
    display:flex; flex-direction:column;
    transition:transform .18s, box-shadow .18s;
  }
  .art-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
  .art-thumb{
    height:160px;
    background:
      linear-gradient(135deg, rgba(30,85,168,.08), rgba(30,85,168,.02)),
      repeating-linear-gradient(45deg, #eef3fb 0 10px, #f7f9fc 10px 20px);
    position:relative;
    display:grid; place-items:center;
    font-family:"JetBrains Mono", monospace; font-size:11px; color:var(--ink-3);
    border-bottom:1px solid var(--line);
  }
  .art-tag{
    position:absolute; top:10px; left:10px;
    background:var(--ink); color:#fff; font-size:11px; font-weight:700;
    padding:3px 8px; border-radius:4px;
  }
  .art-body{padding:16px 18px 18px}
  .art-title{font-size:15px; font-weight:700; line-height:1.55; margin-bottom:8px}
  .art-meta{font-size:11px; color:var(--ink-3); display:flex; gap:10px; font-family:"JetBrains Mono", monospace}

  .art-nav{display:flex; gap:8px}
  .art-nav button{
    width:40px; height:40px; border-radius:50%;
    border:1px solid var(--line); background:#fff;
    display:grid; place-items:center;
  }
  .art-nav button:hover{border-color:var(--ink)}

  /* Trust */
  #trust{
    position:relative;
    background:linear-gradient(180deg,#fff 0%,#f7f9fc 100%);
    padding-top:56px;
    padding-bottom:34px;
  }
  #trust-reviews{
    position:relative;
    background:#f7f9fc;
    padding-top:8px;
    padding-bottom:52px;
  }
  .trust-top{
    display:grid;
    grid-template-columns:1.35fr repeat(2, minmax(0, 1fr));
    gap:16px;
    margin-bottom:0;
  }
  .trust-stat{
    position:relative;
    min-height:168px;
    padding:22px 20px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    box-shadow:0 14px 36px -28px rgba(11,31,58,.45);
    overflow:hidden;
  }
  .trust-stat::after{
    content:"";
    position:absolute;
    right:-28px;
    bottom:-28px;
    width:96px;
    height:96px;
    border-radius:50%;
    background:rgba(30,85,168,.08);
  }
  .trust-stat--main{
    background:linear-gradient(135deg,#0b1f3a,#1e55a8 120%);
    color:#fff;
    border-color:transparent;
  }
  .trust-stat--main::after{background:rgba(255,255,255,.12);}
  .trust-stat__tag{
    display:inline-flex;
    align-items:center;
    border:1px solid rgba(30,85,168,.16);
    border-radius:999px;
    padding:4px 10px;
    color:var(--brand-2);
    background:var(--brand-soft);
    font-size:11px;
    font-weight:900;
    letter-spacing:.08em;
  }
  .trust-stat--main .trust-stat__tag{
    color:#fff;
    background:rgba(255,255,255,.14);
    border-color:rgba(255,255,255,.24);
  }
  .trust-num{
    font-family:"Noto Serif JP", serif; font-weight:900;
    font-size:clamp(34px, 4.5vw, 46px);
    color:var(--ink);
    line-height:1;
    margin-top:18px;
  }
  .trust-stat--main .trust-num{color:#fff;}
  .trust-num .u{font-size:18px; color:var(--ink-3); font-family:"Noto Sans JP", sans-serif}
  .trust-stat--main .trust-num .u{color:rgba(255,255,255,.78);}
  .trust-lbl{font-size:14px; color:var(--ink); margin-top:10px; font-weight:900; line-height:1.55}
  .trust-stat--main .trust-lbl{color:#fff;}
  .trust-desc{margin:8px 0 0; color:var(--ink-3); font-size:12.5px; line-height:1.65; font-weight:700;}
  .trust-stat--main .trust-desc{color:rgba(255,255,255,.78);}
  .scroll-hint{
    display:none;
  }

  .reviews{
    display:grid; grid-template-columns:repeat(3, 1fr); gap:18px;
  }
  .review{
    position:relative;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    padding:22px;
    overflow:hidden;
    box-shadow:0 12px 32px -26px rgba(11,31,58,.45);
  }
  .review::after{
    content:attr(data-num);
    position:absolute;
    top:10px;
    right:16px;
    color:rgba(30,85,168,.08);
    font-family:"Noto Serif JP", serif;
    font-size:54px;
    font-weight:900;
    line-height:1;
    letter-spacing:-.06em;
    pointer-events:none;
  }
  .review::before{
    content:"";
    position:absolute;
    left:0;
    top:20px;
    bottom:20px;
    width:4px;
    border-radius:0 999px 999px 0;
    background:linear-gradient(var(--brand),#cf9b2f);
  }
  .review h3{
    margin:0 0 8px;
    color:var(--ink);
    font-size:16px;
    line-height:1.55;
    font-weight:900;
  }
  .review p{font-size:14px; margin:0 0 14px; line-height:1.8; color:var(--ink-2);}
  .review-who{
    display:flex; align-items:center; gap:10px;
    font-size:12px; color:var(--ink-3);
  }
  .review-who .av{
    width:10px; height:10px; border-radius:50%;
    background:linear-gradient(135deg,var(--brand),#cf9b2f);
    flex:0 0 auto;
  }

  .sources{
    margin-top:24px; padding:18px 20px;
    background:#fff; border:1px dashed var(--line);
    border-radius:14px;
    font-size:12px; color:var(--ink-3);
  }
  .sources b{color:var(--ink); display:block; margin-bottom:6px}
  @media (max-width:1100px){
    .trust-top{grid-template-columns:repeat(2,1fr)}
    .reviews{grid-template-columns:1fr}
  }
  @media (max-width:560px){
    #trust{padding-top:42px;}
    .scroll-hint{
      display:flex;
      align-items:center;
      justify-content:flex-end;
      position:relative;
      top:auto;
      right:auto;
      z-index:3;
      width:100%;
      height:34px;
      margin:-10px 2px 8px;
      pointer-events:none;
    }
    .scroll-hint__swipe{
      display:block;
      width:58px;
      height:auto;
      opacity:0;
      transform:translateX(-10px);
      transform-origin:center;
      will-change:transform, opacity;
    }
    .scroll-hint.is-visible .scroll-hint__swipe{
      animation:swipeHint 2.6s ease-out 1 both;
    }
    .scroll-hint.is-visible + .trust-top > .trust-stat,
    .scroll-hint.is-visible + .reviews > .review,
    .scroll-hint.is-visible + .krv-merit__grid > .krv-merit__card,
    .scroll-hint.is-visible + .krv-flow__grid > .krv-flow__card,
    .scroll-hint.is-visible + .krv-choose__list > .krv-choose__item{
      animation:cardSwipeNudge 2.6s ease-out 1 both;
    }
    @keyframes swipeHint{
      0%{transform:translateX(-12px); opacity:0;}
      18%{opacity:.18;}
      48%{transform:translateX(8px); opacity:.26;}
      100%{transform:translateX(16px); opacity:0;}
    }
    @keyframes cardSwipeNudge{
      0%,100%{transform:translateX(0);}
      24%{transform:translateX(0);}
      48%{transform:translateX(clamp(-76px, -15vw, -44px));}
      72%{transform:translateX(8px);}
    }
    @media (prefers-reduced-motion: reduce){
      .scroll-hint.is-visible .scroll-hint__swipe{animation:none; opacity:.18;}
      .scroll-hint.is-visible + .trust-top > .trust-stat,
      .scroll-hint.is-visible + .reviews > .review,
      .scroll-hint.is-visible + .krv-merit__grid > .krv-merit__card,
      .scroll-hint.is-visible + .krv-flow__grid > .krv-flow__card,
      .scroll-hint.is-visible + .krv-choose__list > .krv-choose__item{animation:none;}
    }
    .trust-top,.reviews{
      display:flex;
      gap:12px;
      overflow-x:auto;
      scroll-snap-type:x mandatory;
      -webkit-overflow-scrolling:touch;
      padding:2px 2px 12px;
      scrollbar-width:none;
    }
    .trust-top{grid-template-columns:none; margin-bottom:0;}
    .trust-top::-webkit-scrollbar{display:none;}
    .trust-stat{
      flex:0 0 min(82vw, 320px);
      min-height:auto;
      scroll-snap-align:start;
    }
    .reviews::-webkit-scrollbar{display:none;}
    .review{
      flex:0 0 min(82vw, 320px);
      scroll-snap-align:start;
    }
  }

  /* CTA */
  .cta{
    background:linear-gradient(135deg, #0b1f3a, #1e55a8 120%);
    color:#fff; text-align:center;
    padding:80px 0;
    position:relative; overflow:hidden;
  }
  .cta::before{
    content:""; position:absolute; inset:0;
    background-image:
      radial-gradient(circle at 20% 20%, rgba(255,255,255,.06) 0, transparent 40%),
      radial-gradient(circle at 80% 80%, rgba(30,85,168,.18) 0, transparent 40%);
  }
  .cta-inner{position:relative; z-index:1}
  .cta h2{font-size:36px; margin:0 0 10px; font-weight:900}
  .cta p{color:#c4d2ea; font-size:15px; margin-bottom:28px}
  .cta-btns{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
  .btn-primary{
    display:inline-flex; align-items:center; gap:10px;
    background:var(--brand); color:#fff; font-weight:800;
    padding:18px 34px; border-radius:999px; font-size:16px;
    box-shadow:0 12px 24px rgba(30,85,168,.35);
    transition:transform .15s, background .15s;
  }
  .btn-primary:hover{background:var(--brand-2); transform:translateY(-1px)}
  .btn-ghost{
    display:inline-flex; align-items:center; gap:10px;
    background:rgba(255,255,255,.08); color:#fff;
    border:1px solid rgba(255,255,255,.3);
    padding:18px 28px; border-radius:999px; font-weight:700; font-size:14px;
  }
  .btn-ghost:hover{background:rgba(255,255,255,.14)}

  /* Footer */
  footer{background:#081627; color:#98a6bf; padding:44px 0 24px; font-size:13px}
  .foot-grid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:28px; margin-bottom:28px}
  @media (max-width:820px){
    footer{padding:36px 0 22px;}
    .foot-grid{
      grid-template-columns:1fr 1fr;
      gap:26px 28px;
      margin-bottom:26px;
    }
    .foot-about{
      grid-column:1 / -1;
      padding-bottom:22px;
      border-bottom:1px solid rgba(255,255,255,.08);
    }
    .foot-about > p{
      max-width:32em;
      margin:0;
      line-height:1.85;
    }
    .foot-grid h5{margin-bottom:10px;}
    .foot-grid > div:last-child{
      grid-column:1 / -1;
    }
    .foot-grid > div:last-child ul{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:10px 20px;
    }
    .foot-info{
      margin-top:18px;
      padding-top:16px;
    }
    .foot-info__row{
      grid-template-columns:72px minmax(0,1fr);
      gap:14px;
      align-items:start;
    }
    .foot-info dt{
      font-size:12px;
    }
    .foot-info dd{
      line-height:1.75;
    }
    .foot-bot{
      text-align:left;
      line-height:1.7;
    }
  }
  .foot-logo{color:#fff; font-weight:900; font-size:16px; margin-bottom:8px}
  .foot-info{
    margin-top:14px;
    padding-top:12px;
    border-top:1px solid rgba(255,255,255,.16);
    color:rgba(255,255,255,.72);
    font-size:12px;
    line-height:1.8;
  }
  .foot-info dl{margin:0;}
  .foot-info__row{
    display:grid;
    grid-template-columns:64px 1fr;
    gap:8px;
    margin:0;
  }
  .foot-info dt{font-weight:800; color:rgba(255,255,255,.86);}
  .foot-info dd{margin:0;}
  .foot-grid h5{color:#fff; margin:0 0 12px; font-size:13px}
  .foot-grid ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px}
  .foot-grid a{color:#98a6bf}
  .foot-grid a:hover{color:#fff}
  .foot-bot{border-top:1px solid rgba(255,255,255,.08); padding-top:18px; text-align:center; font-size:11px; color:#6b7a94}
  @media (max-width:820px){
    .foot-grid > div:last-child ul{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:10px 20px;
    }
    .foot-bot{
      text-align:left;
      line-height:1.7;
    }
  }

  /* Static pages */
  .static-page{
    background:linear-gradient(180deg,#f6f9fd 0%,#fff 36%);
    border-bottom:1px solid var(--line);
  }
  .static-page__inner{
    max-width:960px;
    margin:0 auto;
    padding:clamp(34px, 7vw, 72px) 24px clamp(54px, 8vw, 88px);
  }
  .static-page__card{
    background:#fff;
    border:1px solid var(--line);
    border-radius:20px;
    box-shadow:var(--shadow-lg);
    padding:clamp(24px, 4.5vw, 44px);
  }
  .static-page__head{
    margin-bottom:28px;
    padding-bottom:22px;
    border-bottom:1px solid var(--line);
  }
  .static-page__kicker{
    margin:0 0 8px;
    color:#cf9b2f;
    font-size:13px;
    letter-spacing:.18em;
    font-weight:800;
  }
  .static-page__title{
    margin:0;
    color:var(--ink);
    font-size:clamp(24px, 4vw, 34px);
    font-weight:900;
    line-height:1.35;
    letter-spacing:-.02em;
  }
  .static-page__lead{
    margin:12px 0 0;
    max-width:720px;
    color:var(--ink-2);
    font-size:15px;
    font-weight:700;
    line-height:1.8;
  }
  .static-page__body{
    color:var(--ink);
    font-size:15px;
    line-height:1.9;
  }
  .static-page__body > *:first-child{margin-top:0;}
  .static-page__body h2{
    margin:2.1em 0 .7em;
    color:var(--brand-2);
    font-size:clamp(18px, 2.8vw, 22px);
    font-weight:900;
    line-height:1.45;
  }
  .static-page__body h3{
    margin:1.5em 0 .5em;
    color:var(--ink);
    font-size:16px;
    font-weight:900;
  }
  .static-page__body p{margin:.9em 0;}
  .static-page__body ul,.static-page__body ol{margin:.9em 0; padding-left:1.35em;}
  .static-page__body li{margin:.4em 0;}
  .static-page__body dl{
    display:grid;
    grid-template-columns:minmax(96px, 150px) 1fr;
    gap:.65em 1em;
    margin:1em 0;
  }
  .static-page__body dt{font-weight:900; color:var(--ink);}
  .static-page__body dd{margin:0;}
  .static-page__body a{color:var(--brand); text-decoration:underline; text-underline-offset:3px;}
  .static-page__note{
    margin:0 0 22px;
    padding:14px 16px;
    border:1px solid var(--line);
    border-radius:12px;
    background:var(--brand-soft);
    color:var(--ink-3);
    font-size:13px;
    line-height:1.75;
  }
  .static-meta{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:18px;
  }
  .static-meta span{
    display:inline-flex;
    align-items:center;
    border:1px solid var(--line);
    border-radius:999px;
    padding:5px 11px;
    background:#fff;
    color:var(--ink-3);
    font-size:12px;
    font-weight:800;
  }
  .contact-layout{
    display:grid;
    grid-template-columns:minmax(0, 1.45fr) minmax(260px, .8fr);
    gap:24px;
    align-items:start;
  }
  .contact-form{
    display:grid;
    gap:14px;
  }
  .contact-field{
    display:grid;
    gap:7px;
    color:var(--ink);
    font-weight:900;
  }
  .contact-field span{
    color:var(--ink-3);
    font-size:13px;
    font-weight:800;
  }
  .contact-field input,
  .contact-field select,
  .contact-field textarea{
    width:100%;
    border:1px solid var(--line);
    border-radius:12px;
    background:#fff;
    padding:13px 14px;
    color:var(--ink);
    font:inherit;
  }
  .contact-field textarea{resize:vertical; min-height:150px;}
  .contact-field input:focus,
  .contact-field select:focus,
  .contact-field textarea:focus{
    outline:2px solid var(--brand-soft);
    border-color:var(--brand);
  }
  .contact-side{
    border:1px solid var(--line);
    border-radius:16px;
    background:#f7f9fc;
    padding:18px;
  }
  .contact-side h2{
    margin:0 0 10px;
    color:var(--brand-2);
    font-size:17px;
  }
  .contact-side p{margin:0 0 12px; color:var(--ink-3); font-size:13.5px; line-height:1.8;}
  .contact-ok{
    margin:0 0 18px;
    border:1px solid rgba(42,169,122,.28);
    border-radius:12px;
    background:rgba(42,169,122,.09);
    color:#16664b;
    padding:13px 14px;
    font-weight:900;
  }
  @media(max-width:720px){
    .static-page__inner{padding:24px 16px 70px;}
    .static-page__card{border-radius:16px; padding:22px 18px;}
    .contact-layout{grid-template-columns:1fr;}
    .static-page__body dl{grid-template-columns:1fr; gap:.2em;}
    .static-page__body dd{margin:0 0 .65em;}
  }

  /* Mobile fixed CTA */
  .mobile-cta{
    display:none;
    position:fixed; bottom:0; left:0; right:0;
    background:#fff; padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    border-top:1px solid var(--line);
    z-index:40;
    box-shadow:0 -4px 14px rgba(11,31,58,.08);
    gap:10px;
  }
  .mobile-cta .btn-primary{flex:1; padding:14px 20px; font-size:14px; justify-content:center}
  .mobile-cta--zip{
    align-items:stretch;
  }
  .mobile-cta__zip-form{
    display:flex;
    align-items:stretch;
    gap:8px;
    width:100%;
  }
  .mobile-cta__zip-field{
    flex:1 1 auto;
    min-width:0;
    display:flex;
    flex-direction:column;
    gap:4px;
  }
  .mobile-cta__zip-label{
    color:var(--ink);
    font-size:11px;
    font-weight:900;
    line-height:1.1;
  }
  .mobile-cta__zip-input{
    width:100%;
    min-width:0;
    border:1px solid var(--line);
    border-radius:12px;
    padding:10px 13px;
    font-family:inherit;
    font-size:16px;
    font-weight:800;
    letter-spacing:.05em;
    background:#f7f9fc;
    color:var(--ink);
  }
  .mobile-cta__zip-input:focus{
    outline:2px solid var(--brand-soft);
    border-color:var(--brand);
    background:#fff;
  }
  .mobile-cta__zip-submit{
    flex:0 0 auto;
    min-width:104px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    border-radius:12px;
    padding:0 14px;
    background:var(--brand);
    color:#fff;
    font-family:inherit;
    font-size:14px;
    font-weight:900;
    white-space:nowrap;
  }
  .mobile-cta__zip-submit svg{
    flex:0 0 auto;
  }
  .mobile-cta__zip-submit:disabled{
    opacity:.65;
    cursor:not-allowed;
  }
  @media (max-width:900px){ .mobile-cta{display:flex} body{padding-bottom:86px} }

  .postal-section{
    background:
      linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0)),
      #14345c;
    color:#fff;
    border-bottom:1px solid rgba(255,255,255,.12);
    padding:56px 0;
    scroll-margin-top: 84px;
  }
  .postal-section-inner{
    max-width:640px; margin:0 auto; padding:0 24px;
  }
  .postal-section__kicker{
    display:inline-flex;
    align-items:center;
    gap:6px;
    margin:0 0 10px;
    color:rgba(255,255,255,.72);
    font-size:12px;
    font-weight:900;
    letter-spacing:.12em;
  }
  .postal-section h2{font-size:22px; font-weight:900; margin:0 0 8px}
  .postal-section p{font-size:14px; color:rgba(255,255,255,.76); margin:0 0 20px}
  .postal-section__note{
    margin:10px 0 0;
    color:rgba(255,255,255,.62);
    font-size:12px;
    line-height:1.7;
  }
  .postal-form{display:flex; gap:10px; flex-wrap:wrap; align-items:stretch}
  .postal-form input{
    flex:1; min-width:200px;
    border:1px solid var(--line); border-radius:10px;
    padding:14px 16px; font-size:16px; font-family:inherit;
    letter-spacing:.08em;
  }
  .postal-form input:focus{outline:2px solid var(--brand-soft); border-color:var(--brand)}
  .postal-section .postal-form input:focus{
    outline:2px solid rgba(255,255,255,.24);
    border-color:#fff;
  }
  .postal-form button{
    padding:14px 22px; border-radius:10px;
    background:var(--brand); color:#fff; font-weight:800; font-size:14px;
    white-space:nowrap;
  }
  .postal-form button:hover{background:var(--brand-2)}
  .postal-section .postal-form button{
    background:#fff;
    color:#14345c;
  }
  .postal-section .postal-form button:hover{background:#edf3f8}

  /* Home: postal + geo side-by-side on desktop */
  .home-duo{
    display:grid;
    grid-template-columns:1fr;
    gap:18px;
    padding:36px 0 10px;
    border-bottom:1px solid var(--line);
    background:#fff;
  }
  .home-duo > section{
    padding:0;
    border-bottom:0;
    background:transparent;
  }
  .home-duo .postal-section-inner{
    max-width:none;
    padding:0 24px;
  }
  @media (min-width: 980px){
    .home-duo{
      grid-template-columns:1fr 1fr;
      align-items:start;
    }
    .home-duo .geo-section .geo-actions{
      justify-content:center;
    }
  }
  @media (max-width: 900px){
    .geo-actions{ justify-content:center; }
  }

  .city-select-page, .area-result-page{
    background:#fff;
    border-bottom:1px solid var(--line);
    min-height:40vh;
  }
  .breadcrumb{color:var(--ink-3); font-size:13px; margin-bottom:16px}
  .breadcrumb a{color:var(--brand); font-weight:700}
  .city-list{
    border:1px solid var(--line); border-radius:12px; overflow:auto;
    max-width:560px;
    max-height:min(70vh, 720px);
  }
  .city-row{
    display:block; padding:14px 18px; border-bottom:1px solid var(--line);
    font-size:15px; font-weight:600; color:var(--ink);
    transition:background .12s;
  }
  .city-row:last-child{border-bottom:0}
  .city-row:hover{background:var(--brand-soft)}

  /* CitySelect (PC: avoid tall 1-column lists) */
  .city-select__table{
    display:grid;
    grid-template-columns:minmax(180px, 220px) 1fr;
    border:1px solid var(--line);
    border-radius:14px;
    background:#fff;
    overflow:hidden;
    max-height:min(62vh, 520px);
  }
  .city-select__left{
    background:var(--bg);
    border-right:1px solid var(--line);
    overflow:auto;
  }
  .city-select__right{
    padding:14px 14px;
    overflow:auto;
  }
  .city-select__cities{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:10px 14px;
  }
  @media (min-width: 1100px){
    .city-select__cities{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
  }
  @media (max-width: 900px){
    .city-select__cities{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
    .city-select__table{ grid-template-columns: minmax(160px, 200px) 1fr; }
  }
  @media (max-width: 560px){
    .city-select__table{ grid-template-columns: 1fr; max-height:none; }
    .city-select__left{ border-right:0; border-bottom:1px solid var(--line); max-height:240px; }
    .city-select__cities{ grid-template-columns:1fr; }
  }

  /* Number rolling animation */
  @keyframes num-pulse{
    0%{transform:scale(1)}
    50%{transform:scale(1.04)}
    100%{transform:scale(1)}
  }
  .pulse{animation:num-pulse .4s ease}

  /* Mobile: 地図→アコーディオンリスト */
  .map-mobile-list{display:none}
  @media (max-width: 820px){
    .map-wrap{
      aspect-ratio:auto;
      min-height:0;
      padding:0;
      background:transparent;
      border:0;
      border-radius:0 !important;
      box-shadow:none;
      overflow:visible;
    }
    .map-overlay{display:none !important;}
    .map-bg{display:none !important;}
    .map-mobile-list{
      display:block;
      position:relative;
      z-index:2;
      padding:0;
      margin:0;
      overflow:visible;
      background:transparent;
      -webkit-overflow-scrolling:touch;
    }
    .mml-section-bar{
      background:var(--line-2);
      color:var(--ink-2);
      font-size:14px;
      font-weight:900;
      padding:14px 16px;
      border-bottom:1px solid var(--line);
      letter-spacing:.02em;
    }
    .mml-acc{border-bottom:1px solid var(--line); background:#fff;}
    .mml-acc-trigger{
      width:100%;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      padding:16px 16px;
      border:0;
      background:#fff;
      font-family:inherit;
      font-size:15px;
      font-weight:700;
      color:var(--ink);
      text-align:left;
      cursor:pointer;
    }
    .mml-acc-trigger:active{background:var(--bg);}
    .mml-chev{
      flex:0 0 auto;
      color:var(--ink-3);
      font-size:11px;
      line-height:1;
      transition:transform .2s ease;
    }
    .mml-acc-trigger.is-open .mml-chev{transform:rotate(180deg);}
    .mml-acc-panel{
      padding:0;
      border:0;
      background:#fff;
    }
    .mml-pref-list{margin:0; padding:0;}
    .mml-pref-row{
      display:block;
      width:100%;
      box-sizing:border-box;
      margin:0;
      padding:14px 16px;
      border:0;
      border-top:1px solid var(--line);
      background:#fff;
      font-family:inherit;
      font-size:15px;
      font-weight:600;
      color:var(--ink);
      text-align:left;
      cursor:pointer;
    }
    .mml-pref-row:active{background:rgba(11,31,58,.03);}
    .mml-pref-row.is-active{
      background:rgba(30,85,168,.08);
      font-weight:800;
    }
  }

  /* ----- シロアリLP: ヘッダーナビ ----- */
  .pestbook-area-selector[data-mode="header"] .pestbook-area-selector__row{
    max-width:1280px;
    flex-wrap:nowrap;
    align-items:center;
    gap:12px;
    padding:8px 20px;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-brand{
    flex:0 0 auto;
    margin-right:0;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-brand__logo{
    height:40px;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-area-selector__spacer{
    display:none;
  }
  .pestbook-header-nav{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:1px;
    flex:1 1 auto;
    flex-wrap:nowrap;
    min-width:0;
    overflow:hidden;
    padding:0 4px;
  }
  .pestbook-header-nav a{
    font-size:11.5px;
    font-weight:800;
    color:var(--ink-2);
    text-decoration:none;
    padding:6px 7px;
    border-radius:999px;
    white-space:nowrap;
  }
  .pestbook-header-nav a:hover{
    background:rgba(30,85,168,.08);
    color:var(--ink);
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-header-fields{
    flex:0 0 auto;
    margin-left:auto;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-header-field{
    min-height:44px;
    padding:2px 12px 1px;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-header-field__label{
    font-size:10px;
    letter-spacing:.04em;
    margin-bottom:3px;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-input{
    width:150px;
    padding:7px 11px;
    font-size:13px;
  }
  .pestbook-area-selector[data-mode="header"] .pestbook-go{
    height:36px;
    padding:0 14px;
    font-size:13px;
  }
  @media (max-width: 1180px){
    .pestbook-header-nav{display:none;}
    .pestbook-area-selector[data-mode="header"] .pestbook-brand{order:1;}
    .pestbook-area-selector[data-mode="header"] .pestbook-header-fields{order:2;}
    .pestbook-area-selector[data-mode="header"] .pestbook-hamburger{
      order:3;
      display:inline-flex;
      margin-left:0;
    }
  }
  @media (max-width: 720px){
    .pestbook-area-selector[data-mode="header"] .pestbook-area-selector__row{
      padding:8px 14px;
    }
    .pestbook-area-selector[data-mode="header"] .pestbook-brand{
      flex:1 1 auto;
      min-width:0;
    }
    .pestbook-area-selector[data-mode="header"] .pestbook-brand__logo{
      height:38px;
    }
    .pestbook-area-selector[data-mode="header"] .pestbook-header-fields{
      display:none;
    }
  }

  /* ----- シロアリLP: タイトル＋地図（一体） ----- */
  .termite-search-top{
    position:relative;
    overflow:hidden;
    border-bottom:1px solid var(--line);
    padding:0 0 40px;
  }
  .termite-search-top .termite-lp-hero__head{
    text-align:center;
    padding:clamp(18px, 3.5vw, 28px) 12px clamp(14px, 2.5vw, 20px);
  }
  .termite-search-top .termite-lp-hero__title{
    text-shadow:0 0 1px #fff, 0 0 8px rgba(255,255,255,.9);
  }
  .termite-search-top .termite-lp-hero__lead{
    text-shadow:0 0 2px #fff, 0 0 10px rgba(255,255,255,.85);
  }
  .termite-lp-hero{
    background:#fff;
    border-bottom:1px solid var(--line);
    padding:0 0 24px;
  }
  .termite-lp-hero__head{
    text-align:center;
    padding:clamp(28px, 6vw, 56px) 12px clamp(20px, 4vw, 36px);
  }
  .termite-lp-hero__title{
    margin:0;
    font-size:clamp(24px, 4.5vw, 38px);
    font-weight:900;
    line-height:1.3;
    letter-spacing:-.02em;
    color:var(--ink);
  }
  .termite-title-break{display:none;}
  .termite-lp-hero__lead{
    margin:12px auto 0;
    max-width:42ch;
    font-size:clamp(14px, 2vw, 16px);
    font-weight:700;
    line-height:1.75;
    color:var(--ink-2);
  }
  @media (max-width: 600px){
    .termite-search-top.pest-top-hero::before{
      background:linear-gradient(180deg, #edf2f8 0%, #f8fafc 44%, #fff 100%);
    }
    .termite-search-top .termite-lp-hero__head{
      position:relative;
      isolation:isolate;
      min-height:190px;
      display:flex;
      flex-direction:column;
      justify-content:center;
      padding:22px 18px 16px;
    }
    .termite-search-top .termite-lp-hero__head::before{
      content:"";
      position:absolute;
      top:0;
      bottom:0;
      left:50%;
      width:100vw;
      transform:translateX(-50%);
      z-index:-1;
      pointer-events:none;
      background:
        linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,.38) 46%, rgba(255,255,255,.76) 100%),
        url("../top-background.webp") center center / cover no-repeat;
    }
    .termite-lp-hero__title{
      font-size:clamp(24px, 7vw, 28px);
      line-height:1.42;
      letter-spacing:-.025em;
      text-wrap:balance;
    }
    .termite-title-break{display:block;}
    .termite-lp-hero__lead{
      max-width:24em;
      font-size:14px;
      line-height:1.85;
      text-wrap:pretty;
    }
  }

  /* ----- krv LP sections (from 更新したいhtml) ----- */
  .krv-merit,.krv-rec,.krv-flow,.krv-case,.krv-choose,.krv-faq{
    --navy:#1d4d80; --navy2:#2a619e; --gold:#cf9b2f; --ink:#23303d; --line:#e3e9f0;
    --cta:#f48000; --cta2:#ffa31f;
    position:relative;
    z-index:0;
    max-width:920px; margin:0 auto; padding:64px 8px; text-align:center; font-family:inherit;
  }
  .krv-merit::before,.krv-rec::before,.krv-flow::before,.krv-case::before,.krv-choose::before,.krv-faq::before{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:calc(50% - 50vw);
    right:calc(50% - 50vw);
    z-index:-1;
    background:var(--krv-section-bg, #fff);
    border-top:1px solid rgba(29,77,128,.08);
    border-bottom:1px solid rgba(29,77,128,.08);
  }
  .krv-rec{max-width:760px; --krv-section-bg:linear-gradient(180deg,#fff8ec 0%,#fffdfa 100%);}
  .krv-merit{--krv-section-bg:#fff;}
  .krv-flow{
    --krv-section-bg:linear-gradient(180deg,#eef5fb 0%,#f8fbff 100%);
    max-width:1240px;
    padding-left:clamp(12px, 3vw, 32px);
    padding-right:clamp(12px, 3vw, 32px);
  }
  .krv-case{max-width:860px; --krv-section-bg:#fff;}
  .krv-choose{max-width:840px; --krv-section-bg:linear-gradient(180deg,#fff8ed 0%,#fffdf8 100%);}
  .krv-faq{max-width:840px; --krv-section-bg:#f4f8fc;}
  .krv-merit__eyebrow,.krv-rec__eyebrow,.krv-flow__eyebrow,.krv-case__eyebrow,.krv-choose__eyebrow,.krv-faq__eyebrow{
    color:var(--gold); font-size:13px; letter-spacing:.2em; font-weight:700; margin:0 0 6px;
  }
  .krv-merit__title,.krv-rec__title,.krv-flow__title,.krv-case__title,.krv-choose__title,.krv-faq__title{
    color:var(--navy) !important; -webkit-text-fill-color:var(--navy);
    font-size:clamp(21px,3.6vw,28px); font-weight:800;
    margin:0 0 10px !important; line-height:1.5; border:0 !important; background:none !important; padding:0 !important;
  }
  .krv-rec__title-row{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    flex-wrap:wrap;
  }
  .krv-rec__pr{
    display:inline-flex;
    align-items:center;
    border:1px solid var(--line);
    border-radius:999px;
    padding:2px 8px;
    color:#6f7b88;
    background:#fff;
    font-size:11px;
    font-weight:800;
    letter-spacing:.08em;
    line-height:1.4;
  }
  .krv-faq__title{margin-bottom:26px !important;}
  .krv-merit__lead,.krv-rec__lead,.krv-flow__lead,.krv-case__lead,.krv-choose__lead{
    color:#566472; font-size:14.5px; line-height:1.8; margin:0 auto 28px; max-width:640px;
  }
  .krv-rec__lead{max-width:620px; margin-bottom:22px; line-height:1.85;}
  .krv-merit__grid{display:grid; grid-template-columns:repeat(2,1fr); gap:16px; text-align:left;}
  .krv-merit__card{
    position:relative; background:#fff; border:1px solid var(--line); border-radius:14px;
    padding:26px 24px 22px; box-shadow:0 8px 22px -16px rgba(29,77,128,.55);
    opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;
  }
  .krv-merit__card::before{
    content:""; position:absolute; left:0; top:18px; bottom:18px; width:4px;
    border-radius:0 4px 4px 0; background:linear-gradient(var(--gold),#e6c068);
  }
  .krv-merit.is-in .krv-merit__card{opacity:1; transform:none;}
  .krv-merit.is-in .krv-merit__card:nth-child(2){transition-delay:.08s;}
  .krv-merit.is-in .krv-merit__card:nth-child(3){transition-delay:.16s;}
  .krv-merit.is-in .krv-merit__card:nth-child(4){transition-delay:.24s;}
  .krv-merit__num{
    display:inline-block; font-size:13px; font-weight:800; letter-spacing:.08em;
    color:var(--navy2); background:#eef4fa; border-radius:20px; padding:4px 12px; margin-bottom:12px;
  }
  .krv-merit__h,.krv-choose__h{
    color:var(--navy) !important; font-size:16.5px; font-weight:800; line-height:1.5; margin:0 0 8px !important;
    border:0 !important; background:none !important; padding:0 !important;
  }
  .krv-choose__h{font-size:16px; margin-bottom:5px !important;}
  .krv-merit__d,.krv-choose__d{color:var(--ink); font-size:14px; line-height:1.85; margin:0;}
  .krv-rec__card{
    background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden;
    box-shadow:0 16px 40px -22px rgba(22,59,99,.55); text-align:left;
  }
  .krv-rec__head{
    position:relative; min-height:176px; padding:22px 24px;
    display:flex; flex-direction:column; justify-content:flex-end; background:#16395f;
  }
  .krv-rec__bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; opacity:.5;}
  .krv-rec__head::after{content:""; position:absolute; inset:0; z-index:2;
    background:linear-gradient(180deg,rgba(20,40,60,.35) 0%,rgba(16,40,70,.82) 100%);}
  .krv-rec__badge{
    position:absolute; top:0; left:0; z-index:4;
    background:var(--gold); color:#fff; font-size:12.5px; font-weight:800; letter-spacing:.06em;
    padding:7px 16px; border-radius:0 0 10px 0;
  }
  .krv-rec__logo{position:relative; z-index:3; background:#fff; align-self:flex-start;
    padding:7px 12px; border-radius:7px; box-shadow:0 2px 10px rgba(0,0,0,.18); margin-bottom:12px;}
  .krv-rec__logo img{display:block; height:30px; width:auto;}
  .krv-rec__catch{position:relative; z-index:3; color:#fff; font-weight:800; margin:0;
    font-size:clamp(16px,2.6vw,19px); line-height:1.5; text-shadow:0 2px 8px rgba(0,0,0,.4);}
  .krv-rec__body{padding:22px 24px 26px;}
  .krv-rec__stats{display:flex; gap:10px; margin-bottom:20px;}
  .krv-rec__stat{flex:1; background:#f3f7fb; border-radius:10px; padding:12px 6px; text-align:center;}
  .krv-rec__stat-num{display:block; color:var(--navy); font-weight:800; font-size:clamp(14px,2.4vw,16px); line-height:1.3;}
  .krv-rec__stat-label{display:block; color:#5a6875; font-size:11px; font-weight:600; margin-top:4px; line-height:1.4;}
  .krv-rec__reasons{list-style:none; padding:0; margin:0 0 22px;}
  .krv-rec__reasons li{display:flex; gap:12px; align-items:flex-start; padding:11px 0; border-bottom:1px dashed var(--line);}
  .krv-rec__reasons li:last-child{border-bottom:0;}
  .krv-rec__reasons div{flex:1;}
  .krv-rec__r-title{display:block; color:var(--navy); font-weight:800; font-size:14.5px; line-height:1.55;}
  .krv-rec__r-sub{display:block; color:#5a6875; font-size:12.5px; line-height:1.7; margin-top:3px;}
  .krv-rec__check{flex-shrink:0; width:24px; height:24px; border-radius:50%; margin-top:1px;
    background:linear-gradient(135deg,var(--navy),var(--navy2)); position:relative;}
  .krv-rec__check::after{content:""; position:absolute; left:8px; top:5px; width:6px; height:10px;
    border-right:2.5px solid #fff; border-bottom:2.5px solid #fff; transform:rotate(45deg);}
  .krv-rec__btn{
    display:block; max-width:520px; margin:0 auto; text-decoration:none;
    background:linear-gradient(180deg,var(--cta2),var(--cta)); color:#fff !important;
    text-align:center; font-weight:900; font-size:clamp(16px,2.8vw,19px); padding:18px 20px;
    border-radius:11px; letter-spacing:.02em;
    box-shadow:0 6px 0 #c46400,0 10px 20px rgba(243,152,0,.35); transition:transform .12s ease,box-shadow .12s ease;
  }
  .krv-rec__btn:hover{transform:translateY(2px); box-shadow:0 4px 0 #c46400,0 6px 12px rgba(243,152,0,.35); color:#fff !important;}
  .krv-case__list{text-align:left;}
  .krv-case__item{
    background:#fff; border:1px solid var(--line); border-radius:12px;
    margin-bottom:14px; overflow:hidden;
    box-shadow:0 6px 18px -14px rgba(29,77,128,.5); transition:box-shadow .25s ease;
  }
  .krv-case__item[open]{box-shadow:0 10px 26px -16px rgba(29,77,128,.6);}
  .krv-case__head{
    list-style:none; cursor:pointer; position:relative; display:flex; flex-wrap:wrap;
    align-items:center; gap:6px 16px; padding:18px 50px 18px 20px;
  }
  .krv-case__head::-webkit-details-marker{display:none;}
  .krv-case__head::after{
    content:""; position:absolute; right:20px; top:50%;
    width:12px; height:12px; margin-top:-7px;
    border-right:2.5px solid var(--gold); border-bottom:2.5px solid var(--gold);
    transform:rotate(45deg); transition:transform .3s ease;
  }
  .krv-case__item[open] .krv-case__head::after{transform:rotate(-135deg);}
  .krv-case__head:hover{background:#f6f9fc;}
  .krv-case__no{
    flex-shrink:0; background:var(--navy); color:#fff; font-size:12px; font-weight:800;
    letter-spacing:.06em; padding:5px 12px; border-radius:6px;
  }
  .krv-case__sum{display:flex; flex-direction:column; gap:2px; flex:1; min-width:200px;}
  .krv-case__place{color:var(--navy); font-weight:800; font-size:14px;}
  .krv-case__symptom{color:#5a6875; font-size:13px; line-height:1.5;}
  .krv-case__body{padding:4px 22px 20px; animation:krvCaseIn .35s ease;}
  .krv-case__dl{margin:0; border-top:1px dashed var(--line); padding-top:14px;}
  .krv-case__dl dt{color:var(--gold); font-size:12.5px; font-weight:800; letter-spacing:.04em; margin-top:12px;}
  .krv-case__dl dt:first-child{margin-top:0;}
  .krv-case__dl dd{margin:3px 0 0; color:var(--ink); font-size:14px; line-height:1.8;}
  .krv-case__price{
    margin:14px 0 0; padding:12px 16px; background:#f3f7fb; border-radius:10px;
    color:var(--navy); font-weight:800; font-size:18px; display:flex; align-items:baseline; gap:8px; flex-wrap:wrap;
  }
  .krv-case__price span{
    font-size:12px; font-weight:800; color:#fff; background:var(--navy2);
    padding:3px 10px; border-radius:5px;
  }
  .krv-case__price em{font-style:normal; font-size:13px; font-weight:700; color:#5a6875;}
  .krv-case__note{color:#8895a3; font-size:11.5px; line-height:1.7; margin:18px 0 0; text-align:left;}
  .krv-flow__grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:clamp(16px, 2vw, 24px);
    text-align:left;
  }
  .krv-flow__card{
    background:#fff;
    border:1px solid var(--line);
    border-radius:16px;
    overflow:hidden;
    box-shadow:0 10px 28px -20px rgba(29,77,128,.55);
  }
  .krv-flow__fig{
    margin:0;
    background:#f7f9fc;
  }
  .krv-flow__img{
    display:block;
    width:100%;
    aspect-ratio:16/11;
    object-fit:cover;
  }
  .krv-flow__note{
    margin:14px 0 0;
    color:#8895a3;
    font-size:11.5px;
    line-height:1.7;
    text-align:left;
  }
  .krv-flow__body{padding:18px 18px 20px;}
  .krv-flow__step{
    display:inline-block;
    color:var(--navy2);
    background:#eef4fa;
    border-radius:999px;
    padding:3px 10px;
    font-size:12px;
    font-weight:800;
    letter-spacing:.06em;
    margin-bottom:8px;
  }
  .krv-flow__h{
    color:var(--navy) !important;
    font-size:clamp(15.5px, 1.4vw, 17px);
    font-weight:800;
    line-height:1.5;
    margin:0 0 6px !important;
    border:0 !important;
    background:none !important;
    padding:0 !important;
  }
  .krv-flow__d{color:var(--ink); font-size:14px; line-height:1.8; margin:0;}
  .krv-choose__list{text-align:left;}
  .krv-choose__item{
    display:flex; gap:16px; align-items:flex-start;
    background:#fff; border:1px solid var(--line); border-radius:12px;
    padding:20px 22px; margin-bottom:12px;
    box-shadow:0 6px 18px -15px rgba(29,77,128,.5);
    opacity:0; transform:translateY(16px); transition:opacity .55s ease, transform .55s ease;
  }
  .krv-choose.is-in .krv-choose__item{opacity:1; transform:none;}
  .krv-choose.is-in .krv-choose__item:nth-child(2){transition-delay:.07s;}
  .krv-choose.is-in .krv-choose__item:nth-child(3){transition-delay:.14s;}
  .krv-choose.is-in .krv-choose__item:nth-child(4){transition-delay:.21s;}
  .krv-choose.is-in .krv-choose__item:nth-child(5){transition-delay:.28s;}
  .krv-choose__check{
    flex-shrink:0; width:30px; height:30px; border-radius:50%;
    background:linear-gradient(135deg,var(--navy),var(--navy2)); position:relative; margin-top:2px;
  }
  .krv-choose__check::after{
    content:""; position:absolute; left:10px; top:6px; width:7px; height:13px;
    border-right:2.5px solid #fff; border-bottom:2.5px solid #fff; transform:rotate(45deg);
  }
  .krv-choose__txt{flex:1;}
  .krv-faq__list{text-align:left;}
  .krv-faq__item{
    background:#fff; border:1px solid var(--line); border-radius:12px;
    margin-bottom:12px; overflow:hidden;
    box-shadow:0 6px 18px -14px rgba(29,77,128,.5); transition:box-shadow .25s ease;
  }
  .krv-faq__item[open]{box-shadow:0 10px 26px -16px rgba(29,77,128,.6);}
  .krv-faq__q{
    list-style:none; cursor:pointer; position:relative;
    padding:18px 52px 18px 54px; font-weight:700; color:var(--navy);
    font-size:clamp(15px,2.4vw,16.5px); line-height:1.55;
    display:flex; align-items:center; min-height:24px;
  }
  .krv-faq__q::-webkit-details-marker{display:none;}
  .krv-faq__q::before{
    content:"Q"; position:absolute; left:18px; top:50%; transform:translateY(-50%);
    width:26px; height:26px; border-radius:50%; background:var(--navy); color:#fff;
    font-size:14px; font-weight:800; display:flex; align-items:center; justify-content:center;
  }
  .krv-faq__q::after{
    content:""; position:absolute; right:20px; top:50%;
    width:13px; height:13px; margin-top:-7px;
    border-right:2.5px solid var(--gold); border-bottom:2.5px solid var(--gold);
    transform:rotate(45deg); transition:transform .3s ease;
  }
  .krv-faq__item[open] .krv-faq__q::after{transform:rotate(-135deg);}
  .krv-faq__q:hover{background:#f6f9fc;}
  .krv-faq__a{
    padding:0 22px 20px 54px; color:var(--ink); font-size:14.5px; line-height:1.85;
    animation:krvFaqIn .35s ease;
  }
  .krv-faq__a p{margin:0;}
  .krv-faq__a strong{color:var(--navy); background:linear-gradient(transparent 62%,rgba(207,155,47,.28) 62%);}
  @keyframes krvCaseIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  @keyframes krvFaqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  @media(max-width:600px){
    .krv-merit,.krv-rec,.krv-flow,.krv-case,.krv-choose,.krv-faq{
      margin:0 auto;
      padding-top:52px;
      padding-bottom:52px;
      padding-left:16px;
      padding-right:16px;
    }
    .krv-merit__eyebrow,.krv-rec__eyebrow,.krv-flow__eyebrow,.krv-case__eyebrow,.krv-choose__eyebrow,.krv-faq__eyebrow{
      font-size:11.5px;
      letter-spacing:.16em;
    }
    .krv-merit__title,.krv-rec__title,.krv-flow__title,.krv-case__title,.krv-choose__title,.krv-faq__title{
      font-size:clamp(21px, 6vw, 24px);
      line-height:1.55;
      letter-spacing:-.025em;
      text-wrap:balance;
    }
    .krv-merit__lead,.krv-rec__lead,.krv-flow__lead,.krv-case__lead,.krv-choose__lead{
      font-size:14px;
      line-height:1.9;
      text-wrap:pretty;
      margin-bottom:16px;
    }
    .krv-merit .scroll-hint,.krv-flow .scroll-hint,.krv-choose .scroll-hint{
      color:#6a7886;
    }
    .krv-merit__grid,.krv-flow__grid,.krv-choose__list{
      display:flex;
      gap:12px;
      overflow-x:auto;
      scroll-snap-type:x mandatory;
      -webkit-overflow-scrolling:touch;
      padding:2px 2px 14px;
      scrollbar-width:none;
    }
    .krv-merit__grid::-webkit-scrollbar,.krv-flow__grid::-webkit-scrollbar,.krv-choose__list::-webkit-scrollbar{display:none;}
    .krv-merit__card,.krv-flow__card,.krv-choose__item{
      flex:0 0 min(82vw, 320px);
      scroll-snap-align:start;
    }
    .krv-merit__card{padding:22px 18px 18px;}
    .krv-rec__title{white-space:normal;}
    .krv-rec__head{min-height:150px; padding:18px;}
    .krv-rec__body{padding:18px 16px 22px;}
    .krv-rec__stats{flex-direction:column; gap:8px;}
    .krv-rec__stat{display:flex; align-items:baseline; justify-content:center; gap:8px; padding:10px;}
    .krv-rec__stat-label{margin-top:0;}
    .krv-rec__btn{font-size:16px; padding:16px 14px;}
    .krv-case__head{padding:16px 42px 16px 16px; gap:8px 10px;}
    .krv-case__sum{min-width:0;}
    .krv-case__place,.krv-case__symptom{text-wrap:pretty;}
    .krv-case__body{padding:4px 16px 18px;}
    .krv-flow__card{display:block;}
    .krv-flow__img{height:auto; aspect-ratio:16/10;}
    .krv-flow__body{padding:14px 16px 16px;}
    .krv-flow__h{font-size:15.5px; line-height:1.6; text-wrap:balance;}
    .krv-choose__item{padding:16px; gap:12px; margin-bottom:0;}
    .krv-choose__check{width:26px; height:26px;}
    .krv-choose__check::after{left:8.5px; top:5px; width:6px; height:11px;}
    .krv-choose__h{line-height:1.6; text-wrap:balance;}
    .krv-faq__q{padding:16px 44px 16px 48px;}
    .krv-faq__a{padding:0 16px 18px 48px; font-size:14px;}
    .krv-faq__q::before{left:14px;}
    .postal-section h2{
      font-size:21px;
      line-height:1.5;
      letter-spacing:-.02em;
      text-wrap:balance;
    }
  }

/* パネル幅が狭いとき: JS が .is-compact-list を付与（820px 超でもリストに切替） */
.pestbook-japan-map.is-compact-list .map-wrap{
  aspect-ratio:auto;
  min-height:0;
  padding:0;
  background:transparent;
  border:0;
  border-radius:0 !important;
  box-shadow:none;
  overflow:visible;
}
.pestbook-japan-map.is-compact-list .map-overlay{display:none !important;}
.pestbook-japan-map.is-compact-list .map-bg{display:none !important;}
.pestbook-japan-map.is-compact-list .map-corner-label{display:none;}
.pestbook-japan-map.is-compact-list .map-mobile-list{
  display:block;
  position:relative;
  z-index:2;
  padding:0;
  margin:0;
  overflow:visible;
  background:transparent;
  -webkit-overflow-scrolling:touch;
}
.pestbook-japan-map.is-compact-list .mml-section-bar{
  background:var(--line-2);
  color:var(--ink-2);
  font-size:14px;
  font-weight:900;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
  letter-spacing:.02em;
}
.pestbook-japan-map.is-compact-list .mml-acc{border-bottom:1px solid var(--line); background:#fff;}
.pestbook-japan-map.is-compact-list .mml-acc-trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 16px;
  border:0;
  background:#fff;
  font-family:inherit;
  font-size:15px;
  font-weight:700;
  color:var(--ink);
  text-align:left;
  cursor:pointer;
}
.pestbook-japan-map.is-compact-list .mml-acc-trigger:active{background:var(--bg);}
.pestbook-japan-map.is-compact-list .mml-chev{
  flex:0 0 auto;
  color:var(--ink-3);
  font-size:11px;
  line-height:1;
  transition:transform .2s ease;
}
.pestbook-japan-map.is-compact-list .mml-acc-trigger.is-open .mml-chev{transform:rotate(180deg);}
.pestbook-japan-map.is-compact-list .mml-acc-panel{
  padding:0;
  border:0;
  background:#fff;
}
.pestbook-japan-map.is-compact-list .mml-pref-list{margin:0; padding:0;}
.pestbook-japan-map.is-compact-list .mml-pref-row{
  display:block;
  width:100%;
  box-sizing:border-box;
  margin:0;
  padding:14px 16px;
  border:0;
  border-top:1px solid var(--line);
  background:#fff;
  font-family:inherit;
  font-size:15px;
  font-weight:600;
  color:var(--ink);
  text-align:left;
  cursor:pointer;
}
.pestbook-japan-map.is-compact-list .mml-pref-row:active{background:rgba(11,31,58,.03);}
.pestbook-japan-map.is-compact-list .mml-pref-row.is-active{
  background:rgba(30,85,168,.08);
  font-weight:800;
}
