@charset "utf-8";
/* ============================================================
   top-add.css  ―  front-page.php 専用の追加スタイル（全面改訂版）
   ・新LP(masse-lp.html)の構成・内容をそのまま採用
   ・カラーは旧サイトのティール基調(#1CBEA1)に統一
   ・新規デザイン部分を「見やすさ優先」で再設計
   ・1rem=10px (html font-size:62.5%) を前提
   ============================================================ */

:root{
  --teal:#1CBEA1;
  --teal-d:#149e85;
  --teal-dd:#0e7d6a;
  --teal-soft:#e8f8f4;     /* 淡いティール背景 */
  --teal-tint:#f1faf8;
  --ink:#1c2b33;
  --ink-2:#3a4a52;
  --gray:#5d6b78;
  --gray-l:#8a96a1;
  --paper:#ffffff;
  --paper-2:#F9F6F3;
  --paper-3:#EEEAE6;
  --hair:#e6e1d8;
  --hair-teal:#cdeae3;
  --accent:#f5821f;        /* ごく一部の差し色（Q・注目数字）に限定使用 */
  --line-green:#06c755;
  --line-green-d:#05a648;
  --lp-maxw:1080px;
  --shadow:0 4px 20px rgba(20,60,56,.08);
  --shadow-h:0 14px 36px rgba(20,60,56,.14);
}

/* 既存サイトと混在するため、追加セクションは .lp スコープで囲う */
.lp{
  font-family:"Noto Sans JP","游ゴシック体","Yu Gothic",sans-serif;
  color:var(--ink);
  line-height:1.85;
  /* 既存フッター(.footer)が margin-top:-72px で食い込む設計のため、
     LP最終セクションが隠れないよう同量の余白を確保する */
  margin-bottom:72px;
}
.lp .disp{
  font-family:'Montserrat',"Noto Sans JP",sans-serif;
  font-weight:700;
  line-height:1.35;
  letter-spacing:.01em;
}
.lp-wrap{max-width:var(--lp-maxw);margin:0 auto;padding:0 24px;}
.lp section{padding:64px 0;}
.lp img{max-width:100%;display:block;}
.lp a{text-decoration:none;}
.lp ul{list-style:none;margin:0;padding:0;}

/* ---- セクション共通見出し ---- */
.lp .eyebrow{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:1.3rem;
  letter-spacing:.18em;
  color:var(--teal);
  text-align:center;
  margin-bottom:10px;
}
.lp .sec-title{
  text-align:center;
  font-size:clamp(2.4rem,4.6vw,3.8rem);
  line-height:1.4;
  margin-bottom:16px;
  color:var(--ink);
}
.lp .sec-title .u{
  background:linear-gradient(transparent 60%,rgba(28,190,161,.28) 60%);
  padding:0 .12em;
}
.lp .sec-lead{
  text-align:center;
  color:var(--gray);
  font-size:1.55rem;
  max-width:680px;
  margin:0 auto 46px;
  line-height:1.95;
}

/* ============================================================
   HERO（ヒーロー）
   ============================================================ */
.lp-hero{
  position:relative;
  background:linear-gradient(160deg,#1cbea1 0%,#149e85 60%,#0e7d6a 100%);
  color:#fff;
  overflow:hidden;
  padding:64px 0 76px;
}
.lp-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 82% 12%,rgba(255,255,255,.16),transparent 45%),
    radial-gradient(circle at 8% 92%,rgba(255,255,255,.10),transparent 42%);
}
.lp-hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:14px;
  background:repeating-linear-gradient(45deg,#ffd23f 0 22px,#0e7d6a 22px 44px);
  opacity:.85;
}
.lp-hero-in{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;}
.lp-hero-copy{min-width:0;}
.lp-hero-art{display:flex;justify-content:center;align-items:center;}
.lp-hero-art img{
  width:100%;max-width:440px;height:auto;
  filter:drop-shadow(0 18px 36px rgba(0,0,0,.22));
}
.lp-hero .tag{
  display:inline-block;background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;font-weight:700;font-size:1.3rem;
  padding:7px 18px;border-radius:999px;margin-bottom:22px;letter-spacing:.04em;
}
.lp-hero h1{
  font-size:clamp(3rem,6.4vw,5.6rem);
  line-height:1.24;margin-bottom:20px;
}
.lp-hero h1 .box{
  background:var(--line-green);color:#fff;
  padding:.06em .3em;border-radius:12px;display:inline-block;margin:.06em 0;
}
.lp-hero .sub{
  font-size:clamp(1.5rem,2.4vw,1.9rem);
  color:#eafaf6;max-width:620px;margin-bottom:30px;line-height:1.95;
}
.lp-hero .sub b{color:#fff;font-weight:700;}
.lp-hero .price{
  display:inline-flex;align-items:baseline;gap:10px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);
  border-radius:16px;padding:16px 26px;margin-bottom:32px;
}
.lp-hero .price .lab{font-size:1.4rem;color:#dff5ef;font-weight:500;}
.lp-hero .price .num{font-family:'Montserrat',sans-serif;font-weight:700;color:#fff;font-size:clamp(4rem,8vw,6rem);line-height:1;}
.lp-hero .price .unit{font-size:1.8rem;font-weight:700;}
.lp-hero .price .tilde{font-size:2.4rem;font-weight:700;}
.lp-hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.btn-hero{
  background:var(--line-green);color:#fff;font-weight:700;font-size:1.8rem;
  padding:18px 34px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 8px 24px rgba(6,199,85,.4);transition:transform .15s;
}
.btn-hero:hover{transform:translateY(-3px);}
.btn-hero svg{width:24px;height:24px;fill:#fff;}
.btn-ghost{
  border:1.5px solid rgba(255,255,255,.55);color:#fff;font-weight:700;
  padding:17px 28px;border-radius:999px;font-size:1.5rem;transition:background .15s;
}
.btn-ghost:hover{background:rgba(255,255,255,.14);}
.lp-hero-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px;}
.lp-hero-badge{
  font-size:1.25rem;color:#eafaf6;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);padding:6px 14px;border-radius:8px;
}
.lp-hero-badge b{color:#fff;font-weight:700;}

/* ============================================================
   STORY（4コマ）
   ============================================================ */
.lp-story{background:var(--paper);}
.koma-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.koma{
  background:var(--paper-2);border:1px solid var(--hair);border-radius:16px;
  padding:26px 20px;position:relative;text-align:center;
}
.koma-no{
  position:absolute;top:-15px;left:16px;width:32px;height:32px;
  background:var(--teal);color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.5rem;
  box-shadow:0 4px 10px rgba(28,190,161,.4);
}
.koma .ico{
  width:64px;height:64px;margin:8px auto 16px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;background:var(--teal-soft);
}
.koma .ico svg{width:32px;height:32px;fill:var(--teal-d);}
.koma h3{font-size:1.7rem;font-weight:700;margin-bottom:10px;line-height:1.45;}
.koma p{font-size:1.35rem;color:var(--gray);line-height:1.75;}
.koma-note{
  text-align:center;margin-top:24px;font-size:1.3rem;color:var(--gray-l);
  background:var(--teal-tint);border:1px dashed var(--hair-teal);
  border-radius:10px;padding:14px 18px;max-width:760px;margin-left:auto;margin-right:auto;
}
/* コマ内のイラスト画像（SVGアイコンの代わりに使う場合） */
.koma .kimg{
  width:100%;height:120px;margin:6px auto 14px;
  display:flex;align-items:center;justify-content:center;
  background:var(--teal-tint);border-radius:12px;overflow:hidden;
}
.koma .kimg img{width:auto;max-height:104px;}

/* 汎用：セクションの中央イラスト（見出し下に置く） */
.sec-art{margin:0 auto 40px;max-width:420px;}
.sec-art img{width:100%;height:auto;}

/* 2カラム（テキスト＋イラスト）汎用 */
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;max-width:980px;margin:0 auto;}
.split-art img{width:100%;max-width:440px;height:auto;margin:0 auto;}

/* ============================================================
   WORRIES（お悩みチェック）
   ============================================================ */
.lp-worries{background:var(--teal);color:#fff;position:relative;overflow:hidden;}
.lp-worries::before{
  content:"";position:absolute;top:-50px;right:-50px;width:260px;height:260px;
  border:32px solid rgba(255,255,255,.08);border-radius:50%;
}
.lp-worries .sec-title{color:#fff;}
.lp-worries .eyebrow{color:#d6fff5;}
.worry-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
  max-width:780px;margin:0 auto;position:relative;z-index:2;
}
.worry{
  background:#fff;border-radius:14px;border-left:5px solid var(--teal-d);
  padding:18px 22px;display:flex;gap:14px;align-items:flex-start;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
}
.worry .q{
  font-family:'Montserrat',sans-serif;font-weight:700;color:var(--accent);
  font-size:2.4rem;line-height:1;flex-shrink:0;
}
.worry p{font-size:1.5rem;line-height:1.7;color:var(--ink);}
.worry p b{color:var(--teal-dd);font-weight:700;}
.worry-punch{text-align:center;margin-top:40px;position:relative;z-index:2;}
.worry-punch .big{font-size:clamp(2.2rem,4.4vw,3.2rem);line-height:1.55;color:#fff;}
.worry-punch .big .hl{
  background:#fff;color:var(--teal-d);padding:.08em .4em;border-radius:8px;
  display:inline-block;margin-top:8px;
}

/* ============================================================
   SERVICES（4ジャンル）
   ============================================================ */
.lp-services{background:var(--paper-2);}
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-bottom:30px;}
.cat{
  background:var(--paper);border:1px solid var(--hair);border-radius:18px;
  overflow:hidden;transition:transform .18s,box-shadow .18s;box-shadow:var(--shadow);
}
.cat:hover{transform:translateY(-4px);box-shadow:var(--shadow-h);}
.cat-head{padding:22px 24px;display:flex;align-items:center;gap:14px;color:#fff;}
.cat-head .ci{
  width:48px;height:48px;background:rgba(255,255,255,.22);border-radius:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cat-head .ci svg{width:26px;height:26px;fill:#fff;}
.cat-head h3{font-size:1.9rem;font-weight:700;line-height:1.35;}
.cat-head .cn{font-family:'Montserrat',sans-serif;font-size:1.1rem;font-weight:700;opacity:.9;letter-spacing:.08em;}
/* 4枚はティールの濃淡でリズムを付ける（旧サイト基調を維持） */
.cat-c1 .cat-head{background:linear-gradient(135deg,#1cbea1,#149e85);}
.cat-c2 .cat-head{background:linear-gradient(135deg,#17a7b0,#0f7f88);}
.cat-c3 .cat-head{background:linear-gradient(135deg,#1bb38a,#0f8f6b);}
.cat-c4 .cat-head{background:linear-gradient(135deg,#12b39b,#0c8f7c);}
.cat-body{padding:20px 24px 24px;}
.cat-body ul{display:flex;flex-wrap:wrap;gap:9px;}
.cat-body li{
  font-size:1.35rem;background:var(--teal-tint);border:1px solid var(--hair-teal);
  border-radius:8px;padding:7px 13px;color:var(--teal-dd);font-weight:500;
}
.svc-more{
  background:var(--teal);color:#fff;border-radius:18px;padding:28px 28px;text-align:center;
}
.svc-more-art{max-width:280px;margin:0 auto 18px;}
.svc-more-art img{width:100%;height:auto;border-radius:14px;background:#fff;padding:10px;}
.svc-more h4{font-size:1.9rem;font-weight:700;margin-bottom:10px;}
.svc-more p{font-size:1.45rem;color:#eafaf6;line-height:1.85;}
.svc-more .tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:16px;}
.svc-more .tags span{
  font-size:1.3rem;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);
  padding:6px 14px;border-radius:8px;
}

/* ============================================================
   COST（雇用コスト比較）
   ============================================================ */
.lp-cost{background:var(--paper);}
.compare{
  max-width:860px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;
  align-items:stretch;border-radius:18px;overflow:hidden;border:1px solid var(--hair);
  box-shadow:var(--shadow);
}
.cmp-col{padding:32px 28px;}
.cmp-a{background:var(--paper-2);}
.cmp-mid{
  display:flex;align-items:center;justify-content:center;background:var(--teal);
  color:#fff;padding:0 10px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:2.2rem;
}
.cmp-b{background:var(--teal);color:#fff;position:relative;}
.cmp-b::before{
  content:"おすすめ";position:absolute;top:16px;right:-32px;background:var(--accent);
  color:#fff;font-size:1.15rem;font-weight:700;padding:4px 36px;transform:rotate(45deg);
}
.cmp-h{font-size:1.8rem;font-weight:700;margin-bottom:6px;}
.cmp-a .cmp-h{color:var(--ink);}
.cmp-b .cmp-h{color:#fff;}
.cmp-sub{font-size:1.25rem;margin-bottom:18px;opacity:.82;}
.cmp-rows li{
  display:flex;justify-content:space-between;gap:12px;padding:10px 0;
  border-bottom:1px dashed rgba(0,0,0,.12);font-size:1.45rem;
}
.cmp-b .cmp-rows li{border-bottom-color:rgba(255,255,255,.22);}
.cmp-rows li .v{font-weight:700;white-space:nowrap;}
.cmp-a .cmp-rows li .v{color:var(--ink-2);}
.cmp-b .cmp-rows li .v{color:#fff;}
.cmp-total{margin-top:18px;padding-top:14px;font-weight:700;}
.cmp-total .t-lab{font-size:1.3rem;display:block;opacity:.72;font-weight:500;}
.cmp-total .t-num{font-family:'Montserrat',sans-serif;font-weight:700;font-size:3rem;line-height:1.25;}
.cmp-a .cmp-total .t-num{color:var(--ink);}
.cmp-b .cmp-total .t-num{color:#fff;}
.cost-note{text-align:center;font-size:1.25rem;color:var(--gray-l);margin:20px auto 0;max-width:760px;line-height:1.8;}

/* ============================================================
   TIME（時間が戻る）
   ============================================================ */
.lp-timesave{
  background:linear-gradient(135deg,#1cbea1,#0e7d6a);color:#fff;text-align:center;
  position:relative;overflow:hidden;
}
.lp-timesave::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% -20%,rgba(255,255,255,.18),transparent 60%);}
.ts-in{position:relative;z-index:2;}
.ts-eye{font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:.14em;font-size:1.3rem;margin-bottom:16px;opacity:.95;}
.ts-big{font-size:clamp(2.6rem,5.4vw,4.4rem);line-height:1.45;font-weight:700;}
.ts-big .num{
  font-family:'Montserrat',sans-serif;font-size:clamp(5.4rem,12vw,11rem);color:#fff;
  display:inline-block;line-height:.9;vertical-align:-.06em;text-shadow:0 4px 0 rgba(0,0,0,.12);
}
.ts-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:720px;margin:38px auto 0;}
.ts-card{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);border-radius:14px;padding:20px 16px;}
.ts-card .tc-n{font-family:'Montserrat',sans-serif;font-weight:700;font-size:2.8rem;color:#fff;line-height:1;}
.ts-card .tc-l{font-size:1.35rem;margin-top:8px;line-height:1.55;}
.ts-foot{margin-top:28px;font-size:1.45rem;opacity:.96;}

/* ============================================================
   HOW LINE（LINEで一言）
   ============================================================ */
.lp-howline{background:var(--paper-2);}
.hl-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;max-width:900px;margin:0 auto;}
.hl-steps{display:flex;flex-direction:column;gap:16px;}
.hl-step{
  display:flex;gap:16px;align-items:flex-start;background:var(--paper);
  border:1px solid var(--hair);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);
}
.hl-step .n{
  width:36px;height:36px;background:var(--teal);color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;
  font-weight:700;flex-shrink:0;font-size:1.7rem;
}
.hl-step h4{font-size:1.6rem;font-weight:700;margin-bottom:4px;}
.hl-step p{font-size:1.4rem;color:var(--gray);line-height:1.65;}
.hl-phone{
  background:#07151f;border-radius:30px;padding:18px;max-width:300px;margin:0 auto;
  box-shadow:0 20px 50px rgba(14,36,56,.28);
}
.hl-phone .scr{background:#8ed2a8;border-radius:20px;padding:18px;min-height:300px;display:flex;flex-direction:column;gap:12px;}
.bubble{max-width:82%;padding:10px 14px;border-radius:14px;font-size:1.35rem;line-height:1.6;}
.bubble.me{align-self:flex-end;background:var(--line-green);color:#fff;border-bottom-right-radius:4px;}
.bubble.them{align-self:flex-start;background:#fff;color:#222;border-bottom-left-radius:4px;}
.bubble .who{display:block;font-size:1.05rem;opacity:.6;margin-bottom:2px;}

/* ============================================================
   REASONS（選ばれる理由）
   ============================================================ */
.lp-reasons{background:var(--teal);color:#fff;}
.lp-reasons .sec-title{color:#fff;}
.lp-reasons .eyebrow{color:#d6fff5;}
.r-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.r-card{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);
  border-radius:18px;padding:34px 26px;text-align:center;position:relative;
}
.r-card .rn{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:4.6rem;
  color:rgba(255,255,255,.25);line-height:1;position:absolute;top:16px;right:22px;
}
.r-card .ri{
  width:68px;height:68px;margin:0 auto 18px;background:rgba(255,255,255,.18);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
}
.r-card .ri svg{width:34px;height:34px;fill:#fff;}
.r-card h3{font-size:1.9rem;font-weight:700;margin-bottom:12px;line-height:1.45;}
.r-card h3 .hl{
  background:#fff;color:var(--teal-d);padding:0 .25em;border-radius:5px;
}
.r-card p{font-size:1.45rem;color:#eafaf6;line-height:1.85;}

/* ============================================================
   PRICE（料金）
   ============================================================ */
.lp-price{background:var(--paper);}
.price-card{
  max-width:580px;margin:0 auto;background:linear-gradient(160deg,#1cbea1,#0e7d6a);
  color:#fff;border-radius:24px;padding:46px 38px;text-align:center;position:relative;overflow:hidden;
  box-shadow:var(--shadow-h);
}
.price-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:8px;
  background:repeating-linear-gradient(45deg,#ffd23f 0 16px,#0e7d6a 16px 32px);
}
.price-card .pl{font-size:1.5rem;color:#eafaf6;margin-bottom:6px;}
.price-card .pn{font-family:'Montserrat',sans-serif;font-weight:700;line-height:1;}
.price-card .pn .num{font-size:clamp(6.4rem,16vw,10.4rem);color:#fff;}
.price-card .pn .yen{font-size:3.4rem;}
.price-card .pn .tilde{font-size:3.4rem;}
.price-card .pn .mo{font-size:2.2rem;}
.price-card .ptax{font-size:1.3rem;color:#cdeae3;margin-top:6px;}
.price-incl{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:28px 0;}
.price-incl span{
  font-size:1.35rem;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);
  padding:8px 15px;border-radius:8px;display:flex;align-items:center;gap:7px;
}
.price-incl span svg{width:16px;height:16px;fill:#fff;}
.price-card .pnote{font-size:1.3rem;color:#dff5ef;margin-top:6px;line-height:1.75;}
.price-card .btn-hero{margin-top:22px;}
.price-art{max-width:300px;margin:0 auto 28px;}
.price-art img{width:100%;height:auto;background:#fff;border-radius:16px;padding:14px;}

/* ============================================================
   FLOW（流れ）
   ============================================================ */
.lp-flow{background:var(--paper-2);}
.flow-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.flow-step{
  background:var(--paper);border:1px solid var(--hair);border-radius:16px;
  padding:28px 20px;text-align:center;position:relative;box-shadow:var(--shadow);
}
.flow-step .fn{
  width:44px;height:44px;margin:0 auto 14px;border-radius:50%;color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;
  font-weight:700;font-size:1.9rem;background:var(--teal);
}
.flow-step:nth-child(2) .fn{background:var(--teal-d);}
.flow-step:nth-child(3) .fn{background:#17a7b0;}
.flow-step:nth-child(4) .fn{background:var(--teal-dd);}
.flow-step h4{font-size:1.6rem;font-weight:700;margin-bottom:8px;}
.flow-step p{font-size:1.35rem;color:var(--gray);line-height:1.7;}

/* ============================================================
   EXTRAS / SUBSIDY（事務代行だけじゃない）
   ============================================================ */
.lp-extras{background:var(--teal-d);color:#fff;}
.lp-extras .sec-title{color:#fff;}
.lp-extras .eyebrow{color:#d6fff5;}
.subsidy{
  max-width:820px;margin:0 auto 34px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);border-radius:18px;padding:32px 34px;
  display:flex;gap:28px;align-items:center;flex-wrap:wrap;
}
.subsidy .s-num{font-family:'Montserrat',sans-serif;font-weight:700;line-height:1;flex-shrink:0;}
.subsidy .s-num .big{font-size:5.4rem;color:#fff;}
.subsidy .s-num .big small{font-size:2.2rem;}
.subsidy .s-txt h4{font-size:2.1rem;font-weight:700;margin-bottom:10px;}
.subsidy .s-txt p{font-size:1.45rem;color:#eafaf6;line-height:1.85;}
.extra-tags{max-width:820px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.extra-box{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:24px 24px;}
.extra-box .ebimg{width:100%;height:130px;margin:-4px 0 16px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.92);border-radius:12px;overflow:hidden;}
.extra-box .ebimg img{width:auto;max-height:120px;}
.extra-box h4{font-size:1.7rem;font-weight:700;color:#fff;margin-bottom:10px;}
.extra-box p{font-size:1.4rem;color:#eafaf6;line-height:1.8;}

/* ============================================================
   FAQ
   ============================================================ */
.lp-faq{background:var(--paper);}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:var(--paper-2);border:1px solid var(--hair);border-radius:14px;overflow:hidden;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease;}
.faq-item.is-open{border-color:var(--hair-teal);box-shadow:0 6px 22px rgba(20,60,56,.08);background:#fff;}
.faq-q{
  padding:20px 24px;font-weight:700;font-size:1.55rem;cursor:pointer;
  display:flex;gap:14px;align-items:center;list-style:none;-webkit-tap-highlight-color:transparent;
}
.faq-q::-webkit-details-marker{display:none;}
.faq-q .qm{color:var(--teal);font-family:'Montserrat',sans-serif;font-weight:700;font-size:2rem;flex-shrink:0;transition:transform .35s cubic-bezier(.16,1,.3,1);}
.faq-item.is-open .faq-q .qm{transform:scale(1.15);}
.faq-q .arr{margin-left:auto;transition:transform .4s cubic-bezier(.16,1,.3,1);color:var(--teal);font-size:1.4rem;}
.faq-item.is-open .faq-q .arr{transform:rotate(180deg);}
/* JS が高さ(px)を制御する開閉ラッパー */
.faq-wrap{height:0;overflow:hidden;transition:height .4s cubic-bezier(.16,1,.3,1);will-change:height;}
.faq-a{padding:2px 24px 22px 56px;font-size:1.4rem;color:var(--gray);line-height:1.9;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .45s cubic-bezier(.16,1,.3,1);}
.faq-item.is-open .faq-a{opacity:1;transform:none;}

/* ============================================================
   NEWS（新着情報一覧）
   ============================================================ */
.lp-news{background:var(--paper-2);padding-bottom:80px;}
.news-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:0;background:var(--paper);border:1px solid var(--hair);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);}
.news-item{display:flex;align-items:center;gap:18px;padding:20px 24px;border-bottom:1px solid var(--hair);transition:background .2s ease,transform .2s ease;}
.news-item:last-child{border-bottom:0;}
.news-item:hover{background:var(--teal-tint);}
.news-date{font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.4rem;color:var(--teal-d);flex-shrink:0;width:104px;letter-spacing:.02em;}
.news-cat{flex-shrink:0;font-size:1.15rem;font-weight:700;color:#fff;background:var(--teal);border-radius:999px;padding:4px 14px;white-space:nowrap;}
.news-title{font-size:1.5rem;font-weight:500;color:var(--ink);line-height:1.6;flex:1;min-width:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.news-item:hover .news-title{color:var(--teal-d);}
.news-arrow{flex-shrink:0;color:var(--teal);font-size:1.6rem;transition:transform .2s ease;}
.news-item:hover .news-arrow{transform:translateX(4px);}
.news-empty{text-align:center;color:var(--gray-l);font-size:1.4rem;padding:30px 20px;}
.news-more{text-align:center;margin-top:36px;}
.news-more a{
  display:inline-flex;align-items:center;gap:10px;border:2px solid var(--teal);color:var(--teal-d);
  font-weight:700;font-size:1.5rem;padding:14px 36px;border-radius:999px;
  transition:background .2s ease,color .2s ease,transform .15s ease;
}
.news-more a:hover{background:var(--teal);color:#fff;transform:translateY(-2px);}
.news-more a svg{width:18px;height:18px;fill:currentColor;}

@media screen and (max-width:680px){
  .news-item{flex-wrap:wrap;gap:8px 12px;padding:18px 18px;}
  .news-date{width:auto;font-size:1.3rem;}
  .news-title{flex-basis:100%;-webkit-line-clamp:3;}
  .news-arrow{display:none;}
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.lp-fcta{
  background:linear-gradient(135deg,#1cbea1,#0e7d6a);color:#fff;text-align:center;
  position:relative;overflow:hidden;
}
.lp-fcta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 120%,rgba(255,255,255,.2),transparent 55%);}
.fcta-in{position:relative;z-index:2;}
.lp-fcta h2{font-size:clamp(2.6rem,5.2vw,4.2rem);line-height:1.45;margin-bottom:18px;font-weight:700;}
.lp-fcta p{font-size:1.6rem;margin-bottom:32px;opacity:.96;}
.fcta-btns{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;}
.btn-white{
  background:#fff;color:var(--teal-d);font-weight:700;font-size:1.8rem;
  padding:18px 38px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.18);transition:transform .15s;
}
.btn-white:hover{transform:translateY(-3px);}
.btn-white svg{width:24px;height:24px;fill:var(--line-green);}
.btn-tel{
  border:2px solid #fff;color:#fff;font-weight:700;font-size:1.7rem;
  padding:15px 30px;border-radius:999px;display:inline-flex;flex-direction:column;
  align-items:center;line-height:1.25;
}
.btn-tel small{font-size:1.1rem;font-weight:400;opacity:.9;margin-top:3px;}

/* ============================================================
   MOBILE STICKY BAR
   ============================================================ */
.lp-mbar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:rgba(20,40,44,.97);backdrop-filter:blur(6px);
  padding:10px 14px;gap:10px;border-top:1px solid rgba(255,255,255,.14);
}
.lp-mbar a{
  flex:1;text-align:center;padding:14px;border-radius:12px;font-weight:700;font-size:1.4rem;
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.lp-mbar .m-line{background:var(--line-green);color:#fff;}
.lp-mbar .m-tel{background:rgba(255,255,255,.14);color:#fff;}
.lp-mbar svg{width:18px;height:18px;fill:#fff;}

/* ============================================================
   既存の干渉回避（前バージョンの調整は不要になったので最小限）
   ============================================================ */

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media screen and (max-width:860px){
  .koma-grid{grid-template-columns:repeat(2,1fr);gap:28px 16px;}
  .r-grid{grid-template-columns:1fr;gap:16px;}
  .flow-grid{grid-template-columns:repeat(2,1fr);}
  .hl-grid{grid-template-columns:1fr;gap:32px;}
  .hl-phone{order:-1;}
  .ts-cards{grid-template-columns:1fr;max-width:360px;}
  .extra-tags{grid-template-columns:1fr;}
  .lp-hero-in{grid-template-columns:1fr;gap:8px;}
  .lp-hero-art{order:-1;max-width:340px;margin:0 auto 8px;}
  .split{grid-template-columns:1fr;gap:24px;}
}
@media screen and (max-width:680px){
  .lp section{padding:48px 0;}
  .cat-grid{grid-template-columns:1fr;}
  .worry-grid{grid-template-columns:1fr;}
  .compare{grid-template-columns:1fr;}
  .cmp-mid{padding:14px;font-size:1.8rem;}
  .cmp-b::before{display:none;}
  .subsidy{flex-direction:column;text-align:center;}
  .lp-hero{padding-bottom:92px;}
  .lp-mbar{display:flex;}
  /* 追従CTA(固定バー)の高さ分、ページ全体に下余白を確保しフッターとの重なりを防ぐ */
  .lp-news{padding-bottom:48px;}
}
/* 追従CTAバーが表示される画面幅では、最終コンテンツ〜フッターが隠れないよう余白を確保 */
@media screen and (max-width:680px){
  body{padding-bottom:74px;}
}

/* PCで横幅を広げすぎない調整（旧サイトと同じ最大幅感） */
@media screen and (min-width:1400px){
  .lp-wrap{max-width:1180px;}
}
