/* ============================================================
   ROUND-ING · landing.css
   Styles specific to index.html (landing page)
   ============================================================ */

/* ── Hero ──────────────────────────────────────────────────── */
.hero-wrap { position: relative; overflow: hidden; }
.hero-bg   { position: absolute; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.hero-orb  { position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none; }
.hero-orb-1 { width:520px;height:520px;background:radial-gradient(circle,rgba(245,158,11,.22),transparent 70%);top:-80px;left:12%;animation:heroDrift1 28s ease-in-out infinite; }
.hero-orb-2 { width:560px;height:560px;background:radial-gradient(circle,rgba(150,216,202,.35),transparent 70%);top:200px;right:8%;animation:heroDrift2 34s ease-in-out infinite; }
.hero-orb-3 { width:460px;height:460px;background:radial-gradient(circle,rgba(46,154,161,.16),transparent 70%);bottom:80px;left:38%;animation:heroDrift3 40s ease-in-out infinite; }
.hero-ecg {
  position:absolute;left:0;right:0;top:300px;height:90px;opacity:.09;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 80' preserveAspectRatio='none'><path d='M0 40 L108 40 L116 38 L124 40 L138 40 L144 12 L152 72 L156 34 L164 40 L196 40 L208 36 L222 46 L232 40 L300 40' stroke='%23003F41' stroke-width='1.2' fill='none' stroke-linecap='round' stroke-linejoin='round' vector-effect='non-scaling-stroke'/></svg>");
  background-repeat:repeat-x;background-size:300px 80px;background-position-y:center;
  animation:ecgScroll 4.5s linear infinite;
  mask-image:linear-gradient(to right,transparent,black 12%,black 88%,transparent);
  -webkit-mask-image:linear-gradient(to right,transparent,black 12%,black 88%,transparent);
}
.hero-cursor-glow {
  position:absolute;left:0;top:0;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(150,216,202,.25) 0%,rgba(46,154,161,.12) 35%,transparent 65%);
  filter:blur(20px);pointer-events:none;opacity:0;transition:opacity .4s;
  will-change:transform,opacity;mix-blend-mode:multiply;z-index:1;
}

/* ── Fade animations ───────────────────────────────────────── */
.fade-up  { animation: fadeUp .7s ease-out both; }
.fade-in  { animation: fadeIn .6s ease-out both; }
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}
.d4{animation-delay:.4s}.d5{animation-delay:.5s}.d6{animation-delay:.6s}

/* ── Stats strip ───────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px,1fr));
  gap: 0;
  padding: 32px 0;
}
.stat-val   { font-family:var(--fMono);font-size:32px;font-weight:500;color:var(--primary);letter-spacing:-.02em;margin-bottom:6px; }
.stat-label { font-family:var(--fBody);font-size:13px;color:var(--text3);font-weight:500;letter-spacing:.02em;text-transform:uppercase; }

/* ── Section rail ──────────────────────────────────────────── */
.ve-rail {
  position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:90;
  display:flex;flex-direction:column;gap:14px;padding:14px 12px;
  font-family:var(--fMono);opacity:0;pointer-events:none;transition:opacity .5s;
  background:rgba(250,250,248,.7);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(0,0,0,.04);border-radius:18px;
  box-shadow:0 8px 24px rgba(0,63,65,.04);align-items:flex-end;
}
.ve-rail.is-visible { opacity:1;pointer-events:auto; }
.ve-rail-item {
  position:relative;display:flex;flex-direction:row-reverse;align-items:center;gap:12px;
  background:none;border:none;padding:0;cursor:pointer;color:#BFBFBD;transition:color .4s;
}
.ve-rail-item:hover, .ve-rail-item.is-active { color:var(--primary); }
.ve-rail-num   { font-size:10px;font-weight:600;letter-spacing:.1em;line-height:1;width:18px;text-align:left;transition:all .4s; }
.ve-rail-tick  { width:18px;height:1px;background:currentColor;opacity:.3;transition:all .4s;flex-shrink:0; }
.ve-rail-item.is-active .ve-rail-tick { width:28px;opacity:1;height:2px; }
.ve-rail-label {
  font-family:var(--fBody);font-size:11px;font-weight:500;letter-spacing:.02em;color:inherit;
  opacity:0;max-width:0;overflow:hidden;transform:translateX(8px);
  transition:max-width .35s,opacity .35s,transform .35s;white-space:nowrap;
}
.ve-rail-item:hover .ve-rail-label { opacity:1;max-width:120px;transform:translateX(0); }

/* ── Ticker ────────────────────────────────────────────────── */
.ve-ticker {
  overflow:hidden;position:relative;
  mask-image:linear-gradient(to right,transparent,black 6%,black 94%,transparent);
  -webkit-mask-image:linear-gradient(to right,transparent,black 6%,black 94%,transparent);
}
.ve-ticker-track { display:flex;gap:52px;width:max-content;animation:tickerScroll 72s linear infinite;will-change:transform; }
.ve-ticker:hover .ve-ticker-track { animation-play-state:paused; }
.ve-ticker-item  { display:flex;align-items:center;gap:10px;white-space:nowrap;font-family:var(--fBody);font-size:13px;font-weight:500;color:#3D3D3D; }
.ve-ticker-icon  { display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;flex-shrink:0; }
.ve-ticker-detail{ color:#8A8A8A;font-weight:400; }
.ve-ticker-sep   { color:#D4D4D2;user-select:none; }
.ve-ticker-time  { font-family:var(--fMono);font-size:11px;color:#999;letter-spacing:.04em; }
.ve-ticker-time.is-live { color:#10B981; }

/* ── Bento cards ───────────────────────────────────────────── */
.ve-bento-card {
  position:relative;border-radius:var(--radius-card);overflow:hidden;
  transition:transform .3s,box-shadow .3s;
}
.ve-bento-card:hover { transform:translateY(-3px); }
.bento-grid       { display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px; }
.bento-grid-small { display:grid;grid-template-columns:repeat(3,1fr);gap:16px; }
.bento-grid-4     { display:grid;grid-template-columns:repeat(4,1fr);gap:16px; }

/* bento mesh bg + grain */
.ve-bento-mesh { position:absolute;inset:0;z-index:0;filter:blur(50px); }
.ve-bento-mesh .orb { position:absolute;border-radius:50%;mix-blend-mode:screen;will-change:transform; }
.orb-a{width:440px;height:440px;background:radial-gradient(circle,rgba(245,158,11,.85),transparent 65%);top:-80px;right:-60px;animation:meshDrift1 20s ease-in-out infinite;}
.orb-b{width:480px;height:480px;background:radial-gradient(circle,rgba(150,216,202,.9),transparent 60%);top:40%;left:-100px;animation:meshDrift2 24s ease-in-out infinite;}
.orb-c{width:360px;height:360px;background:radial-gradient(circle,rgba(46,154,161,.8),transparent 60%);bottom:-80px;right:30%;animation:meshDrift3 28s ease-in-out infinite;}
.ve-bento-grain {
  position:absolute;inset:0;z-index:1;opacity:1;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='320' height='320'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.65 0'/></filter><rect width='320' height='320' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
.ve-bento-grain-light {
  position:absolute;inset:0;z-index:2;opacity:.55;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='280' height='280'><filter id='nl'><feTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.35 0'/></filter><rect width='280' height='280' filter='url(%23nl)'/></svg>");
  mix-blend-mode:screen;
}
.bento-label { font-family:var(--fBody);font-size:13px;font-weight:500;color:#8A8A8A;margin-bottom:8px;letter-spacing:.01em; }
.bento-split { position:relative;padding:32px;color:#fff;overflow:hidden; }

/* ── Mini bento cards ──────────────────────────────────────── */
.ve-mini-card {
  position:relative;border-radius:20px;overflow:hidden;min-height:240px;padding:20px;
  display:flex;flex-direction:column;justify-content:flex-start;color:#fff;transition:transform .3s;
}
.ve-mini-card:hover { transform:translateY(-3px); }
.ve-mini-waves {
  position:absolute;inset:0;z-index:1;opacity:.35;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='400' viewBox='0 0 600 400' fill='none'><path d='M-50 80 Q 80 50, 220 80 T 480 80 T 720 80' stroke='white' stroke-width='1.2' fill='none' opacity='0.55'/><path d='M-50 130 Q 100 100, 240 130 T 500 130 T 720 130' stroke='white' stroke-width='1.2' fill='none' opacity='0.55'/><path d='M-50 180 Q 80 150, 220 180 T 480 180 T 720 180' stroke='white' stroke-width='1.2' fill='none' opacity='0.55'/><path d='M-50 230 Q 100 200, 240 230 T 500 230 T 720 230' stroke='white' stroke-width='1.2' fill='none' opacity='0.55'/></svg>");
  background-size:cover;background-repeat:no-repeat;mix-blend-mode:screen;
}
.ve-mini-footer {
  margin-top:12px;padding:14px 18px;background:#fff;border:1px solid rgba(0,0,0,.05);
  border-radius:12px;font-family:var(--fBody);font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.005em;
}
.ve-mini-chip {
  display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;
  background:rgba(255,255,255,.95);color:var(--text);font-family:var(--fBody);font-size:11px;font-weight:600;
  letter-spacing:.01em;backdrop-filter:blur(8px);box-shadow:0 1px 3px rgba(0,0,0,.06);position:relative;z-index:3;
}
.ve-mini-geo {
  position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;
  pointer-events:none;opacity:.78;mix-blend-mode:screen;
}
.ve-mini-geo svg { width:62%;max-width:200px;height:auto; }

/* ── Dashboard mockup ──────────────────────────────────────── */
.dash-side-item { transition:background .18s,color .18s,transform .18s;cursor:pointer; }
.dash-side-item:hover { background:rgba(150,216,202,.2)!important;color:var(--primary)!important; }
.dash-kpi { transition:transform .22s,box-shadow .22s,border-color .22s;cursor:pointer; }
.dash-kpi:hover { transform:translateY(-2px);box-shadow:0 8px 20px rgba(46,154,161,.14),0 0 0 1px rgba(46,154,161,.3);border-color:transparent!important; }
.dash-row { transition:background .18s;cursor:pointer; }
.dash-row:hover { background:rgba(150,216,202,.1); }
@keyframes kpiFlash { 0%{background:#fff}30%{background:#ECFDF5}100%{background:#fff} }
.kpi-flash { animation:kpiFlash 1.4s ease-out; }

/* ── Identity / Two-col grid ───────────────────────────────── */
.identity-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

/* ── ORA widget ────────────────────────────────────────────── */
.ve-ora-aurora {
  position:absolute;inset:-40%;
  background:radial-gradient(circle at 20% 30%,rgba(245,158,11,.18),transparent 45%),
             radial-gradient(circle at 80% 70%,rgba(150,216,202,.22),transparent 50%),
             radial-gradient(circle at 50% 50%,rgba(46,154,161,.12),transparent 55%);
  filter:blur(40px);animation:auroraShift 14s ease-in-out infinite;pointer-events:none;z-index:0;
}
.ve-ora-caret {
  display:inline-block;width:2px;height:1.05em;background:#F59E0B;
  margin-left:3px;vertical-align:text-bottom;animation:caretBlink 1s step-end infinite;
}
.ve-ora-think-dot {
  display:inline-block;width:6px;height:6px;border-radius:50%;background:#F59E0B;
  margin:0 2px;animation:thinkingDot 1.2s ease-in-out infinite;
}
.ve-ora-mark { animation:oraMarkPulse 3.2s ease-in-out infinite;transform-origin:center; }

/* ── Mesh interlude ────────────────────────────────────────── */
.ve-mesh { position:relative;overflow:hidden;isolation:isolate; }
.ve-mesh-bg { position:absolute;inset:0;z-index:0;filter:blur(60px); }
.ve-mesh-orb { position:absolute;border-radius:50%;mix-blend-mode:multiply;will-change:transform; }
.mesh-orb-1{width:520px;height:520px;background:radial-gradient(circle,rgba(245,158,11,.55),transparent 68%);top:-140px;left:10%;animation:meshDrift1 22s ease-in-out infinite;}
.mesh-orb-2{width:620px;height:620px;background:radial-gradient(circle,rgba(150,216,202,.78),transparent 62%);top:20px;left:38%;animation:meshDrift2 26s ease-in-out infinite;}
.mesh-orb-3{width:560px;height:560px;background:radial-gradient(circle,rgba(46,154,161,.55),transparent 65%);bottom:-160px;right:8%;animation:meshDrift3 30s ease-in-out infinite;}
.mesh-orb-4{width:380px;height:380px;background:radial-gradient(circle,rgba(0,63,65,.35),transparent 68%);bottom:40px;left:18%;animation:meshDrift4 34s ease-in-out infinite;}
.ve-mesh-grain {
  position:absolute;inset:0;z-index:1;opacity:.35;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.08 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}

/* ── Chat bubbles (ORA surface card) ───────────────────────── */
.ve-chat-bubble {
  display:inline-block;padding:10px 16px;border-radius:18px;
  font-family:var(--fBody);font-size:13px;line-height:1.45;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);max-width:260px;
  opacity:0;animation:chatRise .6s ease-out forwards;
}
.ve-chat-user  { background:rgba(255,255,255,.22);color:#fff;border:1px solid rgba(255,255,255,.18); }
.ve-chat-agent { background:rgba(255,255,255,.96);color:var(--text);box-shadow:0 4px 12px rgba(0,0,0,.08); }
.ve-chat-action {
  background:rgba(255,255,255,.96);color:var(--text);
  display:inline-flex;align-items:center;gap:8px;padding:6px 14px 6px 6px;border-radius:100px;
  font-family:var(--fBody);font-size:12px;font-weight:500;box-shadow:0 4px 12px rgba(0,0,0,.1);
  opacity:0;animation:chatRise .6s ease-out forwards;
}

/* ── Reviews ───────────────────────────────────────────────── */
.ve-review-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start; }

/* ── Video / play btn ──────────────────────────────────────── */
.ve-play-button {
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:92px;height:92px;border-radius:50%;background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:none;
  box-shadow:0 10px 40px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;pointer-events:none;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;z-index:3;
  animation:playPulse 2.6s ease-out infinite;
}
.ve-video-placeholder:hover .ve-play-button { transform:translate(-50%,-50%) scale(1.08); }
.ve-video-placeholder { transition:transform .4s;cursor:pointer;display:block;border:none;padding:0; }
.ve-video-placeholder:hover { transform:scale(1.005); }

/* ── FAQ ───────────────────────────────────────────────────── */
details { border-top:1px solid var(--rule); }
details summary {
  padding:20px 0;font-family:var(--fBody);font-size:16px;font-weight:600;color:var(--text);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
}
details p {
  font-family:var(--fBody);font-size:15px;line-height:1.7;color:var(--text2);
  padding-bottom:20px;max-width:640px;
}
.faq-icon { transition:transform .2s;flex-shrink:0;margin-left:16px; }
details[open] .faq-icon { transform:rotate(45deg); }

/* ── Traction row ──────────────────────────────────────────── */
.traction-row { display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center; }

/* ── Landing-page keyframes ────────────────────────────────── */
@keyframes heroDrift1  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,50px) scale(1.08)} }
@keyframes heroDrift2  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,30px) scale(1.1)} }
@keyframes heroDrift3  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-40px) scale(1.05)} }
@keyframes ecgScroll   { 0%{background-position-x:0}100%{background-position-x:-300px} }
@keyframes meshDrift1  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(80px,60px) scale(1.1)} }
@keyframes meshDrift2  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-90px,40px) scale(1.08)} }
@keyframes meshDrift3  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,-70px) scale(1.12)} }
@keyframes meshDrift4  { 0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,-40px) scale(1.05)} }
@keyframes auroraShift { 0%,100%{transform:translate(-10%,-10%) rotate(0deg)}33%{transform:translate(8%,-4%) rotate(40deg)}66%{transform:translate(-4%,8%) rotate(-30deg)} }
@keyframes tickerScroll{ 0%{transform:translateX(0)}100%{transform:translateX(-50%)} }
@keyframes caretBlink  { 0%,55%{opacity:1}56%,100%{opacity:0} }
@keyframes thinkingDot { 0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1} }
@keyframes oraMarkPulse{ 0%,100%{filter:drop-shadow(0 0 0px rgba(245,158,11,0));transform:scale(1)}50%{filter:drop-shadow(0 0 6px rgba(245,158,11,.4));transform:scale(1.04)} }
@keyframes playPulse   { 0%{box-shadow:0 10px 40px rgba(0,0,0,.25),0 0 0 0 rgba(255,255,255,.35)}70%{box-shadow:0 10px 40px rgba(0,0,0,.25),0 0 0 24px rgba(255,255,255,0)}100%{box-shadow:0 10px 40px rgba(0,0,0,.25),0 0 0 0 rgba(255,255,255,0)} }
@keyframes chatRise    { from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)} }
@keyframes dotTwinkle  { 0%,100%{box-shadow:0 1px 3px rgba(0,0,0,.15)}50%{box-shadow:0 0 0 3px rgba(16,185,129,.25),0 1px 3px rgba(0,0,0,.15)} }

/* ── Landing responsive ────────────────────────────────────── */
@media (max-width: 768px) {
  .hero-mockup { transform:perspective(0) rotateY(0) rotateX(0) scale(.62)!important;transform-origin:top center!important;margin-bottom:-160px!important; }
  .bento-grid,.bento-grid-small,.bento-grid-4,.ve-review-grid,.identity-grid { grid-template-columns:1fr!important;gap:16px!important; }
  .traction-row { grid-template-columns:1fr!important;gap:32px!important; }
  .stats-grid { grid-template-columns:repeat(2,1fr)!important; }
  .ora-grid   { grid-template-columns:1fr!important; }
  h1 { font-size:36px!important; }
  h2 { font-size:28px!important; }
}
