/* ═══════════════════════════════════════════
   HOME — Apple × Framer × Aurora · 110%
═══════════════════════════════════════════ */
.hp { background:#000; color:#fff; }
.hp, .hp * { font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif; }

.hp-canvas { position:relative; isolation:isolate; overflow:hidden; }
.hp-dark { background:#000; }
.hp-mid  { background:#0a0a0a; }

.hp-h2 { font-size:clamp(28px,3.4vw,46px); font-weight:600; letter-spacing:-0.025em; line-height:1.08; margin:0; color:#fff; }
.hp-h3 { font-size:clamp(18px,1.5vw,22px); font-weight:600; letter-spacing:-0.015em; line-height:1.25; margin:0; color:#fff; }
.hp-eyebrow { display:inline-block; font-size:13px; font-weight:500; letter-spacing:0.04em; text-transform:uppercase; color:rgba(255,255,255,0.5); margin:0; }
.hp-eyebrow.accent { color:#7dd3fc; }
.hp-lead { font-size:clamp(15px,1.2vw,17px); font-weight:400; line-height:1.55; letter-spacing:-0.005em; color:rgba(255,255,255,0.66); }
.hp-p { font-size:14px; line-height:1.6; color:rgba(255,255,255,0.6); margin:0; }

.hp-row { display:flex; gap:10px; flex-wrap:wrap; }
.hp-btn-primary, .hp-btn-ghost {
  display:inline-flex; align-items:center; gap:6px;
  padding:12px 24px; border-radius:980px;
  font-size:14px; font-weight:500; letter-spacing:-0.005em;
  text-decoration:none; transition:all 0.2s; border:1px solid transparent; cursor:pointer;
}
.hp-btn-primary {
  color:#fff;
  background:linear-gradient(135deg,#0284c7,#06b6d4 50%,#5ef77f);
  background-size:200% 200%; animation:hpGradMove 6s ease infinite;
  box-shadow:0 12px 40px rgba(2,132,199,0.4);
}
.hp-btn-primary:hover { transform:translateY(-2px); box-shadow:0 16px 48px rgba(2,132,199,0.55); }
.hp-btn-ghost {
  background:rgba(255,255,255,0.06); color:#fff;
  border-color:rgba(255,255,255,0.18); backdrop-filter:blur(20px);
}
.hp-btn-ghost:hover { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.32); transform:translateY(-1px); }
.hp-link { display:inline-flex; align-items:center; gap:4px; color:#7dd3fc; text-decoration:none; font-size:14px; font-weight:500; }
.hp-link::after { content:'›'; font-size:18px; line-height:0.8; transform:translateY(-1px); transition:transform 0.2s; }
.hp-link:hover::after { transform:translateX(4px) translateY(-1px); }

@keyframes hpGradMove { 0%,100% { background-position:0% 50%; } 50% { background-position:100% 50%; } }

/* ═══════════════════════════════════════════
   1 · CINEMATIC HERO
═══════════════════════════════════════════ */
.hp-hero {
  position:relative; min-height:100vh;
  padding:130px clamp(20px,4vw,56px) 100px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:42px;
  text-align:center; overflow:hidden;
}
.hp-aurora { position:absolute; inset:-25%; pointer-events:none; z-index:0; filter:blur(80px); opacity:0.6; }
.hp-aurora::before, .hp-aurora::after, .hp-aurora-3, .hp-aurora-4 { content:''; position:absolute; border-radius:50%; }
.hp-aurora::before { width:780px; height:780px; background:radial-gradient(circle,#0284c7 0%,transparent 70%); top:-12%; left:-15%; animation:hpA1 20s ease-in-out infinite; }
.hp-aurora::after  { width:680px; height:680px; background:radial-gradient(circle,#06b6d4 0%,transparent 70%); top:18%; right:-18%; animation:hpA2 24s ease-in-out infinite; }
.hp-aurora-3 { position:absolute; width:620px; height:620px; background:radial-gradient(circle,#5ef77f 0%,transparent 70%); bottom:-18%; left:25%; animation:hpA3 28s ease-in-out infinite; }
.hp-aurora-4 { position:absolute; width:520px; height:520px; background:radial-gradient(circle,#3b82f6 0%,transparent 70%); top:35%; left:35%; animation:hpA4 22s ease-in-out infinite; }
@keyframes hpA1 { 0%,100% { transform:translate(0,0) scale(1); } 50% { transform:translate(100px,50px) scale(1.2); } }
@keyframes hpA2 { 0%,100% { transform:translate(0,0) scale(1); } 50% { transform:translate(-80px,90px) scale(0.85); } }
@keyframes hpA3 { 0%,100% { transform:translate(0,0) scale(1); } 50% { transform:translate(60px,-60px) scale(1.25); } }
@keyframes hpA4 { 0%,100% { transform:translate(0,0) scale(1); } 50% { transform:translate(-50px,40px) scale(1.15); } }

/* Grid overlay */
.hp-grid {
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 70% 50% at 50% 50%, black 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 70% 50% at 50% 50%, black 30%, transparent 80%);
}

.hp-hero > * { position:relative; z-index:2; }

.hp-hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:500; letter-spacing:0.04em; text-transform:uppercase;
  color:#fff; padding:7px 16px; border-radius:100px;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(20px);
  animation:hpFade 0.8s ease both;
}
.hp-hero-tag-dot { width:6px; height:6px; border-radius:50%; background:#5ef77f; box-shadow:0 0 12px rgba(94,247,127,0.8); animation:hpPulse 1.6s ease-in-out infinite; }

/* Massive headline */
.hp-hero-title {
  font-size:clamp(48px,8vw,120px); font-weight:600; letter-spacing:-0.04em; line-height:0.98; margin:0;
  max-width:1400px;
  animation:hpFade 1s ease 0.1s both;
}
.hp-hero-title .gradient {
  background:linear-gradient(135deg,#60a5fa 0%,#3b82f6 30%,#06b6d4 50%,#06b6d4 75%,#5ef77f 100%);
  background-size:300% 300%; background-clip:text; -webkit-background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
  animation:hpGradMove 7s ease infinite;
  position:relative; display:inline-block;
}

/* Word rotator */
.hp-word-stage {
  display:inline-block; position:relative;
  height:1em; vertical-align:bottom;
  min-width:0.5em;
}
.hp-word-stage .word {
  position:absolute; left:0; right:0; top:0; white-space:nowrap; text-align:center;
  background:linear-gradient(135deg,#60a5fa 0%,#3b82f6 35%,#06b6d4 70%,#5ef77f 100%);
  background-size:200% 200%; background-clip:text; -webkit-background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
  animation:hpGradMove 7s ease infinite;
  opacity:0; transform:translateY(40%) rotateX(60deg);
  transition:opacity 0.5s, transform 0.5s;
}
.hp-word-stage .word.in {
  opacity:1; transform:translateY(0) rotateX(0deg);
}
.hp-word-stage .word.out {
  opacity:0; transform:translateY(-40%) rotateX(-60deg);
}

.hp-hero-sub { max-width:680px; margin:0 auto; animation:hpFade 1s ease 0.25s both; }
.hp-hero-actions { justify-content:center; animation:hpFade 1s ease 0.4s both; }

/* Floating service-picker chips */
.hp-chips {
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
  max-width:780px; animation:hpFade 1s ease 0.55s both;
}
.hp-chip {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:500; color:rgba(255,255,255,0.85);
  padding:8px 16px; border-radius:100px;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.12);
  text-decoration:none; transition:all 0.2s;
  backdrop-filter:blur(20px);
}
.hp-chip:hover {
  background:rgba(255,255,255,0.1); border-color:rgba(125,211,252,0.4);
  transform:translateY(-2px); color:#fff;
}
.hp-chip-dot { width:5px; height:5px; border-radius:50%; background:linear-gradient(135deg,#0284c7,#06b6d4); }

/* Floating live cards */
.hp-floats {
  position:absolute; inset:0; pointer-events:none; z-index:1;
}
.hp-float {
  position:absolute; pointer-events:auto;
  background:rgba(20,20,28,0.7); backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.1); border-radius:16px;
  padding:14px 16px;
  display:flex; flex-direction:column; gap:4px; text-align:left;
  box-shadow:0 20px 50px rgba(0,0,0,0.5);
  animation:hpFloat 7s ease-in-out infinite;
  min-width:160px;
}
.hp-float-icon { width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:14px; margin-bottom:4px; }
.hp-float-label { font-size:10px; color:rgba(255,255,255,0.5); letter-spacing:0.06em; text-transform:uppercase; }
.hp-float-val { font-size:18px; font-weight:600; color:#fff; letter-spacing:-0.02em; }
.hp-float-1 { left:3%;  top:18%; animation-delay:0s; }
.hp-float-2 { right:3%; top:24%; animation-delay:-2s; }
.hp-float-3 { left:6%;  bottom:14%; animation-delay:-4s; }
.hp-float-4 { right:6%; bottom:18%; animation-delay:-1s; }
@keyframes hpFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-14px); } }
@media (max-width:1100px){ .hp-floats { display:none; } }

@keyframes hpPulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }
@keyframes hpFade { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }

/* ═══════════════════════════════════════════
   2 · MARQUEE BRANCHEN
═══════════════════════════════════════════ */
.hp-marquee-wrap { padding:60px 0; overflow:hidden; position:relative; }
.hp-marquee-wrap::before, .hp-marquee-wrap::after {
  content:''; position:absolute; top:0; bottom:0; width:160px; z-index:2; pointer-events:none;
}
.hp-marquee-wrap::before { left:0; background:linear-gradient(90deg,#0a0a0a,transparent); }
.hp-marquee-wrap::after  { right:0; background:linear-gradient(-90deg,#0a0a0a,transparent); }
.hp-marquee-label { text-align:center; font-size:12px; color:rgba(255,255,255,0.4); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:32px; }
.hp-marquee-track {
  display:flex; gap:10px; width:max-content;
  animation:hpMarquee 50s linear infinite;
}
@keyframes hpMarquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.hp-mtag {
  font-size:13px; color:rgba(255,255,255,0.7); padding:8px 18px;
  border-radius:100px; border:1px solid rgba(255,255,255,0.1);
  white-space:nowrap; background:rgba(255,255,255,0.02);
  transition:all 0.2s;
}
.hp-mtag:hover { color:#fff; border-color:rgba(125,211,252,0.4); }

/* ═══════════════════════════════════════════
   3 · STATEMENT
═══════════════════════════════════════════ */
.hp-statement { padding:clamp(80px,12vw,180px) clamp(20px,4vw,56px); text-align:center; position:relative; }
.hp-statement::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 70% 50% at 50% 50%, rgba(2,132,199,0.12), transparent 60%);
}
.hp-statement-h { position:relative; font-size:clamp(36px,5vw,76px); font-weight:600; letter-spacing:-0.025em; line-height:1.05; margin:0 auto 32px; max-width:1200px; }
.hp-statement-h .grad-x {
  background:linear-gradient(135deg,#60a5fa 0%,#3b82f6 50%,#5ef77f 100%);
  background-clip:text; -webkit-background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
}
.hp-statement-sub { position:relative; max-width:680px; margin:0 auto; }

/* ═══════════════════════════════════════════
   4 · METRICS BAR
═══════════════════════════════════════════ */
.hp-section { padding:clamp(80px,10vw,140px) 0; }
.hp-section-head {
  padding:0 clamp(20px,4vw,56px); max-width:1480px; margin:0 auto 56px;
  display:flex; flex-direction:column; gap:14px;
}
.hp-section-head.center { text-align:center; align-items:center; }

.hp-metrics {
  max-width:1480px; margin:0 auto; padding:0 clamp(20px,4vw,56px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
@media (max-width:900px){ .hp-metrics { grid-template-columns:repeat(2,1fr); } }
.hp-metric {
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
  border-radius:18px; padding:28px; position:relative; overflow:hidden;
  display:flex; flex-direction:column; gap:6px;
  transition:all 0.3s;
}
.hp-metric::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(circle 200px at var(--x,50%) var(--y,50%), rgba(125,211,252,0.08), transparent 60%);
  opacity:0; transition:opacity 0.3s;
}
.hp-metric:hover { border-color:rgba(125,211,252,0.4); transform:translateY(-3px); }
.hp-metric:hover::after { opacity:1; }
.hp-metric-num {
  font-size:clamp(32px,3.4vw,52px); font-weight:600; letter-spacing:-0.04em; line-height:1;
  background:linear-gradient(135deg,#60a5fa 0%,#5ef77f 100%);
  background-clip:text; -webkit-background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
}
.hp-metric-label { font-size:13px; color:rgba(255,255,255,0.6); }
.hp-metric-sub { font-size:11px; color:rgba(255,255,255,0.4); margin-top:auto; padding-top:10px; }

/* ═══════════════════════════════════════════
   5 · SERVICES MEGA-BENTO
═══════════════════════════════════════════ */
.hp-bento {
  max-width:1480px; margin:0 auto; padding:0 clamp(20px,4vw,56px);
  display:grid; grid-template-columns:repeat(6,1fr); gap:14px;
  grid-auto-rows:minmax(200px,auto);
}
.hp-bcell {
  position:relative; overflow:hidden;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
  border-radius:20px; padding:28px;
  display:flex; flex-direction:column; gap:14px;
  transition:all 0.3s;
  text-decoration:none; color:inherit;
  cursor:pointer;
}
.hp-bcell::before {
  content:''; position:absolute; inset:0; padding:1px;
  background:linear-gradient(135deg, rgba(96,165,250,0.5), rgba(94,247,127,0.5), rgba(6,182,212,0.5));
  border-radius:20px;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity:0; transition:opacity 0.3s; pointer-events:none;
}
.hp-bcell::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(circle 300px at var(--x,50%) var(--y,50%), rgba(125,211,252,0.1), transparent 60%);
  opacity:0; transition:opacity 0.3s;
}
.hp-bcell:hover { transform:translateY(-4px); border-color:transparent; }
.hp-bcell:hover::before { opacity:1; }
.hp-bcell:hover::after { opacity:1; }

.hp-b-1 { grid-column:span 4; grid-row:span 2; min-height:420px; }
.hp-b-2 { grid-column:span 2; grid-row:span 2; min-height:420px; }
.hp-b-3 { grid-column:span 3; }
.hp-b-4 { grid-column:span 3; }
.hp-b-5 { grid-column:span 2; }
.hp-b-6 { grid-column:span 2; }
.hp-b-7 { grid-column:span 2; }
@media (max-width:1100px){
  .hp-bento { grid-template-columns:repeat(4,1fr); }
  .hp-b-1, .hp-b-2 { grid-column:span 4; min-height:340px; grid-row:auto; }
  .hp-b-3, .hp-b-4 { grid-column:span 2; }
  .hp-b-5, .hp-b-6, .hp-b-7 { grid-column:span 4; }
}
@media (max-width:600px){
  .hp-bento { grid-template-columns:1fr; }
  .hp-b-1, .hp-b-2, .hp-b-3, .hp-b-4, .hp-b-5, .hp-b-6, .hp-b-7 { grid-column:span 1; }
}

.hp-bcell-icon {
  width:48px; height:48px; border-radius:13px;
  display:flex; align-items:center; justify-content:center; font-size:22px;
  background:linear-gradient(135deg, var(--c1, #0284c7), var(--c2, #06b6d4));
  box-shadow:0 12px 28px var(--shadow, rgba(2,132,199,0.4));
}
.hp-bcell-eyebrow { font-size:12px; letter-spacing:0.06em; text-transform:uppercase; color:#7dd3fc; font-weight:500; }
.hp-bcell-title { font-size:clamp(20px,1.8vw,28px); font-weight:600; letter-spacing:-0.02em; color:#fff; line-height:1.2; }
.hp-bcell-desc { font-size:14px; line-height:1.55; color:rgba(255,255,255,0.65); }
.hp-bcell-cta { font-size:13px; color:#7dd3fc; margin-top:auto; display:inline-flex; align-items:center; gap:4px; }
.hp-bcell-cta::after { content:'›'; font-size:18px; line-height:0.8; transform:translateY(-1px); transition:transform 0.2s; }
.hp-bcell:hover .hp-bcell-cta::after { transform:translateX(4px) translateY(-1px); }

/* Mini-animations inside cells */
.hp-mini-wave {
  display:flex; gap:3px; align-items:flex-end; height:60px; margin-top:auto;
}
.hp-mini-wave .bar {
  width:4px; background:linear-gradient(180deg,#60a5fa,#06b6d4); border-radius:2px;
  animation:hpWave 1.2s ease-in-out infinite;
}
@keyframes hpWave { 0%,100% { height:20%; } 50% { height:100%; } }

.hp-mini-flow {
  display:flex; flex-direction:column; gap:6px; margin-top:auto;
  font-family:'SF Mono', Monaco, monospace; font-size:11px;
}
.hp-mini-flow-row {
  display:flex; align-items:center; gap:8px;
  padding:6px 10px; border-radius:8px;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06);
}
.hp-mini-flow-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }

.hp-mini-chat {
  margin-top:auto; display:flex; flex-direction:column; gap:6px;
}
.hp-mini-bubble {
  padding:8px 12px; border-radius:12px; font-size:12px; max-width:90%;
}
.hp-mini-bubble.them { background:rgba(255,255,255,0.06); align-self:flex-start; border-bottom-left-radius:4px; }
.hp-mini-bubble.me { background:linear-gradient(135deg,#0284c7,#06b6d4); align-self:flex-end; border-bottom-right-radius:4px; color:#fff; }

.hp-mini-cal {
  display:grid; grid-template-columns:repeat(7,1fr); gap:3px; margin-top:auto;
}
.hp-mini-cal-day {
  aspect-ratio:1; border-radius:5px;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.05);
  font-size:10px; color:rgba(255,255,255,0.4); display:flex; align-items:center; justify-content:center;
}
.hp-mini-cal-day.has { background:rgba(94,247,127,0.15); border-color:rgba(94,247,127,0.4); color:#5ef77f; font-weight:600; }
.hp-mini-cal-day.today { background:linear-gradient(135deg,#0284c7,#06b6d4); color:#fff; border-color:transparent; }

.hp-mini-browser {
  margin-top:auto; aspect-ratio:16/10; border-radius:10px; overflow:hidden;
  background:linear-gradient(135deg,#0a0a0a,#1a1a2e);
  border:1px solid rgba(255,255,255,0.1); position:relative;
}
.hp-mini-browser-bar {
  height:18px; background:rgba(0,0,0,0.5); display:flex; align-items:center; gap:4px; padding:0 8px;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.hp-mini-browser-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,0.2); }
.hp-mini-browser-content {
  padding:14px; display:flex; flex-direction:column; gap:6px;
}
.hp-mini-browser-bar-line { height:6px; border-radius:3px; background:linear-gradient(90deg,#0284c7,#06b6d4,transparent); }
.hp-mini-browser-bar-line.s { width:30%; }
.hp-mini-browser-bar-line.m { width:60%; opacity:0.6; }
.hp-mini-browser-bar-line.l { width:80%; opacity:0.4; }

/* ═══════════════════════════════════════════
   6 · SCROLL TIMELINE
═══════════════════════════════════════════ */
.hp-timeline {
  max-width:1280px; margin:0 auto; padding:0 clamp(20px,4vw,56px);
  display:grid; grid-template-columns:1fr 1.2fr; gap:60px; align-items:start;
}
@media (max-width:980px){ .hp-timeline { grid-template-columns:1fr; gap:40px; } }
.hp-timeline-side { position:sticky; top:100px; }
@media (max-width:980px){ .hp-timeline-side { position:relative; top:0; } }
.hp-timeline-steps { display:flex; flex-direction:column; }
.hp-timeline-step {
  display:flex; gap:18px; padding:22px 0; cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,0.08);
  transition:all 0.3s;
}
.hp-timeline-step:first-child { border-top:1px solid rgba(255,255,255,0.08); }
.hp-ts-num {
  flex-shrink:0; width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.18);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:600; color:rgba(255,255,255,0.5);
  transition:all 0.3s;
}
.hp-timeline-step.active .hp-ts-num {
  background:linear-gradient(135deg,#0284c7,#06b6d4); color:#fff; border-color:transparent;
  box-shadow:0 0 24px rgba(2,132,199,0.5);
}
.hp-ts-title { font-size:18px; font-weight:600; color:rgba(255,255,255,0.5); letter-spacing:-0.015em; margin-bottom:6px; transition:color 0.3s; }
.hp-timeline-step.active .hp-ts-title { color:#fff; }
.hp-ts-meta { font-size:12px; color:rgba(255,255,255,0.72); margin-bottom:6px; letter-spacing:0.04em; text-transform:uppercase; font-weight:500; }
.hp-ts-desc { font-size:14px; line-height:1.55; color:rgba(255,255,255,0.6); }
.hp-timeline-visual {
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.1);
  border-radius:22px; padding:32px; min-height:480px;
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; gap:20px;
}
.hp-timeline-visual::before {
  content:''; position:absolute; inset:0; padding:1px;
  background:linear-gradient(135deg, rgba(96,165,250,0.4), rgba(94,247,127,0.4), rgba(6,182,212,0.4));
  border-radius:22px;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity:0.5; pointer-events:none;
}
.hp-tv-stage {
  display:none; flex-direction:column; gap:14px; flex:1;
}
.hp-tv-stage.active {
  display:flex;
  animation:hpFade 0.5s ease both;
}
.hp-tv-eyebrow { font-size:12px; color:#7dd3fc; letter-spacing:0.06em; text-transform:uppercase; }
.hp-tv-title { font-size:24px; font-weight:600; letter-spacing:-0.02em; color:#fff; line-height:1.2; }
.hp-tv-rows { display:flex; flex-direction:column; gap:8px; }
.hp-tv-row {
  display:flex; align-items:center; gap:12px; padding:12px 14px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;
}
.hp-tv-row-icon {
  width:32px; height:32px; border-radius:9px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:14px;
  background:linear-gradient(135deg,#0284c7,#06b6d4);
}
.hp-tv-row-text { display:flex; flex-direction:column; gap:2px; }
.hp-tv-row-title { font-size:13px; font-weight:600; color:#fff; }
.hp-tv-row-sub { font-size:11px; color:rgba(255,255,255,0.5); }
.hp-tv-row-pill { margin-left:auto; font-size:11px; color:#5ef77f; padding:3px 9px; border-radius:100px; background:rgba(94,247,127,0.12); border:1px solid rgba(94,247,127,0.3); }

/* ═══════════════════════════════════════════
   7 · TESTIMONIALS
═══════════════════════════════════════════ */
.hp-testi {
  max-width:1280px; margin:0 auto; padding:0 clamp(20px,4vw,56px);
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
@media (max-width:980px){ .hp-testi { grid-template-columns:1fr; } }
.hp-testi-card {
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
  border-radius:20px; padding:28px;
  display:flex; flex-direction:column; gap:18px;
  transition:all 0.3s;
}
.hp-testi-card:hover { transform:translateY(-4px); border-color:rgba(125,211,252,0.4); }
.hp-testi-quote { font-size:18px; font-weight:500; line-height:1.45; color:#fff; letter-spacing:-0.015em; flex:1; }
.hp-testi-quote::before { content:'"'; font-size:48px; line-height:0; position:relative; top:18px; color:#7dd3fc; opacity:0.6; margin-right:4px; }
.hp-testi-meta { display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid rgba(255,255,255,0.08); }
.hp-testi-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg, var(--c1, #0284c7), var(--c2, #06b6d4));
  display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:600;
  color:#fff;
}
.hp-testi-name { font-size:14px; font-weight:600; color:#fff; }
.hp-testi-role { font-size:12px; color:rgba(255,255,255,0.5); }
.hp-testi-pill {
  display:inline-block; font-size:11px; color:#5ef77f; padding:3px 9px;
  border-radius:100px; background:rgba(94,247,127,0.12); border:1px solid rgba(94,247,127,0.3);
  margin-bottom:6px; align-self:flex-start; font-weight:500;
}

/* ═══════════════════════════════════════════
   8 · FINAL CTA
═══════════════════════════════════════════ */
.hp-cta {
  max-width:1100px; margin:0 auto; padding:100px clamp(20px,4vw,56px); text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:24px;
  position:relative;
}
.hp-cta::before {
  content:''; position:absolute; inset:-20%;
  background:radial-gradient(ellipse 60% 50% at 50% 50%, rgba(2,132,199,0.2), transparent 60%);
  pointer-events:none; z-index:-1; filter:blur(40px);
}
.hp-cta h2 { font-size:clamp(36px,5vw,76px); font-weight:600; letter-spacing:-0.025em; line-height:1.05; margin:0; }
.hp-cta h2 .grad-x {
  background:linear-gradient(135deg,#60a5fa 0%,#3b82f6 50%,#5ef77f 100%);
  background-clip:text; -webkit-background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
}
.hp-cta p { font-size:clamp(15px,1.4vw,19px); color:rgba(255,255,255,0.66); max-width:600px; margin:0; line-height:1.5; }

/* Reveal-on-scroll */
.r-up { opacity:0; transform:translateY(28px); transition:opacity 0.8s, transform 0.8s; }
.r-up.in { opacity:1; transform:none; }
