@charset "UTF-8";
/* ファクタリングパートナーズ（建設業専門ファクタリング）広告LP
   運営: SENWAファイナンシャル株式会社 / ドメイン: factoring-partners.jp */

:root{
  --green:#3aa636;
  --green-d:#2c8a2a;
  --green-dd:#1d6b1c;
  --green-l:#69c259;
  --green-light:#62c651;   /* もう1色の薄い緑（波） */
  --yellow:#ffe24a;
  --lime:#d6f15a;
  --accent:#e8412a;
  --cta:#ff8a1f;
  --cta-d:#e9731a;
  --pop:"Zen Kaku Gothic New",sans-serif;
  --round:"Zen Kaku Gothic New",sans-serif;
}

/* ヒーローブロック（ヘッダー／ヒーロー／CTAバー）だけ元フォントを維持 */
.lp-header,.hero,.cta-bar{
  --pop:"Mochiy Pop One",sans-serif;
  --round:"M PLUS Rounded 1c",sans-serif;
  font-family:var(--round);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:#222;
  font-family:"Zen Kaku Gothic New",system-ui,sans-serif;
  font-weight:500;line-height:1.7;background:#fff;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none}

/* ===== ヘッダー（透過オーバーレイ） ===== */
.lp-header{
  position:absolute;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem max(clamp(14px,3vw,36px), calc((100% - 1080px) / 2));background:transparent;
}
.lp-logo{display:block;line-height:0}
.lp-logo img{height:clamp(42px,4.8vw,60px);width:auto;display:block}
.header-cta{
  font-family:var(--round);font-weight:800;font-size:.92rem;color:#fff;
  background:linear-gradient(180deg,var(--cta),var(--cta-d));
  padding:.55em 1.2em;border-radius:999px;box-shadow:0 4px 0 #c85f10;transition:.15s;
}
.header-cta:active{transform:translateY(2px);box-shadow:0 2px 0 #c85f10}

/* ===== ヒーロー（スマホは画像／PRはCSS） ===== */
.hero-mobile{display:none}
.hero-mobile img{width:100%;height:auto;display:block}

.hero{
  position:relative;overflow:hidden;isolation:isolate;
  min-height:589px;
  background:
    radial-gradient(120% 90% at 15% 0%, #57bd49 0%, transparent 55%),
    linear-gradient(160deg,#46ad3c 0%, var(--green) 50%, var(--green-d) 100%);
}

/* --- 背景装飾 --- */
.hero-shapes{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-shapes>*{position:absolute}
.band-left{left:0;top:0;bottom:0;width:34px;background:var(--green-dd)}
.band-left::after{content:"";position:absolute;top:0;bottom:0;right:7px;width:3px;background:rgba(255,255,255,.85)}
.tex-tl{left:0;top:0;width:46%;height:58%;
  background:radial-gradient(circle, rgba(255,255,255,.16) 1.6px, transparent 2px);
  background-size:16px 16px;opacity:.55;mask-image:linear-gradient(135deg,#000,transparent 70%)}
/* 人物背後の白ブロブ（頭が上端／下は濃緑の三角が乗っかる高さまで） */
.white-blob{right:7%;top:28%;width:min(460px,40%);height:64%;background:#fff;
  border-radius:50% 50% 48% 52% / 50% 50% 46% 46%;
  filter:drop-shadow(0 18px 40px rgba(0,0,0,.10))}
.white-blob::before{content:"";position:absolute;width:30%;aspect-ratio:1;background:#fff;border-radius:50%;top:-12%;left:8%}
.white-blob::after{content:"";position:absolute;width:22%;aspect-ratio:1;background:#fff;border-radius:50%;top:-7%;right:12%}
/* 下部の薄緑の波（もう1色の緑・斜めに流れて地面を作る） */
.wave-light{left:-14%;right:-14%;bottom:-110px;height:320px;
  background:linear-gradient(180deg,#73d063 0%, var(--green-light) 60%, #4cae3e 100%);
  border-radius:50%;transform:rotate(-4deg)}
/* 服の斜め裾に沿った濃い緑の三角ウェッジ（白の上に乗る／右端まで届かせる）
   左端=hero-inner左から固定px、右端=ビューポート右端まで calc で伸ばす */
.hero-inner>.ground-dark{z-index:1;left:0;right:calc(540px - 50vw);top:0;bottom:0;height:auto;
  background:linear-gradient(160deg,#2c8a28 0%,#1c641b 100%);
  clip-path:polygon(700px 100%, 100% calc(633px - 13.87vw), 100% 100%)}
/* 右下ハーフトーン */
.halftone{right:0;bottom:0;width:30%;height:40%;
  background:radial-gradient(circle, var(--lime) 2px, transparent 2.6px);
  background-size:18px 18px;opacity:.4;mask-image:radial-gradient(circle at 100% 100%, #000, transparent 72%)}
/* 右上の円・黄ドット */
.ring{border-radius:50%;border:6px solid rgba(255,255,255,.32)}
.ring1{top:5%;right:30%;width:62px;height:62px}
.ring2{top:17%;right:25%;width:28px;height:28px;border-width:5px}
.ydot{border-radius:50%;background:var(--yellow)}
.ydot1{top:8%;right:38%;width:24px;height:24px}
.ydot2{top:27%;right:35%;width:13px;height:13px}

/* --- レイアウト：左上コピー／左下バッジ／右に人物（縦貫通） --- */
.hero-inner{
  position:relative;z-index:2;max-width:1080px;margin:0 auto;min-height:inherit;
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);grid-template-rows:auto 1fr auto;
  grid-template-areas:"copy person" "gap person" "trust person";
  padding:64px clamp(16px,4vw,56px) 0;column-gap:8px;
}
/* hero-inner基準で配置（人物と一緒に追従させる） */
.hero-inner>.white-blob,.hero-inner>.ground-dark,.hero-inner>.halftone,
.hero-inner>.ring,.hero-inner>.ydot{position:absolute;pointer-events:none}
.hero-copy{grid-area:copy;position:relative;z-index:2;min-width:0;max-width:100%}

/* --- 人物（右・縦貫通で底まで） --- */
.hero-person{grid-area:person;align-self:end;justify-self:end;position:relative;z-index:3;
  min-width:0;width:min(620px,112%);margin-bottom:-2px}
.hero-person img{position:relative;z-index:1;width:100%;height:auto;filter:drop-shadow(0 14px 22px rgba(0,0,0,.22))}
.badge-online{
  position:absolute;top:0;right:2%;z-index:4;
  display:grid;place-items:center;width:clamp(86px,11vw,124px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#fff06a,var(--yellow));
  color:var(--green-dd);font-family:var(--pop);font-size:clamp(13px,1.5vw,18px);line-height:1.25;text-align:center;
  box-shadow:0 8px 18px rgba(0,0,0,.22);transform:rotate(-7deg);
}
.hero-label{
  display:inline-block;margin:0 0 12px;
  font-family:var(--pop);font-size:clamp(14px,1.6vw,19px);
  color:#fff;background:var(--green-dd);padding:.4em 1.5em .4em 1.1em;
  clip-path:polygon(3% 0,100% 0,97% 100%,0 100%);
  box-shadow:0 4px 10px rgba(0,0,0,.18);letter-spacing:.02em;
}
.hero-ribbon{margin:2px 0 2px;display:flex;align-items:center}
.hero-ribbon span{
  position:relative;font-family:var(--pop);font-size:clamp(17px,2.1vw,24px);color:#fff;
  letter-spacing:.04em;text-shadow:0 2px 5px rgba(0,0,0,.25);padding:0 30px;
}
.hero-ribbon span::before,.hero-ribbon span::after{
  content:"";position:absolute;top:50%;width:5px;height:1.4em;background:var(--lime);border-radius:2px;
}
.hero-ribbon span::before{left:4px;transform:translateY(-50%) rotate(18deg);box-shadow:10px 0 0 var(--lime)}
.hero-ribbon span::after{right:4px;transform:translateY(-50%) rotate(-18deg);box-shadow:-10px 0 0 var(--lime)}

.hero-title{margin:0;font-family:var(--pop);line-height:1.14;color:#fff;letter-spacing:.005em}
.hero-title span{display:block}
.hero-title .l1{font-size:clamp(40px,6.6vw,76px);color:var(--yellow);
  text-shadow:0 4px 0 var(--green-dd),0 6px 12px rgba(0,0,0,.28)}
.hero-title .l2{font-size:clamp(40px,6.8vw,78px);color:#fff;
  text-shadow:0 4px 0 var(--green-dd),0 6px 12px rgba(0,0,0,.28)}
.hero-title .l3{font-size:clamp(22px,3.2vw,38px);margin-top:.12em;text-shadow:0 3px 0 rgba(0,0,0,.18)}
.hero-title .l4{font-size:clamp(24px,3.6vw,42px);margin-top:.16em;text-shadow:0 3px 0 rgba(0,0,0,.18)}
.hero-title .box{display:inline-block;color:var(--green-d);background:#fff;border-radius:10px;
  padding:0 .2em;margin-right:.12em;box-shadow:0 4px 0 rgba(0,0,0,.14);text-shadow:none}

/* --- 信頼バッジ3点（左下） --- */
.hero-trust{
  grid-area:trust;align-self:end;position:relative;z-index:2;max-width:680px;
  margin:18px 0 28px;padding:0;list-style:none;
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.hero-trust li{
  display:flex;align-items:center;gap:11px;background:#fff;border-radius:14px;
  padding:11px 15px;box-shadow:0 8px 18px rgba(0,0,0,.14);
}
.hero-trust i{font-size:30px;color:var(--green);flex:0 0 auto}
.hero-trust p{margin:0;font-family:var(--round);line-height:1.2;color:#2b2b2b}
.hero-trust .sm{display:inline;font-size:12px;font-weight:700;color:#555}
.hero-trust strong{display:inline-block;font-family:var(--pop);font-size:22px;color:var(--green-d);vertical-align:-1px;margin:0 .06em}
.hero-trust strong.sm2{font-size:14px;color:#2b2b2b;display:block;margin:0;font-weight:800}

/* ===== CTAバー ===== */
.cta-bar{text-align:center;padding:22px 16px 24px;
  background:linear-gradient(180deg,#eef6ea,#ffffff)}
.hero-eligible{
  display:inline-flex;align-items:center;gap:.5em;margin:0 0 12px;
  font-family:var(--round);font-weight:800;font-size:clamp(14px,1.8vw,18px);color:var(--green-d);
  background:#fff;padding:.5em 1.3em;border-radius:999px;box-shadow:0 4px 12px rgba(0,0,0,.12);
  border:2px solid #cfe9c6;
}
.hero-eligible i{color:var(--green)}
.hero-eligible b{color:var(--accent);font-weight:900}
.btn-cta{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--pop);font-size:clamp(17px,2.4vw,23px);color:#fff;
  background:linear-gradient(180deg,#ffae3d,var(--cta) 60%,var(--cta-d));
  padding:.85em 2em;border-radius:999px;
  box-shadow:0 7px 0 #c85f10,0 12px 22px rgba(0,0,0,.22);transition:.15s;
}
.btn-cta:active{transform:translateY(4px);box-shadow:0 3px 0 #c85f10,0 6px 12px rgba(0,0,0,.22)}
.hero-cta-note{margin:.7em 0 0;color:#5a6a52;font-size:12.5px;font-weight:700}

/* ===== 共通（本文セクション） ===== */
.wrap{max-width:1040px;margin:0 auto;padding:0 clamp(16px,4vw,32px)}
.sec-eyebrow{display:none}
.sec-title{margin:0 0 .8em;text-align:center;font-family:var(--pop);line-height:1.35;
  font-size:clamp(23px,3.6vw,38px);color:#1f2b1c}
.sec-title b{color:var(--green-d)}
.sec-title.light{color:#fff}
.sec-title.light b{color:var(--yellow)}
.sp-br{display:none}

/* ===== お任せください（バナー・背景になじませる） ===== */
.omakase{background:#fdfefc;padding:clamp(20px,4vw,44px) 16px 0}
.omakase img{max-width:1000px;width:100%;margin:0 auto;border-radius:0;box-shadow:none}

/* ===== お悩み ===== */
.worry{background:#f3f6ef;padding:clamp(48px,7vw,80px) 0 0;position:relative}
.worry-list{list-style:none;margin:0 auto;padding:0;max-width:920px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.worry-list li{display:flex;align-items:center;gap:14px;background:#fff;border-radius:14px;
  padding:18px 20px;box-shadow:0 6px 16px rgba(0,0,0,.06);border-left:5px solid var(--green-l)}
.worry-list i{font-size:26px;color:var(--green);flex:0 0 auto;width:34px;text-align:center}
.worry-list p{margin:0;font-size:clamp(14px,1.7vw,16px);line-height:1.6}
.worry-list b{color:var(--accent);font-weight:800}
.worry-bridge{margin:24px auto 0;text-align:center}
.worry-bridge-arrow{width:clamp(340px,40vw,540px);height:auto;margin:-90px auto -60px;
  animation:bounceY 1.6s ease-in-out infinite}
.worry-bridge-inner{display:flex;align-items:flex-end;justify-content:center;gap:clamp(16px,3vw,40px)}
.worry-bridge-text{margin:0 0 30px}
.worry-bridge-text span{display:inline-block;
  font-family:var(--pop);font-size:clamp(18px,2.6vw,28px);color:#1f2b1c;line-height:1.5}
.worry-bridge-text b{color:var(--green-d)}
.worry-bridge-person{width:clamp(290px,34vw,430px);height:auto;flex:0 0 auto;
  display:block;margin-bottom:0}
@keyframes bounceY{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ===== 特長 ===== */
.feat{padding:clamp(48px,7vw,84px) 0;
  background:radial-gradient(120% 80% at 50% 0%,#46ad3c 0%,var(--green) 45%,var(--green-d) 100%)}
.feat-rows{max-width:940px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(26px,4vw,46px)}
.feat-row{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(20px,4vw,46px)}
.feat-row.reverse .feat-img{order:2}
.feat-img{margin:0}
.feat-img img{width:100%;border-radius:18px;box-shadow:0 16px 32px rgba(0,0,0,.22)}
.feat-text h3{margin:0 0 .6em;font-family:var(--round);font-weight:900;
  font-size:clamp(20px,2.6vw,27px);color:#fff;padding-left:14px;border-left:6px solid var(--yellow);line-height:1.3}
.feat-text p{margin:0;font-size:clamp(14px,1.7vw,16px);line-height:1.85;color:#eafbe4}

/* ===== ファクタリングとは ===== */
.about-fc{padding:clamp(48px,7vw,84px) 0;background:#fff}
.about-lead{max-width:800px;margin:0 auto 18px;text-align:left;
  font-size:clamp(15px,1.9vw,17px);line-height:1.95;color:#333}
.about-lead:last-of-type{margin-bottom:36px}
.about-lead b{color:var(--green-d);font-weight:800}
.fc-type{max-width:880px;margin:0 auto 28px;background:#f3f6ef;border-radius:18px;
  padding:clamp(20px,3vw,32px);box-shadow:0 6px 18px rgba(0,0,0,.05)}
.fc-type-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.fc-type-head h3{margin:0;font-family:var(--round);font-weight:800;font-size:clamp(16px,2.1vw,20px);color:#1f2b1c}
.badge2,.badge3{flex:0 0 auto;font-family:var(--pop);font-size:18px;color:#fff;border-radius:10px;
  padding:.25em .7em;box-shadow:0 4px 0 rgba(0,0,0,.12)}
.badge2{background:linear-gradient(180deg,var(--cta),var(--cta-d))}
.badge3{background:linear-gradient(180deg,var(--green),var(--green-d))}
.fc-type-note{margin:0 0 18px;font-size:14.5px;color:#3a4a35;background:#fff;border-radius:12px;padding:12px 16px}
.fc-type-note i{color:var(--green);margin-right:.3em}
.fc-type-note b{color:var(--green-d)}
.fc-fig{margin:0}
.fc-fig img{width:100%;max-width:760px;margin:0 auto;border-radius:12px;background:#fff}

/* ===== メリット ===== */
.merit{padding:clamp(48px,7vw,84px) 0;background:#f3f6ef}
.merit-list{list-style:none;margin:0 auto;padding:0;max-width:980px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.merit-list li{background:#fff;border-radius:16px;padding:26px 22px;box-shadow:0 8px 20px rgba(0,0,0,.06);
  border-left:5px solid var(--green-l)}
.merit-list h3{margin:0 0 .5em;font-family:var(--round);font-weight:800;font-size:17px;color:#1f2b1c}
.merit-list p{margin:0;font-size:13.5px;line-height:1.7;color:#555}

/* ===== ご相談バナー ===== */
.consult{background:#f3f6ef;padding:clamp(28px,5vw,56px) 0}
.consult-band{position:relative;max-width:900px;margin:0 auto;
  background:linear-gradient(120deg,#46ad3c 0%,var(--green) 45%,var(--green-d) 100%);
  border-radius:28px;min-height:188px;padding:30px 44px 30px 280px;
  display:flex;flex-direction:column;justify-content:center;
  box-shadow:0 16px 34px rgba(0,0,0,.16)}
.consult-person{position:absolute;left:26px;bottom:0;width:228px;height:auto;
  filter:drop-shadow(0 12px 20px rgba(0,0,0,.22))}
.consult-h{margin:0;font-family:var(--pop);line-height:1.3;color:#fff;
  font-size:clamp(22px,3.4vw,35px);text-shadow:0 2px 6px rgba(0,0,0,.18)}
.consult-h .hl{color:var(--yellow)}
.consult-sub{margin:16px 0 0;padding-top:16px;border-top:2px solid rgba(255,255,255,.55);
  font-family:var(--round);font-weight:700;color:#fff;font-size:clamp(14px,1.9vw,18px)}

/* ===== 比較 ===== */
.compare{padding:clamp(48px,7vw,84px) 0;background:#eef2f4}
.compare-fig{margin:0;max-width:820px;margin:0 auto}
.compare-fig img{width:100%;border-radius:0}
.compare-note{max-width:780px;margin:14px auto 0;text-align:center;font-size:12px;color:#888}

/* ===== 流れ（GIF） ===== */
.flow{padding:clamp(24px,4vw,48px) 0;background:#fafbfb}
.flow-fig{margin:0 auto;max-width:1040px;padding:0 clamp(12px,3vw,24px)}
.flow-fig img{width:100%;border-radius:12px}

/* ===== FAQ ===== */
.faq{padding:clamp(48px,7vw,84px) 0;background:#fff}
.faq-list{list-style:none;margin:0 auto;padding:0;max-width:780px}
.faq-list li{margin-bottom:12px}
.faq-list details{background:#f3f6ef;border-radius:12px;overflow:hidden;border:1px solid #e4eadd}
.faq-list summary{cursor:pointer;list-style:none;padding:17px 50px 17px 52px;position:relative;
  font-family:var(--round);font-weight:700;font-size:15px;color:#1f2b1c}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::before{content:"Q";position:absolute;left:16px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;display:grid;place-items:center;border-radius:50%;
  font-family:var(--pop);font-size:14px;color:#fff;background:var(--green)}
.faq-list summary::after{content:"\f078";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;right:18px;top:50%;transform:translateY(-50%);color:var(--green);font-size:14px;transition:.2s}
.faq-list details[open] summary::after{transform:translateY(-50%) rotate(180deg)}
.faq-a{padding:0 20px 18px 52px;font-size:14px;line-height:1.8;color:#444}

/* ===== フォーム ===== */
.form-sec{padding:clamp(48px,7vw,84px) 0;
  background:radial-gradient(120% 80% at 50% 0%,#46ad3c 0%,var(--green) 45%,var(--green-d) 100%)}
.form-head{position:relative;z-index:1;margin:0 auto;max-width:680px;
  display:flex;align-items:center;gap:clamp(8px,1.6vw,22px)}
.form-person{flex:0 0 auto;width:clamp(190px,23vw,320px);aspect-ratio:679/720;
  object-fit:cover;object-position:center top;margin-bottom:-30px;
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.2))}
.form-head-text{flex:1 1 auto;min-width:0;text-align:left;padding:clamp(6px,1.5vw,18px) 0}
.form-head-text .sec-title{font-size:clamp(21px,2.7vw,31px);white-space:nowrap}
.form-card{position:relative;z-index:2}
.form-head-text .sec-title{text-align:left}
.form-sub{text-align:left;margin:0;font-size:clamp(13.5px,1.7vw,15.5px);line-height:1.8}
.form-sub.light{color:#eafbe4}.form-sub b{color:var(--yellow)}
.form-card{max-width:680px;margin:0 auto;background:#fff;border-radius:20px;
  padding:clamp(24px,4vw,40px);box-shadow:0 20px 44px rgba(0,0,0,.22)}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-card label{display:block;margin-bottom:16px;font-family:var(--round);font-weight:700;font-size:14px;color:#2b3a26}
.form-card label.f-full{display:block}
.req{display:inline-block;font-size:11px;color:#fff;background:var(--accent);border-radius:4px;
  padding:.1em .6em;margin-left:.4em;vertical-align:1px;font-weight:700}
.form-card input,.form-card select,.form-card textarea{
  width:100%;margin-top:7px;padding:12px 14px;font-size:15px;font-family:inherit;
  border:1.5px solid #d3ddc9;border-radius:10px;background:#fafdf8;color:#222;transition:.15s}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(58,166,54,.15);background:#fff}
.form-card textarea{resize:vertical}
.f-radio{margin:0 0 16px;padding:0;border:none}
.f-radio legend{padding:0;font-family:var(--round);font-weight:700;font-size:14px;color:#2b3a26}
.radio-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:9px}
.radio{display:inline-flex;align-items:center;gap:.5em;flex:1 1 0;min-width:140px;margin:0;cursor:pointer;
  padding:11px 16px;border:1.5px solid #d3ddc9;border-radius:10px;background:#fafdf8;
  font-weight:700;font-size:14px;transition:.15s}
.radio input{width:auto;margin:0;accent-color:var(--green);flex:0 0 auto}
.radio:has(input:checked){border-color:var(--green);background:#eef7ea;box-shadow:0 0 0 2px rgba(58,166,54,.18)}
.radio span{user-select:none}
.form-btn{width:100%;margin-top:8px;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--pop);font-size:clamp(17px,2.4vw,21px);color:#fff;
  background:linear-gradient(180deg,#ffae3d,var(--cta) 60%,var(--cta-d));
  padding:.9em 1em;border-radius:999px;box-shadow:0 7px 0 #c85f10,0 12px 22px rgba(0,0,0,.2);transition:.15s}
.form-btn:active{transform:translateY(4px);box-shadow:0 3px 0 #c85f10}
.form-btn:disabled{opacity:.6;cursor:default}
.form-privacy{margin:14px 0 0;text-align:center;font-size:12px;color:#777}
.form-privacy a{color:var(--green-d);text-decoration:underline}
.form-status{margin:12px 0 0;text-align:center;font-size:14px;font-weight:700;min-height:1.2em}
.form-status.ok{color:var(--green-d)}
.form-status.err{color:var(--accent)}

/* ===== フッター ===== */
.lp-footer{background:#1b2a17;color:#cdd8c5;padding:46px 0 110px}
.foot-inner{display:flex;align-items:center;gap:clamp(24px,5vw,56px)}
.foot-logo{flex:0 0 auto;display:block;line-height:0}
.foot-logo img{width:clamp(140px,17vw,190px);height:auto}
.foot-main{flex:1 1 auto;text-align:left}
.foot-brand{margin:0 0 14px}
.foot-brand img{height:clamp(38px,4.4vw,52px);width:auto}
.foot-op{margin:0 0 14px;font-family:var(--round);font-weight:700;font-size:14px;color:#a9d49d}
.foot-desc{max-width:680px;margin:0 auto 20px;font-size:12.5px;line-height:1.8;color:#9ca893}
.foot-links{list-style:none;display:flex;flex-wrap:wrap;justify-content:flex-start;gap:8px 22px;margin:0 0 18px;padding:0}
.foot-links a{color:#cdd8c5;font-size:13px}
.foot-links a:hover{color:#fff;text-decoration:underline}
.foot-copy{margin:0;font-size:11.5px;color:#6f7d66}

/* ===== 下部固定バー ===== */
.fixed-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  display:flex;align-items:stretch;
  background:#fff;border-top:3px solid #1a9fd4;
  box-shadow:0 -4px 18px rgba(0,0,0,.18);
  transform:translateY(110%);transition:transform .35s ease;
  font-family:var(--round);
}
.fixed-bar.show{transform:translateY(0)}
.fb-phone{display:flex;align-items:center;gap:14px;padding:8px 18px;flex:0 0 auto}
.fb-badges{display:flex;flex-direction:column;gap:5px}
.fb-badges span{font-size:13px;font-weight:800;color:#fff;background:#1b3a5c;
  padding:.18em .5em;border-radius:3px;text-align:center;white-space:nowrap;
  clip-path:polygon(0 0,100% 0,93% 100%,0 100%)}
.fb-lead{margin:0;font-size:clamp(15px,1.4vw,19px);font-weight:800;color:#1b3a5c;letter-spacing:.02em}
.fb-lead i{color:#1a9fd4;margin-right:.15em}
.fb-hours{margin:4px 0 0;font-size:12.5px;font-weight:700;color:#333}
.fb-btns{display:flex;flex:1 1 auto;gap:10px;align-items:center;padding:10px 18px 10px 0}
.fb-btn{flex:1 1 0;min-width:0;text-align:center;border-radius:8px;padding:13px 8px;
  color:#fff;font-weight:800;font-size:14px;line-height:1.35;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(0,0,0,.18);transition:.15s}
.fb-btn b{font-size:15px}
.fb-btn:active{transform:translateY(2px)}
.fb-web{background:linear-gradient(180deg,#ef6321,#d94f12)}
.fb-line{background:#06c755;flex-direction:row;gap:9px}
.fb-line i{font-size:26px}
.fb-line span{display:block}

/* ===== レスポンシブ ===== */
@media (max-width:820px){
  /* スマホ：ヘッダーは緑バー（白ロゴが映える・ロゴでバーいっぱい） */
  .lp-header{position:relative;padding:.18rem .8rem;
    background:linear-gradient(180deg,#46ad3c,#34982f);box-shadow:0 2px 10px rgba(0,0,0,.14)}
  .lp-logo img{height:48px}
  .header-cta{font-size:.74rem;padding:.5em .85em;white-space:nowrap}
  /* スマホ：CSSヒーローを隠して画像ヒーローを表示 */
  .hero{display:none}
  .hero-mobile{display:block}
  .hero{min-height:0}
  .hero-inner{grid-template-columns:1fr;grid-template-rows:auto auto auto;
    grid-template-areas:"copy" "person" "trust";padding:24px 16px 0}
  .hero-copy{max-width:100%;text-align:center}
  .hero-ribbon{justify-content:center}
  .hero-person{justify-self:center;width:min(360px,86%);margin:6px auto 0}
  .badge-online{right:auto;left:0;top:6%}
  .white-blob{right:50%;transform:translateX(50%);top:auto;bottom:0;width:min(360px,88%);height:52%}
  .wave-light{bottom:-150px;height:280px}
  .ground-dark{clip-path:polygon(0 84%,100% 68%,100% 100%,0 100%)}
  .hero-trust{grid-template-columns:1fr;gap:10px;max-width:430px;margin:0 auto 18px}
  .ring1,.ring2,.ydot1,.ydot2{display:none}
  body{padding-bottom:62px}
  /* 下部固定バー：スマホはコンパクト（電話＋WEB＋LINE） */
  /* スマホ：バッジを上＋相談メッセージ、右にボタン2つ */
  .fb-phone{flex-direction:column;justify-content:center;gap:4px;padding:4px 4px 4px 8px;flex:0 0 auto;max-width:42vw}
  .fb-badges{display:flex;flex-direction:row;gap:3px}
  .fb-badges span{font-size:8.5px;padding:.14em .5em;clip-path:none;border-radius:3px}
  .fb-hours{display:none}
  .fb-lead{display:block;margin:0;font-size:clamp(10px,2.7vw,12px);line-height:1.25;font-weight:800}
  .fb-lead i{display:none}
  .fb-lead-full{display:none}
  .fb-btns{padding:5px 6px 5px 0;gap:6px}
  .fb-btn{font-size:9.5px;padding:7px 3px;border-radius:7px;line-height:1.25}
  .fb-btn b{font-size:11px}
  .fb-line{flex-direction:column;gap:1px}
  .fb-line i{font-size:15px}

  /* 本文セクション：スマホ */
  .sp-br{display:inline}
  .worry-list{grid-template-columns:1fr;gap:12px}
  /* スマホ：人物を大きく＆下端（袖ライン）を緑セクションに合わせる */
  .worry{padding-bottom:0}
  .worry-bridge{margin-bottom:0}
  .worry-bridge-inner{flex-direction:column;align-items:center;gap:18px}
  .worry-bridge-text{margin:0}
  .worry-bridge-person{width:min(360px,90%);margin-bottom:0}
  .feat-row,.feat-row.reverse{grid-template-columns:1fr;gap:14px}
  .feat-row.reverse .feat-img{order:0}
  .feat-text{text-align:center}
  .feat-text h3{padding-left:0;border-left:none;display:inline-block;
    border-bottom:4px solid var(--yellow);padding-bottom:.2em}
  .feat-text p{text-align:left}
  .merit-list{grid-template-columns:1fr;gap:14px}
  /* ご相談バナー：PCと同じ横長（人物左・テキスト右）を維持 */
  .consult-band{min-height:140px;padding:18px 16px 18px clamp(108px,32vw,150px)}
  .consult-person{width:clamp(96px,29vw,150px);left:6px}
  .consult-h{font-size:clamp(16px,4.4vw,22px)}
  .consult-sub{margin-top:10px;padding-top:10px;font-size:clamp(11.5px,3.1vw,15px)}
  .f-row{grid-template-columns:1fr;gap:0}
  /* スマホも人物左・説明右をキープ（横並び） */
  .form-head{gap:8px;max-width:none}
  .form-person{width:34vw;max-width:170px;margin-bottom:-18px}
  .form-head-text{padding-bottom:6px}
  .form-head-text,.form-head-text .sec-title,.form-sub{text-align:left}
  .form-head-text .sec-title{font-size:clamp(16px,4.6vw,22px)}
  .form-sub{font-size:clamp(10.5px,3vw,13px)}
  .lp-footer{padding-bottom:96px}
  .foot-inner{flex-direction:column;text-align:center;gap:22px}
  .foot-main{text-align:center}
  .foot-links{justify-content:center}
}
@media (max-width:480px){
  .worry-bridge span{font-size:19px}
}
