/* ==========================================================================
   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;
  --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;
}
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;}

/* ===== レイアウト基本 ===== */
.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;}
.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-block;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-ghost{
  display:inline-block;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（シネマティック / HOME） ===== */
.hero{
  position:relative;min-height:92vh;
  background-image:url('/images/bwfb-meeting-room-service.jpg');
  background-size:cover;background-position:center right;
  display:flex;align-items:center;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(95deg,rgba(251,250,248,0.99) 0%,rgba(251,250,248,0.95) 32%,rgba(251,250,248,0.55) 58%,rgba(251,250,248,0.08) 85%);
}
.hero__inner{position:relative;max-width:1140px;width:100%;margin:0 auto;padding:150px 24px 170px;}
.hero__label{display:inline-flex;align-items:center;gap:10px;color:var(--teal-dark);font-size:0.8rem;font-weight:700;letter-spacing:0.08em;margin-bottom:1.6rem;}
.hero__label::before{content:"";width:36px;height:2px;background:var(--teal);}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.4rem);font-weight:800;line-height:1.3;letter-spacing:0.01em;margin-bottom:1.7rem;color:var(--navy);}
.hero__sub{color:var(--text-sub);font-size:clamp(0.95rem,1.4vw,1.08rem);line-height:2.05;margin-bottom:2.5rem;max-width:560px;font-weight:500;}
.hero__sub strong{color:var(--text);font-weight:700;}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero__strip{position:absolute;left:0;right:0;bottom:0;z-index:2;background:rgba(255,255,255,0.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(18,42,67,0.08);}
.hero__strip-inner{max-width:1140px;margin:0 auto;padding:18px 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.hero__strip-item{display:flex;align-items:baseline;gap:10px;font-size:0.85rem;color:var(--text-sub);border-left:2px solid var(--teal);padding-left:14px;}
.hero__strip-item b{color:var(--navy);font-size:0.95rem;}

/* ===== 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;}

/* ===== 数字（箱なし） ===== */
.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;}
.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;}

/* ===== データカード（業界データ） ===== */
.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;}

/* ===== 料金（規模別カード） ===== */
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:3.2rem;}
.plan-card{position:relative;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:30px 24px;display:flex;flex-direction:column;transition:border-color .2s,transform .2s,box-shadow .2s;}
.plan-card:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:var(--shadow-hover);}
.plan-card.is-popular{border-color:var(--teal);background:linear-gradient(180deg,var(--teal-soft) 0%,var(--white) 60%);}
.plan-card__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--teal);color:#fff;font-size:0.7rem;font-weight:700;padding:4px 16px;border-radius:999px;white-space:nowrap;}
.plan-card__size{font-size:1.3rem;font-weight:800;color:var(--navy);margin-bottom:0.3rem;}
.plan-card__freq{font-size:0.8rem;color:var(--teal-dark);font-weight:700;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px dashed var(--border);}
.plan-card__items{list-style:none;display:flex;flex-direction:column;gap:0.55rem;flex:1;margin-bottom:1.3rem;}
.plan-card__items li{font-size:0.82rem;color:var(--text-sub);display:flex;gap:0.45em;align-items:flex-start;line-height:1.6;}
.plan-card__items li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}
.plan-card__price{font-size:0.82rem;font-weight:700;color:var(--text-light);text-align:center;background:var(--ivory);border-radius:8px;padding:0.6em 0;margin-bottom:0.9rem;}
.plan-card__cta{display:block;text-align:center;background:var(--navy);color:#fff;font-size:0.85rem;font-weight:700;padding:12px;border-radius:8px;transition:background .2s;}
.plan-card__cta:hover{background:var(--teal);}

/* 料金が決まる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;}

/* 契約条件 */
.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;}

/* ===== 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;}

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

/* ===== レスポンシブ ===== */
@media (max-width:980px){
  .stats,.steps,.datagrid,.tcards,.factors__grid,.contract__grid{grid-template-columns: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:74px 0;}
  .header__nav{display:none;}
  .burger{display:block;}
  .hero{min-height:auto;background-position:66% center;}
  .hero::before{background:linear-gradient(180deg,rgba(251,250,248,0.97) 0%,rgba(251,250,248,0.9) 45%,rgba(251,250,248,0.32) 100%);}
  .hero__inner{padding:120px 24px 220px;}
  .hero h1{font-size:clamp(2.05rem,8.8vw,2.6rem);line-height:1.38;}
  .hero__sub{font-size:0.95rem;}
  .hero__cta{flex-direction:column;}
  .hero__strip-inner{grid-template-columns:1fr;gap:8px;padding:12px 24px;}
  .hero__strip-item{font-size:0.78rem;padding-left:10px;}
  .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;}
  .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;}
}
