/* =========================================================
   税務調査LP（全国対応）専用スタイル — 派手・集中型
   variables.css / reset.css の上に読み込む
   ========================================================= */
/* 共通ヘッダー/フッターを使用。スマホは追従CTAバー分の余白を確保 */
@media (max-width: 919px) { .lp-page { padding-bottom: 64px; } }
.lp-wrap { width: min(100%, 1080px); margin-inline: auto; padding-inline: clamp(16px, 4vw, 32px); }
.lp-eyebrow { display: block; text-align: center; font-family: var(--ff-en); font-size: var(--fs-13); letter-spacing: .24em; color: var(--c-gold); font-weight: 700; text-transform: uppercase; margin-bottom: 14px; }

/* ===== LPヘッダー ===== */
.lp-header { position: sticky; top: 0; z-index: 40; background: rgba(7,21,13,.92); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(201,161,58,.25); }
.lp-header__inner { width: min(100%, 1080px); margin-inline: auto; padding: 10px clamp(16px,4vw,32px); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.lp-header__brand { display: inline-flex; align-items: center; gap: 10px; color: #fff; font-weight: 700; font-size: var(--fs-15); }
.lp-header__brand img { width: 40px; height: 40px; background: #fff; border-radius: 8px; padding: 3px; }
.lp-header__tel { display: inline-flex; align-items: center; gap: 6px; color: var(--c-gold-soft); font-family: var(--ff-en); font-weight: 700; font-size: var(--fs-18); white-space: nowrap; }
@media (max-width: 600px) { .lp-header__brand span { display: none; } .lp-header__tel { font-size: var(--fs-16); } }

/* ===== HERO ===== */
.lp-hero { position: relative; overflow: hidden; padding: clamp(48px,8vw,90px) 0 clamp(56px,9vw,100px); background: radial-gradient(ellipse at 70% 0%, #1d5d3a 0%, #0e3d27 45%, #07150d 100%); color: #fff; text-align: center; }
.lp-hero__deco { position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 25%, rgba(201,161,58,.28), transparent 45%), radial-gradient(ellipse at 12% 75%, rgba(47,170,107,.25), transparent 50%); pointer-events: none; }
.lp-hero__pattern { position: absolute; inset: 0; background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><g fill='none' stroke='%23c9a13a' stroke-opacity='0.12' stroke-width='1.5'><circle cx='300' cy='300' r='260'/><circle cx='300' cy='300' r='190'/><circle cx='300' cy='300' r='120'/></g></svg>") center / 760px; pointer-events: none; opacity: .8; }
.lp-hero__inner { position: relative; width: min(100%, 1080px); margin-inline: auto; padding-inline: clamp(16px,4vw,32px); }
.lp-hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 9px 20px; margin-bottom: 26px; background: rgba(255,255,255,.08); border: 1.5px solid var(--c-gold); border-radius: var(--r-full); font-size: var(--fs-13); letter-spacing: .08em; color: var(--c-gold-soft); font-weight: 600; }
.lp-hero__eyebrow svg { color: var(--c-gold); }
.lp-hero__h1 { font-family: var(--ff-display); font-weight: 900; line-height: 1.28; margin-bottom: 24px; text-shadow: 0 6px 30px rgba(0,0,0,.45); }
.lp-hero__h1-sub { display: block; font-size: clamp(18px,3vw,26px); color: var(--c-gold-soft); }
.lp-hero__h1-main { display: block; font-size: clamp(34px,7vw,72px); letter-spacing: .01em; }
.lp-hero__h1-main em { font-style: normal; color: var(--c-gold-soft); position: relative; }
.lp-hero__h1-main em::after { content: ""; position: absolute; left: -2%; right: -2%; bottom: 6px; height: 12px; background: rgba(201,161,58,.3); border-radius: 6px; z-index: -1; }
.lp-hero__h1-sub2 { display: block; font-size: clamp(22px,4vw,40px); margin-top: 4px; }
.lp-hero__lead { font-size: clamp(var(--fs-15),1.7vw,var(--fs-18)); line-height: 2; color: rgba(255,255,255,.95); max-width: 760px; margin: 0 auto 28px; }
.lp-hero__lead strong { color: var(--c-gold-soft); font-weight: 700; }
.lp-hero__badges { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 34px; }
.lp-badge { display: inline-flex; align-items: center; gap: 6px; padding: 9px 18px; background: rgba(255,255,255,.1); border: 1px solid rgba(201,161,58,.45); border-radius: var(--r-full); font-size: var(--fs-14); font-weight: 600; color: #fff; }
.lp-badge svg { color: var(--c-gold-soft); }
.lp-hero__note { margin-top: 22px; font-size: var(--fs-14); color: var(--c-gold-soft); }
.lp-hero__note strong { color: #ffe7a0; }

/* ===== 画像HERO ===== */
.lp-hero--image { padding: 0; background: var(--c-green-dark); }
.lp-hero__picture { display: block; }
.lp-hero__img { display: block; width: 100%; height: auto; max-width: 100%; }

/* ===== HERO直下CTA ===== */
.lp-hero-cta { padding: clamp(28px,4vw,44px) 0; background: linear-gradient(180deg, #07150d, #0e3d27); color: #fff; }
.lp-hero-cta__note { text-align: center; font-size: var(--fs-14); color: var(--c-gold-soft); margin-bottom: 20px; }
.lp-hero-cta__note strong { color: #ffe7a0; }

/* ===== CTAボタン（大） ===== */
.lp-hero__cta, .lp-final__actions { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 880px; margin: 0 auto; }
@media (max-width: 720px) { .lp-hero__cta, .lp-final__actions { grid-template-columns: 1fr; } }
.lp-btn { position: relative; display: flex; align-items: center; gap: 16px; padding: 20px 26px; border-radius: var(--r-16); text-align: left; overflow: hidden; transition: transform .18s, box-shadow .2s; min-width: 0; }
.lp-btn__icon { flex-shrink: 0; width: 60px; height: 60px; border-radius: 50%; display: grid; place-items: center; }
.lp-btn__body { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; flex: 1; }
.lp-btn__label { font-size: var(--fs-12); font-weight: 700; opacity: .85; letter-spacing: .04em; }
.lp-btn__num { font-family: var(--ff-en); font-size: clamp(24px,3.4vw,32px); font-weight: 800; white-space: nowrap; }
.lp-btn__main { font-size: var(--fs-20); font-weight: 800; }
.lp-btn__hours { font-size: var(--fs-12); opacity: .8; }
.lp-btn__arrow { font-size: 26px; font-weight: 800; transition: transform .2s; }
/* 電話：白地 */
.lp-btn--tel { background: #fff; color: var(--c-green-dark); box-shadow: 0 12px 30px rgba(0,0,0,.3); border: 2px solid var(--c-gold); }
.lp-btn--tel:hover { transform: translateY(-3px); box-shadow: 0 18px 42px rgba(0,0,0,.45); }
.lp-btn--tel .lp-btn__icon { background: var(--c-green-dark); color: var(--c-gold); box-shadow: inset 0 0 0 4px rgba(201,161,58,.3); }
.lp-btn--tel .lp-btn__num { color: var(--c-green-dark); }
/* メール：金グラデ＋脈動 */
.lp-btn--mail { background: linear-gradient(135deg, var(--c-gold) 0%, #b0871f 100%); color: #1c1300; box-shadow: 0 12px 30px rgba(201,161,58,.5); border: 2px solid rgba(255,255,255,.35); animation: lp-pulse 2.2s ease-in-out infinite; }
.lp-btn--mail::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.5) 50%, transparent 70%); transform: translateX(-120%); animation: lp-shine 3.2s ease-in-out infinite; }
.lp-btn--mail:hover { transform: translateY(-3px); box-shadow: 0 18px 46px rgba(201,161,58,.65); }
.lp-btn--mail:hover .lp-btn__arrow { transform: translateX(6px); }
.lp-btn--mail .lp-btn__icon { background: #1c1300; color: var(--c-gold-soft); }
@keyframes lp-pulse { 0%,100%{ box-shadow: 0 12px 30px rgba(201,161,58,.5);} 50%{ box-shadow: 0 12px 44px rgba(201,161,58,.85);} }
@keyframes lp-shine { 0%,60%{ transform: translateX(-120%);} 100%{ transform: translateX(120%);} }
.lp-btn--sm { padding: 14px 20px; }
.lp-btn--sm .lp-btn__icon { width: 46px; height: 46px; }

/* ===== セクション共通 ===== */
.lp-sec { padding: clamp(56px,8vw,96px) 0; background: #fafbf9; color: var(--c-text); }
.lp-sec--alt { background: #eef3ee; }
.lp-h2 { font-family: var(--ff-display); font-size: clamp(26px,4.2vw,44px); font-weight: 900; line-height: 1.35; text-align: center; color: var(--c-green-dark); margin-bottom: 40px; }
.lp-h2 em { font-style: normal; color: var(--c-gold); background: linear-gradient(180deg, transparent 62%, rgba(201,161,58,.25) 62%); padding: 0 4px; }
.lp-h2--light { color: #fff; }
.lp-sec--solution { background: linear-gradient(135deg, #0e3d27, #1d5d3a); color: #fff; text-align: center; }
.lp-lead-light { font-size: clamp(var(--fs-15),1.6vw,var(--fs-18)); line-height: 2.1; max-width: 800px; margin: 0 auto; color: rgba(255,255,255,.95); }
.lp-lead-light strong { color: var(--c-gold-soft); }

/* ===== 不安 ===== */
.lp-sec--worry { background: #fbf3f1; }
.lp-worry-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 14px; max-width: 920px; margin: 0 auto; }
.lp-worry { display: flex; align-items: center; gap: 14px; padding: 18px 22px; background: #fff; border: 1px solid #f0d2cc; border-radius: var(--r-12); font-size: var(--fs-15); line-height: 1.6; box-shadow: var(--sh-sm); }
.lp-worry__x { flex-shrink: 0; width: 30px; height: 30px; border-radius: 50%; background: var(--c-niou-red); color: #fff; display: grid; place-items: center; font-weight: 800; font-family: var(--ff-display); }
.lp-worry strong { color: var(--c-niou-red); }
.lp-worry-catch { text-align: center; margin-top: 32px; font-family: var(--ff-display); font-size: clamp(20px,3vw,30px); font-weight: 700; color: var(--c-green-dark); }
.lp-worry-catch strong { color: var(--c-gold); }

/* ===== HERO直下の注記 ===== */
.lp-hero-note { background: linear-gradient(180deg, #07150d, #0e3d27); padding: 18px 0; }
.lp-hero-note p { text-align: center; font-size: var(--fs-14); color: var(--c-gold-soft); margin: 0; }
.lp-hero-note strong { color: #ffe7a0; }

/* ===== セクション共通リード ===== */
.lp-sec-lead { text-align: center; max-width: 720px; margin: -20px auto 36px; font-size: var(--fs-15); line-height: 1.9; color: var(--c-text-mute); }

/* ===== 経歴 ===== */
.lp-timeline { max-width: 760px; margin: 44px auto 0; padding: 28px 30px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); box-shadow: var(--sh-sm); }
.lp-timeline__title { display: flex; align-items: center; gap: 10px; font-size: var(--fs-17); color: var(--c-green-dark); font-weight: 700; margin-bottom: 16px; }
.lp-timeline__title svg { color: var(--c-gold); }

/* ===== 調査で見られるポイント ===== */
.lp-points { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; max-width: 900px; margin: 0 auto; }
@media (max-width: 680px) { .lp-points { grid-template-columns: 1fr; } }
.lp-point-item { display: flex; gap: 12px; align-items: flex-start; padding: 20px 22px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); box-shadow: var(--sh-sm); transition: transform .15s, border-color .15s; }
.lp-point-item:hover { transform: translateY(-3px); border-color: var(--c-emerald); }
.lp-point-item svg { flex-shrink: 0; color: var(--c-emerald); margin-top: 4px; }
.lp-point-item h3 { font-size: var(--fs-16); color: var(--c-green-dark); font-weight: 700; margin-bottom: 6px; }
.lp-point-item p { font-size: var(--fs-13); line-height: 1.8; color: var(--c-text-mute); }

/* ===== 対応する税理士（代表者）===== */
.lp-rep { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(28px,5vw,52px); align-items: center; max-width: 960px; margin: 0 auto; }
@media (max-width: 768px) { .lp-rep { grid-template-columns: 1fr; } }
.lp-rep__photo { border-radius: var(--r-24); overflow: hidden; box-shadow: var(--sh-lg); aspect-ratio: 4/5; }
.lp-rep__photo picture, .lp-rep__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.lp-rep__role { font-size: var(--fs-13); color: var(--c-gold); font-weight: 700; letter-spacing: .1em; }
.lp-rep__name { font-family: var(--ff-display); font-size: clamp(26px,3.4vw,38px); font-weight: 900; color: var(--c-green-dark); margin: 6px 0 18px; }
.lp-rep__name span { display: block; font-size: var(--fs-13); color: var(--c-text-mute); font-weight: 500; margin-top: 6px; }
.lp-rep__text { font-size: var(--fs-15); line-height: 2; color: var(--c-text); margin-bottom: 14px; }
.lp-rep__text strong { color: var(--c-green-dark); }
.lp-rep__creds { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.lp-rep__creds span { padding: 6px 13px; background: var(--c-bg-soft); border: 1px solid var(--c-sage); border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 600; color: var(--c-green-dark); white-space: nowrap; }

/* ===== 強み（数字・背景画像対応）===== */
.lp-sec--strength { position: relative; background: #07150d; background-size: cover; background-position: center; color: #fff; }
.lp-sec__overlay { position: absolute; inset: 0; background: rgba(7,21,13,.8); pointer-events: none; }
.lp-sec--strength .lp-wrap { position: relative; z-index: 1; }
.lp-sec--strength .lp-h2 { color: #fff; }
.lp-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; max-width: 820px; margin: 0 auto 36px; }
@media (max-width: 600px) { .lp-stats { grid-template-columns: 1fr; } }
.lp-stat { text-align: center; padding: 28px 18px; background: rgba(255,255,255,.06); border: 1.5px solid rgba(201,161,58,.4); border-radius: var(--r-16); }
.lp-stat__num { display: block; font-family: var(--ff-display); font-size: clamp(40px,6vw,60px); font-weight: 900; color: var(--c-gold-soft); line-height: 1; }
.lp-stat__num small { font-size: var(--fs-18); margin-left: 2px; }
.lp-stat__label { display: block; margin-top: 8px; font-size: var(--fs-13); color: rgba(255,255,255,.85); }
.lp-careers { display: grid; gap: 16px; max-width: 820px; margin: 0 auto; }
.lp-career { display: flex; gap: 18px; align-items: flex-start; padding: 24px 26px; background: rgba(255,255,255,.05); border-radius: var(--r-16); border-left: 4px solid var(--c-gold); }
.lp-career__tag { flex-shrink: 0; padding: 6px 14px; background: var(--c-gold); color: #1c1300; border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 800; }
.lp-career h3 { font-size: var(--fs-18); color: #fff; margin-bottom: 8px; font-weight: 700; }
.lp-career p { font-size: var(--fs-14); line-height: 1.85; color: rgba(255,255,255,.8); }

/* ===== 中間CTAバンド ===== */
.lp-cta-band { padding: clamp(36px,5vw,56px) 0; background: linear-gradient(135deg, var(--c-gold) 0%, #b0871f 100%); text-align: center; }
.lp-cta-band__text { font-family: var(--ff-display); font-size: clamp(20px,3.2vw,32px); font-weight: 800; color: #1c1300; margin-bottom: 22px; }
.lp-cta-band__text em { font-style: normal; color: var(--c-green-dark); }
.lp-cta-band__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.lp-cta-band .lp-btn--mail { background: var(--c-green-dark); color: #fff; animation: none; border-color: rgba(255,255,255,.3); }
.lp-cta-band .lp-btn--mail .lp-btn__icon { background: #fff; color: var(--c-green-dark); }

/* ===== こんなケースに対応 ===== */
.lp-cases { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
@media (max-width: 820px) { .lp-cases { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .lp-cases { grid-template-columns: 1fr; } }
.lp-case { padding: 26px 24px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s, border-color .2s; }
.lp-case:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--c-emerald); }
.lp-case__icon { width: 56px; height: 56px; border-radius: var(--r-12); background: linear-gradient(135deg, var(--c-emerald), var(--c-green-dark)); color: #fff; display: grid; place-items: center; margin-bottom: 14px; }
.lp-case h3 { font-size: var(--fs-17); color: var(--c-green-dark); font-weight: 700; margin-bottom: 10px; }
.lp-case p { font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* ===== 基礎知識 prose ===== */
.lp-prose { max-width: 800px; margin: 0 auto; }
.lp-prose h3 { font-size: var(--fs-19); color: var(--c-green-dark); font-weight: 700; margin: 28px 0 12px; padding-left: 16px; border-left: 5px solid var(--c-gold); }
.lp-prose h3:first-child { margin-top: 0; }
.lp-prose p { font-size: var(--fs-15); line-height: 2; color: var(--c-text); margin-bottom: 12px; }
.lp-prose strong { color: var(--c-green-dark); }

/* ===== 基礎知識（派手カード）===== */
.lp-know { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
@media (max-width: 820px) { .lp-know { grid-template-columns: 1fr; max-width: 560px; margin-inline: auto; } }
.lp-know__card { background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); padding: 28px 26px; box-shadow: var(--sh-sm); border-top: 5px solid var(--c-gold); transition: transform .2s, box-shadow .2s; }
.lp-know__card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); }
.lp-know__head { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.lp-know__q { flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: var(--c-gold-soft); display: grid; place-items: center; font-family: var(--ff-display); font-size: var(--fs-22); font-weight: 900; }
.lp-know__head h3 { font-size: var(--fs-18); color: var(--c-green-dark); font-weight: 700; line-height: 1.4; }
.lp-know__card p { font-size: var(--fs-14); line-height: 1.9; color: var(--c-text-mute); }
.lp-know__card strong { color: var(--c-green-dark); }
.lp-know__danger { color: var(--c-niou-red) !important; }
.lp-know__years { display: flex; align-items: center; justify-content: center; gap: 8px; margin-bottom: 16px; }
.lp-know__year { display: flex; flex-direction: column; align-items: center; width: 64px; height: 64px; justify-content: center; border-radius: 12px; background: var(--c-bg-soft); border: 1.5px solid var(--c-sage); }
.lp-know__year b { font-family: var(--ff-display); font-size: 28px; color: var(--c-green-dark); line-height: 1; }
.lp-know__year small { font-size: 10px; color: var(--c-text-mute); margin-top: 4px; }
.lp-know__year--max { background: linear-gradient(135deg, var(--c-niou-red), #8a2b22); border-color: var(--c-niou-red); }
.lp-know__year--max b, .lp-know__year--max small { color: #fff; }
.lp-know__arrow { color: var(--c-gold); font-size: 12px; }

/* ===== 料金（派手）===== */
.lp-sec--price { position: relative; background: #07150d; background-size: cover; background-position: center; color: #fff; }
.lp-sec--price .lp-wrap { position: relative; z-index: 1; }
.lp-price2 { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; max-width: 880px; margin: 0 auto; }
@media (max-width: 720px) { .lp-price2 { grid-template-columns: 1fr; max-width: 420px; } }
.lp-price2__card { position: relative; background: rgba(255,255,255,.97); border-radius: var(--r-16); padding: 38px 24px 28px; text-align: center; box-shadow: 0 12px 30px rgba(0,0,0,.3); display: flex; flex-direction: column; align-items: center; }
.lp-price2__card--main { background: linear-gradient(180deg,#fff,#fbf7ea); border: 2px solid var(--c-gold); }
.lp-price2__ribbon { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); display: inline-flex; align-items: center; gap: 5px; padding: 6px 16px; background: linear-gradient(135deg,var(--c-gold),#a07d20); color: #1c1300; border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 800; white-space: nowrap; box-shadow: var(--sh-sm); }
.lp-price2__icon { width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: var(--c-gold-soft); display: grid; place-items: center; margin-bottom: 14px; }
.lp-price2__card--main .lp-price2__icon { background: linear-gradient(135deg, var(--c-gold), #a07d20); color: #fff; }
.lp-price2__label { font-size: var(--fs-13); color: var(--c-text-mute); font-weight: 600; line-height: 1.5; }
.lp-price2__label small { font-size: 11px; display: block; }
.lp-price2__val { font-family: var(--ff-display); font-size: clamp(30px,4vw,42px); font-weight: 900; color: var(--c-green-dark); line-height: 1; margin-top: 10px; }
.lp-price2__card--main .lp-price2__val { color: #a07d20; }
.lp-price2__val small { font-size: var(--fs-15); color: var(--c-text-mute); }
.lp-price2__plus { text-align: center; margin-top: 26px; font-size: var(--fs-16); color: #fff; }
.lp-price2__plus strong { color: var(--c-gold-soft); }
.lp-price2__note { text-align: center; margin-top: 10px; font-size: var(--fs-13); color: rgba(255,255,255,.8); }
.lp-price2__note strong { color: var(--c-gold-soft); }

/* ===== 料金（明細表デザイン）===== */
.lp-fee { max-width: 720px; margin: 0 auto; background: #fff; border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-md); border: 1px solid var(--c-border); }
.lp-fee__row { display: flex; align-items: center; gap: 18px; padding: 22px 28px; border-bottom: 1px solid var(--c-border); }
.lp-fee__row:last-of-type { border-bottom: 0; }
.lp-fee__row--main { background: linear-gradient(180deg,#fff,#fbf7ea); border-left: 5px solid var(--c-gold); }
.lp-fee__icon { flex-shrink: 0; width: 50px; height: 50px; border-radius: 50%; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: var(--c-gold-soft); display: grid; place-items: center; }
.lp-fee__row--main .lp-fee__icon { background: linear-gradient(135deg, var(--c-gold), #a07d20); color: #fff; }
.lp-fee__name { flex: 1; font-size: var(--fs-16); font-weight: 700; color: var(--c-green-dark); line-height: 1.4; }
.lp-fee__name small { display: block; font-size: var(--fs-12); color: var(--c-text-mute); font-weight: 500; margin-top: 3px; }
.lp-fee__price { font-family: var(--ff-display); font-size: clamp(26px,3.4vw,34px); font-weight: 900; color: var(--c-green-dark); white-space: nowrap; }
.lp-fee__row--main .lp-fee__price { color: #a07d20; }
.lp-fee__price span { font-size: var(--fs-14); color: var(--c-text-mute); font-weight: 600; }
.lp-fee__success { display: flex; align-items: center; gap: 16px; padding: 20px 28px; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: #fff; }
.lp-fee__success-plus { font-family: var(--ff-display); font-size: 28px; font-weight: 900; color: var(--c-gold-soft); }
.lp-fee__success-body { flex: 1; display: flex; flex-direction: column; }
.lp-fee__success-label { font-size: var(--fs-12); color: rgba(255,255,255,.8); letter-spacing: .08em; }
.lp-fee__success-val { font-size: var(--fs-20); font-weight: 800; color: var(--c-gold-soft); }
.lp-fee__success-note { font-size: var(--fs-12); color: rgba(255,255,255,.75); white-space: nowrap; }
.lp-fee__foot { text-align: center; margin-top: 20px; font-size: var(--fs-13); color: var(--c-text-mute); }
.lp-fee__foot strong { color: var(--c-green-dark); }
@media (max-width: 520px) {
    .lp-fee__row { gap: 12px; padding: 18px 18px; }
    .lp-fee__icon { width: 42px; height: 42px; }
    .lp-fee__success { padding: 16px 18px; gap: 10px; }
    .lp-fee__success-note { display: none; }
}

/* ===== 小さめバナー ===== */
.lp-sec--banner { padding: clamp(32px,4vw,48px) 0; }
.promo-banner--sm { max-width: 600px; }

/* ===== 最終CTA背景画像対応 ===== */
.lp-final { background-size: cover; background-position: center; }

/* ===== 比較表 ===== */
.lp-compare { max-width: 760px; margin: 0 auto; overflow-x: auto; }
.lp-compare__table { width: 100%; min-width: 560px; border-collapse: separate; border-spacing: 0; background: #fff; border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-md); }
.lp-compare__table th, .lp-compare__table td { padding: 16px 18px; text-align: center; font-size: var(--fs-14); border-bottom: 1px solid var(--c-border); }
.lp-compare__table thead th { background: var(--c-bg-soft); color: var(--c-text-mute); font-weight: 700; }
.lp-compare__table thead th.lp-compare__us { background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: #fff; font-size: var(--fs-15); }
.lp-compare__table tbody td:first-child { text-align: left; font-weight: 700; color: var(--c-green-dark); background: var(--c-bg-soft); }
.lp-compare__table td.lp-compare__us { background: rgba(201,161,58,.08); font-weight: 700; color: var(--c-green-dark); }
.lp-compare__table td.lp-compare__us svg { color: var(--c-emerald); vertical-align: -2px; margin-right: 4px; }
.lp-compare__table tbody tr:last-child td { border-bottom: 0; }

/* ===== 選ばれる理由 ===== */
.lp-reasons { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
@media (max-width: 820px) { .lp-reasons { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; } }
.lp-reason { position: relative; padding: 40px 28px 30px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); box-shadow: var(--sh-sm); text-align: center; transition: transform .2s, box-shadow .2s; }
.lp-reason:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }
.lp-reason__no { position: absolute; top: 14px; right: 20px; font-family: var(--ff-display); font-size: 44px; color: rgba(201,161,58,.18); font-weight: 900; }
.lp-reason__icon { width: 80px; height: 80px; margin: 0 auto 18px; border-radius: 50%; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: var(--c-gold-soft); display: grid; place-items: center; }
.lp-reason h3 { font-size: var(--fs-20); color: var(--c-green-dark); font-weight: 700; margin-bottom: 12px; }
.lp-reason p { font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* ===== 流れ ===== */
.lp-flow { display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; }
@media (max-width: 900px) { .lp-flow { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 480px) { .lp-flow { grid-template-columns: 1fr; } }
.lp-flow__step { position: relative; padding: 30px 18px 22px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); text-align: center; }
.lp-flow__no { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: #fff; display: grid; place-items: center; font-family: var(--ff-display); font-weight: 800; box-shadow: var(--sh-sm); }
.lp-flow__step h3 { font-size: var(--fs-15); color: var(--c-green-dark); margin: 6px 0 8px; font-weight: 700; }
.lp-flow__step p { font-size: var(--fs-13); line-height: 1.7; color: var(--c-text-mute); }

/* ===== 料金 ===== */
.lp-price { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.lp-price__item { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 20px 26px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); }
.lp-price__item--main { border-color: var(--c-gold); background: linear-gradient(180deg, #fff, #fbf7ea); box-shadow: 0 8px 24px rgba(201,161,58,.2); }
.lp-price__label { font-size: var(--fs-14); font-weight: 600; color: var(--c-text); }
.lp-price__val { font-family: var(--ff-display); font-size: clamp(26px,3.4vw,34px); font-weight: 800; color: var(--c-green-dark); white-space: nowrap; }
.lp-price__val small { font-size: var(--fs-14); color: var(--c-text-mute); }
.lp-price__item--main .lp-price__val { color: #a07d20; }
.lp-price__note { text-align: center; margin-top: 20px; font-size: var(--fs-13); color: var(--c-text-mute); line-height: 1.8; }
.lp-price__note strong { color: var(--c-green-dark); }

/* ===== FAQ ===== */
.lp-faq { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.lp-faq__item { background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); overflow: hidden; }
.lp-faq__q { display: flex; align-items: center; gap: 16px; padding: 20px 24px; cursor: pointer; font-size: var(--fs-15); font-weight: 700; color: var(--c-green-dark); list-style: none; }
.lp-faq__q::-webkit-details-marker { display: none; }
.lp-faq__q::before { content: "Q"; flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%; background: var(--c-green-dark); color: #fff; display: grid; place-items: center; font-family: var(--ff-display); font-weight: 800; }
.lp-faq__q::after { content: "+"; margin-left: auto; font-size: 24px; color: var(--c-green); transition: transform .2s; }
.lp-faq__item[open] .lp-faq__q::after { transform: rotate(45deg); }
.lp-faq__a { padding: 0 24px 22px 72px; font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* ===== 最終CTA ===== */
.lp-final { position: relative; overflow: hidden; padding: clamp(60px,9vw,110px) 0; background: radial-gradient(ellipse at 50% 0%, #1d5d3a, #0e3d27 50%, #07150d 100%); color: #fff; text-align: center; }
.lp-final__deco { position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 30%, rgba(201,161,58,.3), transparent 50%); pointer-events: none; }
.lp-final__inner { position: relative; }
.lp-final__eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 9px 22px; margin-bottom: 22px; background: rgba(201,161,58,.14); border: 1.5px solid var(--c-gold); border-radius: var(--r-full); font-size: var(--fs-13); letter-spacing: .14em; color: var(--c-gold-soft); font-weight: 600; }
.lp-final__eyebrow svg { color: var(--c-gold); }
.lp-final__h2 { font-family: var(--ff-display); font-size: clamp(26px,4.5vw,46px); font-weight: 900; line-height: 1.4; margin-bottom: 18px; text-shadow: 0 4px 24px rgba(0,0,0,.4); }
.lp-final__h2 em { font-style: normal; color: var(--c-gold-soft); }
.lp-final__sub { font-size: clamp(var(--fs-15),1.5vw,var(--fs-17)); line-height: 1.95; color: rgba(255,255,255,.92); margin-bottom: 36px; }

/* ===== LPフッター ===== */
.lp-footer { background: #050f08; color: rgba(255,255,255,.6); padding: 40px 0 96px; text-align: center; }
.lp-footer__inner { width: min(100%, 1080px); margin-inline: auto; padding-inline: clamp(16px,4vw,32px); }
.lp-footer__name { font-size: var(--fs-16); font-weight: 700; color: #fff; margin-bottom: 10px; }
.lp-footer__info { font-size: var(--fs-12); line-height: 1.8; margin-bottom: 14px; }
.lp-footer__links { font-size: var(--fs-12); margin-bottom: 14px; }
.lp-footer__links a { color: var(--c-gold-soft); }
.lp-footer__links a:hover { color: var(--c-gold); text-decoration: underline; }
.lp-footer__copy { font-size: var(--fs-11); color: rgba(255,255,255,.4); }

/* ===== 追従CTAバー ===== */
.lp-sticky { position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(201,161,58,.4); box-shadow: 0 -6px 20px rgba(0,0,0,.3); }
.lp-sticky a { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 8px; font-weight: 700; }
.lp-sticky__tel { background: #fff; color: var(--c-green-dark); }
.lp-sticky__tel svg { color: var(--c-green); }
.lp-sticky__label { display: block; font-size: 10px; opacity: .8; }
.lp-sticky__num { display: block; font-family: var(--ff-en); font-size: var(--fs-16); font-weight: 800; }
.lp-sticky__mail { background: linear-gradient(135deg, var(--c-gold), #b0871f); color: #1c1300; font-size: var(--fs-15); }
@media (min-width: 920px) { .lp-sticky { display: none; } } /* PCは追従バー不要（上部CTA常時見えるため） */
