
  :root{
    /* ── NextHome ブランドトークン ── */
    --white:#FFFFFF;
    --base:#FBFDFE;        /* ほんのり水色がかった白 */
    --sky:#4FAECC;         /* ブランド水色（落ち着いたミズイロ） */
    --sky-deep:#2E8FB0;    /* 押せる水色（CTA・リンク） */
    --sky-soft:#EAF5F9;    /* 淡い水色の面 */
    --sky-mist:#DDEEF5;    /* 波・装飾 */
    --navy:#27486B;        /* 締め色（ネイビー寄りブルーグレー） */
    --navy-deep:#1E3A57;
    --ink:#2F3B45;         /* 本文（真っ黒にしない） */
    --muted:#687682;
    --line:#E3EBF0;        /* 罫線 */
    --gold:#E8B85C;        /* 星評価のみ */
    --line-green:#06C755;  /* LINEボタンのみ */
    --r:14px;
    --shadow-s:0 2px 10px rgba(39,72,107,.07);
    --shadow-m:0 8px 26px rgba(39,72,107,.12);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:'Noto Sans JP','Hiragino Sans','Yu Gothic',sans-serif;
    color:var(--ink);background:var(--white);font-size:15.5px;line-height:2.0;
    letter-spacing:.015em;
  }
  .hd{font-family:'Zen Kaku Gothic New','Noto Sans JP',sans-serif;font-weight:700;letter-spacing:.05em}
  .en{font-family:'Outfit',sans-serif;letter-spacing:.22em;font-weight:600}
  .wrap{max-width:1060px;margin:0 auto;padding:0 22px}
  a{color:var(--sky-deep)}

  .mock-note{
    background:repeating-linear-gradient(-45deg,#FDF8EA,#FDF8EA 12px,#F8F0D8 12px,#F8F0D8 24px);
    border-bottom:1px solid #EEE5C8;text-align:center;font-size:12px;
    padding:5px 12px;color:#7A6A3A;position:relative;z-index:70;
  }

  /* ════ ヘッダー ════ */
  header{
    position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
    border-bottom:1px solid var(--line);backdrop-filter:blur(8px);
  }
  .head-in{display:flex;align-items:center;gap:20px;padding:11px 22px;max-width:1180px;margin:0 auto}
  .logo{display:flex;align-items:center;gap:10px;text-decoration:none}
  .logo .mark{
    width:38px;height:38px;border-radius:11px;flex:none;
    background:linear-gradient(135deg,var(--sky) 0%,var(--sky-deep) 100%);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-family:'Outfit';font-weight:600;font-size:17px;
    box-shadow:0 2px 8px rgba(79,174,204,.35);
  }
  .logo .t b{font-size:15.5px;color:var(--navy);letter-spacing:.03em;display:block;line-height:1.3;font-weight:700}
  .logo .t span{font-size:10px;color:var(--muted);letter-spacing:.06em}
  .head-nav{margin-left:auto;display:flex;gap:20px;font-size:13px}
  .head-nav a{color:var(--ink);text-decoration:none;position:relative;padding:4px 0}
  .head-nav a::after{
    content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
    background:var(--sky);transition:right .25s;border-radius:2px;
  }
  .head-nav a:hover::after{right:0}
  .head-cta{
    margin-left:6px;background:var(--sky-deep);color:#fff;text-decoration:none;
    font-size:12.5px;font-weight:700;border-radius:24px;padding:9px 18px;white-space:nowrap;
    box-shadow:0 3px 10px rgba(46,143,176,.3);transition:transform .15s,box-shadow .15s;
  }
  .head-cta:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(46,143,176,.4)}
  @media(max-width:860px){.head-nav,.head-cta{display:none}}

  /* ════ ファーストビュー ════ */
  .hero{
    position:relative;overflow:hidden;
    background:
      radial-gradient(ellipse 900px 480px at 88% -10%, rgba(79,174,204,.16), transparent 62%),
      radial-gradient(ellipse 700px 420px at -8% 108%, rgba(79,174,204,.10), transparent 60%),
      linear-gradient(175deg,#F4FAFC 0%,var(--white) 58%);
  }
  /* 背景のごく薄い同心円（水紋＝相談の波紋。読みやすさ優先で極薄） */
  .hero .ripple{
    position:absolute;border-radius:50%;border:1.5px solid rgba(79,174,204,.13);
    pointer-events:none;
  }
  .hero .r1{width:520px;height:520px;right:-130px;top:-180px}
  .hero .r2{width:760px;height:760px;right:-250px;top:-300px}
  .hero .r3{width:340px;height:340px;left:-150px;bottom:-160px;border-color:rgba(79,174,204,.10)}
  .hero-in{
    position:relative;max-width:1060px;margin:0 auto;
    padding:58px 22px 86px;display:grid;grid-template-columns:1.25fr .75fr;gap:44px;align-items:center;
  }
  @media(max-width:860px){.hero-in{grid-template-columns:1fr;padding:40px 22px 78px}}
  .eyebrow{
    display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--navy);
    background:#fff;border:1px solid var(--sky-mist);border-radius:24px;
    padding:5px 16px;margin-bottom:20px;font-weight:700;box-shadow:var(--shadow-s);
  }
  .eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--sky);flex:none}
  .hero h1{
    font-family:'Zen Kaku Gothic New';font-weight:900;
    font-size:clamp(24px,4vw,34px);line-height:1.78;letter-spacing:.04em;color:var(--navy-deep);
  }
  .hero h1 .soft{font-weight:700;font-size:.72em;display:block;color:var(--ink);margin-bottom:10px;letter-spacing:.06em}
  .hero h1 em{
    font-style:normal;color:var(--sky-deep);
    background:linear-gradient(transparent 72%,rgba(79,174,204,.22) 72%);
    padding:0 1px;border-radius:2px;
  }
  .hero .lead{margin-top:18px;font-size:15px;color:#4A5763;max-width:34em}

  /* CTA：主従をつける */
  .cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:26px;max-width:500px}
  .cta{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    border-radius:13px;padding:15px 8px 13px;font-weight:700;font-size:15px;letter-spacing:.04em;
    text-decoration:none;text-align:center;border:2px solid transparent;
    transition:transform .18s,box-shadow .18s,filter .18s;
  }
  .cta small{font-size:10.5px;font-weight:500;opacity:.88;letter-spacing:.03em}
  .cta:hover{transform:translateY(-2px)}
  .cta.assess{
    background:linear-gradient(135deg,var(--sky) 0%,var(--sky-deep) 90%);color:#fff;
    box-shadow:0 6px 18px rgba(46,143,176,.35);grid-column:1/-1;font-size:16.5px;padding:17px 8px 15px;
  }
  .cta.assess:hover{box-shadow:0 10px 24px rgba(46,143,176,.45);filter:brightness(1.04)}
  .cta.photo{background:#fff;color:var(--sky-deep);border-color:var(--sky);box-shadow:var(--shadow-s)}
  .cta.photo:hover{background:var(--sky-soft)}
  .cta.line{background:var(--line-green);color:#fff;box-shadow:0 4px 14px rgba(6,199,85,.28)}
  .cta.tel{background:#fff;color:var(--navy);border-color:#C8D6E0;box-shadow:var(--shadow-s)}
  .cta.tel:hover{border-color:var(--navy)}

  /* 写真だけ相談の帯（強み導線） */
  .photo-band{
    margin-top:16px;max-width:500px;display:flex;gap:13px;align-items:flex-start;
    background:#fff;border:1.5px dashed var(--sky);border-radius:13px;padding:13px 16px;
    box-shadow:var(--shadow-s);
  }
  .photo-band .ic{
    flex:none;width:42px;height:42px;border-radius:11px;background:var(--sky-soft);
    display:flex;align-items:center;justify-content:center;color:var(--sky-deep);
  }
  .photo-band b{font-size:13.5px;color:var(--sky-deep);display:block;line-height:1.6}
  .photo-band p{font-size:12px;color:var(--muted);line-height:1.75;margin-top:2px}

  /* hero右：会社の安心材料カード（代表カードの置き換え） */
  .trust{
    background:rgba(255,255,255,.86);backdrop-filter:blur(2px);
    border:1px solid var(--sky-mist);border-radius:18px;padding:22px;
    box-shadow:var(--shadow-m);
  }
  .trust .t-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
  .trust .t-head .en{font-size:10px;color:var(--sky-deep)}
  .trust .t-head b{font-size:14px;color:var(--navy)}
  .trust ul{list-style:none}
  .trust li{
    display:flex;gap:10px;align-items:flex-start;font-size:13px;line-height:1.7;
    padding:9px 0;border-bottom:1px solid var(--line);
  }
  .trust li:last-of-type{border-bottom:none}
  .trust li .ck{
    flex:none;width:20px;height:20px;border-radius:50%;background:var(--sky-soft);
    color:var(--sky-deep);display:flex;align-items:center;justify-content:center;margin-top:4px;
  }
  .trust .kuchikomi{
    margin-top:12px;background:var(--sky-soft);border-radius:11px;padding:11px 14px;
    font-size:12px;color:var(--navy);display:flex;align-items:center;gap:10px;
  }
  .trust .kuchikomi .stars{color:var(--gold);letter-spacing:2px;font-size:13px}

  /* ════ 波形の区切り ════ */
  .wave{display:block;width:100%;height:54px;margin-bottom:-1px}
  @media(max-width:640px){.wave{height:34px}}

  /* ════ セクション共通 ════ */
  section{position:relative}
  .sec-pad{padding:64px 0 72px}
  .sec-head{text-align:center;margin-bottom:38px}
  .sec-head .en{font-size:11px;color:var(--sky-deep);display:block;margin-bottom:8px}
  .sec-head h2{
    font-family:'Zen Kaku Gothic New';font-weight:900;color:var(--navy-deep);
    font-size:clamp(21px,3.1vw,27px);letter-spacing:.06em;line-height:1.7;
  }
  .sec-head .bar{width:46px;height:4px;border-radius:2px;background:var(--sky);margin:14px auto 0}
  .sec-head p{font-size:13.5px;color:var(--muted);margin-top:12px}

  /* ════ お悩みの声（吹き出し） ════ */
  .voice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px 16px}
  .voice{
    position:relative;background:#fff;border:1px solid var(--sky-mist);border-radius:16px;
    padding:19px 20px 16px;text-decoration:none;color:var(--ink);display:block;
    box-shadow:var(--shadow-s);transition:transform .2s,box-shadow .2s,border-color .2s;
  }
  .voice::after{ /* 吹き出しのしっぽ */
    content:"";position:absolute;left:30px;bottom:-9px;width:16px;height:16px;
    background:#fff;border-left:1px solid var(--sky-mist);border-bottom:1px solid var(--sky-mist);
    transform:rotate(-45deg);border-radius:0 0 0 4px;
  }
  .voice:hover{transform:translateY(-4px);box-shadow:var(--shadow-m);border-color:var(--sky)}
  .voice .q{
    font-family:'Zen Kaku Gothic New';font-weight:700;font-size:15px;color:var(--navy-deep);
    line-height:1.75;display:flex;gap:8px;
  }
  .voice .q::before{content:"“";color:var(--sky);font-size:24px;line-height:1;font-family:'Outfit'}
  .voice .a{font-size:12.5px;color:var(--muted);line-height:1.8;margin:8px 0 10px}
  .voice .a b{color:var(--sky-deep);font-weight:700}
  .voice .chip{
    display:inline-block;font-size:10.5px;color:var(--sky-deep);background:var(--sky-soft);
    border-radius:5px;padding:2px 9px;font-weight:700;letter-spacing:.04em;
  }
  .voice-foot{text-align:center;font-size:13px;color:var(--muted);margin-top:34px}

  /* ════ 相談しやすい理由 ════ */
  .riyu-wrap{background:linear-gradient(180deg,var(--sky-soft),#F3F9FB)}
  .riyu{display:grid;grid-template-columns:repeat(auto-fit,minmax(265px,1fr));gap:18px}
  .riyu .item{
    background:#fff;border-radius:16px;padding:28px 24px 26px;box-shadow:var(--shadow-s);
    border-top:4px solid var(--sky);transition:transform .2s,box-shadow .2s;
  }
  .riyu .item:hover{transform:translateY(-3px);box-shadow:var(--shadow-m)}
  .riyu .ic{
    width:52px;height:52px;border-radius:14px;background:var(--sky-soft);
    display:flex;align-items:center;justify-content:center;color:var(--sky-deep);margin-bottom:14px;
  }
  .riyu b{font-family:'Zen Kaku Gothic New';display:block;font-size:16px;color:var(--navy-deep);
    margin-bottom:8px;line-height:1.7;letter-spacing:.04em}
  .riyu p{font-size:13.5px;line-height:1.95;color:#46535E}

  /* ════ 流れ ════ */
  .flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;counter-reset:step;position:relative}
  .flow .step{
    background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 14px 16px;
    text-align:center;counter-increment:step;box-shadow:var(--shadow-s);
    transition:transform .2s,box-shadow .2s;position:relative;
  }
  .flow .step:hover{transform:translateY(-3px);box-shadow:var(--shadow-m)}
  .flow .step::before{
    content:"0" counter(step);font-family:'Outfit';font-weight:600;font-size:13px;
    color:var(--sky);display:block;letter-spacing:.18em;margin-bottom:6px;
  }
  .flow b{font-family:'Zen Kaku Gothic New';font-size:14.5px;display:block;margin-bottom:5px;color:var(--navy-deep)}
  .flow p{font-size:11.5px;color:var(--muted);line-height:1.75}
  .flow-note{text-align:center;font-size:12.5px;color:var(--muted);margin-top:22px}

  /* ════ 動画・コラム ════ */
  .two-col{display:grid;grid-template-columns:1fr 1fr;gap:34px}
  @media(max-width:780px){.two-col{grid-template-columns:1fr}}
  .col-head{margin-bottom:16px}
  .col-head .en{font-size:10.5px;color:var(--sky-deep)}
  .col-head h3{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:19px;color:var(--navy-deep);letter-spacing:.05em;margin-top:4px}
  .video-ph{
    aspect-ratio:16/9;border-radius:16px;color:#fff;position:relative;overflow:hidden;
    background:linear-gradient(135deg,#37536F,#27486B);
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
    font-size:12.5px;box-shadow:var(--shadow-m);
  }
  .video-ph .play{
    width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.16);
    border:1.5px solid rgba(255,255,255,.4);
    display:flex;align-items:center;justify-content:center;font-size:19px;
  }
  .post{
    display:flex;gap:14px;align-items:flex-start;text-decoration:none;color:var(--ink);
    padding:14px 12px;border-radius:12px;transition:background .15s;
  }
  .post:hover{background:var(--sky-soft)}
  .post .thumb{
    flex:none;width:74px;height:56px;border-radius:9px;background:var(--sky-mist);
    display:flex;align-items:center;justify-content:center;color:var(--sky-deep);font-size:10px;
  }
  .post .date{font-size:11px;color:var(--muted);font-family:'Outfit';letter-spacing:.08em}
  .post .cat{font-size:10px;color:var(--sky-deep);background:var(--sky-soft);border-radius:4px;padding:1px 7px;margin-left:7px;font-weight:700}
  .post b{display:block;font-size:13.5px;font-weight:500;margin-top:3px;line-height:1.7}
  .post:hover b{color:var(--sky-deep)}

  /* ════ FAQ ════ */
  .faq-wrap{background:linear-gradient(180deg,#F6FAFC,var(--sky-soft))}
  .faq{max-width:780px;margin:0 auto}
  details{
    background:#fff;border:1px solid var(--sky-mist);border-radius:14px;
    margin-bottom:11px;overflow:hidden;box-shadow:var(--shadow-s);
    transition:box-shadow .2s;
  }
  details:hover{box-shadow:var(--shadow-m)}
  summary{
    cursor:pointer;padding:17px 48px 17px 18px;font-weight:700;font-size:14.5px;
    list-style:none;display:flex;gap:13px;align-items:flex-start;color:var(--navy-deep);
    position:relative;line-height:1.75;
  }
  summary::-webkit-details-marker{display:none}
  summary .qm{
    flex:none;width:26px;height:26px;border-radius:50%;background:var(--sky);color:#fff;
    font-family:'Outfit';font-size:13px;display:flex;align-items:center;justify-content:center;margin-top:2px;
  }
  summary::after{
    content:"";position:absolute;right:19px;top:26px;width:9px;height:9px;
    border-right:2px solid var(--sky-deep);border-bottom:2px solid var(--sky-deep);
    transform:rotate(45deg);transition:transform .2s;
  }
  details[open] summary::after{transform:rotate(-135deg);top:30px}
  details .a{padding:2px 20px 18px 57px;font-size:13.5px;color:#46535E;line-height:1.95}

  /* ════ 対応地域 ════ */
  .chiiki{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;max-width:760px;margin:0 auto}
  .chiiki a{
    text-decoration:none;font-size:13.5px;color:var(--navy);background:#fff;
    border:1px solid var(--sky-mist);border-radius:24px;padding:7px 18px;font-weight:500;
    box-shadow:var(--shadow-s);transition:all .15s;
  }
  .chiiki a.main{border-color:var(--sky);color:var(--sky-deep);font-weight:700}
  .chiiki a:hover{background:var(--sky-soft);transform:translateY(-1px)}
  .chiiki-note{text-align:center;font-size:12.5px;color:var(--muted);margin-top:18px}

  /* ════ 最終CTA ════ */
  .last-cta{
    position:relative;color:#fff;text-align:center;overflow:hidden;
    background:linear-gradient(150deg,#2C5170 0%,var(--navy-deep) 70%);
  }
  .last-cta .ripple{position:absolute;border-radius:50%;border:1.5px solid rgba(255,255,255,.07);pointer-events:none}
  .last-cta .r1{width:480px;height:480px;left:-160px;top:-200px}
  .last-cta .r2{width:680px;height:680px;left:-260px;top:-300px}
  .last-cta .in{position:relative;padding:66px 22px 72px;max-width:680px;margin:0 auto}
  .last-cta h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(19px,3vw,25px);letter-spacing:.05em;line-height:1.9}
  .last-cta p{font-size:13.5px;opacity:.82;margin:14px 0 28px}
  .last-cta .cta-grid{margin:0 auto;max-width:520px}
  .last-cta .cta.assess{background:#fff;color:var(--sky-deep);box-shadow:0 8px 24px rgba(0,0,0,.25)}
  .last-cta .cta.photo{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.5)}
  .last-cta .cta.photo:hover{background:rgba(255,255,255,.18)}
  .last-cta .cta.tel{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}

  /* ════ フッター ════ */
  footer{background:#22323F;color:#B9C4CC;font-size:12.5px;padding:42px 0 120px}
  footer .wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:34px}
  @media(max-width:700px){footer .wrap{grid-template-columns:1fr}}
  footer b{color:#fff;font-size:14px;display:block;margin-bottom:10px;letter-spacing:.04em}
  footer a{color:#B9C4CC}
  footer .links{display:flex;flex-wrap:wrap;gap:7px 18px;margin-top:8px}
  footer .legal{grid-column:1/-1;border-top:1px solid #3A4B59;padding-top:16px;font-size:11.5px;color:#8593A0}

  /* ════ スマホ固定CTA ════ */
  .fixed-bar{
    position:fixed;left:10px;right:10px;bottom:10px;z-index:60;display:none;
    grid-template-columns:1fr 1.1fr 1.3fr;gap:7px;
  }
  .fixed-bar a{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;
    padding:10px 4px 9px;text-decoration:none;font-size:12.5px;font-weight:700;
    border-radius:13px;box-shadow:0 4px 16px rgba(39,72,107,.22);letter-spacing:.02em;
  }
  .fixed-bar a small{font-size:9px;font-weight:500;opacity:.85}
  .fixed-bar .f-tel{background:#fff;color:var(--navy);border:1.5px solid #C8D6E0}
  .fixed-bar .f-line{background:var(--line-green);color:#fff}
  .fixed-bar .f-assess{background:linear-gradient(135deg,var(--sky),var(--sky-deep));color:#fff}
  @media(max-width:860px){.fixed-bar{display:grid}body{padding-bottom:4px}}

  /* ════ スクロール出現アニメーション ════ */
  [data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
  [data-reveal].in{opacity:1;transform:none}
  .stagger>*{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
  .stagger.in>*{opacity:1;transform:none}
  .stagger.in>*:nth-child(1){transition-delay:.02s}
  .stagger.in>*:nth-child(2){transition-delay:.09s}
  .stagger.in>*:nth-child(3){transition-delay:.16s}
  .stagger.in>*:nth-child(4){transition-delay:.23s}
  .stagger.in>*:nth-child(5){transition-delay:.30s}
  .stagger.in>*:nth-child(6){transition-delay:.37s}
  .stagger.in>*:nth-child(7){transition-delay:.44s}
  .stagger.in>*:nth-child(8){transition-delay:.51s}
  @media(prefers-reduced-motion:reduce){
    *{transition:none!important;animation:none!important}
    [data-reveal],.stagger>*{opacity:1!important;transform:none!important}
    html{scroll-behavior:auto}
  }

  #toast{
    position:fixed;left:50%;bottom:92px;transform:translateX(-50%);
    background:var(--navy-deep);color:#fff;font-size:13px;padding:10px 18px;border-radius:10px;
    opacity:0;pointer-events:none;transition:opacity .2s;max-width:90vw;z-index:99;
  }
  #toast.show{opacity:.96}
