
*,*::before,*::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --bg-pure: #030303; --bg-elevated: #0a0a0c; 
  --bg-card: rgba(16, 18, 28, 0.72); 
  --white: #ffffff; --white-strong: #ffffff; 
  --gray: #c8c8d0; --gray-dim: #9a9aa5; --gray-faint: #32323c;
  --gold: #D4A843; --gold-light: #E8C860; --gold-dark: #B8922E;
  --gold-gradient: linear-gradient(135deg, #E8C860 0%, #D4A843 40%, #B8922E 70%, #D4A843 100%);
  --gold-border: rgba(212, 168, 67, 0.4);
  
  --sans: 'Inter', 'PingFang TC', 'Microsoft JhengHei', 'Microsoft YaHei', 'Noto Sans TC', system-ui, sans-serif;
  --heading: 'Syne', 'Inter', 'PingFang TC', 'Microsoft JhengHei', 'Noto Sans TC', sans-serif;
  
  --fs-hero: clamp(2.2rem, 7.2vw, 6.9rem);
  --fs-h2: clamp(1.65rem, 4.3vw, 3.35rem);
  --fs-h3: clamp(1.25rem, 2.2vw, 1.95rem);
  --fs-body: clamp(1rem, 1.15vw, 1.2rem);
  --fs-sm: clamp(0.9rem, 0.9vw, 1rem);
  --fs-xs: clamp(0.75rem, 0.8vw, 0.9rem);
  --fs-xxs: 0.72rem;
  
  --section-pad: clamp(100px, 11vw, 180px);
  --grid-max: 1320px;
}

html { scroll-behavior: auto; background: var(--bg-pure); }
body { 
  background: var(--bg-pure); color: var(--white); font-family: var(--sans); 
  font-weight: 400; line-height: 1.8; overflow-x: hidden; cursor: none;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; letter-spacing: 0;
  line-break: strict;
  word-break: keep-all;
  overflow-wrap: break-word;
}
::selection { background: var(--gold); color: var(--bg-pure); }
img { max-width: 100%; display: block; object-fit: cover; }
a, button { color: var(--gold); text-decoration: none; cursor: none; outline: none; border: none; background: none; font-family: inherit;}
h1, h2, h3, h4, h5, h6 { line-break: strict; word-break: keep-all; overflow-wrap: anywhere; text-wrap: balance; }
p, li, .faq-q, .faq-a-inner, .g-cap, .mod-text, .ev-title, .ev-quote { line-break: strict; word-break: keep-all; overflow-wrap: break-word; text-wrap: pretty; }

body::after { content: ''; position: fixed; inset: 0; z-index: 9998; pointer-events: none; opacity: 0.04; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
#webgl-canvas { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 1; pointer-events: none; opacity: 0.97; }
#mobile-ambient-canvas { display: none; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 1; pointer-events: none; opacity: 0; }

.cursor { position: fixed; width: 20px; height: 20px; border: 1.5px solid var(--white); border-radius: 50%; pointer-events: none; z-index: 99999; transform: translate(-50%, -50%); mix-blend-mode: difference; display: flex; align-items: center; justify-content: center; transition: width 0.3s cubic-bezier(0.23, 1, 0.32, 1), height 0.3s cubic-bezier(0.23, 1, 0.32, 1), background 0.3s, border-color 0.3s; }
.cursor-dot { position: fixed; width: 4px; height: 4px; background: var(--white); border-radius: 50%; pointer-events: none; z-index: 99999; transform: translate(-50%, -50%); mix-blend-mode: difference; }
.cursor-text { font-size: 8px; font-weight: 800; letter-spacing: 2px; color: var(--bg-pure); opacity: 0; transition: opacity 0.2s; mix-blend-mode: normal; text-align: center; }
.cursor.hovering { width: 60px; height: 60px; background: rgba(255,255,255,0.1); border-color: transparent; backdrop-filter: blur(4px); }
.cursor.action { width: 80px; height: 80px; background: var(--gold); border-color: var(--gold); mix-blend-mode: normal; }
.cursor.action .cursor-text { opacity: 1; }
@media (max-width: 1024px) { .cursor, .cursor-dot { display: none; } body, a, button { cursor: auto; } }

.preloader { position: fixed; inset: 0; z-index: 100000; background: radial-gradient(circle at 50% 35%, rgba(212,168,67,0.16), transparent 42%), linear-gradient(180deg, rgba(3,3,3,0.96) 0%, rgba(3,3,3,0.92) 100%); backdrop-filter: blur(12px); display: flex; align-items: center; justify-content: center; flex-direction: column; pointer-events: none; transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.7s ease, transform 0.7s cubic-bezier(0.22, 1, 0.36, 1); }
.preloader::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(212,168,67,0.12); opacity: 0.9; }
.preloader > * { position: relative; z-index: 1; transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.7s ease; }
.preloader.is-hidden { opacity: 0; visibility: hidden; transform: scale(1.015); }
.preloader.is-hidden > * { opacity: 0; transform: translateY(-18px); }
.pre-counter { font-family: var(--heading); font-size: clamp(3.8rem, 9vw, 7rem); font-weight: 800; color: var(--gold); line-height: 1; text-shadow: 0 0 28px rgba(212,168,67,0.22); }
.pre-sub { font-size: var(--fs-xs); letter-spacing: 6px; text-transform: uppercase; color: var(--gray-dim); margin-top: 12px; text-align: center; padding: 0 20px; }
.pre-bar-wrap { width: min(240px, calc(100vw - 72px)); height: 1px; background: rgba(255,255,255,0.1); margin-top: 30px; position: relative; overflow: hidden; }
.pre-bar { position: absolute; top: 0; left: 0; height: 100%; width: 0%; background: var(--gold-gradient); box-shadow: 0 0 24px rgba(212,168,67,0.45); }

.container { max-width: var(--grid-max); margin: 0 auto; padding: 0 clamp(24px, 5vw, 60px); position: relative; z-index: 1; }
.section { padding: var(--section-pad) 0; position: relative; }
.label { font-size: var(--fs-xxs); font-weight: 800; letter-spacing: 5px; text-transform: uppercase; color: var(--gold); display: inline-flex; align-items: center; gap: 10px; margin-bottom: 24px; }
.label::before { content: ''; width: 24px; height: 1.5px; background: var(--gold); }
.heading-xl { font-family: var(--heading); font-size: var(--fs-hero); font-weight: 900; line-height: 1.15; letter-spacing: -0.02em; color: var(--white-strong); }
.heading-lg { font-family: var(--heading); font-size: var(--fs-h2); font-weight: 800; line-height: 1.25; letter-spacing: -0.01em; color: var(--white-strong); }
.title-chunk { display: block; }
.balance-title { text-wrap: balance; }
.copy-safe { line-break: strict; word-break: keep-all; overflow-wrap: break-word; text-wrap: pretty; }
.nowrap-token { white-space: nowrap !important; display: inline-block; }
.price-safe, .price-safe * { white-space: nowrap !important; }

.char-wrap { display: inline-block; }
.char { display: inline-block; opacity: 1; transform: none; will-change: transform, opacity; }
html.js-enhanced .char { opacity: 0; transform: translateY(30px); }
.text-gold { color: var(--gold); } 
.text-gold .char { background: var(--gold-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }

.badge { display: inline-block; padding: 6px 14px; border: 1px solid var(--gold-border); font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); margin: 0 6px 8px 0; border-radius: 4px; background: rgba(212,168,67,0.05); backdrop-filter: blur(5px); }

.icon-svg { width: 1.5em; height: 1.5em; fill: currentColor; }
.icon-svg-stroke { width: 1.5em; height: 1.5em; fill: none; stroke: currentColor; stroke-width: 1.95; stroke-linecap: round; stroke-linejoin: round; }

.btn { display: inline-flex; align-items: center; justify-content: center; position: relative; overflow: hidden; font-weight: 800; font-size: var(--fs-sm); letter-spacing: 2px; text-transform: uppercase; padding: 22px 48px; border-radius: 4px; transition: transform 0.3s, box-shadow 0.3s, background 0.3s, border 0.3s; border: 1px solid transparent; text-align: center; }
.btn-primary { background: var(--gold-gradient); color: var(--bg-pure) !important; }
.btn-primary:hover { box-shadow: 0 10px 40px rgba(212, 168, 67, 0.4); transform: translateY(-3px); }
.btn-outline { border-color: var(--gray-dim); color: var(--white); }
.btn-outline:hover { border-color: var(--gold); color: var(--gold); background: rgba(212,168,67,0.1); }

nav { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 24px 0; transition: background 0.4s, padding 0.4s; }
nav.scrolled { background: rgba(3,3,3,0.92); backdrop-filter: blur(20px); padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
.nav-inner { display: flex; justify-content: space-between; align-items: center; }
.logo { display: flex; flex-direction: column; gap: 2px; align-items: flex-start; line-height: 1; }
.logo-main { font-weight: 900; font-size: 18px; letter-spacing: -0.3px; font-family: var(--heading); color: var(--white-strong); }
.logo-main .divider { color: var(--gold); margin: 0 4px; }
.logo-role { font-size: 10px; font-weight: 700; color: var(--gray-dim); font-family: var(--sans); letter-spacing: 1.8px; text-transform: uppercase; }
nav ul { display: flex; gap: 32px; list-style: none; align-items: center; transition: 0.3s; }
nav ul a { font-size: var(--fs-xs); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gray); transition: color 0.3s; }
nav ul a:hover { color: var(--gold); }
.nav-toggle { display: none; width: 30px; height: 20px; flex-direction: column; justify-content: space-between; z-index: 1001; }
.nav-toggle span { width: 100%; height: 2px; background: var(--white); transition: 0.3s; }
@media(max-width: 900px) {
  nav ul { position: fixed; top: 0; right: -100%; width: 100%; height: 100vh; background: var(--bg-pure); flex-direction: column; justify-content: center; gap: 40px; }
  nav ul.active { right: 0; }
  .nav-toggle { display: flex; }
  .nav-toggle.active span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
  .nav-toggle.active span:nth-child(2) { opacity: 0; }
  .nav-toggle.active span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }
}

@media (max-width: 1023px) and (prefers-reduced-motion: no-preference) {
  #webgl-canvas { display: none; }
  #mobile-ambient-canvas { display: block; opacity: 0.94; }
}

.save-data #mobile-ambient-canvas,
.reduced-motion #mobile-ambient-canvas { display: none !important; opacity: 0 !important; }

.hero { min-height: 100vh; display: flex; align-items: center; padding-top: 10vh; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none; background: radial-gradient(ellipse at 50% 42%, rgba(232,200,96,0.2) 0%, rgba(120,156,210,0.12) 30%, rgba(3,3,3,0) 68%); }
.hero-content { max-width: 900px; position: relative; z-index: 3; }
.hero-bg-img { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.hero-bg-img img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; opacity: 0.4; filter: grayscale(0.22) contrast(1.05); mix-blend-mode: normal; }
.hero-bg-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to right, rgba(3,3,3,0.68) 0%, rgba(3,3,3,0.14) 52%, rgba(3,3,3,0.58) 100%), linear-gradient(to bottom, rgba(3,3,3,0.02) 56%, rgba(3,3,3,0.88) 100%); }
.hero-title { max-width: 12ch; }
.hero-title-line { display: block; }
.hero-title-pre,
.hero-title-flow { display: inline; }
.hero-title-flow { white-space: nowrap; }
.hero-subtitle { font-size: var(--fs-body); color: var(--gray); max-width: 680px; margin-top: 38px; line-height: 1.95; font-weight: 350; }
.hero-subtitle strong { color: var(--white-strong); font-weight: 700; }
.industry-focus { color: var(--gold-light); font-weight: 700; }
.text-gray { color: var(--gray); font-size: var(--fs-body); line-height: 1.9; font-weight: 400; }
.hero-buttons { display: flex; gap: 20px; margin-top: 50px; flex-wrap: wrap; }
.scroll-indicator { position: absolute; bottom: 46px; right: clamp(24px, 5vw, 60px); display: flex; flex-direction: column; align-items: center; gap: 12px; opacity: 0.45; z-index: 3; }
.scroll-indicator span { font-size: 9px; letter-spacing: 4px; text-transform: uppercase; font-weight: 800; }
.scroll-line { width: 1px; height: 60px; background: var(--gray-faint); position: relative; overflow: hidden; }
.scroll-line::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 50%; background: var(--gold); animation: scroll 2s ease-in-out infinite; }
@keyframes scroll { 0% { top: -50%; } 100% { top: 150%; } }

.marquee-wrapper { overflow: hidden; padding: 2.5vw 0; background: var(--gold-gradient); color: var(--bg-pure); font-family: var(--heading); font-weight: 900; font-size: clamp(2rem, 4vw, 3.5rem); white-space: nowrap; display: flex; transform: rotate(-2deg) scale(1.05); box-shadow: 0 0 50px rgba(212,168,67,0.3); position: relative; z-index: 2; margin-bottom: 80px; }
.marquee { display: flex; animation: marquee 25s linear infinite; }
.marquee span { padding-right: 2vw; display: inline-block; letter-spacing: 2px; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

.stats-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; text-align: center; border-top: 1px solid rgba(255,255,255,0.08); border-bottom: 1px solid rgba(255,255,255,0.08); padding: 60px 0; margin-bottom: 100px; background: rgba(10,10,12,0.4); backdrop-filter: blur(5px); }
@media(max-width: 768px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } .stats-grid .stat-item:last-child { grid-column: span 2; } }
.stat-number { font-family: var(--heading); font-size: clamp(3rem, 5vw, 4.8rem); font-weight: 900; color: var(--gold-light); line-height: 1; margin-bottom: 12px; text-shadow: 0 0 24px rgba(232,200,96,0.5), 0 0 56px rgba(212,168,67,0.2);}
.stat-desc { font-size: var(--fs-xs); color: var(--gray); letter-spacing: 3px; text-transform: uppercase; font-weight: 700; display: flex; align-items: center; justify-content: center; gap: 8px; }

.logo-overflow { overflow: hidden; position: relative; z-index: 2; }
.logo-overflow::before, .logo-overflow::after { content: ''; position: absolute; top: 0; bottom: 0; width: 250px; z-index: 2; pointer-events: none; }
.logo-overflow::before { left: 0; background: linear-gradient(90deg, var(--bg-pure), transparent); }
.logo-overflow::after { right: 0; background: linear-gradient(-90deg, var(--bg-pure), transparent); }
@media(max-width:768px) { .logo-overflow::before, .logo-overflow::after { width: 60px; } }
.logo-scroll-track { display: flex; gap: 16px; width: max-content; margin-bottom: 14px; }
.logo-item {
  flex-shrink: 0;
  width: 242px;
  min-height: 106px;
  border: 1px solid rgba(212,168,67,0.22);
  display: flex;
  flex-direction: column;
  gap: 7px;
  align-items: center;
  justify-content: center;
  padding: 9px 11px 10px;
  color: var(--gray);
  background: linear-gradient(160deg, rgba(18,20,28,0.92), rgba(10,12,18,0.88));
  backdrop-filter: blur(8px);
  border-radius: 8px;
  transition: 0.28s;
  text-decoration: none;
}
.logo-item:hover {
  border-color: rgba(212,168,67,0.65);
  background: linear-gradient(160deg, rgba(28,31,42,0.93), rgba(12,13,20,0.9));
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,0.35), 0 0 0 1px rgba(212,168,67,0.26);
}
.logo-logo-wrap {
  width: 100%;
  height: 74px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: 7px 8px;
  background: radial-gradient(130% 145% at 50% 8%, rgba(255,255,255,0.2) 0%, rgba(16,19,30,0.94) 44%, rgba(8,10,16,0.98) 100%);
  border: 1px solid rgba(212,168,67,0.24);
}
.logo-logo-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  opacity: 1;
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0) 42%);
}
.logo-logo-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: radial-gradient(80% 72% at 50% 48%, rgba(232,200,96,0.18), rgba(232,200,96,0) 72%);
}
.logo-logo-wrap img.logo-source {
  position: relative;
  z-index: 3;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  opacity: 1;
  mix-blend-mode: normal;
  
  filter: url('#logoRecolorGold') brightness(1.06) contrast(1.12) drop-shadow(0 0 0.8px rgba(255,246,214,0.32)) drop-shadow(0 0 3px rgba(212,168,67,0.12));
  transition: opacity .26s ease, filter .26s ease, transform .26s ease;
}
.logo-name {
  font-size: 10px;
  font-weight: 700;
  color: rgba(245,247,250,0.9);
  letter-spacing: 0.6px;
  line-height: 1.2;
  text-align: center;
  width: 100%;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.logo-item:hover .logo-name { color: #ffffff; }
.logo-item:hover img.logo-source {
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  transform: scale(1.015);
  z-index: 5;
}
@media(max-width: 768px) {
  .logo-item { width: 212px; min-height: 98px; }
  .logo-logo-wrap { height: 68px; }
  .logo-name { font-size: 9px; }
}

.spotlight-card { background: linear-gradient(160deg, rgba(14,16,24,0.86) 0%, rgba(10,12,20,0.78) 45%, rgba(8,10,16,0.82) 100%); backdrop-filter: blur(20px) saturate(112%); border: 1.2px solid rgba(255,255,255,0.14); position: relative; overflow: hidden; transform-style: preserve-3d; will-change: transform; border-radius: 8px; box-shadow: 0 14px 42px rgba(0,0,0,0.4), inset 0 0 0 1px rgba(255,255,255,0.03); }
.spotlight-card::before { content: ''; position: absolute; inset: -1px; padding: 1px; background: radial-gradient(600px circle at var(--mouse-x) var(--mouse-y), rgba(212,168,67,0.35), transparent 40%); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; opacity: 0; transition: opacity 0.4s; z-index: 2; }
.spotlight-card:hover::before { opacity: 1; }
.spotlight-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0) 28%, rgba(3,3,3,0.08) 100%); pointer-events: none; z-index: 0; }
.spotlight-card-content { position: relative; z-index: 1; transform: translateZ(30px); height: 100%; display: flex; flex-direction: column; }

.hscroll-viewport { overflow-x: auto; scrollbar-width: none; cursor: grab; padding-bottom: 40px; padding-left: clamp(24px, calc((100vw - var(--grid-max))/2 + 24px), 10vw); }
.hscroll-viewport::-webkit-scrollbar { display: none; }
.hscroll-viewport:active { cursor: grabbing; }
.hscroll-track { display: flex; gap: 32px; width: max-content; margin-top: 30px; }
.section-header-flex { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 20px; }
.slider-controls { display: flex; gap: 12px; position: relative; z-index: 6; }
.slider-btn { width: 54px; height: 54px; border: 1px solid rgba(255,255,255,0.15); border-radius: 50%; background: var(--bg-card); color: var(--white); display: flex; align-items: center; justify-content: center; font-size: 20px; transition: 0.3s; backdrop-filter: blur(5px); position: relative; z-index: 7; pointer-events: auto; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.05); }
.slider-btn:hover { border-color: var(--gold); color: var(--gold); background: rgba(212,168,67,0.15); transform: scale(1.05); box-shadow: 0 0 0 1px rgba(212,168,67,0.35), 0 8px 22px rgba(0,0,0,0.35); }

.ev-card { width: 458px; flex-shrink: 0; padding: 40px 38px; min-height: 458px; }
@media(max-width: 768px) { .ev-card { width: 336px; padding: 30px 28px; min-height: 420px; } }
.ev-card-gold { position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: var(--gold-gradient); }
.ev-type { font-size: 10px; font-weight: 800; letter-spacing: 2.4px; color: var(--gold); text-transform: uppercase; margin-bottom: 16px; display:flex; align-items:center; gap:8px; }
.ev-title { font-size: 1.28rem; font-weight: 800; line-height: 1.36; color: var(--white-strong); margin-bottom: 12px; }
.ba-row { display: flex; gap: 10px; margin-bottom: 8px; font-size: 0.84rem; color: var(--gray); align-items: flex-start; line-height: 1.5; }
.ba-tag { flex-shrink: 0; width: 60px; font-size: 9px; font-weight: 800; letter-spacing: 1.5px; text-align: center; padding: 5px 0; border-radius: 3px; }
.ba-tag.before { border: 1px solid var(--gray-dim); }
.ba-tag.after { color: var(--bg-pure); background: var(--gold); }

.ev-kpi-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin: 16px 0 16px; }
.ev-kpi { border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.02); border-radius: 6px; padding: 10px 10px 9px; }
.ev-kpi-num { font-family: var(--heading); font-size: 1.18rem; font-weight: 800; color: var(--gold-light); line-height: 1.08; }
.ev-kpi-lab { font-size: 10px; color: var(--gray); letter-spacing: 1.4px; text-transform: uppercase; margin-top: 6px; }

.ev-proof-list { list-style: none; padding: 0; margin: 0 0 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.ev-proof-item { border: 1px solid rgba(212,168,67,0.35); background: rgba(212,168,67,0.08); color: var(--gold-light); font-size: 10px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; padding: 6px 10px; border-radius: 999px; }

.ev-testimonial { margin-top: auto; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.1); display: flex; gap: 14px; align-items: center; }
.ev-avatar { width: 54px; height: 54px; border-radius: 50%; overflow: hidden; border: 1px solid rgba(255,255,255,0.18); flex-shrink: 0; background: #0f172a; }
.ev-avatar img { width: 100%; height: 100%; object-fit: cover; }
.ev-quote { font-size: clamp(0.89rem, 0.9vw, 0.98rem); color: var(--white); font-style: italic; line-height: 1.62; margin-bottom: 12px; font-weight: 380; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden; }
.ev-author { font-size: var(--fs-sm); color: var(--white-strong); font-weight: 800; }
.ev-author span { color: var(--gray); font-weight: 500; font-size: 12px; letter-spacing: 1px; }
.ev-company { color: var(--gray-dim); font-size: 11px; letter-spacing: 1.2px; text-transform: uppercase; margin-top: 3px; }
.ev-video-trigger { margin-top: 8px; width: 100%; justify-content: center; }

.evidence-more { margin-top: 38px; }
.evidence-more-head { display: flex; justify-content: space-between; align-items: center; gap: 16px; color: var(--white-strong); font-size: 1rem; font-weight: 800; letter-spacing: 1px; margin-bottom: 12px; }
.evidence-more-head > span { display: inline-flex; align-items: center; gap: 10px; }
.evidence-more-head > span::before { content: ''; width: 16px; height: 1px; background: var(--gold); }
.evidence-trust { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.evidence-trust span { border: 1px solid rgba(212,168,67,0.34); color: var(--gold-light); background: rgba(212,168,67,0.08); padding: 6px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: 0.8px; }
.evidence-more-viewport { overflow-x: auto; scrollbar-width: none; cursor: grab; }
.evidence-more-viewport::-webkit-scrollbar { display: none; }
.evidence-more-track { display: flex; gap: 12px; width: max-content; }
.more-quote-card { width: 340px; background: rgba(12,14,20,0.76); border: 1px solid rgba(255,255,255,0.12); border-radius: 8px; padding: 13px 14px; min-height: 126px; display: flex; flex-direction: column; gap: 10px; }
.more-quote-text { color: var(--gray); font-size: 0.89rem; line-height: 1.58; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden; }
.more-meta { margin-top: auto; display: flex; align-items: center; gap: 10px; }
.more-avatar { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; border: 1px solid rgba(255,255,255,0.18); background: #111827; flex-shrink: 0; }
.more-avatar img { width: 100%; height: 100%; object-fit: cover; }
.more-name { color: var(--white-strong); font-size: 12px; font-weight: 700; }
.more-role { color: var(--gray-dim); font-size: 11px; margin-top: 2px; }
.evidence-actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 10px; }
.evidence-video-btn { min-height: 54px; padding: 0 18px; font-size: 0.9rem; display: inline-flex; align-items: center; gap: 8px; }
.evidence-video-list { display: none; width: 100%; justify-content: flex-end; gap: 8px; margin-top: 6px; }
.evidence-video-list.show { display: flex; flex-wrap: wrap; }
.evidence-video-chip { border: 1px solid rgba(255,255,255,0.14); color: var(--gray); background: rgba(14,16,23,0.72); border-radius: 999px; font-size: 12px; padding: 6px 12px; }
.evidence-video-chip:hover { border-color: rgba(212,168,67,0.5); color: var(--gold-light); }
@media(max-width: 640px) {
  .ev-kpi-grid { grid-template-columns: 1fr; }
  .more-quote-card { width: 300px; min-height: 118px; }
}

.module-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 24px; margin-top: 60px; }
.module-card { flex: 1 1 calc(33.333% - 24px); padding: 50px 40px; min-width: 320px; }
@media(max-width: 1024px) { .module-card { flex: 1 1 calc(50% - 24px); } }
@media(max-width: 768px) { .module-card { flex: 1 1 100%; padding: 40px 30px; } }

.mod-num { font-family: var(--sans); font-size: 11px; font-weight: 800; color: var(--white-strong); background: rgba(255,255,255,0.1); padding: 6px 14px; border-radius: 4px; display: inline-block; letter-spacing: 2px; margin-bottom: 24px; border: 1px solid rgba(255,255,255,0.1); }
.mod-title { font-size: 1.3rem; font-weight: 800; color: var(--white-strong); line-height: 1.5; margin-bottom: 30px; }
.mod-card-icon { margin-bottom: 20px; color: var(--gold); opacity: 0.86; }
.mod-card-icon svg { width: 38px; height: 38px; fill: none; stroke: currentColor; stroke-width: 1.95; stroke-linecap: round; stroke-linejoin: round; }
.mod-row { display: flex; gap: 16px; margin-bottom: 20px; align-items: flex-start; min-width: 0; }
.mod-icon { flex-shrink: 0; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: 50%; font-size: 14px; }
.mod-icon.pain { color: var(--gray-dim); background: rgba(255,255,255,0.05); }
.mod-icon.val { color: var(--bg-pure); background: var(--gold); }
.mod-text { flex: 1; min-width: 0; font-size: 0.95rem; color: var(--gray); line-height: 1.7; font-weight: 400; }
.mod-text strong { color: var(--white-strong); display: block; margin-bottom: 4px; font-size: 12px; text-transform: uppercase; letter-spacing: 2px; font-weight: 700;}
.mod-tags { border-top: 1px solid rgba(255,255,255,0.08); margin-top: auto; padding-top: 30px; display: flex; flex-wrap: wrap; gap: 8px; }

.gallery-item { flex-shrink: 0; width: 420px; height: 300px; position: relative; overflow: hidden; border-radius: 8px; border: 1px solid rgba(255,255,255,0.08); }
@media(max-width: 768px) { .gallery-item { width: 320px; height: 220px; } }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
.gallery-item:hover img { transform: scale(1.08); }
.g-cap { position: absolute; bottom: 0; left: 0; right: 0; padding: 40px 24px 20px; background: linear-gradient(transparent, rgba(3,3,3,0.95)); font-size: var(--fs-sm); font-weight: 700; color: var(--white-strong); pointer-events: none; text-shadow: 0 2px 10px rgba(0,0,0,0.8); }

.lightbox { display: none; position: fixed; inset: 0; z-index: 10000; background: rgba(3,3,3,.98); backdrop-filter: blur(16px); align-items: center; justify-content: center; flex-direction: column; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 90vw; max-height: 75vh; object-fit: contain; box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
.lb-cap { margin-top: 24px; font-size: 1.2rem; font-weight: 700; color: var(--gold); letter-spacing: 1px; }
.lb-close { position: absolute; top: 30px; right: 40px; font-size: 30px; color: var(--white); transition: .3s; z-index: 10001; }
.lb-close:hover { color: var(--gold); transform: scale(1.1); }
.lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 60px; height: 60px; border: 1px solid rgba(255,255,255,0.15); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--white); transition: .3s; backdrop-filter: blur(5px); z-index: 10001; }
.lb-nav:hover { border-color: var(--gold); color: var(--gold); background: rgba(212,168,67,0.15); }
.lb-nav.prev { left: 40px; } .lb-nav.next { right: 40px; }

.video-modal { display: none; position: fixed; inset: 0; z-index: 10010; background: rgba(3,3,3,0.92); backdrop-filter: blur(12px); align-items: center; justify-content: center; padding: 24px; }
.video-modal.open { display: flex; }
.video-modal-inner { width: min(980px, 92vw); background: rgba(12,14,20,0.92); border: 1px solid rgba(255,255,255,0.16); border-radius: 12px; padding: 18px 18px 14px; box-shadow: 0 24px 70px rgba(0,0,0,0.55); }
.video-modal video { width: 100%; max-height: 74vh; border-radius: 10px; background: #000; object-fit: contain; }
.video-cap { margin-top: 10px; color: var(--gray); font-size: var(--fs-sm); line-height: 1.6; }
.video-close { position: absolute; top: 26px; right: 34px; font-size: 30px; color: var(--white); transition: .3s; z-index: 10011; }
.video-close:hover { color: var(--gold); transform: scale(1.08); }

.about-grid { display: grid; grid-template-columns: 400px 1fr; gap: 80px; align-items: start; margin-top: 60px; }
@media(max-width:900px) { .about-grid { grid-template-columns: 1fr; gap: 40px; } .about-photo { max-width: 350px; margin: 0 auto; } }
.about-frame { position: relative; aspect-ratio: 3/4; overflow: hidden; border: 1px solid rgba(255,255,255,0.08); border-radius: 4px; }
.about-frame img { width: 100%; height: 100%; filter: grayscale(0.5) contrast(1.1); transition: filter .6s; }
.about-frame:hover img { filter: grayscale(0); }
.cm { position: absolute; width: 20px; height: 20px; pointer-events: none; z-index: 2; }
.cm::before, .cm::after { content: ''; position: absolute; background: var(--gold); }
.cm.tl { top: 12px; left: 12px; } .cm.tl::before { width: 14px; height: 2px; } .cm.tl::after { width: 2px; height: 14px; }
.cm.tr { top: 12px; right: 12px; } .cm.tr::before { width: 14px; height: 2px; right: 0; } .cm.tr::after { width: 2px; height: 14px; right: 0; }
.cm.bl { bottom: 12px; left: 12px; } .cm.bl::before { width: 14px; height: 2px; bottom: 0; } .cm.bl::after { width: 2px; height: 14px; bottom: 0; }
.cm.br { bottom: 12px; right: 12px; } .cm.br::before { width: 14px; height: 2px; bottom: 0; right: 0; } .cm.br::after { width: 2px; height: 14px; bottom: 0; right: 0; }
.spec-row { display: grid; grid-template-columns: 120px 1fr; gap: 20px; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,0.08); font-size: var(--fs-sm); align-items: baseline; }
.spec-key { font-size: 11px; font-weight: 800; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; }
.about-caption { margin-top: 14px; color: var(--gray-dim); }
.about-name { font-size: 1.15rem; font-weight: 900; color: var(--white-strong); letter-spacing: 0.6px; }
.about-role { font-size: 11px; text-transform: uppercase; letter-spacing: 2px; color: var(--gold-light); margin-top: 6px; }
.about-actions { margin-top: 46px; display: flex; flex-wrap: wrap; gap: 16px; justify-content: flex-start; }

.draft-wrapper { display: flex; gap: 80px; max-width: 1300px; margin: 80px auto 0; padding: 0 clamp(24px, 5vw, 60px); position: relative; }
@media(max-width: 900px) { .draft-wrapper { flex-direction: column; } }
.draft-sticky-left { flex: 1; position: sticky; top: 200px; height: fit-content; }
.draft-scrolling-right { flex: 1.2; display: flex; flex-direction: column; gap: 40vh; padding-bottom: 20vh; }

.draft-big-letter { font-family: var(--heading); font-size: clamp(10rem, 18vw, 22rem); font-weight: 900; line-height: 1; margin-bottom: 30px; transition: all 0.4s ease; background: linear-gradient(135deg, rgba(232,200,96,0.62) 0%, rgba(212,168,67,0.48) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; filter: drop-shadow(0 0 28px rgba(212,168,67,0.22)); opacity: 0.98; }
.draft-big-letter.active { background: var(--gold-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; filter: drop-shadow(0 0 62px rgba(212,168,67,0.42)); opacity: 1; }
.draft-progress-bar { width: 100%; max-width: 300px; height: 4px; background: rgba(255,255,255,0.1); border-radius: 4px; overflow: hidden; position: relative; margin-top: 40px; }
.draft-progress-fill { position: absolute; top: 0; left: 0; height: 100%; width: 0%; background: var(--gold-gradient); transition: width 0.3s; }
.draft-mobile-stepper { display: none; }
.draft-mobile-stepper-card { background: rgba(8,10,18,0.82); border: 1px solid rgba(255,255,255,0.08); border-radius: 18px; padding: 16px 18px 14px; backdrop-filter: blur(16px); box-shadow: 0 18px 46px rgba(0,0,0,0.3); }
.draft-mobile-stepper-top { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 14px; }
.draft-mobile-letter { font-family: var(--heading); font-size: clamp(2.6rem, 7vw, 4rem); font-weight: 900; line-height: 1; background: var(--gold-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; filter: drop-shadow(0 0 20px rgba(212,168,67,0.2)); }
.draft-mobile-label { font-size: 10px; font-weight: 800; letter-spacing: 2.2px; text-transform: uppercase; color: var(--gold); margin-bottom: 6px; }
.draft-mobile-name { font-family: var(--heading); font-size: clamp(1.2rem, 2.8vw, 1.7rem); font-weight: 800; color: var(--white-strong); line-height: 1.05; }
.draft-mobile-count { font-size: 11px; font-weight: 800; letter-spacing: 2px; color: var(--gray-dim); text-transform: uppercase; }
.draft-mobile-meta { margin-top: 10px; color: var(--gray); font-size: 0.94rem; line-height: 1.5; }
.draft-progress-bar-mobile { max-width: none; margin-top: 14px; }

.draft-card { position: relative; overflow: hidden; background: var(--bg-card); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,0.08); padding: 60px; border-radius: 12px; opacity: 0.2; transition: opacity 0.4s, transform 0.4s, border-color 0.3s, box-shadow 0.3s; transform: scale(0.95); }
.draft-card.active { opacity: 1; transform: scale(1); border-color: var(--gold-border); box-shadow: 0 20px 60px rgba(0,0,0,0.6); }
.draft-card h3 { font-family: var(--heading); font-size: var(--fs-h2); font-weight: 800; color: var(--white-strong); margin-bottom: 8px; }
.draft-card h4 { font-size: 13px; font-weight: 800; color: var(--gold); letter-spacing: 4px; text-transform: uppercase; margin: 0 0 30px 0; padding-bottom: 30px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.draft-card p { font-size: var(--fs-body); color: var(--gray); line-height: 2; font-weight: 400; }

.pricing-tier { margin-bottom: 100px; }
.pricing-tier-header { display: flex; align-items: center; gap: 30px; margin-bottom: 40px; }
.pricing-tier-num { font-family: var(--sans); font-size: clamp(3rem, 5vw, 4.5rem); font-weight: 900; color: var(--bg-pure); -webkit-text-stroke: 1.9px var(--gold); paint-order: stroke fill; stroke-linejoin: round; text-shadow: 0 0 20px rgba(212,168,67,0.2); line-height: 1; }
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 24px; }

.p-card { padding: 52px 50px 56px; }
.p-head { margin-bottom: 14px; }
.p-card-top { position: relative; top: auto; left: auto; right: auto; height: 2px; background: var(--gold-gradient); margin-top: 12px; opacity: 0.95; border-radius: 2px; box-shadow: 0 0 14px rgba(212,168,67,0.24); }
.p-price { font-family: var(--heading); font-size: 2.5rem; font-weight: 800; color: var(--gold); margin: 18px 0 38px; border-bottom: 1px solid rgba(255,255,255,0.14); padding-bottom: 38px; }
.plan-name { line-height: 1.33; margin: 0; padding: 0; font-weight: 760; color: var(--white-strong); }
.plan-meta { font-size:12px; color:var(--gray); letter-spacing:0.9px; margin: 8px 0 0; font-weight: 550; }
.p-card ul { list-style: none; margin-bottom: 50px; flex-grow: 1; }
.p-card ul li { margin-bottom: 20px; font-size: var(--fs-sm); color: #d0d0d8; position: relative; padding-left: 28px; line-height: 1.8; }
.p-card ul li::before { content: '✦'; position: absolute; left: 0; color: var(--gold); font-size: 12px; top: 4px; }

.p-card.horizontal { grid-column: 1 / -1; display: flex; gap: 80px; align-items: flex-start; }
.p-card.horizontal .p-left { flex: 1; position: relative; padding-right: 60px; }
.p-card.horizontal .p-left::after { content: ''; position: absolute; top: 18px; bottom: 18px; right: -1px; width: 1px; background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,0.16) 14%, rgba(255,255,255,0.16) 86%, rgba(255,255,255,0) 100%); }
.p-card.horizontal .p-right { flex: 2; display: flex; flex-direction: column; width: 100%; padding-left: 28px; }
.p-card.horizontal .plan-name { padding-top: 0; }
.p-card.horizontal ul { column-count: 2; column-gap: 40px; margin-bottom: 32px; margin-top: 10px; }
.p-card.horizontal .p-right .btn { margin-top: 4px; }
@media(max-width: 900px) { 
  .p-card.horizontal { flex-direction: column; gap: 40px; align-items: flex-start; } 
  .p-card.horizontal .p-left { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); padding-right: 0; padding-bottom: 40px; width: 100%; } 
  .p-card.horizontal .p-left::after { display: none; }
  .p-card.horizontal .p-right { padding-left: 0; }
  .p-card.horizontal ul { column-count: 1; margin-top: 0; }
  .p-card { padding: 42px 28px 44px; }
}

.offer-box { background: rgba(212,168,67,0.08); border: 1px solid var(--gold-border); padding: 50px 60px; display: flex; flex-direction: column; justify-content: center; border-radius: 8px; }

.process-timeline { display: flex; justify-content: space-between; align-items: flex-start; margin: 80px 0 40px; position: relative; }
.process-timeline::before { content: ''; position: absolute; top: 35px; left: 0; right: 0; height: 1px; background: rgba(255,255,255,0.15); z-index: 0; }
.process-step { flex: 1; text-align: center; position: relative; z-index: 1; padding: 0 10px; }
.p-circle { width: 70px; height: 70px; border-radius: 50%; background: var(--bg-elevated); border: 1.9px solid var(--gold); color: var(--gold); font-family: var(--heading); font-weight: 800; font-size: 1.4rem; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; box-shadow: 0 0 20px rgba(212,168,67,0.2); transition: 0.3s; }
.process-step:hover .p-circle { background: var(--gold); color: var(--bg-pure); transform: scale(1.1); }
.p-title { font-size: var(--fs-sm); font-weight: 800; color: var(--white-strong); }
@media(max-width: 768px) {
  .process-timeline { flex-direction: column; gap: 40px; }
  .process-timeline::before { top: 0; bottom: 0; left: 35px; width: 1px; height: auto; right: auto; }
  .process-step { display: flex; align-items: center; text-align: left; gap: 24px; }
  .p-circle { margin: 0; flex-shrink: 0; }
}

.bento { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 50px; }
.bento-item { padding: 50px 40px; }
.bento-item.span-2 { grid-column: span 2; }
@media(max-width: 900px) { .bento { grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 600px) { .bento { grid-template-columns: 1fr; } }
.bento-icon { width: 40px; height: 40px; color: var(--gold); margin-bottom: 24px; }
.del-name { font-weight: 800; font-size: 1.2rem; color: var(--white-strong); margin-bottom: 12px; }
.del-desc { font-size: var(--fs-sm); color: var(--gray); line-height: 1.8; font-weight: 400; }

.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 50px; }
@media(max-width: 768px) { .fit-grid { grid-template-columns: 1fr; } }
.fit-card { padding: 60px 50px; }
.fit-card h3 { font-family: var(--heading); font-size: 1.5rem; margin-bottom: 30px; text-transform: uppercase; letter-spacing: 3px; font-weight: 900; }
.fit-card.yes h3 { color: var(--gold); }
.fit-card ul { list-style: none; }
.fit-card ul li { font-size: var(--fs-body); color: var(--gray); margin-bottom: 20px; padding-left: 32px; position: relative; line-height: 1.8; }
.fit-card.yes ul li::before { content: '✦'; position: absolute; left: 0; color: var(--gold); font-size: 14px; top: 5px; }
.fit-card.no ul li::before { content: '✕'; position: absolute; left: 2px; color: var(--gray-dim); font-size: 14px; top: 5px; }

.faq-list { max-width: 800px; margin: 60px auto 0; }
.faq-item { border-bottom: 1px solid rgba(255,255,255,0.08); }
.faq-q { width: 100%; text-align: left; padding: 36px 0; font-size: 1.2rem; font-weight: 700; color: var(--white-strong); display: flex; justify-content: space-between; align-items: center; gap: 20px; line-height: 1.6; transition: color 0.3s; }
.faq-q:hover { color: var(--gold); }
.faq-icon { width: 36px; height: 36px; border: 1.2px solid rgba(255,255,255,0.2); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--gold); flex-shrink: 0; transition: all .4s; }
.faq-q:hover .faq-icon { border-color: var(--gold); background: rgba(212,168,67,0.1); }
.faq-q.active .faq-icon { background: var(--gold); color: var(--bg-pure); border-color: var(--gold); transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .5s cubic-bezier(.23,1,.32,1); }
.faq-a-inner { padding: 0 0 36px; font-size: var(--fs-body); color: var(--gray); line-height: 2; font-weight: 400; }

.bridge-cta { margin: 80px auto; max-width: 900px; padding: 60px 40px; background: rgba(212, 168, 67, 0.05); border: 1px solid rgba(212, 168, 67, 0.2); border-radius: 8px; text-align: center; backdrop-filter: blur(10px); }
.bridge-cta h3 { font-family: var(--heading); font-size: var(--fs-h3); font-weight: 800; color: var(--white-strong); margin-bottom: 16px; }
.bridge-cta p { font-size: var(--fs-body); color: var(--gray); margin-bottom: 32px; font-weight: 400; }

.final-cta { text-align: center; padding: clamp(120px, 18vw, 200px) 24px; position: relative; z-index: 2; }

.final-cta::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 80vw; height: 80vw; background: radial-gradient(circle, rgba(212,168,67,0.15) 0%, transparent 70%); pointer-events: none; z-index: -1; }
.final-cta h2 { font-size: clamp(3rem, 7vw, 6.4rem); line-height: 1.04; letter-spacing: -0.02em; text-wrap: balance; }
.final-cta h2 .text-gold { display: inline-block; white-space: nowrap; }
.final-cta-title-desktop { display: block; }
.final-cta-title-mobile { display: none; width: 100%; margin: 0 auto; font-size: 1rem; line-height: 1; letter-spacing: 0; text-wrap: normal; }
.final-cta-title-shell { width: min(100%, 36rem); margin: 0 auto; display: grid; justify-items: center; gap: 0.06em; font-size: clamp(11px, 1.55vw, 19px); }
.final-cta-title-line { display: block; white-space: nowrap; line-height: 0.92; letter-spacing: -0.045em; text-align: center; }
.final-cta-title-line-top,
.final-cta-title-line-mid { font-family: var(--heading); font-weight: 900; color: var(--white-strong); }
.final-cta-title-line-accent { font-family: var(--heading); font-weight: 900; background: var(--gold-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.final-cta-title-line-top { font-size: 5.45em; }
.final-cta-title-line-mid { font-size: 2.95em; }
.final-cta-title-line-accent { font-size: 4.15em; }
.final-cta .btn-primary { transform: scale(1.1); font-size: 1.2rem; padding: 24px 64px; border-radius: 4px; box-shadow: 0 15px 50px rgba(212,168,67,0.4); }
.final-cta .btn-primary:hover { transform: scale(1.15) translateY(-3px); box-shadow: 0 25px 70px rgba(212,168,67,0.6); }

.footer { border-top: 1px solid rgba(255,255,255,0.08); padding: 80px 0 40px; position: relative; z-index: 2; background: rgba(3,3,3,0.9); backdrop-filter: blur(20px); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 50px; max-width: 1300px; margin: 0 auto; padding: 0 clamp(24px, 5vw, 60px); }
@media(max-width: 768px) { .footer-grid { grid-template-columns: 1fr; } }
.f-title { font-size: 1.8rem; font-weight: 900; font-family: var(--heading); margin-bottom: 12px; color: var(--white-strong); }
.f-links { display: flex; flex-direction: column; gap: 16px; }
.f-links a { font-size: var(--fs-xs); color: var(--gray); font-weight: 600; letter-spacing: 2px; text-transform: uppercase; transition: 0.3s; }
.f-links a:hover { color: var(--gold); padding-left: 8px; }

.reveal { opacity: 1; transform: none; }
html.js-enhanced .reveal { opacity: 0; transform: translateY(40px); }
@media(max-width: 900px) {
  .hero-content { max-width: 100%; }
  .scroll-indicator { right: 16px; bottom: 30px; opacity: 0.38; }
}
@media(max-width: 640px) {
  .title-chunk { display: inline; }
  .hero-title {
    max-width: 10ch;
    line-height: 1.02;
  }
  .hero-title .hero-title-line,
  .hero-title .hero-title-pre,
  .hero-title .hero-title-flow { display: block; }
  .hero-title .hero-title-flow { margin-top: 0.06em; }
  .hero-title .hero-title-bottom { margin-top: 0.08em; }
  .hero-buttons .btn,
  .bridge-cta .btn,
  .p-card .btn,
  .p-right .btn { width: 100%; }
  .hero-buttons { width: 100%; }
}

@media (max-width: 1200px) {
  .container { padding: 0 clamp(20px, 3.2vw, 36px); }
  nav ul { gap: 22px; }
  .btn { padding: 18px 34px; letter-spacing: 1.2px; }
  .hero-content { max-width: 760px; }
  .draft-wrapper { gap: 56px; }
}

@media (max-width: 992px) {
  :root { --section-pad: clamp(82px, 10vw, 130px); }
  .hero { min-height: 90vh; padding-top: 12vh; }
  .hero-subtitle { margin-top: 26px; max-width: 100%; line-height: 1.8; }
  .hero-buttons { margin-top: 34px; }
  .scroll-indicator { opacity: 0.3; bottom: 20px; right: 14px; }
  .stats-grid { gap: 14px; padding: 42px 0; margin-bottom: 72px; }
  .gallery-item { width: 360px; height: 250px; }
  .module-card { min-width: 280px; padding: 38px 28px; }
  .p-card { padding: 42px 28px; }
  .fit-card { padding: 40px 30px; }
  .bridge-cta { padding: 42px 28px; }
}

@media (max-width: 768px) {
  .hscroll-viewport { padding-left: 20px; padding-bottom: 24px; }
  .heading-xl { line-height: 1.1; }
  .heading-lg { line-height: 1.18; }
  .label { letter-spacing: 3px; }
  nav { padding: 16px 0; }
  .logo-main { font-size: 16px; }
  .logo-role { font-size: 9px; letter-spacing: 1.2px; }
  .scroll-indicator { display: none; }
  .stats-grid { margin-bottom: 56px; }
  .stat-number { font-size: clamp(2.2rem, 11vw, 3.4rem); }
  .slider-btn { width: 44px; height: 44px; font-size: 17px; }
  .module-card { min-width: 0; }
  .module-card .title-chunk { display: block; }
  .mod-title {
    font-size: clamp(1.05rem, 4.6vw, 1.3rem);
    line-height: 1.34;
    overflow-wrap: anywhere;
  }
  .mod-row { gap: 12px; }
  .mod-text {
    font-size: 0.92rem;
    line-height: 1.66;
    overflow-wrap: anywhere;
  }
  .draft-sticky-left { position: relative; top: auto; }
  .draft-scrolling-right { gap: 22vh; padding-bottom: 10vh; }
  .draft-card { padding: 38px 24px; }
  .pricing-grid { grid-template-columns: 1fr; }
  .p-card.horizontal { gap: 24px; }
  .p-card.horizontal .p-left { padding-bottom: 24px; }
  .p-card.horizontal .p-right { width: 100%; }
  .about-actions { margin-top: 30px; }
  .final-cta { padding: clamp(88px, 20vw, 120px) 20px; }
  .final-cta .btn-primary { transform: none; font-size: 1rem; padding: 18px 28px; width: 100%; max-width: 420px; }
  .final-cta .btn-primary:hover { transform: translateY(-2px); }
}

@media (max-width: 480px) {
  .mod-title { font-size: clamp(1rem, 4.9vw, 1.16rem); }
  .mod-text { font-size: 0.9rem; line-height: 1.62; }
}

@media (max-width: 480px) {
  .container { padding: 0 16px; }
  .hero { min-height: 86vh; }
  .hero-buttons { gap: 12px; }
  .btn { padding: 16px 20px; font-size: 0.84rem; }
  .marquee-wrapper { margin-bottom: 48px; }
  .gallery-item { width: 286px; height: 198px; }
  .g-cap { padding: 24px 16px 14px; }
  .faq-q { font-size: 1.02rem; padding: 24px 0; }
  .faq-icon { width: 30px; height: 30px; font-size: 16px; }
  .about-name { font-size: 0.94rem; }
  .about-role { font-size: 10px; letter-spacing: 1.5px; }
  .f-links a { letter-spacing: 1px; }
}

:root {
  --rwd-side-pad: clamp(16px, 4vw, 32px);
}

body { overflow-x: hidden; }
body.menu-open { overflow: hidden; overscroll-behavior: none; }
section[id] { scroll-margin-top: 110px; }
.section-header-flex > *,
.evidence-more-head > *,
.pricing-tier-header > * { min-width: 0; }

@supports (height: 100svh) {
  .hero { min-height: 100svh; }
}

@supports (height: 100dvh) {
  .hero { min-height: 100dvh; }
}

@media (max-width: 1200px) {
  .container {
    padding-left: max(var(--rwd-side-pad), env(safe-area-inset-left));
    padding-right: max(var(--rwd-side-pad), env(safe-area-inset-right));
  }
  .hscroll-viewport {
    padding-left: var(--rwd-side-pad);
    padding-right: var(--rwd-side-pad);
  }
  .hscroll-track { gap: clamp(18px, 2.5vw, 28px); }
  .ev-card { width: min(420px, calc(100vw - (var(--rwd-side-pad) * 2))); }
  .more-quote-card { width: min(320px, calc(100vw - (var(--rwd-side-pad) * 2))); }
  .gallery-item {
    width: min(380px, calc(100vw - (var(--rwd-side-pad) * 2)));
    height: clamp(220px, 34vw, 280px);
  }
  .pricing-grid { grid-template-columns: 1fr; }
  .p-card.horizontal { gap: 32px; }
  .section-header-flex { align-items: flex-start; }
  .evidence-actions { width: 100%; justify-content: flex-start; }
  .pricing-tier-header { align-items: flex-start; }
}

@media (max-width: 1024px) {
  .hero {
    min-height: 100svh;
    min-height: 100dvh;
    padding-top: clamp(112px, 16vh, 140px);
    padding-bottom: 56px;
    align-items: flex-end;
  }
  .hero-content { max-width: min(100%, 720px); }
  .module-card { flex: 1 1 100%; min-width: 0; }
  .about-grid { gap: 32px; }
  .fit-grid { grid-template-columns: 1fr; }
  .pricing-tier-header {
    flex-direction: column;
    gap: 16px;
    margin-bottom: 28px;
  }
  .process-timeline {
    flex-direction: column;
    gap: 32px;
  }
  .process-timeline::before {
    top: 0;
    bottom: 0;
    left: 35px;
    right: auto;
    width: 1px;
    height: auto;
  }
  .process-step {
    display: flex;
    align-items: center;
    text-align: left;
    gap: 20px;
    padding: 0;
  }
  .p-circle { margin: 0; flex-shrink: 0; }
}

@media (max-width: 900px) {
  nav ul {
    left: 0;
    right: auto;
    width: 100%;
    padding: max(104px, calc(env(safe-area-inset-top) + 84px)) clamp(20px, 6vw, 32px) max(32px, calc(env(safe-area-inset-bottom) + 24px));
    justify-content: flex-start;
    align-items: stretch;
    gap: 18px;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
  @supports (height: 100svh) { nav ul { height: 100svh; } }
  @supports (height: 100dvh) { nav ul { height: 100dvh; } }
  nav ul.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  nav ul li { width: 100%; }
  nav ul a {
    display: flex;
    width: 100%;
    justify-content: center;
  }
  nav ul li:last-child { margin-top: 10px; }
  nav ul li:last-child .btn {
    width: min(100%, 420px) !important;
    margin: 0 auto;
    padding: 16px 24px !important;
    font-size: 0.88rem !important;
  }
  .hero-buttons { gap: 14px; }
  .section-header-flex { gap: 16px; }
  .evidence-more-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .offer-box { padding: 36px 28px; }
  .fit-card,
  .bento-item { padding: 36px 26px; }
  .bridge-cta { padding: 36px 24px; }
}

@media (max-width: 768px) {
  section[id] { scroll-margin-top: 96px; }
  .hero-bg-img img {
    opacity: 0.48;
    filter: grayscale(0.14) contrast(1.08);
  }
  .hero {
    min-height: 100svh;
    min-height: 100dvh;
    padding-top: clamp(104px, 14vh, 132px);
    padding-bottom: 44px;
  }
  .hero-subtitle {
    margin-top: 22px;
    line-height: 1.75;
  }
  .btn {
    width: auto;
    min-height: 52px;
    padding: 16px 22px;
    letter-spacing: 1px;
  }
  .hscroll-viewport {
    padding-left: var(--rwd-side-pad);
    padding-right: var(--rwd-side-pad);
    padding-bottom: 20px;
    scroll-snap-type: x proximity;
    scroll-padding-left: var(--rwd-side-pad);
  }
  .hscroll-track,
  .evidence-more-track { gap: clamp(12px, 3vw, 18px); }
  .ev-card,
  .gallery-item,
  .more-quote-card {
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }
  .ev-card {
    width: min(360px, calc(100vw - (var(--rwd-side-pad) * 2)));
    min-height: 0;
    padding: 30px 22px 28px;
  }
  .more-quote-card {
    width: min(320px, calc(100vw - (var(--rwd-side-pad) * 2)));
    min-height: 0;
  }
  .gallery-item {
    width: min(340px, calc(100vw - (var(--rwd-side-pad) * 2)));
    height: clamp(200px, 58vw, 240px);
  }
  .g-cap { padding: 28px 18px 16px; }
  .ba-row { gap: 8px; }
  .ba-tag { width: 56px; }
  .ev-testimonial { align-items: flex-start; }
  .p-card { padding: 34px 22px 36px; }
  .p-price {
    margin-bottom: 28px;
    padding-bottom: 28px;
    font-size: clamp(2rem, 9vw, 2.5rem);
  }
  .p-card ul { margin-bottom: 28px; }
  .p-card.horizontal .spotlight-card-content { flex-direction: column !important; }
  .p-card.horizontal .p-left,
  .p-card.horizontal .p-right {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }
  .p-card.horizontal .p-left { padding-bottom: 22px; }
  .final-cta h2 { font-size: clamp(2.6rem, 12vw, 4.3rem); }
  .video-modal { padding: 16px; }
  .video-modal-inner {
    width: min(100%, 720px);
    padding: 14px 14px 12px;
  }
}

@media (max-width: 640px) {
  .hero-buttons,
  .about-actions,
  .evidence-actions,
  .slider-controls { width: 100%; }
  .hero-buttons .btn,
  .bridge-cta .btn,
  .p-card .btn,
  .p-right .btn,
  .about-actions .btn,
  .evidence-actions .btn {
    width: 100%;
    max-width: none;
  }
  .slider-controls { justify-content: flex-start; }
  .evidence-trust { gap: 6px; }
  .ev-type {
    font-size: 0.62rem;
    letter-spacing: 1.8px;
  }
  .ev-title {
    font-size: 1.12rem;
    line-height: 1.42;
  }
  .ev-card {
    padding: 24px 18px 22px;
    min-height: 0;
  }
  .ev-type {
    margin-bottom: 12px;
    gap: 6px;
    letter-spacing: 1.6px;
  }
  .ev-title {
    font-size: 1.04rem;
    line-height: 1.32;
    margin-bottom: 10px;
  }
  .ba-row {
    gap: 8px;
    margin-bottom: 6px;
    font-size: 0.78rem;
    line-height: 1.42;
  }
  .ba-tag {
    width: 54px;
    font-size: 8px;
    letter-spacing: 1px;
    padding: 4px 0;
  }
  .ev-kpi-grid {
    gap: 6px;
    margin: 12px 0 12px;
  }
  .ev-kpi {
    padding: 8px 8px 7px;
    border-radius: 5px;
  }
  .ev-kpi-num {
    font-size: 1.02rem;
    line-height: 1.02;
  }
  .ev-kpi-lab {
    font-size: 9px;
    margin-top: 4px;
    letter-spacing: 1px;
  }
  .ev-proof-list {
    gap: 6px;
    margin-bottom: 10px;
  }
  .ev-proof-item {
    font-size: 9px;
    letter-spacing: 0.8px;
    padding: 5px 8px;
  }
  .ev-quote {
    font-size: 0.84rem;
    line-height: 1.5;
    margin-bottom: 8px;
    -webkit-line-clamp: 2;
  }
  .ev-testimonial {
    gap: 10px;
    padding-top: 10px;
  }
  .ev-avatar {
    width: 42px;
    height: 42px;
  }
  .ev-author { font-size: 0.9rem; }
  .ev-author span {
    font-size: 11px;
    letter-spacing: 0.6px;
  }
  .ev-company {
    font-size: 10px;
    letter-spacing: 0.8px;
  }
  .spec-row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 16px 0;
  }
  .faq-q { align-items: flex-start; }
  .lb-close,
  .video-close {
    top: 18px;
    right: 18px;
  }
  .lb-nav {
    width: 48px;
    height: 48px;
  }
  .lb-nav.prev { left: 16px; }
  .lb-nav.next { right: 16px; }
}

@media (max-width: 560px) {
  .ev-kpi-grid {
    margin: 10px 0 8px;
    gap: 5px;
  }
  .ev-kpi {
    padding: 7px 7px 6px;
  }
  .ev-kpi-num { font-size: 0.96rem; }
  .ev-kpi-lab {
    font-size: 8.5px;
    margin-top: 3px;
  }
  .ev-proof-list { display: none; }
  .ev-quote {
    display: -webkit-box;
    font-size: 0.78rem;
    line-height: 1.42;
    margin-bottom: 6px;
    -webkit-line-clamp: 2;
  }
  .ev-testimonial {
    margin-top: 6px;
    padding-top: 8px;
    gap: 8px;
    align-items: flex-start;
  }
  .ev-avatar {
    display: block;
    width: 34px;
    height: 34px;
  }
  .ev-author { font-size: 0.82rem; }
  .ev-author span { font-size: 10px; }
  .ev-company {
    font-size: 9px;
    letter-spacing: 0.6px;
    margin-top: 2px;
  }
}

@media (max-width: 480px) {
  :root { --rwd-side-pad: 16px; }
  .hero { padding-bottom: 36px; }
  .hero-title {
    max-width: 9.5ch;
    font-size: clamp(2.15rem, 9.6vw, 2.8rem);
  }
  .hero-subtitle { font-size: 0.98rem; }
  .label {
    letter-spacing: 2px;
    gap: 8px;
  }
  .label::before { width: 18px; }
  .marquee-wrapper { margin-bottom: 40px; }
  .stats-grid {
    gap: 10px;
    padding: 28px 0;
  }
  .stat-desc {
    letter-spacing: 1.4px;
    gap: 6px;
  }
  .ev-card { width: calc(100vw - (var(--rwd-side-pad) * 2)); }
  .more-quote-card { width: calc(100vw - (var(--rwd-side-pad) * 2)); }
  .gallery-item {
    width: calc(100vw - (var(--rwd-side-pad) * 2));
    height: clamp(188px, 56vw, 220px);
  }
  .ev-card {
    width: calc(100vw - (var(--rwd-side-pad) * 2) - 8px);
    padding: 22px 16px 20px;
  }
  .ev-title {
    font-size: 1rem;
    line-height: 1.28;
  }
  .pricing-tier { margin-bottom: 72px; }
  .pricing-tier-num { font-size: clamp(2.4rem, 11vw, 3.4rem); }
  .final-cta { padding: clamp(72px, 18vw, 108px) 16px; }
  .final-cta .container { padding-left: 8px; padding-right: 8px; }
  .final-cta-title-shell { width: 100%; font-size: 11px; }
}

@media (max-width: 1024px) {
  .final-cta-title-desktop { display: none; }
  .final-cta-title-mobile { display: block; }
  .draft-wrapper {
    flex-direction: column;
    gap: 24px;
    margin-top: 56px;
  }
  .draft-sticky-left { display: none; }
  .draft-scrolling-right {
    width: 100%;
    gap: 18px;
    padding-bottom: 0;
  }
  .draft-mobile-stepper {
    display: block;
    position: sticky;
    top: max(92px, calc(env(safe-area-inset-top) + 76px));
    z-index: 5;
    margin-bottom: 6px;
  }
  .draft-card {
    padding: 34px 24px 30px;
    opacity: 1;
    transform: none;
  }
  .draft-card::before {
    content: attr(data-letter);
    position: absolute;
    top: 14px;
    right: 18px;
    font-family: var(--heading);
    font-size: clamp(4.4rem, 12vw, 7.2rem);
    font-weight: 900;
    line-height: 1;
    color: rgba(212,168,67,0.12);
    -webkit-text-stroke: 0;
    pointer-events: none;
    z-index: 0;
  }
  .draft-card > * {
    position: relative;
    z-index: 1;
  }
  .draft-card h3 {
    padding-right: clamp(74px, 16vw, 120px);
    margin-bottom: 10px;
  }
  .draft-card h4 {
    margin-bottom: 22px;
    padding-bottom: 20px;
    letter-spacing: 3px;
  }
  .draft-card p { line-height: 1.85; }
  .draft-card.active {
    border-color: rgba(212,168,67,0.42);
    box-shadow: 0 20px 50px rgba(0,0,0,0.42);
    background: rgba(12,14,24,0.92);
  }
  .draft-card.active::before {
    color: rgba(212,168,67,0.16);
  }
}

@media (max-width: 640px) {
  .draft-mobile-stepper {
    top: max(84px, calc(env(safe-area-inset-top) + 68px));
  }
  .draft-mobile-stepper-card { padding: 14px 14px 12px; }
  .draft-mobile-stepper-top {
    grid-template-columns: auto 1fr;
    gap: 12px;
  }
  .draft-mobile-count {
    grid-column: 2;
    justify-self: flex-start;
    margin-top: 2px;
  }
  .draft-mobile-meta {
    margin-top: 8px;
    font-size: 0.88rem;
  }
  .draft-card {
    padding: 30px 20px 26px;
    border-radius: 14px;
  }
  .draft-card::before {
    top: 12px;
    right: 14px;
    font-size: clamp(3.6rem, 16vw, 5rem);
  }
  .draft-card h3 { padding-right: 68px; }
}

@media (hover: none), (pointer: coarse) {
  .cursor,
  .cursor-dot { display: none !important; }
  body,
  a,
  button { cursor: auto; }
  .spotlight-card::before { display: none; }
  .spotlight-card-content { transform: none; }
}

