/* ============================================
   ELEVATE AGENT LP — RED NEON FUTURE
   Background: Lavender Blush #fff0f5
   ============================================ */

/* ---------- Variables ---------- */
:root {
  /* ── 背景 lavenderblush系 ── */
  --bg-base:      #fff0f5;   /* メイン背景 lavenderblush */
  --bg-section1:  #fff0f5;
  --bg-section2:  #fff0f5;   /* 全セクション同一 lavenderblush */
  --bg-section3:  #fff0f5;
  --bg-card:      rgba(255,255,255,0.88);
  --bg-card2:     rgba(255,240,245,0.95);

  /* ── アクセント RED ── */
  --red:          #dc143c;
  --red-bright:   #ff1a4a;
  --red-glow:     rgba(220,20,60,0.55);
  --red-soft:     rgba(220,20,60,0.10);
  --red-border:   rgba(220,20,60,0.25);

  /* ── Hero背景（ダーク維持） ── */
  --hero-bg1:     #060b14;
  --hero-bg2:     #0a0a18;

  /* ── テキスト ── */
  --text-dark:    #1a1a2e;
  --text-mid:     #3a3a5c;
  --text-muted:   #6b6b8a;
  --text-light:   rgba(26,26,46,0.55);
  --text-white:   #ffffff;
  --text-w80:     rgba(255,255,255,0.85);
  --text-w60:     rgba(255,255,255,0.60);
  --text-w40:     rgba(255,255,255,0.40);

  /* ── Glass (light) ── */
  --glass-bg:     rgba(255,255,255,0.75);
  --glass-border: rgba(220,20,60,0.18);
  --glass-shadow: 0 8px 32px rgba(180,0,40,0.10);

  /* ── Hero Glass (dark) ── */
  --hero-glass:   rgba(10,10,24,0.65);
  --hero-gborder: rgba(220,20,60,0.22);

  /* Fonts */
  --ff-jp:   'Noto Sans JP', sans-serif;
  --ff-en:   'Inter', sans-serif;
  --ff-disp: 'Rajdhani', 'Inter', sans-serif;

  /* Shadows */
  --shadow-red:  0 0 28px rgba(220,20,60,0.38), 0 0 60px rgba(220,20,60,0.15);
  --shadow-card: 0 6px 28px rgba(180,0,40,0.10), 0 2px 8px rgba(180,0,40,0.06);
  --shadow-lg:   0 16px 56px rgba(180,0,40,0.14);

  /* Gradients */
  --grad-red:    linear-gradient(135deg,#c00028 0%,#ff1a4a 50%,#c00028 100%);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { background:#fff0f5; color:var(--text-dark); font-family:var(--ff-jp); line-height:1.75; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; object-fit:cover; }
ul { list-style:none; }

/* ---------- Utility ---------- */
.neon-red { color:var(--red-bright); text-shadow:0 0 8px var(--red-glow),0 0 24px rgba(220,20,60,0.18); }

/* Light mode glass card */
.glass-card {
  background:rgba(255,255,255,0.88);
  border:1px solid rgba(220,20,60,0.18);
  border-radius:16px;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 8px 32px rgba(180,0,40,0.10);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.glass-card:hover {
  transform:translateY(-4px);
  border-color:rgba(220,20,60,0.38);
  box-shadow:0 12px 40px rgba(180,0,40,0.16);
}

/* Hero dark glass */
.hero .glass-card {
  background:var(--hero-glass);
  border-color:var(--hero-gborder);
  box-shadow:0 8px 32px rgba(0,0,0,0.45);
}
.hero .glass-card:hover {
  border-color:rgba(220,20,60,0.45);
  box-shadow:0 12px 44px rgba(0,0,0,0.55);
}

.section-container { max-width:1200px; margin:0 auto; padding:0 48px; }
.section-pad { padding:120px 0; }
.sec-line-top { position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(220,20,60,0.35),transparent); pointer-events:none; }
.sec-label {
  display:inline-block; font-family:var(--ff-disp); font-size:.72rem; font-weight:700;
  letter-spacing:.3em; color:var(--red-bright);
  background:rgba(220,20,60,0.08); border:1px solid rgba(220,20,60,0.25);
  border-radius:4px; padding:4px 14px; margin-bottom:18px; text-transform:uppercase;
}
.section-header { text-align:center; margin-bottom:68px; }
.sec-title { font-size:clamp(2rem,3.5vw,3rem); font-weight:900; line-height:1.25; margin-bottom:16px; letter-spacing:-.02em; color:var(--text-dark); }
.sec-lead { font-size:1.05rem; color:var(--text-muted); max-width:620px; margin:0 auto; }
.mt16 { margin-top:16px; }

/* ---------- Scroll Reveal ---------- */
.scroll-reveal { opacity:0; transform:translateY(44px); transition:opacity .85s ease,transform .85s ease; }
.scroll-reveal.revealed { opacity:1; transform:translateY(0); }
.slide-left { opacity:0; transform:translateX(-56px); transition:opacity .85s ease,transform .85s ease; }
.slide-left.revealed { opacity:1; transform:translateX(0); }
.slide-right { opacity:0; transform:translateX(56px); transition:opacity .85s ease,transform .85s ease; }
.slide-right.revealed { opacity:1; transform:translateX(0); }

/* ---------- Buttons ---------- */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--grad-red); color:var(--text-white);
  font-family:var(--ff-jp); font-weight:700; font-size:1rem;
  padding:15px 38px; border-radius:50px; border:none; cursor:pointer;
  box-shadow:var(--shadow-red); transition:all .3s ease; letter-spacing:.04em;
}
.btn-primary:hover { transform:translateY(-2px) scale(1.02); box-shadow:0 0 44px rgba(220,20,60,.7),0 0 88px rgba(220,20,60,.3); }
.btn-secondary {
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:var(--text-dark);
  font-family:var(--ff-jp); font-weight:700; font-size:1rem;
  padding:15px 36px; border-radius:50px; border:2px solid rgba(220,20,60,.4);
  cursor:pointer; transition:all .3s ease;
}
.btn-secondary:hover { border-color:var(--red-bright); background:rgba(220,20,60,.06); box-shadow:0 0 18px rgba(220,20,60,.15); }
.btn-xl { font-size:1.15rem; padding:20px 56px; }
.btn-sm { font-size:.85rem; padding:10px 22px; }
.pulse-btn { animation:pulse-glow 2.8s infinite; }
@keyframes pulse-glow { 0%,100%{box-shadow:var(--shadow-red)} 50%{box-shadow:0 0 52px rgba(220,20,60,.7),0 0 100px rgba(220,20,60,.35)} }

/* ============================================
   PROGRESS BAR
   ============================================ */
.progress-bar-wrap { position:fixed; top:0; left:0; right:0; height:2px; z-index:9999; }
.progress-bar { height:100%; width:0%; background:var(--grad-red); box-shadow:0 0 10px rgba(220,20,60,.8); transition:width .1s linear; }

/* ============================================
   NAVBAR
   ============================================ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:900;
  padding:14px 0; transition:background .4s, backdrop-filter .4s;
}
.navbar.scrolled {
  background:rgba(255,240,245,0.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(220,20,60,0.18);
  box-shadow:0 2px 20px rgba(180,0,40,0.10);
}
/* ヒーロー上のナビはダーク */
.navbar:not(.scrolled) { background:transparent; }
.navbar:not(.scrolled) .logo-text,
.navbar:not(.scrolled) .nav-links a,
.navbar:not(.scrolled) .logo-by { color:var(--text-white); }
.navbar:not(.scrolled) .nav-links a:hover { color:var(--red-bright); }

.nav-container { max-width:1200px; margin:0 auto; padding:0 48px; display:flex; align-items:center; gap:28px; }
.nav-logo { display:flex; flex-direction:column; line-height:1; }
.logo-text { font-family:var(--ff-disp); font-size:1.45rem; font-weight:700; letter-spacing:.04em; color:var(--text-dark); transition:color .3s; }
.logo-accent { color:var(--red-bright); text-shadow:0 0 12px var(--red-glow); }
.logo-by { font-size:.58rem; color:var(--text-muted); letter-spacing:.14em; margin-top:2px; transition:color .3s; }
.nav-links { display:flex; gap:22px; margin-left:auto; }
.nav-links a { font-size:.84rem; font-weight:500; color:var(--text-mid); transition:color .2s; letter-spacing:.04em; }
.nav-links a:hover { color:var(--red-bright); }
.nav-cta { background:var(--grad-red); color:var(--text-white); font-size:.84rem; font-weight:700; padding:10px 26px; border-radius:50px; transition:all .3s; white-space:nowrap; box-shadow:0 0 16px rgba(220,20,60,.3); }
.nav-cta:hover { box-shadow:var(--shadow-red); transform:translateY(-1px); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; margin-left:auto; }
.hamburger span { display:block; width:24px; height:2px; background:var(--text-dark); border-radius:2px; transition:all .3s; }
.navbar:not(.scrolled) .hamburger span { background:var(--text-white); }

/* ============================================
   HERO  ★ 前回デザイン（センター配置）に戻す
   ============================================ */
.hero {
  position:relative; min-height:100vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:radial-gradient(ellipse at 30% 50%,rgba(80,0,20,0.85) 0%,var(--hero-bg1) 65%),
             radial-gradient(ellipse at 80% 20%,rgba(10,20,80,0.5) 0%,transparent 60%);
  overflow:hidden; padding-top:80px;
}
#heroCanvas { position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(135deg,rgba(6,11,20,.65) 0%,rgba(6,11,20,.2) 100%);
}
.data-lines { position:absolute; inset:0; width:100%; height:100%; z-index:2; pointer-events:none; }
.dl { stroke-dasharray:350 1100; stroke-dashoffset:1400; animation:dl-flow 5s linear infinite; }
.dl1{animation-delay:0s;animation-duration:4.2s}
.dl2{animation-delay:1.1s;animation-duration:6s}
.dl3{animation-delay:2.3s;animation-duration:4.8s}
.dl4{animation-delay:.6s;animation-duration:7s}
@keyframes dl-flow{0%{stroke-dashoffset:1400}100%{stroke-dashoffset:-350}}
.particles { position:absolute; inset:0; z-index:3; pointer-events:none; }
.particle { position:absolute; border-radius:50%; animation:part-rise linear infinite; }
@keyframes part-rise{0%{transform:translateY(100vh);opacity:0}10%{opacity:1}90%{opacity:.6}100%{transform:translateY(-5vh);opacity:0}}
.scan-line {
  position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(220,20,60,.5),rgba(255,80,80,.9),rgba(220,20,60,.5),transparent);
  z-index:4; animation:scan 4.5s ease-in-out infinite;
  box-shadow:0 0 12px rgba(220,20,60,.5); pointer-events:none;
}
@keyframes scan{0%{top:-2%;opacity:0}5%{opacity:1}95%{opacity:.8}100%{top:102%;opacity:0}}

/* Hero content — センター */
.hero-content {
  position:relative; z-index:10;
  width:100%; max-width:900px;
  padding:100px 40px 80px;
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:24px;
}

/* 3D ロゴ */
.hero-logo-3d {
  position:relative; margin-bottom:8px;
  animation:logo-float 4.5s ease-in-out infinite;
}
@keyframes logo-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.logo3d-text { font-family:var(--ff-disp); font-size:3.2rem; font-weight:700; letter-spacing:.06em; color:var(--text-white); text-shadow:0 2px 20px rgba(0,0,0,.8); position:relative; z-index:1; }
.logo3d-accent { color:var(--red-bright); text-shadow:0 0 18px var(--red-glow),0 0 50px rgba(220,20,60,.25); }
.logo3d-sub { font-family:var(--ff-disp); font-size:.72rem; letter-spacing:.38em; color:rgba(255,255,255,0.4); margin-top:6px; }
.logo3d-glow { position:absolute; inset:-20px; background:radial-gradient(ellipse,rgba(220,20,60,.12) 0%,transparent 70%); animation:glow-beat 3.2s ease-in-out infinite; pointer-events:none; }
@keyframes glow-beat{0%,100%{opacity:.5}50%{opacity:1}}
.ring { position:absolute; border:1px solid rgba(220,20,60,.15); border-radius:50%; pointer-events:none; }
.r1 { inset:-14px; animation:ring-rot 9s linear infinite; }
.r2 { inset:-26px; border-color:rgba(220,20,60,.07); animation:ring-rot 14s linear infinite reverse; }
@keyframes ring-rot{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(220,20,60,.12); border:1px solid rgba(220,20,60,.45);
  border-radius:50px; padding:8px 20px; font-size:.84rem; font-weight:700; color:var(--red-bright);
  animation:badge-glow 3s ease-in-out infinite;
}
@keyframes badge-glow{0%,100%{border-color:rgba(220,20,60,.45)}50%{border-color:rgba(220,20,60,.9);box-shadow:0 0 18px rgba(220,20,60,.3)}}

.hero-title { font-size:clamp(2.2rem,4.5vw,3.8rem); font-weight:900; line-height:1.2; letter-spacing:-.03em; color:var(--text-white); }
.hero-title em { font-style:normal; }
.hero-sub { font-size:1.2rem; color:var(--text-w80); max-width:620px; }
.hero-sub2 { font-size:.95rem; color:var(--text-w60); max-width:600px; }
.hero-cta-block { display:flex; flex-direction:column; align-items:center; gap:10px; margin-top:8px; }
.cta-note { font-size:.7rem; color:rgba(255,255,255,.35); }

.line-reveal { display:block; opacity:0; transform:translateY(28px); animation:line-in .8s ease forwards; animation-play-state:paused; }
.d1{animation-delay:.18s}.d2{animation-delay:.36s}.d3{animation-delay:.54s}.d4{animation-delay:.72s}
.hero-content .line-reveal { animation-play-state:running; }
@keyframes line-in{to{opacity:1;transform:translateY(0)}}

/* Hero stats strip */
.hero-stats-strip {
  position:relative; z-index:10;
  display:flex; gap:0; background:rgba(6,11,20,0.8);
  border-top:1px solid rgba(220,20,60,0.2); width:100%;
  backdrop-filter:blur(20px);
}
.hss-item {
  flex:1; display:flex; align-items:center; justify-content:center; gap:14px;
  padding:22px 16px; border-right:1px solid rgba(220,20,60,0.12);
}
.hss-item:last-child { border-right:none; }
.hss-item i { font-size:1.3rem; color:var(--red-bright); }
.hss-item strong { font-family:var(--ff-disp); font-size:1.6rem; font-weight:700; color:var(--red-bright); display:block; line-height:1; text-shadow:0 0 14px var(--red-glow); }
.hss-item span { font-size:.72rem; color:var(--text-w60); margin-top:2px; }

/* Scroll indicator */
.scroll-indicator { position:absolute; bottom:80px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; z-index:10; animation:si-in 1s ease 2s both; }
@keyframes si-in{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.scroll-indicator span { font-family:var(--ff-disp); font-size:.62rem; letter-spacing:.3em; color:rgba(255,255,255,.35); }
.scroll-line-anim { width:1px; height:48px; background:linear-gradient(to bottom,rgba(220,20,60,.65),transparent); animation:scroll-grow 2.2s ease-in-out infinite; }
@keyframes scroll-grow{0%{height:0;opacity:1}100%{height:48px;opacity:0}}

/* ============================================
   PROBLEMS
   ============================================ */
.problems { background:#fff0f5; position:relative; overflow:hidden; }
.problems::after { content:''; position:absolute; top:80px; right:-60px; width:320px; height:320px; background:radial-gradient(circle,rgba(220,20,60,.06) 0%,transparent 70%); pointer-events:none; }

/* Tri infographic */
.tri-wrap { display:flex; flex-direction:column; align-items:center; gap:2px; margin-bottom:68px; max-width:780px; margin-left:auto; margin-right:auto; }
.tri-row { width:100%; display:flex; justify-content:center; }
.tri-r1{width:100%}.tri-r2{width:82%}.tri-r3{width:64%}
.tri-box {
  width:100%; padding:28px 40px; text-align:center;
  background:var(--glass-bg); border:1px solid rgba(220,20,60,.2);
  backdrop-filter:blur(12px); border-radius:8px; transition:border-color .3s;
}
.tri-r1 .tri-box { border-color:rgba(220,20,60,.35); background:rgba(220,20,60,.08); }
.tri-r2 .tri-box { border-color:rgba(220,20,60,.22); }
.tri-r3 .tri-box { border-color:rgba(220,20,60,.14); }
.tri-box:hover { border-color:rgba(220,20,60,.5); }
.tri-icon-wrap { font-size:2rem; color:var(--red-bright); margin-bottom:10px; filter:drop-shadow(0 0 8px var(--red-glow)); }
.tri-box h3 { font-size:1.1rem; font-weight:700; margin-bottom:8px; color:var(--text-dark); }
.tri-box p { font-size:.88rem; color:var(--text-muted); line-height:1.65; }
.tri-stat-badge { display:inline-block; margin-top:10px; font-family:var(--ff-disp); font-size:.75rem; font-weight:700; letter-spacing:.1em; color:var(--red-bright); background:rgba(220,20,60,.1); border:1px solid rgba(220,20,60,.28); border-radius:20px; padding:4px 14px; }
.tri-connector { color:var(--red-bright); font-size:.95rem; opacity:.5; padding:4px 0; animation:bounce-dn 1.8s ease-in-out infinite; }
@keyframes bounce-dn{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* Stats grid */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:68px; }
.stat-card { padding:32px 20px; text-align:center; position:relative; overflow:hidden; }
.stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad-red); opacity:0; transition:opacity .3s; }
.stat-card:hover::before { opacity:1; }
.stat-num {
  font-family:var(--ff-disp); font-size:2.8rem; font-weight:700; color:var(--red-bright); line-height:1;
  background:linear-gradient(90deg,#dc143c,#ff6080,#dc143c); background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:shimmer 4s linear infinite;
}
@keyframes shimmer{0%{background-position:0% center}100%{background-position:200% center}}
.stat-unit { font-size:.95rem; font-weight:700; color:var(--text-mid); margin-top:4px; }
.stat-label { font-size:.74rem; color:var(--text-muted); margin-top:8px; line-height:1.45; }

/* Problem scene */
.problem-scene { position:relative; border-radius:20px; overflow:hidden; height:400px; }
.scene-img-wrap { position:relative; width:100%; height:100%; }
.scene-img-wrap img { width:100%; height:100%; object-fit:cover; filter:brightness(.7) saturate(.85); }
.scene-img-overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(6,11,20,.7) 0%,transparent 60%); }
.scene-caption { position:absolute; bottom:28px; left:36px; max-width:460px; padding:22px 26px; }
.scene-caption i { color:var(--red-bright); font-size:1.1rem; margin-bottom:8px; display:block; }
.scene-caption p { font-size:.98rem; color:var(--text-white); line-height:1.7; font-style:italic; margin-bottom:8px; }
.scene-caption span { font-size:.76rem; color:rgba(255,255,255,.5); }

/* ============================================
   SOLUTION
   ============================================ */
.solution { background:#fff0f5; position:relative; overflow:hidden; }
.grid-bg {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(220,20,60,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(220,20,60,.03) 1px,transparent 1px);
  background-size:64px 64px; animation:grid-drift 22s linear infinite;
}
@keyframes grid-drift{0%{background-position:0 0}100%{background-position:64px 64px}}

.sol-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-bottom:48px; position:relative; z-index:1; }
.sol-card { padding:38px 30px; position:relative; overflow:hidden; cursor:default; }
.sol-card::after { content:''; position:absolute; inset:0; background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(220,20,60,.08) 0%,transparent 55%); opacity:0; transition:opacity .3s; pointer-events:none; border-radius:inherit; }
.sol-card:hover::after { opacity:1; }
.sol-num { position:absolute; top:16px; right:22px; font-family:var(--ff-disp); font-size:4rem; font-weight:700; color:rgba(220,20,60,.06); line-height:1; user-select:none; }
.sol-icon { width:56px; height:56px; background:rgba(220,20,60,.09); border:1px solid rgba(220,20,60,.25); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.6rem; color:var(--red-bright); margin-bottom:18px; transition:all .3s; }
.sol-card:hover .sol-icon { background:rgba(220,20,60,.18); box-shadow:0 0 16px rgba(220,20,60,.25); }
.sol-card h3 { font-size:1.05rem; font-weight:700; margin-bottom:12px; color:var(--text-dark); line-height:1.45; }
.sol-card p { font-size:.88rem; color:var(--text-mid); line-height:1.75; margin-bottom:16px; }
.sol-tags { display:flex; gap:8px; flex-wrap:wrap; }
.sol-tags span { font-size:.68rem; padding:3px 10px; border:1px solid rgba(220,20,60,.3); border-radius:20px; color:var(--red-bright); background:rgba(220,20,60,.07); }

/* Formula */
.formula-block { padding:40px 48px; text-align:center; margin-bottom:0; position:relative; z-index:1; overflow:hidden; }
.formula-block::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at center,rgba(220,20,60,.05) 0%,transparent 70%); pointer-events:none; }
.formula-label { font-family:var(--ff-disp); font-size:.78rem; letter-spacing:.3em; color:var(--text-muted); margin-bottom:20px; text-transform:uppercase; }
.formula-eq { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:14px; }
.fe-item { display:flex; align-items:center; gap:8px; font-size:1.2rem; font-weight:700; background:rgba(220,20,60,.06); border:1px solid rgba(220,20,60,.18); border-radius:8px; padding:10px 18px; color:var(--text-dark); }
.fe-item i { color:var(--red-bright); font-size:.82rem; animation:up-bounce 1.6s ease-in-out infinite; }
@keyframes up-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.fe-op { font-family:var(--ff-disp); font-size:1.8rem; font-weight:700; color:rgba(220,20,60,.4); }
.fe-eq { font-family:var(--ff-disp); font-size:1.8rem; font-weight:700; color:var(--text-muted); }
.fe-result { font-size:1.3rem; font-weight:900; background:rgba(220,20,60,.08); border:1px solid rgba(220,20,60,.35); border-radius:8px; padding:10px 20px; display:flex; align-items:center; color:var(--red-bright); }
.fe-result sup { font-size:.6em; vertical-align:super; margin-left:3px; }
.formula-block>p { font-size:.84rem; color:var(--text-muted); }

/* ============================================
   PLATFORM
   ============================================ */
.platform { background:#fff0f5; position:relative; overflow:hidden; }

.platform-layout { display:grid; grid-template-columns:400px 1fr; gap:64px; align-items:center; margin-bottom:72px; }

/* Phone */
.phone-wrap { position:relative; display:flex; align-items:center; justify-content:center; }
.phone-outer { position:relative; }
.phone-frame {
  width:268px; height:556px;
  background:linear-gradient(160deg,#1a1a2a,#0d0d1a);
  border-radius:42px; border:2px solid rgba(220,20,60,.3);
  padding:18px 14px;
  box-shadow:0 0 0 6px rgba(20,20,30,.9),0 0 60px rgba(220,20,60,.18),0 20px 60px rgba(0,0,0,.4);
  position:relative; overflow:hidden;
}
.phone-notch { position:absolute; top:0; left:50%; transform:translateX(-50%); width:80px; height:8px; background:#0d0d1a; border-radius:0 0 8px 8px; z-index:10; }
.phone-screen { height:100%; border-radius:30px; overflow:hidden; background:#090e1a; padding:12px; }
.ps-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; padding-top:8px; }
.ps-logo { font-family:var(--ff-disp); font-size:1.05rem; font-weight:700; color:#fff; }
.ps-logo em { color:var(--red-bright); font-style:normal; }
.ps-badge { font-size:.52rem; background:rgba(220,20,60,.18); border:1px solid rgba(220,20,60,.38); border-radius:4px; padding:2px 7px; color:var(--red-bright); }
.ps-progress-block { background:rgba(255,255,255,.04); border-radius:8px; padding:10px; margin-bottom:10px; }
.ps-prog-label { font-size:.58rem; color:rgba(255,255,255,.4); margin-bottom:5px; }
.ps-prog-bar { height:4px; background:rgba(255,255,255,.08); border-radius:2px; overflow:hidden; margin-bottom:3px; }
.ps-prog-fill { height:100%; width:68%; background:var(--grad-red); border-radius:2px; animation:prog-pulse 3s ease-in-out infinite alternate; }
@keyframes prog-pulse{from{width:68%}to{width:72%}}
.ps-prog-pct { font-size:.58rem; color:var(--red-bright); font-weight:700; }
.ps-courses { display:flex; flex-direction:column; gap:5px; margin-bottom:10px; }
.ps-course { display:flex; align-items:center; gap:7px; padding:7px 8px; background:rgba(255,255,255,.03); border-radius:7px; border:1px solid rgba(255,255,255,.04); }
.ps-course.active { background:rgba(220,20,60,.07); border-color:rgba(220,20,60,.25); }
.ps-course i { font-size:.8rem; color:var(--red-bright); width:18px; text-align:center; flex-shrink:0; }
.pc-name { font-size:.58rem; color:#fff; font-weight:600; }
.pc-sub { font-size:.5rem; color:rgba(255,255,255,.4); }
.pc-tag { margin-left:auto; font-size:.48rem; padding:2px 6px; border-radius:4px; white-space:nowrap; }
.pc-tag.learning { background:rgba(220,20,60,.18); color:var(--red-bright); }
.pc-tag.next { background:rgba(255,255,255,.05); color:rgba(255,255,255,.6); }
.pc-tag.lock { background:rgba(255,255,255,.03); color:rgba(255,255,255,.4); }
.ps-mbti { background:rgba(220,20,60,.07); border:1px solid rgba(220,20,60,.18); border-radius:8px; padding:10px; text-align:center; }
.ps-mbti-label { font-size:.54rem; color:rgba(255,255,255,.4); margin-bottom:4px; display:flex; align-items:center; justify-content:center; gap:6px; }
.img-note { font-size:.5rem; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); border-radius:3px; padding:1px 5px; color:rgba(255,255,255,.6); }
.ps-mbti-type { font-family:var(--ff-disp); font-size:1.15rem; font-weight:700; color:#fff; display:flex; align-items:center; justify-content:center; gap:8px; }
.mbti-role { font-size:.54rem; background:rgba(220,20,60,.18); border:1px solid rgba(220,20,60,.3); border-radius:4px; padding:2px 6px; color:var(--red-bright); }
.ps-mbti-match { font-size:.58rem; color:rgba(255,255,255,.4); margin-top:4px; }
.ps-mbti-match strong { color:var(--red-bright); }
.phone-glow { position:absolute; bottom:-24px; left:50%; transform:translateX(-50%); width:180px; height:50px; background:radial-gradient(ellipse,rgba(220,20,60,.4) 0%,transparent 70%); filter:blur(18px); pointer-events:none; }
.phone-bubbles { position:absolute; inset:0; pointer-events:none; }
.pb { position:absolute; background:var(--glass-bg); border:1px solid rgba(220,20,60,.25); border-radius:12px; padding:9px 14px; font-size:.72rem; font-weight:700; text-align:center; color:var(--text-dark); backdrop-filter:blur(12px); animation:pb-float 4s ease-in-out infinite; }
.pb i { display:block; color:var(--red-bright); font-size:.95rem; margin-bottom:3px; }
.pb small { display:block; font-size:.58rem; color:var(--text-muted); }
.pb1{top:8%;left:-22%;animation-delay:0s}
.pb2{top:46%;right:-20%;animation-delay:1.4s}
.pb3{bottom:12%;left:-20%;animation-delay:2.8s}
@keyframes pb-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Platform features */
.pf-list { display:flex; flex-direction:column; gap:16px; }
.pf-item { display:flex; gap:20px; padding:26px; align-items:flex-start; }
.pf-item:hover { transform:translateX(6px); border-color:rgba(220,20,60,.35); }
.pf-icon { width:50px; height:50px; background:rgba(220,20,60,.09); border:1px solid rgba(220,20,60,.25); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; color:var(--red-bright); flex-shrink:0; transition:all .3s; }
.pf-item:hover .pf-icon { background:rgba(220,20,60,.18); box-shadow:0 0 16px rgba(220,20,60,.22); }
.pf-item h3 { font-size:1rem; font-weight:700; margin-bottom:6px; color:var(--text-dark); }
.pf-item p { font-size:.86rem; color:var(--text-mid); line-height:1.72; }

/* Flow */
.flow-wrap { text-align:center; margin-bottom:68px; }
.flow-title { font-family:var(--ff-disp); font-size:.78rem; letter-spacing:.3em; color:var(--text-muted); margin-bottom:28px; text-transform:uppercase; }
.flow-steps { display:flex; align-items:center; justify-content:center; }
.flow-step { display:flex; flex-direction:column; align-items:center; gap:10px; padding:20px 16px; background:var(--glass-bg); border:1px solid rgba(220,20,60,.14); border-radius:12px; min-width:100px; transition:all .3s; cursor:default; }
.flow-step:hover,.active-step { border-color:rgba(220,20,60,.45)!important; background:rgba(220,20,60,.08)!important; box-shadow:0 4px 24px rgba(220,20,60,.12); }
.fs-icon { width:46px; height:46px; background:rgba(220,20,60,.09); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:var(--red-bright); }
.active-step .fs-icon { background:rgba(220,20,60,.22); box-shadow:0 0 14px rgba(220,20,60,.3); }
.fs-label { font-size:.7rem; font-weight:600; color:var(--text-muted); line-height:1.4; text-align:center; }
.active-step .fs-label { color:var(--red-bright); }
.flow-arrow { color:rgba(220,20,60,.35); font-size:.8rem; padding:0 8px; flex-shrink:0; }

/* Platform image row */
.platform-img-row { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.pir-img { position:relative; border-radius:14px; overflow:hidden; height:250px; }
.pir-img img { width:100%; height:100%; object-fit:cover; filter:brightness(.75) saturate(.85); transition:transform .5s ease; }
.pir-img:hover img { transform:scale(1.04); }
.pir-badge { position:absolute; bottom:14px; left:14px; right:14px; padding:10px 16px; font-size:.78rem; font-weight:600; text-align:center; border-radius:10px; }
.pir-badge i { margin-right:6px; color:var(--red-bright); }

/* ============================================
   RESULTS
   ============================================ */
.results { background:#fff0f5; position:relative; overflow:hidden; }
.results::after { content:''; position:absolute; top:-60px; right:-60px; width:360px; height:360px; background:radial-gradient(circle,rgba(220,20,60,.05) 0%,transparent 70%); pointer-events:none; }

.results-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:60px; position:relative; z-index:1; }
.result-card { padding:30px 24px; display:flex; flex-direction:column; gap:16px; position:relative; overflow:hidden; }
.featured-card { border-color:rgba(220,20,60,.4); box-shadow:0 8px 40px rgba(220,20,60,.12); }
.featured-card::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at top,rgba(220,20,60,.05) 0%,transparent 70%); pointer-events:none; }
.rc-badge { display:inline-block; font-family:var(--ff-disp); font-size:.68rem; font-weight:700; letter-spacing:.2em; color:var(--red-bright); background:rgba(220,20,60,.09); border:1px solid rgba(220,20,60,.25); border-radius:4px; padding:4px 10px; align-self:flex-start; }
.feat-badge { background:rgba(220,20,60,.18); border-color:rgba(220,20,60,.55); }
.rc-company { font-size:.84rem; font-weight:600; color:var(--text-muted); }
.rc-person { display:flex; align-items:center; gap:14px; }
.rc-person img { width:56px; height:56px; border-radius:50%; object-fit:cover; border:2px solid rgba(220,20,60,.35); transition:transform .4s; }
.result-card:hover .rc-person img { transform:scale(1.06); }
.rc-person>div { display:flex; flex-direction:column; gap:3px; }
.rc-name { font-size:.86rem; font-weight:700; color:var(--text-dark); }
.rc-role { font-size:.72rem; color:var(--text-muted); }
.rc-numbers { display:flex; gap:12px; flex-wrap:wrap; }
.rc-num-box { display:flex; flex-direction:column; gap:4px; flex:1; min-width:100px; background:rgba(220,20,60,.06); border:1px solid rgba(220,20,60,.14); border-radius:10px; padding:12px; text-align:center; }
.rc-num-box.wide { min-width:100%; }
.rc-num {
  font-family:var(--ff-disp); font-size:1.6rem; font-weight:700; display:block;
  background:linear-gradient(90deg,#dc143c,#ff6080,#dc143c); background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:shimmer 3s linear infinite;
}
.big-num { font-size:2rem!important; }
.rc-num-box>span:last-child { font-size:.68rem; color:var(--text-muted); line-height:1.3; }
.result-card blockquote { font-size:.82rem; color:var(--text-mid); line-height:1.8; border-left:2px solid rgba(220,20,60,.35); padding-left:14px; font-style:italic; flex:1; }

/* ============================================
   PLANNING
   ============================================ */
.planning { background:#fff0f5; position:relative; overflow:hidden; }
.planning-layout { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.planning-single { grid-template-columns:1fr; max-width:700px; margin-left:auto; margin-right:auto; }
.planning-cred { display:flex; flex-direction:column; gap:18px; }
.cred-card { display:flex; gap:18px; align-items:center; padding:24px 26px; }
.cred-icon { width:50px; height:50px; background:rgba(220,20,60,.09); border:1px solid rgba(220,20,60,.25); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:var(--red-bright); flex-shrink:0; }
.cred-num { font-family:var(--ff-disp); font-size:1.35rem; font-weight:700; margin-bottom:4px; }
.cred-desc { font-size:.84rem; color:var(--text-muted); line-height:1.6; }
.cred-desc strong { color:var(--text-dark); }
.planning-flow { display:flex; flex-direction:column; gap:22px; }
.pf-header { display:flex; gap:18px; align-items:center; padding:26px 28px; }
.pf-header i { font-size:1.8rem; flex-shrink:0; }
.pf-header h3 { font-size:1.05rem; font-weight:700; margin-bottom:6px; color:var(--text-dark); }
.req-note { font-size:.88rem; color:var(--text-muted); }
.req-note strong { color:var(--red-bright); }
.contact-cta { padding:28px 30px; display:flex; gap:18px; align-items:flex-start; }
.contact-cta i { font-size:1.8rem; margin-top:4px; flex-shrink:0; }
.contact-cta h4 { font-size:1rem; font-weight:700; margin-bottom:8px; color:var(--text-dark); }
.contact-cta p { font-size:.86rem; color:var(--text-muted); line-height:1.7; }

/* ============================================
   CLOSING
   ============================================ */
.closing { background:#fff0f5; position:relative; overflow:hidden; padding-bottom:80px; }
.closing-logo-bg { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:var(--ff-disp); font-size:clamp(5rem,14vw,13rem); font-weight:900; color:rgba(220,20,60,.04); letter-spacing:.2em; white-space:nowrap; user-select:none; pointer-events:none; }
.closing-content { text-align:center; position:relative; z-index:1; max-width:780px; margin:0 auto 56px; }
.closing-badge-wrap { margin-bottom:26px; }
.closing-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(220,20,60,.1); border:1px solid rgba(220,20,60,.4); border-radius:50px; padding:10px 28px; font-size:.9rem; font-weight:700; color:var(--red-bright); animation:badge-glow 3s ease-in-out infinite; }
.closing-badge i { animation:flame 1.2s ease-in-out infinite alternate; }
@keyframes flame{from{transform:scale(1)}to{transform:scale(1.2)}}
.closing-title { font-size:clamp(1.7rem,3.2vw,2.8rem); font-weight:900; line-height:1.35; margin-bottom:22px; color:var(--text-dark); }
.closing-sub { font-size:1.05rem; color:var(--text-muted); line-height:1.8; margin-bottom:38px; }
.closing-cta { display:flex; justify-content:center; margin-bottom:20px; }
.closing-note { font-size:.72rem; color:var(--text-light); }

/* Company card */
.company-card { display:flex; align-items:center; gap:48px; padding:34px 46px; max-width:700px; margin:0 auto; position:relative; z-index:1; border-color:rgba(220,20,60,.22); }
.cc-logo { display:flex; flex-direction:column; gap:4px; }
.cc-name { font-family:var(--ff-disp); font-size:2rem; font-weight:700; color:var(--red-bright); text-shadow:0 0 12px rgba(220,20,60,.3); }
.cc-type { font-size:.7rem; color:var(--text-muted); letter-spacing:.1em; }
.cc-info { display:flex; flex-direction:column; gap:12px; flex:1; }
.cc-row { display:flex; align-items:center; gap:12px; font-size:.88rem; color:var(--text-mid); }
.cc-row i { color:var(--red-bright); width:16px; flex-shrink:0; }
.cc-row a { color:var(--red-bright); text-decoration:underline; text-underline-offset:3px; transition:opacity .2s; }
.cc-row a:hover { opacity:.8; }

/* ============================================
   FOOTER
   ============================================ */
.footer { background:#fff0f5; border-top:1px solid rgba(220,20,60,.18); padding:44px 0; }
.footer-inner { max-width:1200px; margin:0 auto; padding:0 48px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-logo span { font-family:var(--ff-disp); font-size:1.35rem; font-weight:700; color:var(--text-dark); }
.footer-logo em { font-style:normal; color:var(--red-bright); }
.footer-by { display:block; font-size:.62rem; color:var(--text-muted); margin-top:2px; }
.footer-links { display:flex; gap:24px; flex-wrap:wrap; }
.footer-links a { font-size:.82rem; color:var(--text-muted); transition:color .2s; }
.footer-links a:hover { color:var(--red-bright); }
.footer-copy { font-size:.72rem; color:var(--text-light); }

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1100px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .sol-grid{grid-template-columns:1fr}
  .results-grid{grid-template-columns:1fr;max-width:580px;margin-left:auto;margin-right:auto}
  .planning-layout{grid-template-columns:1fr}
  .company-card{flex-direction:column;text-align:center;gap:22px;padding:28px}
  .platform-layout{grid-template-columns:1fr;gap:40px}
  .phone-wrap{justify-content:center}
  .platform-img-row{grid-template-columns:1fr 1fr}
  .hss-item span{font-size:.65rem}
}

@media(max-width:768px){
  html{font-size:15px}
  .section-container{padding:0 24px}
  .section-pad{padding:88px 0}
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:62px;left:0;right:0;background:rgba(255,240,245,.99);border-bottom:1px solid rgba(220,20,60,.18);padding:20px 24px;gap:16px;backdrop-filter:blur(20px)}
  .navbar:not(.scrolled) .nav-links.open a{color:var(--text-dark)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .tri-r1,.tri-r2,.tri-r3{width:100%}
  .formula-eq{gap:8px}
  .fe-item{font-size:.95rem;padding:8px 10px}
  .fe-op,.fe-eq{font-size:1.4rem}
  .fe-result{font-size:1rem}
  .flow-steps{flex-wrap:wrap;gap:8px;justify-content:center}
  .flow-step{min-width:72px;padding:12px 8px}
  .flow-arrow{display:none}
  .platform-img-row{grid-template-columns:1fr}
  .closing-cta{flex-direction:column;align-items:center}
  .btn-xl{font-size:.95rem;padding:15px 28px;width:100%;max-width:380px;justify-content:center}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-copy{text-align:center}
  .hero-stats-strip{flex-wrap:wrap}
  .hss-item{flex-basis:50%;border-bottom:1px solid rgba(220,20,60,.1)}
}
