/* ===========================================================
   No.10 AI×完全成果報酬｜業務改善支援 LP
   テーマカラー：ディープネイビー × オレンジ（CV最適化・統一パレット）
   （AIのテック感×成果（成長）の象徴）
   =========================================================== */

/* ===== Variables ===== */
:root{
  --primary:#1A3A6E;
  --primary-dark:#102449;
  --primary-light:#2C5DA5;
  --accent:#FF7849;
  --accent-dark:#E85F2C;
  --accent-soft:#FFD9C4;
  --text:#1B2330;
  --text-soft:#4A5468;
  --muted:#8A93A6;
  --line:#E2E6EF;
  --bg:#FFFFFF;
  --bg-soft:#F4F7FB;
  --bg-deep:#0E1F3D;
  --success:#22C55E;
  --warn:#F59E0B;
  --danger:#D14F4F;
  --radius:12px;
  --radius-lg:20px;
  --shadow:0 6px 24px rgba(20,40,80,.08);
  --shadow-lg:0 18px 48px rgba(20,40,80,.14);
  --container:1140px;
}

/* ===== Reset / Base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  font-weight:500;color:var(--text);line-height:1.85;background:var(--bg);
  -webkit-font-smoothing:antialiased;font-feature-settings:"palt";
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.en{font-family:"Inter",sans-serif;letter-spacing:.04em;font-weight:700}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:900;letter-spacing:.04em;border-radius:999px;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  white-space:nowrap;text-align:center;
}
.btn-cta{background:var(--accent);color:#fff;padding:12px 24px;font-size:14px;box-shadow:0 6px 16px rgba(255,120,73,.40)}
.btn-cta:hover{background:var(--accent-dark);color:#fff;transform:translateY(-2px);box-shadow:0 10px 22px rgba(255,120,73,.50)}
.btn-lg{padding:18px 32px;font-size:16px}
.btn-xl{padding:22px 40px;font-size:17px;line-height:1.4;flex-wrap:wrap}
.btn-xl small{display:block;width:100%;font-size:12px;font-weight:700;opacity:.95;margin-top:4px;letter-spacing:.04em}
.btn-ghost{background:#fff;color:var(--primary);border:2px solid var(--primary);padding:14px 28px;font-size:14px}
.btn-ghost:hover{background:var(--primary);color:#fff}
.btn-block{width:100%}
.btn-cta{position:relative}
.btn-cta::after{
  content:"";position:absolute;inset:0;border-radius:inherit;border:2px solid var(--accent);
  opacity:0;animation:ctaPulse 2.6s ease-out infinite;
}
.btn-cta.btn-xl::after{animation-duration:2.2s}
@keyframes ctaPulse{0%{opacity:.55;transform:scale(1)}80%{opacity:0;transform:scale(1.18)}100%{opacity:0;transform:scale(1.18)}}
.header-actions .btn-cta::after,.float-cta .btn-cta::after,.urgency-banner .btn-cta::after{display:none}

/* ===== Scroll progress bar ===== */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:200;
  background:linear-gradient(90deg,var(--accent) 0%,var(--accent-dark) 100%);
  box-shadow:0 0 10px rgba(255,120,73,.6);transition:width .1s ease-out;
}

/* ===== Reveal-on-scroll ===== */
html.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
html.js .reveal.in{opacity:1;transform:translateY(0)}
html.js .reveal-d1{transition-delay:.10s}
html.js .reveal-d2{transition-delay:.20s}
html.js .reveal-d3{transition-delay:.30s}
@media (prefers-reduced-motion: reduce){html.js .reveal{opacity:1;transform:none;transition:none}}

/* ===== Urgency Banner ===== */
.urgency-banner{
  background:linear-gradient(90deg,var(--accent-dark) 0%,var(--accent) 100%);color:#fff;
  padding:10px 0;font-size:14px;font-weight:700;line-height:1.5;
  position:relative;z-index:1;
}
.urgency-inner{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;text-align:center}
.urgency-pill{background:rgba(0,0,0,.20);color:#fff;padding:3px 12px;border-radius:999px;font-size:12px;font-weight:900;letter-spacing:.06em}
.urgency-banner strong{font-weight:900}
.urgency-banner .num{font-family:"Inter",sans-serif;font-weight:900;font-size:18px;color:var(--accent-soft);margin:0 2px}
@media(max-width:780px){
  .urgency-banner{font-size:12.5px;padding:8px 0}
  .urgency-banner .num{font-size:16px}
}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);
  backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);
}
.urgency-banner + .site-header{top:0}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:36px;width:auto}
.header-tagline{
  display:inline-flex;align-items:center;gap:10px;margin-left:18px;padding-left:18px;
  border-left:1px solid var(--line);font-size:13.5px;font-weight:700;color:var(--primary);
  letter-spacing:.02em;line-height:1.4;
}
.header-actions{display:flex;align-items:center;gap:16px;margin-left:auto}
.header-tel{display:flex;align-items:center;gap:8px;font-weight:900;color:var(--primary);font-size:14px}
.header-tel .num{font-family:"Inter",sans-serif;font-size:19px;letter-spacing:.02em;font-weight:900}
@media(max-width:980px){.header-tagline{display:none}}
@media(max-width:780px){
  .header-tel{display:none}
  .header-inner{height:64px}
  .logo img{height:28px}
  .btn-cta{padding:10px 16px;font-size:12px}
  .urgency-banner + .site-header{top:0}
}

/* ===== Hero (Light Tinted, Layered) ===== */
.hero{
  position:relative;color:var(--text);padding:80px 0 96px;overflow:hidden;
  background:
    /* large orange blob (top right) */
    radial-gradient(900px 520px at 100% -10%,rgba(255,120,73,.30),transparent 55%),
    /* navy blob (bottom left) */
    radial-gradient(820px 620px at -10% 110%,rgba(26,58,110,.24),transparent 55%),
    /* small orange spot middle-right */
    radial-gradient(360px 320px at 78% 50%,rgba(255,120,73,.16),transparent 70%),
    /* tinted base (pale navy-blue) */
    linear-gradient(180deg,#EAF0F8 0%,#D7E1EE 100%);
  border-bottom:1px solid var(--line);
}
/* Top accent strip — navy to orange gradient */
.hero::after{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--primary) 0%,var(--primary-light) 50%,var(--accent) 100%);
  z-index:2;
}
/* Soft dot pattern overlay */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(26,58,110,.08) 1.2px,transparent 1.2px);
  background-size:22px 22px;
  mask-image:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent);
  opacity:.7;
}
.hero-deco{position:absolute;pointer-events:none}
.hero-deco-1{top:12%;right:40%;width:84px;height:84px;border:2px dashed rgba(255,120,73,.50);border-radius:50%;opacity:.7;animation:floatA 9s ease-in-out infinite}
.hero-deco-2{bottom:14%;right:6%;width:160px;height:160px;border:2px solid rgba(26,58,110,.18);border-radius:32% 68% 70% 30% / 30% 30% 70% 70%;opacity:.6;animation:floatB 11s ease-in-out infinite}
.hero-deco-3{top:62%;left:5%;width:32px;height:32px;background:var(--accent);border-radius:50%;opacity:.30;filter:blur(2px);animation:floatA 7s ease-in-out infinite reverse}
.hero-deco-4{top:22%;left:40%;width:12px;height:12px;background:var(--primary);border-radius:50%;opacity:.35;animation:floatB 6s ease-in-out infinite}
@keyframes floatA{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-22px) rotate(40deg)}}
@keyframes floatB{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(18px) rotate(-30deg)}}

.hero-inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(180deg,#fff 0%,#F4F7FB 100%);
  border:1px solid rgba(26,58,110,.20);color:var(--primary);font-size:13.5px;font-weight:900;
  padding:7px 18px 7px 14px;border-radius:999px;margin-bottom:24px;
  box-shadow:0 4px 14px rgba(20,40,80,.08),0 1px 0 #fff inset;
  letter-spacing:.02em;
}
.hero-eyebrow::before{
  content:"";width:8px;height:8px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 0 4px rgba(255,120,73,.18);
}
.hero h1{font-size:36px;font-weight:900;line-height:1.55;letter-spacing:0;margin-bottom:22px;color:var(--primary)}
.hero h1 .accent{
  background:linear-gradient(120deg,var(--primary-light) 0%,var(--primary) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:900;
}
.hero h1 .underline{
  background-image:linear-gradient(transparent 70%,rgba(255,120,73,.30) 70%);
  background-repeat:no-repeat;
}
.hero h1 .num{
  font-family:"Inter",sans-serif;font-weight:900;font-size:1.04em;color:var(--accent);
}
/* Strong emphasis on a single key digit (e.g. "0" in "請求0円") */
.hero h1 .num.emph{
  font-size:1.55em;letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  filter:drop-shadow(0 6px 18px rgba(255,120,73,.45));
  margin:0 4px;
  animation:numEmphPulse 2.2s ease-in-out infinite;
}
@keyframes numEmphPulse{
  0%,100%{filter:drop-shadow(0 6px 18px rgba(255,120,73,.40))}
  50%{filter:drop-shadow(0 8px 26px rgba(255,120,73,.65))}
}
/* Keep a phrase on one line at PC width */
.hero h1 .nobr{display:inline-block;white-space:nowrap}
@media(max-width:780px){.hero h1 .nobr{display:inline;white-space:normal}}
.hero-sub{font-size:16px;line-height:1.95;color:var(--text-soft);margin-bottom:28px;font-weight:500}
.hero-sub strong{color:var(--primary);font-weight:900}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:22px}
.hero-cta .btn-cta{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  box-shadow:0 14px 30px rgba(255,120,73,.36),0 4px 10px rgba(255,120,73,.20),0 1px 0 rgba(255,255,255,.30) inset;
}
.hero-cta .btn-cta:hover{
  background:linear-gradient(135deg,var(--accent-dark) 0%,var(--accent) 100%);
  box-shadow:0 20px 40px rgba(255,120,73,.48),0 6px 14px rgba(255,120,73,.26);
}
.hero-cta .btn-ghost{background:#fff;color:var(--primary);border-color:rgba(26,58,110,.30)}
.hero-cta .btn-ghost:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.hero-microtrust{font-size:13px;color:var(--muted);margin-bottom:28px;line-height:1.7}
.hero-microtrust span{color:var(--accent);font-weight:900}
.hero-trust{display:flex;flex-wrap:wrap;gap:24px;color:var(--text-soft);font-size:14px;font-weight:700}
.hero-trust span{display:flex;align-items:center;gap:6px}
.hero-trust span::before{content:"✓";color:var(--accent);font-weight:900}

.hero h1, .hero-sub, .hero-cta, .hero-trust, .hero-eyebrow, .hero-microtrust{animation:heroIn .9s cubic-bezier(.2,.7,.2,1) both}
.hero-eyebrow{animation-delay:.05s}
.hero h1{animation-delay:.15s}
.hero-sub{animation-delay:.30s}
.hero-cta{animation-delay:.45s}
.hero-microtrust{animation-delay:.50s}
.hero-trust{animation-delay:.60s}
@keyframes heroIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ===== Hero Scorecard (Light, Floating on navy stage) ===== */
.hero-visual{position:relative}
.hero-visual::before{
  content:"";position:absolute;z-index:0;
  top:-22px;right:-28px;width:88%;height:96%;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 70%,rgba(255,120,73,.45) 110%);
  border-radius:38% 62% 58% 42% / 50% 36% 64% 50%;
  opacity:.18;filter:blur(28px);
  animation:floatStage 14s ease-in-out infinite;
}
@keyframes floatStage{
  0%,100%{transform:translate(0,0) rotate(0deg)}
  50%{transform:translate(-8px,10px) rotate(6deg)}
}
.hero-scorecard{
  position:relative;z-index:1;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:
    0 28px 64px rgba(16,36,73,.18),
    0 8px 20px rgba(16,36,73,.10),
    0 1px 0 rgba(255,255,255,.9) inset;
  overflow:hidden;
}
.hero-scorecard::before{
  content:"";position:absolute;inset:-1px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,rgba(255,120,73,.55),transparent 45%,rgba(26,58,110,.30));
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  -webkit-mask-composite:xor;mask-composite:exclude;padding:1.5px;pointer-events:none;
}
.scorecard-head{
  position:relative;padding:16px 26px 16px 30px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:10px;
  background:linear-gradient(180deg,#fff 0%,#F4F7FB 100%);
}
.scorecard-head::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--accent) 0%,var(--accent-dark) 100%);
}
.scorecard-head::before{
  content:"";width:8px;height:8px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 12px rgba(255,120,73,.55);animation:dotPulse 2s ease-in-out infinite;
}
@keyframes dotPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}
.scorecard-title{font-size:13px;font-weight:900;color:var(--primary);letter-spacing:.10em}
.scorecard-body{padding:8px 26px}
.big-stat{
  padding:22px 0;border-bottom:1px dashed var(--line);
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;
}
.big-stat:last-of-type{border-bottom:none}
.big-stat-label{font-size:13.5px;font-weight:700;color:var(--text-soft);line-height:1.6}
.big-stat-label strong{color:var(--primary);font-weight:900;display:block;font-size:15.5px;margin-bottom:4px}
.big-stat-num{
  font-family:"Inter",sans-serif;font-weight:900;line-height:.95;
  display:flex;align-items:flex-start;justify-content:flex-end;letter-spacing:-.02em;
  color:var(--accent);text-align:right;
}
.big-stat-num .pre,.big-stat-num .v{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 12px rgba(255,120,73,.20));
}
.big-stat-num .pre{font-size:46px;font-weight:900;margin-right:2px;line-height:1}
.big-stat-num .v{font-size:74px;line-height:1}
.big-stat-num .u{font-size:30px;margin-left:4px;line-height:1.2;color:var(--accent-dark)}
.big-stat-num .v.small{font-size:60px}
.big-stat-num .v.tight{font-size:44px;letter-spacing:-.01em;white-space:nowrap}
.big-stat.cool .big-stat-num{color:var(--primary)}
.big-stat.cool .big-stat-num .pre,.big-stat.cool .big-stat-num .v{
  background:linear-gradient(135deg,var(--primary-light) 0%,var(--primary) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 12px rgba(26,58,110,.20));
}
.big-stat.cool .big-stat-num .u{color:var(--text-soft)}
.scorecard-foot{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:#FAFBFD;border-top:1px solid var(--line);
}
.foot-stat{padding:14px 8px;text-align:center;border-right:1px solid var(--line)}
.foot-stat:last-child{border-right:none}
.foot-stat .l{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.04em;display:block;margin-bottom:4px}
.foot-stat .v{font-family:"Inter",sans-serif;font-weight:900;color:var(--primary);font-size:18px;line-height:1.1}
.foot-stat .v .u{font-size:11px;color:var(--accent-dark);margin-left:2px}

@media(max-width:900px){
  .hero{padding:60px 0 70px}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero h1{font-size:26px}
  .hero-sub{font-size:15px}
  .scorecard-body{padding:0 18px}
  .big-stat{grid-template-columns:1fr;gap:6px;padding:18px 0}
  .big-stat-num{justify-content:flex-start}
  .big-stat-num .v{font-size:64px}
  .big-stat-num .v.small{font-size:54px}
  .big-stat-num .v.tight{font-size:42px}
  .big-stat-num .pre{font-size:40px}
  .scorecard-foot{grid-template-columns:repeat(2,1fr)}
  .foot-stat{border-right:none;border-bottom:1px solid var(--line)}
}

/* ===== Section base ===== */
section{padding:88px 0}
.section-head{text-align:center;margin-bottom:48px;position:relative}
.section-eyebrow{
  display:inline-block;font-size:13px;font-weight:900;color:var(--accent-dark);
  letter-spacing:.18em;margin-bottom:14px;
}
.section-title{font-size:36px;font-weight:900;line-height:1.45;color:var(--primary);letter-spacing:.01em;position:relative;padding-bottom:18px}
.section-title .br{display:block}
.section-title::after{
  content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%) scaleX(1);
  width:60px;height:3px;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);
  transform-origin:center;transition:transform .9s cubic-bezier(.2,.7,.2,1) .25s;
}
html.js .section-head .section-title::after{transform:translateX(-50%) scaleX(0)}
html.js .section-head.in .section-title::after{transform:translateX(-50%) scaleX(1)}
.section-lead{font-size:16.5px;color:var(--text-soft);margin-top:22px;max-width:780px;margin-left:auto;margin-right:auto;line-height:1.95}
@media(max-width:780px){
  section{padding:64px 0}
  .section-title{font-size:25px}
}

/* ===== Pain ===== */
.pain{background:var(--bg-soft);position:relative}
.pain::before{
  content:"";position:absolute;left:50%;top:-1px;transform:translateX(-50%);
  width:0;height:0;border-left:24px solid transparent;border-right:24px solid transparent;border-top:18px solid #fff;
}
.pain-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.pain-item{
  background:#fff;border-radius:var(--radius);padding:24px 28px;display:flex;align-items:center;gap:20px;
  box-shadow:var(--shadow);position:relative;border-left:4px solid var(--accent);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.pain-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-left-color:var(--accent-dark)}
.pain-item-icon{
  flex:0 0 56px;width:56px;height:56px;border-radius:50%;background:#FFEDE3;color:var(--accent-dark);
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;
  transition:transform .3s ease;
}
.pain-item:hover .pain-item-icon{transform:scale(1.08) rotate(-6deg)}
.pain-item p{font-weight:700;font-size:16px;line-height:1.75;color:var(--text)}
.pain-item p strong{background:linear-gradient(transparent 65%,var(--accent-soft) 65%);font-weight:900}
@media(max-width:780px){.pain-grid{grid-template-columns:1fr}}

/* ===== Mid CTA blocks ===== */
.mid-cta{
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-light) 100%);
  color:#fff;border-radius:var(--radius-lg);padding:40px 48px;
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,360px);gap:28px;align-items:center;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.mid-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(255,120,73,.28),transparent 40%),
             radial-gradient(circle at 90% 30%,rgba(255,120,73,.22),transparent 35%);
}
.mid-cta-text{position:relative}
.mid-cta-text .lead{font-size:13px;font-weight:900;color:var(--accent);letter-spacing:.16em;margin-bottom:8px;text-transform:uppercase}
.mid-cta-text h3{font-size:24px;font-weight:900;line-height:1.5;margin-bottom:8px}
.mid-cta-text h3 strong{color:var(--accent-soft);font-weight:900}
.mid-cta-text p{font-size:14.5px;color:#D6DEEC;line-height:1.85}
.mid-cta-action{position:relative;display:flex;flex-direction:column;align-items:stretch;gap:10px;min-width:0}
.mid-cta-action .btn{box-shadow:0 12px 28px rgba(255,120,73,.50);width:100%;white-space:normal;padding:20px 24px}
.mid-cta-action small{font-size:12px;color:var(--accent-soft);font-weight:700;text-align:right}
.mid-cta-section{padding:40px 0;background:#fff}
.mid-cta-section.alt{background:var(--bg-soft)}
@media(max-width:780px){
  .mid-cta{grid-template-columns:1fr;padding:28px 24px;gap:18px}
  .mid-cta-action{align-items:stretch}
  .mid-cta-action .btn{width:100%}
  .mid-cta-text h3{font-size:19px}
}

/* ===== Market context ===== */
.market{background:#fff;position:relative}
.market-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:36px}
.market-card{
  background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;
  position:relative;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.market-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.market-card-num{
  font-family:"Inter",sans-serif;font-weight:900;font-size:11px;color:var(--accent-dark);
  letter-spacing:.18em;margin-bottom:14px;display:block;
}
.market-card-stat{
  font-family:"Inter",sans-serif;font-weight:900;color:var(--primary);
  display:flex;align-items:baseline;gap:4px;margin-bottom:14px;line-height:1;
}
.market-card-stat .v{font-size:54px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.market-card-stat .u{font-size:20px;font-weight:900;color:var(--accent-dark)}
.market-card-title{font-size:17px;font-weight:900;color:var(--primary);margin-bottom:10px;line-height:1.55}
.market-card-desc{font-size:14.5px;color:var(--text-soft);line-height:1.85}
.market-conclusion{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;
  border-radius:var(--radius-lg);padding:28px 32px;display:flex;align-items:center;gap:18px;
  box-shadow:var(--shadow-lg);
}
.market-conclusion-icon{
  flex:0 0 56px;width:56px;height:56px;border-radius:14px;background:rgba(255,120,73,.30);
  display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:28px;font-weight:900;
}
.market-conclusion-text{font-size:15.5px;font-weight:700;line-height:1.85}
.market-conclusion-text strong{color:var(--accent-soft);font-weight:900}
@media(max-width:900px){
  .market-grid{grid-template-columns:1fr;gap:18px}
  .market-conclusion{flex-direction:column;text-align:center;align-items:flex-start}
}

/* ===== Solution ===== */
.solution{background:#fff}
.solution-flow{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:stretch;max-width:980px;margin:0 auto}
.flow-card{padding:36px 28px;border-radius:var(--radius-lg);text-align:center}
.flow-card.before{background:var(--bg-soft);border:1px solid var(--line)}
.flow-card.after{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff}
.flow-label{font-size:12px;font-weight:900;letter-spacing:.16em;margin-bottom:14px;display:block}
.flow-card.before .flow-label{color:var(--muted)}
.flow-card.after .flow-label{color:var(--accent-soft)}
.flow-card h3{font-size:22px;font-weight:900;margin-bottom:14px;line-height:1.55}
.flow-card.before h3{color:var(--text)}
.flow-card ul{text-align:left;font-size:15px;line-height:1.95}
.flow-card li{padding-left:22px;position:relative;margin-bottom:8px;font-weight:600}
.flow-card.before li::before{content:"×";color:var(--danger);font-weight:900;position:absolute;left:0;top:0}
.flow-card.after li{color:#D6DEEC}
.flow-card.after li::before{content:"○";color:var(--accent);font-weight:900;position:absolute;left:0;top:0}
.flow-card-icon{
  width:64px;height:64px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
}
.flow-card.before .flow-card-icon{background:#FFE4E4;color:var(--danger)}
.flow-card.after .flow-card-icon{background:rgba(255,120,73,.20);color:var(--accent);border:1px solid rgba(255,120,73,.45)}
.flow-card-icon svg{width:32px;height:32px}
.flow-arrow{display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--accent);font-weight:900}
@media(max-width:780px){
  .solution-flow{grid-template-columns:1fr;gap:18px}
  .flow-arrow{transform:rotate(90deg)}
}

/* ===== Features ===== */
.features{background:var(--bg-soft)}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{background:#fff;border-radius:var(--radius-lg);padding:36px 28px;box-shadow:var(--shadow);position:relative;transition:transform .25s ease,box-shadow .25s ease}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.feature-num{
  font-family:"Inter",sans-serif;font-weight:900;font-size:14px;color:var(--accent-dark);
  letter-spacing:.16em;margin-bottom:16px;display:flex;align-items:center;gap:10px;
}
.feature-num::before{content:"";width:24px;height:2px;background:var(--accent)}
.feature h3{font-size:22px;font-weight:900;color:var(--primary);line-height:1.55;margin-bottom:16px;min-height:68px}
.feature p{font-size:15.5px;line-height:1.95;color:var(--text-soft)}
.feature-icon{
  width:80px;height:80px;border-radius:18px;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;
  margin-bottom:24px;box-shadow:0 8px 20px rgba(26,58,110,.30);
  position:relative;overflow:hidden;
}
.feature-icon::before{
  content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,120,73,.40),transparent 60%);
  opacity:0;transition:opacity .4s ease;
}
.feature:hover .feature-icon::before{opacity:1}
.feature-icon svg{width:42px;height:42px;position:relative;z-index:1;transition:transform .35s ease}
.feature:hover .feature-icon svg{transform:scale(1.1) rotate(-4deg)}
@media(max-width:900px){.features-grid{grid-template-columns:1fr}.feature h3{min-height:auto}}

/* ===== Function list ===== */
.functions{background:var(--bg-soft)}
.function-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.function-group{
  background:#fff;border-radius:var(--radius-lg);padding:32px 28px;box-shadow:var(--shadow);
  border-top:4px solid var(--accent);
}
.function-group:nth-child(2){border-top-color:var(--primary-light)}
.function-group:nth-child(3){border-top-color:var(--primary)}
.function-group-head{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px dashed var(--line)}
.function-group-icon{
  flex:0 0 44px;width:44px;height:44px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;
}
.function-group-icon svg{width:24px;height:24px}
.function-group-title{font-size:17px;font-weight:900;color:var(--primary);line-height:1.4}
.function-group-title small{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.06em;display:block;margin-top:2px}
.function-list{display:grid;gap:12px}
.function-list li{
  font-size:14.5px;font-weight:600;color:var(--text);line-height:1.7;
  padding-left:26px;position:relative;
}
.function-list li::before{
  content:"";position:absolute;left:0;top:8px;width:14px;height:14px;
  background:var(--accent);clip-path:polygon(20% 50%,40% 70%,80% 25%,90% 35%,40% 90%,10% 60%);
  opacity:.85;
}
.function-list li strong{color:var(--primary);font-weight:900}
@media(max-width:900px){.function-groups{grid-template-columns:1fr;gap:18px}}

/* ===== Benefits ===== */
.benefits{background:#fff}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.benefit{
  text-align:center;padding:32px 24px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);border:1px solid var(--line);
}
.benefit-num{
  font-family:"Inter",sans-serif;font-weight:900;color:var(--primary);
  display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:10px;
}
.benefit-num .v{font-size:64px;line-height:1;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.benefit-num .u{font-size:24px;color:var(--accent)}
.benefit-label{font-size:15px;font-weight:900;color:var(--primary);margin-bottom:10px}
.benefit-desc{font-size:14.5px;color:var(--text-soft);line-height:1.85}
@media(max-width:780px){.benefits-grid{grid-template-columns:1fr}}

/* ===== Cases ===== */
.cases{background:var(--bg-soft)}
.case-list{display:grid;gap:24px}
.case{
  background:#fff;border-radius:var(--radius-lg);padding:32px;display:grid;
  grid-template-columns:280px 1fr;gap:32px;box-shadow:var(--shadow);
}
.case-tag{
  display:inline-block;font-size:12px;font-weight:900;letter-spacing:.14em;
  background:#FFEDE3;color:var(--accent-dark);padding:6px 14px;border-radius:999px;margin-bottom:14px;
}
.case-title{font-size:19px;font-weight:900;color:var(--primary);line-height:1.55;margin-bottom:8px}
.case-meta{font-size:13px;color:var(--muted);font-weight:700}
.case-results{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:6px}
.case-result{padding:18px;background:var(--bg-soft);border-radius:10px;border-left:3px solid var(--accent)}
.case-result-label{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:6px}
.case-result-value{font-family:"Inter",sans-serif;font-weight:900;font-size:24px;color:var(--primary)}
.case-result-value .small{font-size:13px;color:var(--text-soft);margin-left:4px}
.case-arrow{color:var(--accent);font-weight:900;margin:0 4px}
.case-detail{font-size:15px;color:var(--text-soft);line-height:1.95;margin-top:16px}
.case-disclaimer{font-size:12px;color:var(--muted);text-align:center;margin-top:24px}
@media(max-width:780px){.case{grid-template-columns:1fr;padding:24px}.case-results{grid-template-columns:1fr}}

/* ===== Comparison Table ===== */
.compare{background:#fff}
.compare-table-wrap{overflow-x:auto;margin:0 auto;max-width:1080px}
.compare-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;
  font-size:14.5px;
}
.compare-table th,.compare-table td{padding:18px 20px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.compare-table thead th{
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;
  font-weight:900;font-size:14px;text-align:center;
}
.compare-table thead th.us{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;
  position:relative;padding-top:14px;padding-bottom:18px;
}
.us-badge{
  display:inline-block;background:#fff;color:var(--accent-dark);
  font-size:11px;font-weight:900;padding:3px 12px;border-radius:999px;
  letter-spacing:.08em;margin-bottom:6px;line-height:1.4;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
}
.compare-table thead th.us .us-name{display:block;font-size:15px;font-weight:900;letter-spacing:.04em}
.compare-table tbody th{
  background:var(--bg-soft);font-weight:900;color:var(--primary);font-size:14.5px;
  width:200px;border-right:1px solid var(--line);
}
.compare-table td{text-align:center;font-weight:700;color:var(--text-soft);line-height:1.6;font-size:14px}
.compare-table td.us{
  background:#FFF7F2;color:var(--accent-dark);font-weight:900;border-left:1px solid var(--accent-soft);border-right:1px solid var(--accent-soft);
}
.compare-table tbody tr:last-child td,.compare-table tbody tr:last-child th{border-bottom:none}
.compare-mark{
  display:inline-block;width:28px;height:28px;border-radius:50%;font-size:16px;font-weight:900;line-height:28px;text-align:center;margin-bottom:4px;
}
.compare-mark.ok{background:#E8F8EE;color:var(--success)}
.compare-mark.mid{background:#FEF3C7;color:var(--warn)}
.compare-mark.no{background:#FFE4E4;color:var(--danger)}
.compare-conclusion{
  margin-top:28px;text-align:center;font-size:15.5px;font-weight:700;color:var(--primary-dark);
  background:var(--bg-soft);border-radius:var(--radius);padding:22px 28px;
}
.compare-conclusion strong{color:var(--accent-dark);font-weight:900}
@media(max-width:780px){
  .compare-table{font-size:12.5px}
  .compare-table th,.compare-table td{padding:12px 10px}
  .compare-table tbody th{width:auto}
}

/* ===== Reasons (Why SELVA) ===== */
.reasons{background:#fff}
.reason-list{display:grid;gap:18px;max-width:980px;margin:0 auto}
.reason{
  display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;
  background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 32px;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.reason:hover{transform:translateX(6px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.reason-num{
  font-family:"Inter",sans-serif;font-weight:900;font-size:48px;line-height:1;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  flex:0 0 70px;text-align:center;
}
.reason-num::after{
  content:"";display:block;width:32px;height:2px;background:var(--accent);margin:8px auto 0;
}
.reason-body h3{font-size:20px;font-weight:900;color:var(--primary);margin-bottom:10px;line-height:1.55}
.reason-body p{font-size:15.5px;color:var(--text-soft);line-height:1.95}
.reason-body p strong{color:var(--primary);font-weight:900}
@media(max-width:780px){
  .reason{grid-template-columns:1fr;gap:14px;padding:24px}
  .reason-num{font-size:42px;text-align:left;flex:none}
  .reason-num::after{margin-left:0}
}

/* ===== Process ===== */
.process{background:#fff}
.process-list{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;position:relative}
.process-list::before{
  content:"";position:absolute;top:36px;left:8%;right:8%;height:2px;
  background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);z-index:0;
}
.step{position:relative;text-align:center;z-index:1}
.step-num{
  width:72px;height:72px;border-radius:50%;background:#fff;border:3px solid var(--primary);
  color:var(--primary);font-family:"Inter",sans-serif;font-weight:900;font-size:24px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:var(--shadow);
}
.step:nth-child(5) .step-num{border-color:var(--accent);color:var(--accent)}
.step h4{font-size:16px;font-weight:900;color:var(--primary);margin-bottom:10px}
.step p{font-size:13.5px;color:var(--text-soft);line-height:1.8}
@media(max-width:780px){
  .process-list{grid-template-columns:1fr;gap:24px}
  .process-list::before{display:none}
}

/* ===== Pricing ===== */
.pricing{background:var(--bg-soft)}
.pricing-card{
  max-width:720px;margin:0 auto;background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);padding:48px;text-align:center;border-top:6px solid var(--accent);
}
.pricing-label{font-size:14px;font-weight:900;color:var(--accent-dark);letter-spacing:.12em;margin-bottom:14px}
.pricing-price{
  display:flex;align-items:baseline;justify-content:center;gap:6px;margin-bottom:20px;
  font-family:"Inter",sans-serif;color:var(--primary);
}
.pricing-price .from{font-size:18px;font-weight:700;color:var(--text-soft)}
.pricing-price .num{font-size:104px;font-weight:900;line-height:1;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.pricing-price .unit{font-size:24px;font-weight:900}
.pricing-price .tilde{font-size:32px;font-weight:900;color:var(--accent)}
.pricing-note{font-size:14px;color:var(--muted);margin-bottom:28px;line-height:1.85}
.pricing-includes{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;text-align:left;margin-bottom:32px}
.pricing-includes li{padding-left:26px;position:relative;font-size:14.5px;font-weight:700;line-height:1.7}
.pricing-includes li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:900}
@media(max-width:780px){
  .pricing-card{padding:32px 24px}
  .pricing-price .num{font-size:80px}
  .pricing-includes{grid-template-columns:1fr}
}

/* ===== FAQ ===== */
.faq{background:#fff}
.faq-list{max-width:880px;margin:0 auto;display:grid;gap:14px}
.faq-item{
  background:var(--bg-soft);border-radius:var(--radius);padding:22px 28px;
  border:1px solid var(--line);transition:background .2s;
}
.faq-item[open]{background:#fff;box-shadow:var(--shadow);border-color:var(--primary-light)}
.faq-item summary{
  font-weight:900;color:var(--primary);font-size:17px;line-height:1.65;cursor:pointer;
  display:flex;align-items:flex-start;gap:14px;list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{
  content:"Q";font-family:"Inter",sans-serif;flex:0 0 32px;width:32px;height:32px;
  background:var(--primary);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:900;
}
.faq-item summary::after{
  content:"＋";margin-left:auto;color:var(--accent-dark);font-weight:900;font-size:22px;flex:0 0 auto;
}
.faq-item[open] summary::after{content:"−"}
.faq-body{
  font-size:15px;color:var(--text-soft);line-height:1.95;margin-top:16px;padding-left:46px;
}

/* ===== Pre-form trust strip ===== */
.pre-form-strip{background:var(--bg-soft);padding:48px 0 64px}
.pre-form-strip .inner{
  max-width:1080px;margin:0 auto;background:#fff;border:2px solid var(--accent);
  border-radius:var(--radius-lg);padding:24px 32px;box-shadow:var(--shadow);
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.pre-form-item{display:flex;align-items:center;gap:12px}
.pre-form-icon{
  flex:0 0 40px;width:40px;height:40px;border-radius:10px;background:#FFEDE3;color:var(--accent-dark);
  display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;
}
.pre-form-item h4{font-size:14px;font-weight:900;color:var(--primary);line-height:1.4;margin-bottom:2px}
.pre-form-item p{font-size:12.5px;color:var(--text-soft);line-height:1.5}
@media(max-width:900px){
  .pre-form-strip .inner{grid-template-columns:repeat(2,1fr);gap:14px;padding:20px}
}
@media(max-width:480px){
  .pre-form-strip .inner{grid-template-columns:1fr}
}

/* ===== Final CTA / Form ===== */
.contact{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;position:relative;overflow:hidden}
.contact::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 20% 20%,rgba(255,120,73,.22),transparent 40%),radial-gradient(circle at 80% 90%,rgba(44,93,165,.50),transparent 50%);
}
.contact-inner{position:relative;display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.contact-msg .section-eyebrow{color:var(--accent)}
.contact-msg h2{font-size:34px;font-weight:900;line-height:1.45;color:#fff;margin-bottom:24px}
.contact-msg p{color:#D6DEEC;font-size:16px;line-height:2.0;margin-bottom:24px}
.no-sales-badge{
  display:inline-flex;align-items:center;gap:8px;background:rgba(34,197,94,.15);
  border:1px solid rgba(34,197,94,.4);color:#9CE9B4;font-size:13px;font-weight:900;
  padding:8px 14px;border-radius:999px;margin-bottom:24px;
}
.no-sales-badge::before{content:"✓";font-weight:900}
.contact-tel{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,120,73,.30);border-radius:var(--radius);
  padding:24px;margin-bottom:24px;
}
.contact-tel-label{font-size:13px;color:var(--accent-soft);font-weight:900;letter-spacing:.14em;margin-bottom:10px}
.contact-tel-num{font-family:"Inter",sans-serif;font-size:38px;font-weight:900;letter-spacing:.02em}
.contact-tel-hours{font-size:13px;color:#D6DEEC;margin-top:8px}
.trust-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.trust-badge{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,120,73,.30);
  padding:9px 16px;border-radius:999px;font-size:13px;font-weight:700;color:var(--accent-soft);
}

.form-card{background:#fff;border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg);color:var(--text)}
.form-card .form-eyebrow{
  display:inline-block;background:var(--accent);color:#fff;font-size:12px;font-weight:900;
  padding:5px 12px;border-radius:999px;letter-spacing:.06em;margin-bottom:14px;
}
.form-card h3{font-size:23px;color:var(--primary);font-weight:900;margin-bottom:8px;line-height:1.5}
.form-card .form-lead{font-size:14.5px;color:var(--text-soft);margin-bottom:14px;line-height:1.85}
.form-reassure{
  background:var(--bg-soft);border-left:3px solid var(--success);border-radius:6px;
  padding:12px 16px;margin-bottom:24px;font-size:13px;color:var(--text-soft);line-height:1.75;
}
.form-reassure strong{color:var(--success);font-weight:900}
.form-row{margin-bottom:18px}
.form-row.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:900;color:var(--primary);margin-bottom:8px}
.form-label .req{font-size:11px;background:var(--accent);color:#fff;padding:3px 9px;border-radius:4px;font-weight:900;letter-spacing:.06em}
.form-label .opt{font-size:11px;background:var(--line);color:var(--muted);padding:3px 9px;border-radius:4px;font-weight:900;letter-spacing:.06em}
.form-input,.form-select,.form-textarea{
  width:100%;padding:14px 16px;font-size:15px;font-family:inherit;color:var(--text);
  background:#FAFBFC;border:1.5px solid var(--line);border-radius:8px;transition:border-color .2s,box-shadow .2s;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,58,110,.12);background:#fff}
.form-textarea{resize:vertical;min-height:110px}
.form-check{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.7;color:var(--text-soft);cursor:pointer}
.form-check input{margin-top:4px;flex:0 0 auto;width:18px;height:18px;accent-color:var(--primary)}
.form-check a{color:var(--primary);text-decoration:underline}
.form-submit{
  width:100%;background:var(--accent);color:#fff;padding:20px;border-radius:10px;
  font-size:17px;font-weight:900;letter-spacing:.04em;margin-top:16px;
  box-shadow:0 8px 22px rgba(255,120,73,.42);transition:transform .15s,background .2s,box-shadow .2s,color .2s;
  line-height:1.4;
}
.form-submit small{display:block;font-size:12px;font-weight:700;opacity:.95;margin-top:4px;letter-spacing:.04em}
.form-submit:hover{background:var(--accent-dark);color:#fff;transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,120,73,.55)}
.form-submit:disabled{opacity:.5;cursor:not-allowed}
.form-submit-note{
  text-align:center;font-size:12.5px;color:var(--muted);font-weight:700;margin-top:14px;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.form-submit-note::before{content:"⏱";color:var(--success);font-size:14px}
.form-error{color:var(--danger);font-size:13px;font-weight:700;margin-top:6px;display:none}
.form-error.show{display:block}
.form-input.invalid,.form-select.invalid,.form-textarea.invalid{border-color:var(--danger);background:#FFF5F5}

.hp-field{position:absolute !important;left:-9999px !important;top:-9999px !important;width:1px;height:1px;opacity:0;pointer-events:none}

.form-submit.is-loading{opacity:.7;cursor:wait;pointer-events:none}
.form-submit .spinner{display:none;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:6px;vertical-align:-3px}
.form-submit.is-loading .spinner{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

.form-result-error{
  display:none;background:#FFF5F5;color:var(--danger);
  border:1.5px solid var(--danger);border-radius:8px;
  padding:14px 18px;margin-top:14px;font-size:14px;font-weight:700;line-height:1.65;
}
.form-result-error.show{display:block}
.form-result-error a{color:var(--danger);text-decoration:underline}

.thanks-card{
  display:none;background:#fff;border-radius:var(--radius-lg);padding:48px 40px;
  box-shadow:var(--shadow-lg);color:var(--text);text-align:center;
}
.thanks-card.show{display:block}
.thanks-icon{
  width:80px;height:80px;border-radius:50%;background:#E8F8EE;color:var(--success);
  display:flex;align-items:center;justify-content:center;font-size:42px;margin:0 auto 20px;font-weight:900;
}
.thanks-card h3{font-size:25px;color:var(--primary);font-weight:900;margin-bottom:14px}
.thanks-card p{font-size:15px;color:var(--text-soft);line-height:1.95}
@media(max-width:900px){
  .contact-inner{grid-template-columns:1fr;gap:36px}
  .form-card{padding:28px 22px}
  .form-row.cols-2{grid-template-columns:1fr}
  .contact-msg h2{font-size:25px}
}

/* ===== Footer ===== */
.site-footer{background:var(--bg-deep);color:#D6DEEC;padding:64px 0 28px;font-size:14px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;margin-bottom:36px}
.footer-logo{height:40px;width:auto;margin-bottom:18px;filter:brightness(0) invert(1)}
.footer-co p{line-height:1.95;margin-bottom:6px}
.footer-co strong{color:#fff;font-weight:900;display:block;font-size:15px;margin-bottom:6px}
.footer-col h4{color:#fff;font-size:13px;font-weight:900;letter-spacing:.12em;margin-bottom:14px}
.footer-col ul li{margin-bottom:8px}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:13px;
}
@media(max-width:780px){.footer-top{grid-template-columns:1fr;gap:28px}}

/* ===== Hero disclaimer ===== */
.hero-disclaimer{
  margin-top:14px;font-size:11.5px;line-height:1.7;color:var(--muted);
  letter-spacing:.02em;text-align:left;
}

/* ===== Hero CTA helper ===== */
.hero-cta-helper{
  font-size:13px;line-height:1.85;color:var(--text-soft);font-weight:500;margin-top:-6px;margin-bottom:24px;
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
}
.cta-tag{
  display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:900;letter-spacing:.04em;
  margin-right:6px;
}
.cta-tag.info{background:#fff;color:var(--primary);border:1px solid rgba(26,58,110,.20)}
.cta-tag.pro{background:rgba(255,120,73,.10);color:var(--accent-dark);border:1px solid rgba(255,120,73,.40)}
@media(max-width:780px){.hero-cta-helper{flex-direction:column;align-items:flex-start;gap:6px}}

/* ===== Activation flow + WHY 完全成果報酬 ===== */
.line-flow-block{
  margin:64px auto 0;max-width:1080px;background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:48px;box-shadow:var(--shadow);
}
.line-flow-head{text-align:center;margin-bottom:36px}
.line-flow-head .section-eyebrow{display:inline-block;font-size:12px;font-weight:900;color:var(--accent-dark);letter-spacing:.18em;margin-bottom:14px}
.line-flow-head h3{font-size:26px;font-weight:900;color:var(--primary);line-height:1.5;margin-bottom:14px}
.line-flow-head p{font-size:15px;color:var(--text-soft);line-height:1.85}

.flow-steps{
  display:grid;grid-template-columns:repeat(7,1fr);gap:8px;list-style:none;margin:0 0 40px 0;padding:0;
  position:relative;
}
.flow-step{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 12px 14px;text-align:center;
  position:relative;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.flow-step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.flow-step::after{
  content:"→";position:absolute;right:-10px;top:50%;transform:translateY(-50%);
  color:var(--accent);font-weight:900;font-size:18px;z-index:1;
}
.flow-step:last-child::after{display:none}
.flow-step .step-num{
  display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;
  font-family:"Inter",sans-serif;font-weight:900;font-size:13px;margin-bottom:8px;
  box-shadow:0 4px 10px rgba(255,120,73,.40);border:none;
}
.flow-step strong{display:block;font-size:13.5px;font-weight:900;color:var(--primary);margin-bottom:6px;line-height:1.4}
.flow-step small{display:block;font-size:11px;color:var(--text-soft);line-height:1.55;font-weight:600}
@media(max-width:1024px){
  .flow-steps{grid-template-columns:repeat(4,1fr);gap:14px}
  .flow-step::after{right:-12px}
  .flow-step:nth-child(4n)::after{display:none}
  .flow-step:last-child::after{display:none}
}
@media(max-width:600px){
  .flow-steps{grid-template-columns:repeat(2,1fr)}
  .flow-step:nth-child(4n)::after{display:block}
  .flow-step:nth-child(2n)::after{display:none}
  .flow-step:last-child::after{display:none}
}

/* ===== WHY 完全成果報酬 value box ===== */
.line-value{
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;
  border-radius:var(--radius-lg);padding:36px 40px;position:relative;overflow:hidden;
}
.line-value::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 90% 10%,rgba(255,120,73,.30),transparent 40%),
             radial-gradient(circle at 10% 90%,rgba(44,93,165,.30),transparent 40%);
}
.line-value-head{position:relative;display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.line-value-pill{
  display:inline-block;background:var(--accent);color:#fff;font-size:11px;font-weight:900;
  padding:5px 12px;border-radius:999px;letter-spacing:.06em;
}
.line-value-head h4{font-size:22px;font-weight:900;line-height:1.5;color:#fff}
.line-value-stats{
  position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;list-style:none;padding:0;
}
.line-value-stats li{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:18px 16px;
}
.line-value-stats li.lv-hi{
  background:linear-gradient(135deg,rgba(255,120,73,.30) 0%,rgba(255,120,73,.12) 100%);
  border:1px solid rgba(255,120,73,.55);box-shadow:0 6px 20px rgba(255,120,73,.24);
}
.line-value-stats .lv-num{
  font-family:"Inter",sans-serif;font-weight:900;font-size:34px;line-height:1;color:#fff;margin-bottom:6px;
}
.line-value-stats .lv-num span{font-size:18px;color:var(--accent-soft);margin-left:2px}
.line-value-stats li.lv-hi .lv-num{color:var(--accent-soft)}
.line-value-stats li.lv-hi .lv-num span{color:var(--accent-soft)}
.line-value-stats .lv-label{font-size:13px;font-weight:900;color:var(--accent-soft);margin-bottom:6px;letter-spacing:.04em}
.line-value-stats li.lv-hi .lv-label{color:var(--accent)}
.line-value-stats .lv-note{font-size:12.5px;color:#D6DEEC;line-height:1.6;font-weight:500}

.line-value-conclusion{
  position:relative;font-size:15px;line-height:1.85;color:#fff;margin-bottom:18px;
  padding-left:14px;border-left:3px solid var(--accent);font-weight:500;
}
.line-value-conclusion strong{color:var(--accent-soft);font-weight:900}
.line-value-features{
  position:relative;list-style:none;padding:0;margin:0;display:grid;gap:8px;
}
.line-value-features li{
  font-size:13.5px;color:#D6DEEC;font-weight:600;line-height:1.7;padding-left:24px;position:relative;
}
.line-value-features li::before{
  content:"✓";position:absolute;left:0;top:0;color:var(--accent);font-weight:900;font-size:14px;
}
.line-value-features li strong{color:#fff;font-weight:900}
@media(max-width:780px){
  .line-flow-block{padding:32px 22px;margin-top:48px}
  .line-flow-head h3{font-size:20px}
  .line-value{padding:28px 22px}
  .line-value-stats{grid-template-columns:1fr;gap:10px}
  .line-value-head h4{font-size:18px}
  .line-value-stats .lv-num{font-size:28px}
}

/* ===== Compare note ===== */
.compare-note{
  margin-top:14px;text-align:center;font-size:12.5px;color:var(--muted);line-height:1.7;
  max-width:920px;margin-left:auto;margin-right:auto;
}

/* ===== Common worries ===== */
.common-worries{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,120,73,.30);border-radius:var(--radius);
  padding:22px 26px;margin-bottom:24px;
}
.common-worries h4{
  font-size:14px;font-weight:900;color:var(--accent-soft);letter-spacing:.04em;margin-bottom:12px;
  display:flex;align-items:center;gap:8px;
}
.common-worries h4::before{
  content:"";width:6px;height:6px;background:var(--accent);border-radius:50%;
}
.common-worries ul{list-style:none;padding:0;margin:0 0 14px 0;display:grid;gap:8px}
.common-worries li{
  font-size:14px;line-height:1.7;color:#D6DEEC;font-weight:500;padding-left:22px;position:relative;
}
.common-worries li::before{
  content:"";position:absolute;left:0;top:8px;width:12px;height:12px;
  border:2px solid var(--accent);border-radius:50%;
}
.common-worries li strong{color:#fff;font-weight:900}
.common-worries .worry-meta{
