/* ==========================================================================
   BWFB — Design System v2 「ライト＆クリーン（シネマティック）」
   全ページ共通スタイル。色やトーンの調整はこのファイル1つで全ページに反映。
   ========================================================================== */

:root{
  --ivory:#fbfaf8;
  --white:#ffffff;
  --teal:#00a8b0;
  --teal-dark:#008b92;
  --teal-soft:#e3f5f6;
  --teal-pale:#d2eef0;
  --navy:#122a43;
  --navy-soft:#1c3a5a;
  --gold:#e0a82e;
  --gold-dark:#caa01f;
  --text:#1d2b38;
  --text-sub:#566776;
  --text-light:#8a98a5;
  --border:#e8e4dd;
  --radius:16px;
  --shadow:0 3px 16px rgba(18,42,67,0.07);
  --shadow-hover:0 8px 28px rgba(18,42,67,0.12);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:96px;}
body{
  font-family:'Noto Sans JP',sans-serif;font-weight:400;
  color:var(--text);background:var(--ivory);line-height:1.9;
  -webkit-font-smoothing:antialiased;
  line-break:strict;overflow-wrap:break-word;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}

/* ===== HEADER ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(251,250,248,0.92);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);
}
.header__inner{
  max-width:1140px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;padding:14px 24px;
}
.header__logo{line-height:1.3;}
.header__logo b{font-size:1.05rem;font-weight:800;letter-spacing:0.02em;}
.header__logo b span{color:var(--teal);}
.header__logo small{display:block;font-size:0.62rem;color:var(--text-light);letter-spacing:0.06em;}
.header__nav{display:flex;align-items:center;gap:1.5rem;}
.header__nav a{font-size:0.85rem;color:var(--text-sub);transition:color .2s;padding:6px 0;}
.header__nav a:hover,.header__nav a.is-active{color:var(--teal);}
.header__nav a.is-active{font-weight:700;}
.header__btn{
  background:var(--teal);color:#fff !important;font-weight:700;
  padding:10px 22px !important;border-radius:999px;transition:background .2s;
}
.header__btn:hover{background:var(--teal-dark);}
.burger{display:none;background:none;border:none;cursor:pointer;width:48px;height:48px;padding:12px;}
.burger span{display:block;height:2px;background:var(--text);margin:5px 0;border-radius:2px;transition:.25s;}
.mobile-nav{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:150;
  background:var(--ivory);padding:90px 28px 40px;flex-direction:column;gap:0.2rem;overflow-y:auto;
}
.mobile-nav.open{display:flex;}
.mobile-nav a{font-size:1.05rem;font-weight:500;color:var(--text);padding:16px 8px;border-bottom:1px solid var(--border);}
.mobile-nav a.nav-cta{color:var(--teal);font-weight:700;border-bottom:none;text-align:center;margin-top:0.8rem;}
.mobile-nav__close{position:absolute;top:42px;right:16px;width:48px;height:48px;background:none;border:none;font-size:1.6rem;color:var(--text);cursor:pointer;}
/* ナビ項目が7つ（トップ＋6）になり、狭いPC幅では横並びが詰まって各項目が2段折返しになるため、960px以下はハンバーガーに切替（横並びは余裕がある幅でのみ表示） */
@media (max-width:960px){
  .header__nav{display:none;}
  .burger{display:block;}
}

/* ===== レイアウト基本 ===== */
.container{max-width:1140px;margin:0 auto;padding:0 24px;}
.container--narrow{max-width:860px;}
.section{padding:100px 0;}
.section--white{background:var(--white);}
.section--sand{background:var(--ivory);}
.section--navy{background:var(--navy);color:#fff;}
.section--navy .eyebrow{color:var(--teal);}
.section--navy .section-title{color:#fff;}
.section--navy .section-lead{color:rgba(255,255,255,0.72);}
.eyebrow{
  display:inline-block;font-family:'Inter',sans-serif;color:var(--teal);
  font-size:0.78rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:1rem;
}
.section-title{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:800;line-height:1.5;letter-spacing:0.02em;margin-bottom:1.2rem;}
.section-lead{color:var(--text-sub);font-size:0.98rem;max-width:640px;}
/* 日本語の改行：keep-all＋文節境界の<wbr>で単語の途中・句読点だけで切らない。strictで禁則処理。見出し/リードはbalanceで行長を均等化 */
.section-title,.section-lead,.page-hero__sub,.hero__sub,.article__title,.article__lead,.article,.article-card__title,.article-card__excerpt,.opt-card__desc,.voices__note,.tprice__note{word-break:keep-all;}
.section-title,.article__title,.section-lead,.page-hero__sub,.hero__sub,.cta h2{text-wrap:balance;}
/* keep-all本文の保険：<wbr>の無い長文がスマホ幅を押し広げて見切れるのを防ぐ（必要時のみ折返し） */
.section-lead,.page-hero__sub,.hero__sub,.article__lead,.opt-card__desc,.voices__note,.tprice__note{overflow-wrap:anywhere;}
.center{text-align:center;}
.center .section-lead{margin:0 auto;}
.nw{display:inline-block;}
.marker{background:linear-gradient(transparent 55%, rgba(0,168,176,0.25) 55%);padding:0 0.08em;}
.wavy{text-decoration:underline wavy var(--teal);text-decoration-thickness:2px;text-underline-offset:7px;}

/* ===== ボタン ===== */
.btn-main{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--teal);color:#fff;font-weight:700;font-size:1rem;
  padding:17px 38px;border-radius:999px;transition:background .2s, transform .2s;
  box-shadow:0 5px 16px rgba(0,168,176,0.3);cursor:pointer;border:none;
}
.btn-main:hover{background:var(--teal-dark);transform:translateY(-1px);}
.btn-main svg,.btn-ghost svg{width:20px;height:20px;flex-shrink:0;}
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--white);color:var(--text);font-weight:500;font-size:1rem;
  padding:17px 32px;border-radius:999px;border:1px solid var(--border);transition:border-color .2s,color .2s;
}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);}
.link-arrow{color:var(--teal);font-weight:700;font-size:0.92rem;display:inline-flex;align-items:center;gap:6px;padding:10px 4px;}
.link-arrow:hover{text-decoration:underline;}

/* ===== HERO（PC=左テキスト+右写真の分割 / HOME） ===== */
.hero{position:relative;background:var(--ivory);overflow:hidden;}
.hero__grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.04fr 0.96fr;align-items:stretch;}
.hero__text{padding:96px 40px 60px;display:flex;flex-direction:column;justify-content:center;}
.hero__eyebrow{display:block;color:var(--teal-dark);font-size:0.95rem;font-weight:700;letter-spacing:0.04em;margin-bottom:1rem;}
.hero__headline{color:var(--navy);font-size:clamp(2.4rem,3.4vw,3.2rem);font-weight:800;line-height:1.26;letter-spacing:0.01em;margin-bottom:1.15rem;}
.hero__headline .hl-teal{color:var(--teal-dark);}
.hero__sub{color:var(--text-sub);font-size:1.02rem;line-height:1.85;font-weight:500;margin-bottom:1.3rem;}
.hero__stats{display:flex;gap:28px;flex-wrap:wrap;padding:1.15rem 0;border-top:1px solid var(--border);margin-bottom:1.4rem;}
.hstat{display:flex;align-items:center;gap:12px;}
.hstat__ic{width:48px;height:48px;border-radius:50%;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hstat__ic svg{width:24px;height:24px;color:var(--teal-dark);}
.hstat__body{display:flex;flex-direction:column;}
.hstat__label{display:block;font-size:0.74rem;color:var(--text-sub);font-weight:700;margin-bottom:2px;}
.hstat__num{display:block;font-family:'Inter','Noto Sans JP',sans-serif;font-size:1.55rem;font-weight:800;color:var(--navy);line-height:1;}
.hstat__num small{font-size:0.5em;color:var(--text-sub);font-weight:700;margin-left:1px;}
.hero__cta{display:flex;flex-direction:column;align-items:flex-start;gap:0.9rem;}
.hero__media{position:relative;min-height:520px;}
.hero__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.hero__text,.hero__media{min-width:0;}/* グリッド項目が中身でビューポートを超えないように（スマホで写真/文字がはみ出すのを防止） */
.hero__badge{position:absolute;right:26px;bottom:26px;width:128px;height:128px;border-radius:50%;background:var(--teal);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-size:0.86rem;font-weight:700;line-height:1.45;box-shadow:0 10px 28px rgba(0,168,176,0.45);}
.hero__badge b{font-size:1.7rem;color:var(--gold);font-weight:800;line-height:1.1;}

/* ===== 4カラム特徴（heroの下） ===== */
.hero-feats{background:var(--white);border-top:1px solid var(--border);}
.hfeat-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);}
.hfeat{padding:34px 28px;border-left:1px solid var(--border);}
.hfeat:first-child{border-left:none;}
.hfeat__icon{width:50px;height:50px;border-radius:50%;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;margin-bottom:15px;}
.hfeat__icon svg{width:25px;height:25px;color:var(--teal-dark);}
.hfeat h3{font-size:1.02rem;font-weight:800;color:var(--navy);margin:0 0 0.55rem;line-height:1.5;}
.hfeat p{font-size:0.87rem;color:var(--text-sub);line-height:1.8;margin:0;}

/* 黄色CTA・トライアル表記 */
.benefits__trial{color:var(--teal-dark);font-weight:700;font-size:0.95rem;letter-spacing:0.04em;}
.btn-yellow{display:inline-flex;align-items:center;justify-content:center;gap:12px;background:var(--gold);color:#3d2e06;font-weight:800;font-size:1.15rem;padding:20px 40px;border-radius:999px;box-shadow:0 10px 28px rgba(224,168,46,0.35);text-decoration:none;transition:transform .15s,box-shadow .15s,background .15s;}
.btn-yellow:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 14px 32px rgba(224,168,46,0.45);}
.btn-yellow svg{width:22px;height:22px;flex-shrink:0;}
.btn-yellow__arrow{width:18px;height:18px;}

/* ===== サービスページ：hero（左テキスト+右写真・ライト） ===== */
.hero--svc .hero__media{min-height:430px;}
.hero--svc .hero__text{padding:120px 40px 60px;}
.hero--svc .hero__eyebrow{font-family:'Inter','Noto Sans JP',sans-serif;letter-spacing:0.12em;text-transform:uppercase;}
.hero--svc .hero__headline{margin-bottom:1.2rem;}
/* タブレット〜小型PC(769〜1024px)：heroが左右2分割でテキスト列が狭いのに見出しが大きく、長い2行目(例:4週間トライアルプラン)の末尾1文字が落ちる。見出しを列幅に合わせて少し縮める */
@media (min-width:769px) and (max-width:1024px){
  .hero__headline{font-size:clamp(1.85rem,3.4vw,2.35rem);}
}

/* POINT：選ばれる理由（5枚カード） */
.point-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:2.8rem;}
.point-card{position:relative;background:var(--white);border:1px solid var(--border);border-radius:14px;padding:42px 18px 26px;text-align:center;box-shadow:var(--shadow);overflow:hidden;}
.point-card__num{position:absolute;top:0;left:0;font-family:'Inter',sans-serif;font-weight:800;font-size:0.82rem;color:#fff;z-index:1;padding:4px 0 0 7px;line-height:1;}
.point-card__num::before{content:"";position:absolute;top:0;left:0;width:46px;height:46px;background:var(--teal);clip-path:polygon(0 0,100% 0,0 100%);z-index:-1;}
.point-card__icon{width:64px;height:64px;border-radius:50%;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.point-card__icon svg{width:30px;height:30px;color:var(--teal-dark);}
.point-card h3{font-size:1.02rem;font-weight:800;color:var(--navy);margin:0 0 0.6rem;line-height:1.5;}
.point-card p{font-size:0.82rem;color:var(--text-sub);line-height:1.75;margin:0;}

/* SERVICE MENU：3枚（写真左＋テキスト右） */
.svc-menu{background:var(--teal-soft);}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:2.6rem;}
.menu-card{display:grid;grid-template-columns:38% 1fr;background:var(--white);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);}
.menu-card__photo{position:relative;min-height:170px;}
.menu-card__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.menu-card__body{padding:22px 22px;display:flex;flex-direction:column;}
.menu-card__body h3{font-size:1.02rem;font-weight:800;color:var(--teal-dark);margin:0 0 0.6rem;line-height:1.45;word-break:keep-all;}
.menu-card__body p{font-size:0.88rem;color:var(--text-sub);line-height:1.8;margin:0 0 1rem;}
.menu-card__link{display:inline-flex;align-items:center;gap:7px;color:var(--teal-dark);font-weight:700;font-size:0.9rem;text-decoration:none;margin-top:auto;}
.menu-card__link svg{width:16px;height:16px;transition:transform .15s;}
.menu-card__link:hover svg{transform:translateX(4px);}

/* CTA帯 */
.cta-band{background:var(--ivory);padding:62px 0;border-top:1px solid var(--border);text-align:center;}
.cta-band__lead{font-size:1.18rem;font-weight:700;color:var(--navy);margin-bottom:1.5rem;}
.cta-band .btn-main{font-size:1.12rem;padding:20px 50px;}
.cta-band__feats{display:flex;justify-content:center;gap:34px;flex-wrap:wrap;margin-top:1.9rem;}
.cta-band__feat{display:inline-flex;align-items:center;gap:8px;font-size:0.9rem;font-weight:600;color:var(--text-sub);}
.cta-band__feat svg{width:20px;height:20px;color:var(--teal);flex-shrink:0;}

/* ===== 実績バンド（hero下の数値帯） ===== */
.stat-band{background:var(--teal-soft);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.stat-band__inner{max-width:1000px;margin:0 auto;padding:32px 24px;display:flex;justify-content:center;gap:56px;flex-wrap:wrap;}
.sbstat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:5px;}
.sbstat__label{font-size:0.82rem;color:var(--text-sub);font-weight:700;}
.sbstat__num{font-family:'Inter','Noto Sans JP',sans-serif;font-size:2.6rem;font-weight:800;color:var(--navy);line-height:1;}
.sbstat__num small{font-size:0.38em;color:var(--text-sub);font-weight:700;margin-left:1px;}

/* ===== 料金プラン カード ===== */
.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin:2.8rem auto 0;max-width:840px;align-items:stretch;}
.plan-card{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--border);border-radius:16px;padding:38px 26px 30px;box-shadow:var(--shadow);text-align:center;}
.plan-card--featured{border:2px solid var(--gold);box-shadow:0 12px 32px rgba(224,168,46,0.2);}
.plan-card__badge{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--gold);color:#3d2e06;font-weight:800;font-size:0.82rem;padding:6px 22px;border-radius:999px;white-space:nowrap;}
.plan-card__name{font-size:1.2rem;font-weight:800;color:var(--navy);margin:0 0 0.5rem;}
.plan-card__for{font-size:0.85rem;color:var(--text-sub);margin:0 0 1.5rem;line-height:1.6;min-height:2.7em;}
.plan-card__price{font-family:'Inter','Noto Sans JP',sans-serif;font-size:2.3rem;font-weight:800;color:var(--navy);line-height:1.1;}
.plan-card__price small{font-size:0.4em;color:var(--text-sub);font-weight:700;}
.plan-card__note{font-size:0.82rem;color:var(--text-sub);margin:0.3rem 0 1.6rem;}
.plan-card__list{list-style:none;padding:0;margin:0 0 1.8rem;text-align:left;display:flex;flex-direction:column;gap:0.7rem;}
.plan-card__list li{display:flex;gap:0.6rem;align-items:flex-start;font-size:0.9rem;color:var(--text);line-height:1.6;}
.plan-card__list li svg{width:18px;height:18px;color:var(--teal);flex-shrink:0;margin-top:3px;}
.plan-card__cta{margin-top:auto;}
.plan-card__cta .btn-main,.plan-card__cta .btn-ghost{width:100%;box-sizing:border-box;}
.plan-note{text-align:center;font-size:0.85rem;color:var(--text-sub);margin-top:1.6rem;}

/* ===== 比較表 ===== */
.cmp-wrap{margin-top:2.6rem;overflow-x:auto;}
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;min-width:560px;}
.cmp-table th,.cmp-table td{padding:15px 18px;text-align:center;border-bottom:1px solid var(--border);font-size:0.92rem;line-height:1.6;}
.cmp-table thead th{font-weight:800;color:#fff;font-size:0.95rem;}
.cmp-table thead th.cmp-old{background:#9aa5b1;}
.cmp-table thead th.cmp-mid{background:transparent;}
.cmp-table thead th.cmp-new{background:var(--teal);}
.cmp-table td.cmp-axis{font-weight:700;color:var(--navy);background:var(--ivory);}
.cmp-table td.cmp-x{color:#b2563f;}
.cmp-table td.cmp-o{color:var(--teal-dark);font-weight:700;}

/* ===== ステップ（導入の流れ） ===== */
.fstep-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:2.8rem;}
.fstep-grid--5{grid-template-columns:repeat(5,1fr);}
.fstep{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--border);border-radius:14px;padding:22px 14px;text-align:center;box-shadow:var(--shadow);}
.fstep__num{font-family:'Inter',sans-serif;font-weight:800;font-size:1.05rem;color:var(--teal-dark);}
.fstep__icon{width:52px;height:52px;border-radius:50%;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;margin:10px auto 12px;}
.fstep__icon svg{width:25px;height:25px;color:var(--teal-dark);}
.fstep h3{font-size:0.93rem;font-weight:800;color:var(--navy);margin:0 0 0.5rem;line-height:1.45;}
.fstep p{font-size:0.78rem;color:var(--text-sub);line-height:1.7;margin:0 0 0.9rem;}
.fstep__eta{margin-top:auto;font-size:0.72rem;color:var(--teal-dark);font-weight:700;background:var(--teal-soft);border-radius:6px;padding:6px 6px;}

/* ===== お客様の声 カード（匿名・写真なし） ===== */
.vcard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:2.6rem;}
.vcard{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:30px 28px;box-shadow:var(--shadow);}
.vcard__stars{color:var(--gold);font-size:0.95rem;letter-spacing:2px;margin-bottom:0.8rem;}
.vcard__headline{font-size:1.06rem;font-weight:800;color:var(--navy);margin:0 0 0.9rem;line-height:1.5;}
.vcard__text{font-size:0.9rem;color:var(--text-sub);line-height:1.85;margin:0 0 1.2rem;}
.vcard__meta{font-size:0.82rem;color:var(--text-light);border-top:1px solid var(--border);padding-top:0.9rem;}

/* ===== 導入事例 カード ===== */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:2.2rem;}
.case-card{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);}
.case-card__photo{aspect-ratio:16/10;}
.case-card__photo img{width:100%;height:100%;object-fit:cover;display:block;}
.case-card__body{padding:20px 22px;}
.case-card__meta{font-size:0.8rem;color:var(--text-sub);margin-bottom:0.5rem;}
.case-card__body h3{font-size:1rem;font-weight:800;color:var(--navy);margin:0 0 0.5rem;}
.case-card__body p{font-size:0.85rem;color:var(--text-sub);line-height:1.7;margin:0;}

/* ===== FAQ アコーディオン ===== */
.faq-acc{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px;margin-top:2.4rem;align-items:start;}
.faq-acc--1{grid-template-columns:1fr;max-width:760px;margin-left:auto;margin-right:auto;}
.faq-item{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.faq-item__q{display:flex;align-items:center;gap:10px;padding:18px 20px;cursor:pointer;font-weight:700;color:var(--navy);font-size:0.95rem;list-style:none;}
.faq-item__q::-webkit-details-marker{display:none;}
.faq-item__q .qmark{color:#fff;background:var(--teal);width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-family:'Inter';font-size:0.8rem;flex-shrink:0;}
.faq-item__q .chev{margin-left:auto;width:18px;height:18px;transition:transform .2s;color:var(--text-sub);flex-shrink:0;}
.faq-item[open] .faq-item__q .chev{transform:rotate(180deg);}
.faq-item__a{padding:0 20px 18px 50px;font-size:0.88rem;color:var(--text-sub);line-height:1.85;}

/* ===== 相談CTAボックス ===== */
.consult-box{background:var(--teal-soft);border-radius:16px;padding:36px 40px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.consult-box__body{flex:1 1 360px;}
.consult-box h3{font-size:1.18rem;font-weight:800;color:var(--navy);margin:0 0 0.7rem;}
.consult-box p{font-size:0.9rem;color:var(--text-sub);margin:0 0 1.1rem;line-height:1.75;}
.consult-box__checks{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:0;}
.consult-box__checks span{font-size:0.85rem;color:var(--teal-dark);font-weight:700;display:inline-flex;align-items:center;gap:5px;}
.consult-box__checks svg{width:16px;height:16px;}
.consult-box .btn-main{flex:0 0 auto;white-space:nowrap;}

/* ===== 汎用：アイコン特徴カード（効果/特徴/サポート/安心） ===== */
.featc-grid{display:grid;gap:20px;margin-top:2.4rem;}
.featc-grid--4{grid-template-columns:repeat(4,1fr);}
.featc-grid--3{grid-template-columns:repeat(3,1fr);}
.featc{text-align:center;padding:6px;}
.featc__icon{width:60px;height:60px;border-radius:50%;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
.featc__icon svg{width:28px;height:28px;color:var(--teal-dark);}
.featc h3,.featc h4{font-size:1rem;font-weight:800;color:var(--navy);margin:0 0 0.5rem;line-height:1.5;}
.featc p{font-size:0.85rem;color:var(--text-sub);line-height:1.75;margin:0;}
.softbox{background:var(--teal-soft);border-radius:18px;padding:40px 32px;}
.cardbox{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:28px 22px;text-align:center;box-shadow:var(--shadow);}

/* ===== PAGE HERO（サブページ用・コンパクト） ===== */
.page-hero{position:relative;background:var(--navy);color:#fff;padding:150px 0 70px;overflow:hidden;}
.page-hero::after{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(0,168,176,0.18) 0%,transparent 65%);pointer-events:none;}
.page-hero__inner{max-width:1140px;margin:0 auto;padding:0 24px;position:relative;}
.page-hero__crumb{font-size:0.78rem;color:rgba(255,255,255,0.6);margin-bottom:1.4rem;}
.page-hero__crumb a{color:rgba(255,255,255,0.6);}
.page-hero__crumb a:hover{color:var(--teal);}
.page-hero__eyebrow{font-family:'Inter',sans-serif;color:var(--teal);font-size:0.78rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;display:block;margin-bottom:0.9rem;}
.page-hero h1{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;line-height:1.4;margin-bottom:1rem;}
.page-hero__sub{font-size:1rem;color:rgba(255,255,255,0.78);line-height:1.95;max-width:640px;}

/* ===== 信頼バッジストリップ ===== */
.badges{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.badges__grid{max-width:1140px;margin:0 auto;padding:34px 24px;display:grid;grid-template-columns:repeat(3,1fr);}
.badge{display:flex;align-items:center;gap:14px;justify-content:center;padding:6px 20px;}
.badge + .badge{border-left:1px solid var(--border);}
.badge__icon{flex-shrink:0;width:46px;height:46px;border-radius:50%;background:var(--teal-soft);color:var(--teal-dark);display:flex;align-items:center;justify-content:center;}
.badge__icon svg{width:22px;height:22px;}
.badge__text b{display:block;font-size:0.97rem;font-weight:800;line-height:1.5;}
.badge__text span{font-size:0.78rem;color:var(--text-sub);}

/* ===== 写真フレーム（ずらしシェイプ） ===== */
.photo-frame{position:relative;}
.photo-frame::before{content:"";position:absolute;top:12px;left:12px;right:-12px;bottom:-12px;background:var(--teal-pale);border-radius:20px;z-index:0;}
.photo-frame img{position:relative;z-index:1;width:100%;border-radius:16px;object-fit:cover;box-shadow:0 14px 40px rgba(18,42,67,0.14);}

/* ===== ジグザグ（サービス） ===== */
.zigzag{margin-top:4.5rem;display:grid;gap:96px;}
.zz{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;text-align:left;}
.zz__num{position:absolute;top:-58px;z-index:0;font-family:'Inter',sans-serif;font-weight:800;font-size:clamp(5rem,9vw,7.5rem);line-height:1;color:rgba(0,168,176,0.13);letter-spacing:-0.02em;pointer-events:none;user-select:none;}
.zz--left .zz__num{right:8px;}
.zz--right .zz__num{left:8px;}
.zz__photo{position:relative;}
.zz--right .zz__photo{order:2;}
.zz--right .zz__body{order:1;}
.zz__photo .photo-frame img{aspect-ratio:16/11;}
.zz--right .photo-frame::before{left:-12px;right:12px;}
.zz__body{position:relative;z-index:1;}
.zz__tag{display:inline-block;font-size:0.7rem;font-weight:700;letter-spacing:0.1em;color:var(--teal-dark);background:var(--teal-soft);padding:4px 14px;border-radius:999px;margin-bottom:1rem;}
.zz__body h3{font-size:clamp(1.3rem,2.2vw,1.65rem);font-weight:800;line-height:1.5;margin-bottom:0.9rem;}
.zz__body p{font-size:0.93rem;color:var(--text-sub);line-height:2.05;}
.zz__list{margin-top:1.2rem;display:flex;flex-direction:column;gap:0.5rem;}
.zz__list li{list-style:none;font-size:0.9rem;color:var(--text-sub);display:flex;gap:0.5em;align-items:flex-start;}
.zz__list li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}
/* ===== 本当の価値（2本柱） ===== */
.valuecore{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:3rem;text-align:left;}
.valuecore__item{position:relative;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;overflow:hidden;box-shadow:var(--shadow);}
.valuecore__item::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:var(--teal);}
.valuecore__num{position:absolute;top:20px;right:26px;font-family:'Inter',sans-serif;font-weight:800;font-size:2.6rem;line-height:1;color:rgba(0,168,176,0.12);}
.valuecore__icon{width:58px;height:58px;border-radius:15px;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;color:var(--teal-dark);margin-bottom:1.4rem;}
.valuecore__icon i,.valuecore__icon svg{width:28px;height:28px;}
.valuecore__item h3{font-size:clamp(1.2rem,2vw,1.4rem);font-weight:800;color:var(--navy);line-height:1.5;margin-bottom:1rem;}
.valuecore__item p{font-size:0.95rem;color:var(--text-sub);line-height:2.05;}
.valuecore__item p strong{color:var(--navy);font-weight:700;}
@media(max-width:760px){.valuecore{grid-template-columns:1fr;gap:18px;margin-top:2.2rem;}.valuecore__item{padding:32px 26px;}}

/* ===== 数字（箱なし） ===== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:4rem;}
.stat{text-align:center;}
.stat__rule{width:40px;height:2px;background:var(--teal);margin:0 auto 1.6rem;}
.stat__num{font-family:'Inter','Noto Sans JP',sans-serif;font-size:clamp(3.5rem,7vw,6rem);font-weight:800;color:var(--navy);line-height:1.05;letter-spacing:-0.02em;}
.stat__num small{font-size:0.32em;font-weight:700;color:var(--text-sub);letter-spacing:0;}
.stat__label{font-size:0.97rem;font-weight:700;margin-top:1rem;line-height:1.6;}
.stat__note{font-size:0.72rem;color:var(--text-light);margin-top:0.6rem;line-height:1.6;}

/* ===== ステップ（横並び/ホーム） ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:3.8rem;}
.step{position:relative;text-align:left;background:var(--navy-soft);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius);padding:40px 30px 36px;}
.step__num{width:46px;height:46px;border-radius:50%;background:var(--teal);color:#fff;font-weight:800;font-size:1.15rem;font-family:'Inter',sans-serif;display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;}
.step h3{font-size:1.12rem;font-weight:800;margin-bottom:0.6rem;line-height:1.5;color:#fff;}
.step p{font-size:0.88rem;color:rgba(255,255,255,0.75);line-height:1.95;}
.step__arrow{position:absolute;top:50%;right:-22px;transform:translateY(-50%);color:var(--teal);z-index:2;}
.steps__more{text-align:center;margin-top:3rem;}

/* ===== 縦タイムライン（導入の流れ詳細ページ） ===== */
.timeline{margin-top:3.5rem;max-width:760px;margin-left:auto;margin-right:auto;display:grid;gap:0;}
.tl{position:relative;display:grid;grid-template-columns:64px 1fr;gap:24px;padding-bottom:38px;}
.tl:last-child{padding-bottom:0;}
.tl::before{content:"";position:absolute;left:31px;top:54px;bottom:-4px;width:2px;background:var(--border);}
.tl:last-child::before{display:none;}
.tl__num{width:64px;height:64px;border-radius:50%;background:var(--teal);color:#fff;font-family:'Inter',sans-serif;font-weight:800;font-size:1.3rem;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;}
.tl__body{padding-top:8px;text-align:left;}
.tl__step{font-family:'Inter',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:0.12em;color:var(--teal);}
.tl__body h3{font-size:1.2rem;font-weight:800;margin:0.2rem 0 0.7rem;}
.tl__body p{font-size:0.92rem;color:var(--text-sub);line-height:2;}

/* ===== お客様の声 ===== */
.voices{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:3.8rem;}
.voices--row{grid-template-columns:repeat(3,1fr);}
.voice{position:relative;background:var(--white);border-left:3px solid var(--teal);border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--shadow);padding:44px 34px 36px;text-align:left;}
.voice__quote{position:absolute;top:10px;right:24px;font-family:Georgia,'Times New Roman',serif;font-size:5.5rem;line-height:1;color:var(--teal-pale);pointer-events:none;user-select:none;}
.voice__stars{color:#f5b942;font-size:0.95rem;letter-spacing:0.15em;margin-bottom:0.8rem;}
.voice__stars span{color:var(--text-sub);font-size:0.8rem;letter-spacing:0;margin-left:0.6em;}
.voice__headline{font-size:1.15rem;font-weight:800;line-height:1.6;margin-bottom:1.4rem;}
.voice__ba{display:grid;gap:12px;margin-bottom:1.4rem;}
.voice__block{background:var(--ivory);border-radius:10px;padding:16px 18px;}
.voice__block--after{background:var(--teal-soft);}
.voice__block b{display:block;font-size:0.72rem;font-weight:700;letter-spacing:0.1em;color:var(--text-light);margin-bottom:0.3rem;}
.voice__block--after b{color:var(--teal-dark);}
.voice__block p{font-size:0.88rem;line-height:1.85;color:var(--text);}
.voice__meta{font-size:0.78rem;color:var(--text-light);border-top:1px solid var(--border);padding-top:1rem;}
.voices__note{font-size:0.76rem;color:var(--text-light);margin-top:1.8rem;text-align:center;line-height:1.8;}
/* ===== 施術責任者（トップ・コンパクト） ===== */
.leader{display:grid;grid-template-columns:290px 1fr;gap:44px;align-items:center;max-width:1000px;margin:0 auto;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 44px;}
.leader__photo{border-radius:14px;overflow:hidden;}
.leader__photo img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top center;display:block;}
.leader__label{display:inline-block;font-size:0.72rem;font-weight:800;letter-spacing:0.1em;color:var(--teal-dark);background:var(--teal-soft);padding:4px 14px;border-radius:999px;margin-bottom:0.9rem;}
.leader__name{font-size:1.6rem;font-weight:800;color:var(--navy);line-height:1.25;margin-bottom:0.45rem;}
.leader__name span{font-size:0.78rem;font-weight:600;color:var(--text-light);margin-left:0.6em;letter-spacing:0.05em;}
.leader__quals{font-size:0.95rem;font-weight:700;color:var(--teal-dark);margin-bottom:1rem;}
.leader__lead{font-size:0.92rem;color:var(--text-sub);line-height:1.95;margin-bottom:1.4rem;}
.leader__career-label{display:block;font-size:0.76rem;font-weight:800;color:var(--navy);margin-bottom:0.7rem;}
.leader__tags{list-style:none;display:flex;flex-wrap:wrap;gap:0.5rem;}
.leader__tags li{font-size:0.8rem;font-weight:600;color:var(--text-sub);background:var(--ivory);border:1px solid var(--border);padding:0.42em 0.95em;border-radius:999px;}
@media(max-width:760px){.leader{grid-template-columns:1fr;gap:24px;padding:28px 22px;}.leader__photo{max-width:230px;margin:0 auto;}.leader__name{font-size:1.4rem;}}

/* ===== データカード（業界データ） ===== */
.datagrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:3.5rem;}
.datacard{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;text-align:left;box-shadow:var(--shadow);}
.datacard__num{font-family:'Inter','Noto Sans JP',sans-serif;font-size:2rem;font-weight:800;color:var(--navy);line-height:1.1;margin-bottom:0.6rem;}
.datacard__num small{font-size:0.5em;color:var(--text-sub);font-weight:700;}
.datacard__label{font-size:0.95rem;font-weight:700;line-height:1.6;margin-bottom:0.8rem;}
.datacard__body{font-size:0.85rem;color:var(--text-sub);line-height:1.9;}
.datacard__src{font-size:0.7rem;color:var(--text-light);margin-top:1rem;}

/* ===== データカード リッチ版（業界データ） ===== */
.datacard--rich{
  position:relative;overflow:hidden;
  padding:34px 30px 30px;
  border-color:var(--border);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
/* 上部のティールのアクセントライン */
.datacard--rich::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--teal) 0%,var(--teal-dark) 100%);
  opacity:0.9;
}
.datacard--rich:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-hover);
  border-color:var(--teal-pale);
}
/* アイコンバッジ */
.datacard__badge{
  width:54px;height:54px;border-radius:50%;
  background:var(--teal-soft);color:var(--teal-dark);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.1rem;
}
.datacard__badge i,.datacard__badge svg{width:26px;height:26px;stroke-width:2.1;}
/* 巨大数字を主役に */
.datacard--rich .datacard__num{
  font-size:clamp(2.6rem,4.4vw,3.4rem);
  font-weight:800;color:var(--navy);line-height:1.05;
  letter-spacing:-0.02em;margin-bottom:0.7rem;
}
.datacard--rich .datacard__num small{
  font-size:0.34em;color:var(--teal-dark);font-weight:700;
  margin-left:0.15em;letter-spacing:0;
}
.datacard--rich .datacard__label{
  font-size:1rem;font-weight:800;color:var(--navy);
  line-height:1.55;margin-bottom:0.7rem;
}
.datacard--rich .datacard__body{
  font-size:0.84rem;color:var(--text-sub);line-height:1.85;
}
.datacard--rich .datacard__src{
  font-size:0.7rem;color:var(--text-light);margin-top:1.1rem;
  padding-top:0.9rem;border-top:1px solid var(--border);
}
/* 重要な数字カードは淡いティール背景でメリハリ */
.datacard--accent{
  background:linear-gradient(170deg,var(--teal-soft) 0%,var(--white) 70%);
  border-color:var(--teal-pale);
}
.datacard--accent .datacard__badge{
  background:var(--teal);color:#fff;
}
.datacard--accent .datacard__num{color:var(--teal-dark);}

/* （旧・料金規模別カード/スリム版CSSは新料金プランデザインへ統合のため削除） */

/* 料金が決まる3要素 */
.factors{margin-top:3.5rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;}
.factors__head{text-align:center;margin-bottom:2rem;}
.factors__head h3{font-size:1.2rem;font-weight:800;color:var(--navy);margin-bottom:0.5rem;}
.factors__head p{font-size:0.9rem;color:var(--text-sub);line-height:1.9;}
.factors__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.factor{text-align:center;background:var(--ivory);border-radius:12px;padding:26px 18px;}
.factor__icon{width:46px;height:46px;border-radius:50%;background:var(--teal-soft);color:var(--teal-dark);display:flex;align-items:center;justify-content:center;margin:0 auto 0.9rem;}
.factor__icon svg{width:22px;height:22px;}
.factor h4{font-size:0.95rem;font-weight:800;color:var(--navy);margin-bottom:0.4rem;}
.factor p{font-size:0.8rem;color:var(--text-sub);line-height:1.8;}

/* トライアルに含まれるもの（1列リスト） */
.included-list{max-width:720px;margin:3.5rem auto 0;display:flex;flex-direction:column;gap:18px;}
.included-item{display:flex;align-items:flex-start;gap:20px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;box-shadow:var(--shadow);}
.included-item__badge{flex-shrink:0;width:52px;height:52px;border-radius:50%;background:var(--teal-soft);color:var(--teal-dark);display:flex;align-items:center;justify-content:center;}
.included-item__badge svg{width:24px;height:24px;}
.included-item__body{flex:1;min-width:0;}
.included-item__body h4{font-size:1.02rem;font-weight:800;color:var(--navy);margin-bottom:0.45rem;}
.included-item__body p{font-size:0.88rem;color:var(--text-sub);line-height:1.85;}
@media(max-width:640px){
  .included-list{margin-top:2.4rem;}
  .included-item{gap:16px;padding:20px 18px;}
  .included-item__badge{width:46px;height:46px;}
  .included-item__badge svg{width:22px;height:22px;}
}

/* 契約条件 */
.contract{margin-top:3.5rem;background:var(--navy);color:#fff;border-radius:var(--radius);padding:40px 38px;}
.contract__head{display:flex;align-items:center;gap:0.8rem;margin-bottom:1.4rem;}
.contract__head h3{font-size:1.15rem;font-weight:800;}
.contract__head .ic{width:42px;height:42px;border-radius:50%;background:rgba(0,168,176,0.2);color:var(--teal);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contract__intro{font-size:0.88rem;color:rgba(255,255,255,0.72);line-height:1.9;margin-bottom:1.6rem;}
.contract__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.contract-item{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:22px 22px;}
.contract-item b{display:block;font-size:0.72rem;letter-spacing:0.1em;color:var(--teal);font-weight:700;margin-bottom:0.5rem;}
.contract-item .v{font-size:1.05rem;font-weight:800;margin-bottom:0.4rem;line-height:1.4;}
.contract-item .n{font-size:0.76rem;color:rgba(255,255,255,0.6);line-height:1.7;}
.contract__ex{margin-top:1.4rem;padding:1rem 1.2rem;background:rgba(0,168,176,0.1);border-left:3px solid var(--teal);border-radius:4px;font-size:0.84rem;color:rgba(255,255,255,0.85);line-height:1.85;}
.contract__ex strong{color:var(--teal);}

/* ===== FAQ アコーディオン ===== */
.faq-list{max-width:820px;margin:3.5rem auto 0;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 26px;font-size:0.98rem;font-weight:700;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:inherit;line-height:1.6;}
.faq-q::after{content:'+';font-size:1.5rem;color:var(--teal);flex-shrink:0;transition:transform .25s;font-weight:400;}
.faq-item.open .faq-q::after{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a__inner{padding:0 26px 24px;font-size:0.9rem;color:var(--text-sub);line-height:2;}
.faq-item.open .faq-a{max-height:600px;}

/* ===== 代表プロフィール ===== */
.profile-box{display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:start;margin-top:1rem;}
.profile-avatar{position:relative;}
.profile-avatar img{width:100%;border-radius:var(--radius);aspect-ratio:3/4;object-fit:cover;box-shadow:var(--shadow-hover);position:relative;z-index:1;}
.profile-avatar::before{content:"";position:absolute;top:14px;left:14px;right:-14px;bottom:-14px;background:var(--teal-pale);border-radius:20px;z-index:0;}
.profile-name{font-size:1.7rem;font-weight:800;}
.profile-kana{font-family:'Inter',sans-serif;font-size:0.85rem;color:var(--text-light);letter-spacing:0.08em;margin-bottom:0.8rem;}
.profile-lic{display:inline-block;background:var(--teal-soft);color:var(--teal-dark);font-size:0.78rem;font-weight:700;padding:5px 16px;border-radius:999px;margin-bottom:1.6rem;}
.profile-bio{font-size:0.95rem;color:var(--text-sub);line-height:2.05;margin-bottom:1.8rem;}
.profile-bio strong{color:var(--text);font-weight:700;}
.profile-label{display:inline-block;font-size:0.72rem;font-weight:700;letter-spacing:0.08em;color:var(--teal);text-transform:uppercase;margin:1.2rem 0 0.7rem;padding-bottom:0.3rem;border-bottom:1.5px solid var(--teal);}
.profile-label--sub{color:var(--text-light);border-bottom-color:var(--border);}
.profile-items{list-style:none;display:flex;flex-direction:column;gap:0.5rem;}
.profile-items li{font-size:0.9rem;color:var(--text-sub);display:flex;gap:0.5em;align-items:flex-start;}
.profile-items li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}
.profile-items--sub li{font-size:0.82rem;color:var(--text-light);}
.profile-items--sub li::before{color:var(--text-light);}
.profile-note{margin-top:1.8rem;display:flex;gap:0.8em;align-items:flex-start;background:var(--teal-soft);border-radius:12px;padding:18px 20px;}
.profile-note .ic{flex-shrink:0;width:30px;height:30px;border-radius:8px;background:rgba(0,168,176,0.18);color:var(--teal-dark);display:flex;align-items:center;justify-content:center;}
.profile-note p{font-size:0.85rem;color:var(--text-sub);line-height:1.85;}

/* ===== トライアル ステップ画像カード ===== */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:3.5rem;}
.tcard{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.tcard__img{aspect-ratio:16/10;overflow:hidden;}
.tcard__img img{width:100%;height:100%;object-fit:cover;}
.tcard__body{padding:24px 24px 28px;text-align:left;}
.tcard__num{display:inline-flex;width:34px;height:34px;border-radius:50%;background:var(--teal);color:#fff;font-family:'Inter',sans-serif;font-weight:800;align-items:center;justify-content:center;margin-bottom:0.9rem;}
.tcard__body h3{font-size:1.05rem;font-weight:800;margin-bottom:0.5rem;line-height:1.5;}
.tcard__body p{font-size:0.85rem;color:var(--text-sub);line-height:1.9;}
.tprice{margin-top:3rem;text-align:center;background:var(--teal-soft);border-radius:var(--radius);padding:40px 28px;}
.tprice__num{font-family:'Inter','Noto Sans JP',sans-serif;font-size:clamp(2.6rem,6vw,3.8rem);font-weight:800;color:var(--navy);line-height:1.1;}
.tprice__num small{font-size:0.35em;color:var(--text-sub);font-weight:700;}
.tprice__note{font-size:0.88rem;color:var(--text-sub);margin-top:0.6rem;}

/* ===== セクション内バナー画像 ===== */
.feature-banner{max-width:1140px;margin:0 auto;padding:0 24px;}
.feature-banner__inner{position:relative;width:100%;aspect-ratio:16/8;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-hover);}
.feature-banner__inner img{width:100%;height:100%;object-fit:cover;}
.feature-banner__cap{text-align:center;font-size:0.8rem;color:var(--text-light);margin-top:0.9rem;}

/* ===== オプションメニュー（3カード） ===== */
.opt-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:3.5rem;}
.opt-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;}
.opt-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:var(--teal-pale);}
.opt-card__img{aspect-ratio:16/10;overflow:hidden;background:var(--teal-soft);}
.opt-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;}
.opt-card:hover .opt-card__img img{transform:scale(1.04);}
.opt-card__body{padding:24px 24px 28px;display:flex;flex-direction:column;align-items:flex-start;flex:1;}
.opt-card__tag{display:inline-block;font-size:0.7rem;font-weight:700;letter-spacing:0.08em;color:var(--teal-dark);background:var(--teal-soft);padding:4px 14px;border-radius:999px;margin-bottom:0.9rem;}
.opt-card__title{font-size:1.12rem;font-weight:800;color:var(--text);margin-bottom:0.7rem;line-height:1.5;}
.opt-card__desc{font-size:0.9rem;color:var(--text-sub);line-height:1.85;}
.opt-card__badge{margin-top:1rem;display:inline-flex;align-items:center;gap:5px;font-size:0.72rem;font-weight:700;color:var(--teal-dark);background:rgba(0,168,176,0.1);border:1px solid var(--teal-pale);padding:4px 12px;border-radius:999px;}
.opt-card__badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);}
.opt-note{text-align:center;font-size:0.82rem;color:var(--text-light);margin-top:2rem;}
@media(max-width:768px){
  .opt-cards{grid-template-columns:1fr;gap:22px;}
}

/* ===== CTA ===== */
.cta{background:var(--ivory);padding:100px 0;}
.cta__box{max-width:860px;margin:0 auto;background:var(--white);border-radius:24px;box-shadow:0 12px 44px rgba(18,42,67,0.1);padding:64px 48px;text-align:center;}
.cta h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;line-height:1.6;margin-bottom:1.2rem;}
.cta p{color:var(--text-sub);font-size:0.98rem;margin-bottom:2.4rem;}
.cta .btn-main{font-size:1.08rem;padding:20px 56px;}
.cta__mail{font-size:0.85rem;color:var(--text-sub);margin-top:2rem;}
.cta__mail a{color:var(--teal);text-decoration:underline;}

/* ===== お問い合わせフォーム ===== */
.form-wrap{max-width:720px;margin:3.5rem auto 0;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:44px 40px;box-shadow:var(--shadow);}
.form-wrap h3{font-size:1.2rem;font-weight:800;text-align:center;margin-bottom:1.8rem;}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form__group{margin-bottom:18px;}
.form__label{display:block;font-size:0.85rem;font-weight:700;margin-bottom:0.5rem;}
.form__label .req{color:#d4694f;font-size:0.7rem;margin-left:0.4em;}
.form__input,.form__select,.form__textarea{width:100%;font-size:1rem;font-family:inherit;padding:13px 16px;border:1px solid var(--border);border-radius:10px;background:var(--ivory);color:var(--text);transition:border-color .2s;}
.form__input:focus,.form__select:focus,.form__textarea:focus{outline:none;border-color:var(--teal);}
.form__textarea{min-height:120px;resize:vertical;line-height:1.8;}
.form__toggle-group{display:flex;flex-wrap:wrap;gap:10px;}
.form__toggle-btn{font-family:inherit;font-size:0.85rem;padding:10px 18px;border:1px solid var(--border);border-radius:999px;background:var(--white);color:var(--text-sub);cursor:pointer;transition:.2s;}
.form__toggle-btn.active{background:var(--teal);color:#fff;border-color:var(--teal);}
.form__privacy{font-size:0.78rem;color:var(--text-light);margin:1rem 0 1.4rem;line-height:1.7;}
.form__privacy a{color:var(--teal);text-decoration:underline;}
.form__submit{width:100%;background:var(--teal);color:#fff;font-size:1.05rem;font-weight:700;font-family:inherit;padding:18px;border:none;border-radius:10px;cursor:pointer;transition:background .2s;}
.form__submit:hover{background:var(--teal-dark);}
.form__success{display:none;background:var(--teal-soft);border-radius:12px;padding:28px;text-align:center;margin-top:1rem;}
.form__success.show{display:block;}
.form__success h4{font-size:1.1rem;font-weight:800;color:var(--teal-dark);margin-bottom:0.5rem;}

/* ===== FOOTER ===== */
.footer{background:var(--navy);color:#fff;padding:70px 0 36px;}
.footer__grid{max-width:1140px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;}
.footer__logo{font-size:1.05rem;font-weight:800;margin-bottom:0.8rem;}
.footer__logo span{color:var(--teal);}
.footer__desc{font-size:0.85rem;color:rgba(255,255,255,0.7);line-height:1.95;}
.footer__col h4{font-family:'Inter','Noto Sans JP',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.12em;color:rgba(255,255,255,0.5);margin-bottom:1.1rem;}
.footer__col a{display:block;font-size:0.88rem;color:rgba(255,255,255,0.78);padding:7px 0;transition:color .2s;}
.footer__col a:hover{color:var(--teal);}
.footer__bottom{max-width:1140px;margin:48px auto 0;padding:28px 24px 0;border-top:1px solid rgba(255,255,255,0.14);font-size:0.76rem;color:rgba(255,255,255,0.55);line-height:2;}
.footer__bottom a{color:inherit;text-decoration:underline;}

/* ===== ブログ一覧 ===== */
.blog-list{max-width:1120px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.article-card{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:32px 30px 26px;overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s;}
.article-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:var(--teal);}
.article-card:hover::before{transform:scaleX(1);}
.article-card__date{font-family:'Inter',sans-serif;font-size:0.76rem;color:var(--teal);font-weight:600;letter-spacing:0.06em;margin-bottom:0.7rem;}
.article-card__title{font-size:1.18rem;font-weight:800;color:var(--navy);line-height:1.55;margin-bottom:0.85rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.article-card__excerpt{font-size:0.86rem;color:var(--text-sub);line-height:1.9;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.article-card__tags{margin-top:1.1rem;display:flex;flex-wrap:wrap;gap:0.4rem;}
.article-card__tags span{font-size:0.7rem;font-weight:700;color:var(--teal-dark);background:var(--teal-soft);padding:0.28em 0.85em;border-radius:999px;}
.article-card__more{margin-top:auto;padding-top:1.4rem;display:inline-flex;align-items:center;gap:6px;font-size:0.83rem;font-weight:700;color:var(--teal);}
.article-card__more span{transition:transform .2s ease;}
.article-card:hover .article-card__more span{transform:translateX(4px);}
@media(max-width:900px){.blog-list{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.blog-list{grid-template-columns:1fr;}}

/* ===== ブログ記事本文 ===== */
.article{max-width:760px;margin:0 auto;padding:0 24px;}
.article__lead{font-size:1.02rem;color:var(--text-sub);line-height:2.05;margin-bottom:2.4rem;padding-bottom:2rem;border-bottom:1px solid var(--border);}
.article h2{font-size:1.5rem;font-weight:800;color:var(--navy);line-height:1.5;margin:2.8rem 0 1rem;padding-left:0.8rem;border-left:4px solid var(--teal);}
.article h3{font-size:1.2rem;font-weight:800;color:var(--navy);margin:2rem 0 0.8rem;}
.article p{font-size:0.97rem;line-height:2.1;margin-bottom:1.3rem;}
.article ul,.article ol{margin:0 0 1.5rem 1.2rem;}
.article li{font-size:0.97rem;line-height:2;margin-bottom:0.5rem;}
.article strong{color:var(--navy);font-weight:700;}
.article__card{background:var(--white);border:1px solid var(--border);border-left:4px solid var(--teal);border-radius:0 12px 12px 0;padding:24px 28px;margin:1.8rem 0;}
.article__card h3{margin-top:0;}
.article__qa{background:var(--teal-soft);border-radius:12px;padding:22px 26px;margin:1.5rem 0;}
.article__qa .q{font-weight:800;color:var(--navy);margin-bottom:0.5rem;}
.article__qa .a{font-size:0.93rem;color:var(--text-sub);line-height:1.95;}
.article__hero-img{width:100%;border-radius:var(--radius);margin-bottom:2.4rem;box-shadow:var(--shadow);}
.article__related{max-width:760px;margin:3.5rem auto 0;padding:2rem 24px 0;border-top:1px solid var(--border);}
.article__related h3{font-size:1.1rem;font-weight:800;margin-bottom:1rem;}
.article__related a{display:block;color:var(--teal-dark);font-size:0.92rem;padding:0.5rem 0;font-weight:600;}
.article__back{display:inline-flex;align-items:center;gap:6px;color:var(--teal);font-weight:700;font-size:0.9rem;margin-top:2rem;}

@media (max-width:980px){.blog-list{grid-template-columns:1fr 1fr;}}
@media (max-width:768px){
  .blog-list{grid-template-columns:1fr;padding:0 20px;}
  .article{padding:0 20px;}
  .article h2{font-size:1.3rem;}
}

/* 追従CTA（スマホ） */
.float-cta{display:none;}

/* ===== レスポンシブ ===== */
@media (max-width:980px){
  .stats,.steps,.tcards,.factors__grid,.contract__grid{grid-template-columns:1fr;}
  .datagrid{grid-template-columns:1fr 1fr;}
  .voices{grid-template-columns:1fr;}
  .step__arrow{display:none;}
  .footer__grid{grid-template-columns:1fr;gap:36px;}
  .plan-grid{grid-template-columns:1fr 1fr;}
  .zigzag{gap:80px;}
  .zz{grid-template-columns:1fr;gap:36px;}
  .zz--right .zz__photo{order:1;}
  .zz--right .zz__body{order:2;}
  .zz__num{top:-46px;}
  .zz--left .zz__num,.zz--right .zz__num{right:0;left:auto;}
  .profile-box{grid-template-columns:1fr;gap:36px;}
  .profile-avatar{max-width:320px;}
}
@media (max-width:768px){
  .section{padding:62px 0;}
  /* 本文を読みやすく（少し大きめ・行間ゆったり） */
  .section-lead,.article__lead{font-size:1.02rem;line-height:1.95;}
  .article p,.article li{font-size:1.02rem;line-height:2.0;}
  .article h2{font-size:1.32rem;line-height:1.5;}
  .article h3{font-size:1.12rem;}
  .zz__body p{font-size:0.97rem;line-height:2.0;}
  .check-card p,.qa p,.qa__q,.cta-box p,.included-item__body p{font-size:0.95rem;line-height:1.9;}
  .article-card__title{font-size:1.14rem;}
  .article-card__excerpt{font-size:0.9rem;}
  .header__nav{display:none;}
  .burger{display:block;}
  /* HERO（スマホ：縦積み） */
  .hero__grid{grid-template-columns:1fr;}
  .hero__text{padding:96px 22px 30px;}
  .hero__eyebrow{font-size:0.82rem;margin-bottom:0.95rem;}
  .hero__headline{font-size:clamp(1.7rem,7vw,2.3rem);line-height:1.32;margin-bottom:1.05rem;}
  .hero__sub{font-size:0.97rem;line-height:1.85;margin-bottom:1.35rem;}
  .hero__stats{gap:12px 16px;padding:1.2rem 0;margin-bottom:1.35rem;}
  .hstat{gap:9px;}
  .hstat__ic{width:38px;height:38px;}
  .hstat__ic svg{width:19px;height:19px;}
  .hstat__num{font-size:1.25rem;}
  .hero__cta{align-items:stretch;gap:0.7rem;}
  .hero__cta .benefits__trial{text-align:center;}
  .hero__media{display:none;}/* スマホではhero写真を非表示（オーナー指示）。見出し＋実績＋CTAだけのスッキリ表示。PCは写真そのまま */
  /* ただしトップページ(.hero。hero--svc以外)だけは、見出し右の空きに写真を配置（オーナー指示） */
  .hero:not(.hero--svc) .hero__grid{position:relative;}
  .hero:not(.hero--svc) .hero__media{display:block;position:absolute;top:128px;right:22px;width:33%;height:182px;min-height:0;border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(18,42,67,0.16);}
  .hero:not(.hero--svc) .hero__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
  .hero:not(.hero--svc) .hero__badge{display:none;}
  /* eyebrowは全幅1行（写真より上）。見出しは少し小さく＋左に寄せ、各行は折り返さず写真と重ねない2行に */
  .hero:not(.hero--svc) .hero__headline{font-size:clamp(1.35rem,5.4vw,1.9rem);padding-right:41%;}
  .hero:not(.hero--svc) .hero__headline .nw{white-space:nowrap;}
  .hero__badge{width:102px;height:102px;right:14px;bottom:14px;font-size:0.76rem;}
  .hero__badge b{font-size:1.35rem;}
  /* 数字セクション：スマホでも横3列で見せる（サイズは小さめ） */
  .stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:2.4rem;}
  .stat__rule{width:24px;margin-bottom:0.7rem;}
  .stat__num{font-size:clamp(1.55rem,8.2vw,2.4rem);}
  .stat__num small{font-size:0.34em;}
  .stat__label{font-size:0.72rem;margin-top:0.55rem;line-height:1.45;}
  .stat__note{font-size:0.6rem;margin-top:0.4rem;line-height:1.4;}
  /* 4カラム特徴（スマホ：2列） */
  .hfeat-grid{grid-template-columns:1fr 1fr;}
  .hfeat{padding:24px 18px;border-left:1px solid var(--border);border-top:none;}
  .hfeat:nth-child(odd){border-left:none;}
  .hfeat:nth-child(n+3){border-top:1px solid var(--border);}
  .hfeat h3{font-size:0.92rem;}
  .hfeat p{font-size:0.82rem;}
  .btn-yellow{font-size:1.04rem;padding:18px 24px;width:100%;box-sizing:border-box;}
  /* サービスページ（スマホ） */
  .hero--svc .hero__text{padding:92px 22px 34px;}
  .hero--svc .hero__media{min-height:220px;aspect-ratio:16/10;}
  .point-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:2rem;}
  .point-card{padding:34px 12px 20px;}
  .point-card__icon{width:54px;height:54px;margin-bottom:12px;}
  .point-card__icon svg{width:26px;height:26px;}
  .point-card h3{font-size:0.95rem;}
  .menu-grid{grid-template-columns:1fr;gap:14px;}
  .menu-card{grid-template-columns:40% 1fr;}
  .menu-card__photo{min-height:130px;}
  .menu-card__body{padding:18px 18px;}
  .cta-band__feats{flex-direction:column;gap:13px;align-items:center;margin-top:1.5rem;}
  .cta-band .btn-main{width:100%;box-sizing:border-box;padding:18px 24px;}
  .btn-main,.btn-ghost{text-align:center;padding:17px 32px;font-size:1.02rem;display:block;}
  .badges__grid{grid-template-columns:1fr;padding:6px 24px;}
  .badge{justify-content:flex-start;padding:16px 4px;}
  .badge + .badge{border-left:none;border-top:1px solid var(--border);}
  .photo-frame::before{top:8px;left:8px;right:-8px;bottom:-8px;}
  .zz--right .photo-frame::before{left:-8px;right:8px;}
  .page-hero{padding:120px 0 56px;}
  .plan-grid{grid-template-columns:1fr;}
  .datagrid{grid-template-columns:1fr;}
  .form__row{grid-template-columns:1fr;}
  .form-wrap{padding:32px 22px;}
  .cta{padding:70px 0;}
  .cta__box{padding:48px 24px;border-radius:18px;}
  .contract,.factors{padding:28px 22px;}
  .profile-avatar{max-width:none;}
  /* スマホ追従CTA */
  .float-cta{display:block;position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--white);border-top:1px solid var(--border);padding:10px 16px;box-shadow:0 -4px 16px rgba(18,42,67,0.08);}
  .float-cta a{display:block;text-align:center;background:var(--teal);color:#fff;font-weight:700;font-size:0.98rem;padding:14px;border-radius:10px;}
  body{padding-bottom:74px;}

  /* === 改行の最適化：スマホでは文中の<br>を無効化し、自然に折り返す === */
  /* （見出し・本文の途中改行がガタつくのを防ぐ。意図した2行ヒーローh1は対象外） */
  .section-lead br,
  .page-hero__sub br,
  .zz__body p br,
  .factor p br,
  .factors__head p br,
  .step p br,
  .voice__block p br,
  .datacard__body br,
  .tcard__body p br,
  .tprice__note br,
  .profile-bio br,
  .contract__intro br,
  .contract__ex br{display:none;}
  /* .nw（語句のまとまり）はPC・スマホ共通でinline-block維持＝語句が途中で切れない */
}

/* ===== ブログ記事 本文（v2） ===== */
.article{padding:44px 24px 80px;}
.breadcrumbs{font-size:0.8rem;color:var(--text-light);margin-bottom:1.4rem;line-height:1.7;}
.breadcrumbs a{color:var(--text-light);text-decoration:none;}
.breadcrumbs a:hover{color:var(--teal);}
.article__date{font-family:'Inter',sans-serif;font-size:0.82rem;color:var(--teal-dark);font-weight:600;letter-spacing:0.04em;margin-bottom:0.6rem;}
.article__title{font-size:clamp(1.5rem,3.4vw,2rem);font-weight:800;line-height:1.45;color:var(--navy);margin-bottom:1.8rem;}
.article__hero{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);margin-bottom:2.4rem;box-shadow:var(--shadow);}
.section-img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:12px;margin:1.4rem 0 1.8rem;box-shadow:var(--shadow);}
.article table{width:100%;border-collapse:collapse;margin:1.2rem 0 1.8rem;font-size:0.92rem;}
.article th,.article td{padding:0.7rem 0.9rem;border:1px solid var(--border);text-align:left;line-height:1.7;}
.article th{background:var(--teal-soft);color:var(--navy);font-weight:700;}
.check-card{background:var(--white);border:1px solid var(--border);border-left:4px solid var(--teal);border-radius:0 12px 12px 0;padding:18px 22px;margin:1.1rem 0;}
.check-card h4{display:flex;align-items:center;gap:0.55rem;font-size:1rem;font-weight:800;color:var(--navy);margin:0 0 0.4rem;}
.check-card h4::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;background:var(--teal);color:#fff;border-radius:50%;font-size:0.78rem;font-weight:800;}
.check-card p{margin-bottom:0;font-size:0.93rem;}
.qa{background:var(--teal-soft);border-radius:12px;padding:18px 22px;margin:1rem 0;}
.qa__q{font-weight:800;color:var(--navy);margin-bottom:0.4rem;}
.qa p{margin-bottom:0;font-size:0.93rem;color:var(--text-sub);}
.step-box{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px 22px;margin:1.1rem 0;display:flex;gap:1rem;align-items:flex-start;}
.step-box__num{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--teal);color:#fff;border-radius:50%;font-weight:800;font-family:'Inter',sans-serif;}
.cta-box{background:var(--navy);color:#fff;border-radius:var(--radius);padding:36px 28px;margin:2.8rem 0;text-align:center;}
.cta-box h3{color:#fff;font-size:1.2rem;font-weight:800;margin:0 0 0.7rem;padding:0;border:none;}
.cta-box p{font-size:0.93rem;color:rgba(255,255,255,0.82);margin-bottom:1.4rem;line-height:1.9;}
.cta-box a{display:inline-block;background:var(--teal);color:#fff;padding:0.85em 2.2em;border-radius:999px;font-weight:700;font-size:0.95rem;text-decoration:none;}
.cta-box a:hover{background:var(--teal-dark);}
.related{background:var(--ivory);border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;margin-top:2.8rem;}
.related h3{font-size:1.05rem;font-weight:800;color:var(--navy);margin:0 0 0.8rem;padding:0;border:none;}
.related a{display:block;padding:0.5rem 0;color:var(--teal-dark);font-size:0.92rem;font-weight:600;text-decoration:none;}
.related a:hover{color:var(--teal);}
@media(max-width:760px){.article{padding:32px 20px 60px;}.article__title{font-size:1.4rem;}}

/* ===== 追加コンポーネントのスマホ対応 ===== */
@media (max-width:768px){
  .stat-band__inner{gap:24px 36px;padding:24px 20px;}
  .sbstat__num{font-size:2rem;}
  .plan-grid{grid-template-columns:1fr;gap:30px;margin-top:2.4rem;}
  .plan-card__for{min-height:0;}
  .cmp-table th,.cmp-table td{padding:12px 12px;font-size:0.84rem;}
  .fstep-grid,.fstep-grid--5{grid-template-columns:1fr 1fr;gap:10px;}
  .fstep{padding:18px 12px;}
  .fstep__eta{font-size:0.66rem;padding:6px 4px;letter-spacing:-0.01em;}
  .vcard-grid{grid-template-columns:1fr;gap:14px;}
  .vcard{padding:24px 22px;}
  .case-grid{grid-template-columns:1fr;gap:14px;}
  .faq-acc{grid-template-columns:1fr;gap:12px;}
  .faq-item__a{padding:0 18px 16px 44px;}
  .consult-box{padding:26px 22px;flex-direction:column;align-items:stretch;gap:1.4rem;}
  .consult-box__body{flex:1 1 auto;}
  .featc-grid--4{grid-template-columns:repeat(2,minmax(0,1fr));}
  /* サポート3項目（flow安心のサポート体制）はスマホで横並び＝アイコン左＋文字右・全幅1列で読みやすく */
  .featc-grid--3{grid-template-columns:1fr;gap:14px;}
  .featc-grid--3 .featc{display:grid;grid-template-columns:auto 1fr;column-gap:16px;text-align:left;padding:16px 16px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);}
  .featc-grid--3 .featc__icon{grid-column:1;grid-row:1 / 3;align-self:center;margin:0;}
  .featc-grid--3 .featc h3{grid-column:2;grid-row:1;align-self:end;margin:0 0 2px;}
  .featc-grid--3 .featc p{grid-column:2;grid-row:2;align-self:start;text-align:left;}
  .softbox{padding:20px 14px;}
  /* スマホはフッター/ナビのリンクをタップしやすく（指で押せる高さに） */
  .footer__col a{padding:11px 0;}
  .mobile-nav a{padding:17px 8px;}
}

/* ===== 改行・本文整え（日本語はフレーズ単位で改行／読み物テキストは左寄せ） ===== */
.faq-item__q,.faq-item__a,.consult-box h3,.consult-box p,.point-card p,.featc p,.fstep h3,.fstep p,
.menu-card__body p,.case-card__body p,.plan-card__for,.plan-card__note,.plan-note,.cta-band__lead,
.vcard__headline,.vcard__text,.sbstat__label{word-break:auto-phrase;line-break:strict;}
/* 中央寄せコンテナ内でも、FAQ・相談ボックスの本文は左寄せで読みやすく */
.faq-item,.faq-item__a,.consult-box{text-align:left;}

/* ===== 日本語タイポ底上げ（2026-06-16）：改行品質のみ全体に付与。font-size/line-heightは各所の調整値を尊重 =====
   見出し：単語の途中で切らない(keep-all)＋行長を均等化(balance)。どうしても入らない時だけ最後の手段で折る(overflow-wrap:anywhere)
   本文・箇条書き：行末の泣き別れ（1〜2文字だけ次行）を抑える(text-wrap:pretty) */
h1,h2,h3,h4,h5,h6,
.section-title,.article__title,.hero__headline,.page-hero__title,
.point-card h3,.featc h3,.menu-card h3,.case-card h3,.plan-card h3,.fstep h3,
.benefit-card h3,.hfeat h3,.opt-card h3,.check-card h3,.included-item h3,.zz h3{
  word-break:keep-all;
  overflow-wrap:anywhere;
  text-wrap:balance;
}
p,li,dd,.lead,.section-lead,.article__lead,.hero__sub,.page-hero__sub{
  text-wrap:pretty;
}
/* 短い中央寄せの注記・カード説明・ラベルは行長を均等化し、最終行に1〜2文字だけ残る泣き別れを防ぐ */
.plan-note,.featc p,.fstep__eta,.featc__eta{text-wrap:balance;}

/* ============================================================
   ブログ index リニューアル（2026-06-17）：写真HERO＋カードグリッド＋サイドバー
   ============================================================ */
.blog-hero{background:linear-gradient(180deg,#ffffff,var(--ivory));border-bottom:1px solid var(--border);overflow:hidden;}
.blog-hero__inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr 0.86fr;align-items:stretch;gap:48px;padding-left:24px;}
.blog-hero__text{padding:72px 0;display:flex;flex-direction:column;justify-content:center;}
.blog-hero__title{font-size:clamp(2.4rem,4.4vw,3.4rem);font-weight:800;color:var(--navy);line-height:1.1;margin:0.25rem 0 0;}
.blog-hero__rule{display:block;width:64px;height:4px;background:var(--teal);border-radius:2px;margin:1.15rem 0 1.45rem;}
.blog-hero__sub{color:var(--text-sub);font-size:1rem;line-height:1.95;max-width:560px;}
.blog-hero__media{min-height:320px;}
.blog-hero__media img{width:100%;height:100%;object-fit:cover;display:block;}

.blog-section{padding:64px 0 92px;}
.blog-layout{display:grid;grid-template-columns:minmax(0,1fr) 304px;gap:48px;align-items:start;}
.blog-heading{font-size:1.3rem;font-weight:800;color:var(--navy);margin:0 0 1.5rem;padding-left:14px;border-left:4px solid var(--teal);}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,232px),1fr));gap:22px;}
.blog-noresult{margin-top:2.2rem;color:var(--text-sub);text-align:center;font-size:0.95rem;}

.bcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;}
.bcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);}
.bcard__thumb{position:relative;aspect-ratio:16/10;background:var(--teal-soft);}
.bcard__thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.bcard__badge{position:absolute;top:10px;left:10px;background:var(--teal);color:#fff;font-size:0.72rem;font-weight:700;padding:4px 10px;border-radius:6px;box-shadow:0 2px 8px rgba(18,42,67,0.18);}
.bcard__body{display:flex;flex-direction:column;gap:0.5rem;padding:15px 16px 18px;flex:1;}
.bcard__date{font-size:0.76rem;color:var(--text-light);font-family:'Inter','Noto Sans JP',sans-serif;letter-spacing:0.03em;}
.bcard__title{font-size:1rem;font-weight:800;color:var(--navy);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.bcard__excerpt{font-size:0.84rem;color:var(--text-sub);line-height:1.7;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.bcard__more{margin-top:auto;color:var(--teal-dark);font-weight:700;font-size:0.85rem;}
.bcard__more span{display:inline-block;transition:transform .2s;}
.bcard:hover .bcard__more span{transform:translateX(4px);}

.blog-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:30px;}
.side-search{display:flex;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;}
.side-search input{flex:1;min-width:0;border:none;outline:none;padding:12px 14px;font-size:0.9rem;font-family:inherit;color:var(--text);background:transparent;}
.side-search__btn{flex:0 0 auto;width:50px;border:none;background:var(--teal);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.side-search__btn:hover{background:var(--teal-dark);}
.side-search__btn svg{width:18px;height:18px;}
.side-title{font-size:1.05rem;font-weight:800;color:var(--navy);margin:0 0 0.9rem;padding-left:11px;border-left:3px solid var(--teal);}
.side-cats{list-style:none;display:flex;flex-direction:column;gap:2px;}
.side-cat{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:0.9rem;color:var(--text);padding:11px 12px;border-radius:8px;text-align:left;transition:background .15s,color .15s;}
.side-cat span{font-size:0.78rem;color:var(--text-light);font-weight:700;font-family:'Inter','Noto Sans JP',sans-serif;}
.side-cat:hover{background:var(--teal-soft);}
.side-cat.is-active{background:var(--teal);color:#fff;}
.side-cat.is-active span{color:rgba(255,255,255,0.85);}
.side-pop{list-style:none;display:flex;flex-direction:column;gap:15px;}
.side-pop__item{display:flex;align-items:center;gap:11px;}
.side-pop__rank{flex:0 0 auto;width:24px;height:24px;border-radius:6px;background:var(--navy);color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:0.8rem;display:flex;align-items:center;justify-content:center;}
.side-pop__item img{flex:0 0 auto;width:58px;height:58px;border-radius:8px;object-fit:cover;}
.side-pop__meta{min-width:0;}
.side-pop__title{font-size:0.82rem;font-weight:700;color:var(--navy);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.side-pop__date{font-size:0.72rem;color:var(--text-light);font-family:'Inter','Noto Sans JP',sans-serif;}

/* ブログ：タブレット以下はサイドバーを下に回す */
@media (max-width:960px){
  .blog-layout{grid-template-columns:1fr;gap:42px;}
  .blog-side{position:static;order:-1;display:grid;grid-template-columns:1fr 1fr;gap:30px 40px;align-items:start;}
  .side-search{grid-column:1 / -1;}
}
@media (max-width:768px){
  .blog-hero__inner{grid-template-columns:1fr;gap:0;padding-left:0;}
  .blog-hero__text{padding:40px 22px 26px;}
  .blog-hero__sub{font-size:0.95rem;line-height:1.9;}
  .blog-hero__media{min-height:0;aspect-ratio:16/9;}
  .blog-section{padding:42px 0 70px;}
  .blog-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr));gap:16px;}
  .blog-side{grid-template-columns:1fr;gap:24px;}
  .side-cats{flex-direction:row;flex-wrap:wrap;gap:8px;}
  .side-cat{width:auto;flex:0 0 auto;justify-content:center;gap:6px;padding:9px 14px;font-size:0.85rem;border:1.5px solid var(--border);border-radius:999px;background:#fff;}
  .side-cat.is-active{border-color:var(--teal);}
}
