/* V2 landing overrides — extracted from auth.py v2_css on 2026-04-21 */

/* V2: Bloomberg-style hero status line (replaces cheap pill) */
.hero-badge{display:inline-flex;align-items:center;gap:14px;background:transparent;border:0;border-radius:0;padding:0;font-size:11px;font-weight:600;color:#7a94b4;letter-spacing:.18em;text-transform:uppercase;margin-bottom:36px;line-height:1}
.hero-badge .live-dot{width:7px;height:7px;border-radius:50%;background:#2ecc71;box-shadow:0 0 10px #2ecc71,0 0 20px rgba(46,204,113,.3);animation:pulse-dot 1.5s ease-in-out infinite;flex-shrink:0}
.hero-badge .live-label{color:#2ecc71;font-weight:800;letter-spacing:.22em}
.hero-badge .hb-sep{color:#2a4060;font-weight:400;margin:0 2px}
.hero-badge .hb-fact{color:#8aa3c0}
.hero-badge .hb-num{color:#e8eef7;font-weight:700}
@media(max-width:600px){.hero-badge{flex-wrap:wrap;gap:8px;font-size:10px;letter-spacing:.14em}}

/* V2: aurora wash behind the globe */
.globe-wrap{position:absolute;left:24%;top:52%;transform:translate(-50%,-50%);width:560px;height:560px;margin:0;pointer-events:none;z-index:0}
@media(max-width:900px){.globe-wrap{left:50%;top:28%;width:380px;height:380px}}
@media(max-width:600px){.globe-wrap{left:50%;top:22%;width:280px;height:280px}}

/* V2: scale down hero dashboard preview */
.hero-inner{grid-template-columns:500px minmax(0,1040px) !important;justify-content:space-between}
.hero-dw-wrap{max-width:1040px;width:100%;justify-self:end}
@media(max-width:1100px){.hero-inner{grid-template-columns:1fr !important}.hero-dw-wrap{max-width:100%;justify-self:stretch}}

/* Anchor hero content under the fixed nav instead of vertically centering it
   in 100vh. The base rule used position:absolute;top:50% which on tall
   monitors created a ~200px empty band between the nav and the hero copy.
   Top padding = fixed nav height (~60px) + 24px breathing room. */
@media(min-width:1101px){
  .hero{min-height:auto;padding:84px clamp(20px,5vw,80px) 80px}
  .hero-inner{position:relative;left:auto;right:auto;top:auto;transform:none;max-width:1640px;margin:0 auto;align-items:start}
}

/* Sharpness-first tilt:
   - Smaller angle (-5deg) → less foreshortening → less pixel interpolation
   - NO image-rendering hint (Chrome's -webkit-optimize-contrast triggers low-quality scaling on rotated layers)
   - NO contrast/saturate filter (amplifies WebP compression noise)
   - Compositor hints (translateZ, backface-visibility, will-change) keep the layer on its own GPU surface */
.hero-inner{perspective:4000px;perspective-origin:30% 50%}
.hero-dw-wrap{
  border-color:rgba(52,152,219,0.10) !important;
  box-shadow:
    0 40px 120px rgba(0,0,0,0.55),
    0 0 220px 40px rgba(34,171,148,0.10),
    0 0 380px 80px rgba(52,152,219,0.06) !important;
  transform:rotateY(-5deg) translateZ(0);
  transform-origin:50% 55%;
  transform-style:preserve-3d;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  will-change:transform;
  transition:transform .7s cubic-bezier(.2,.8,.2,1);
}
.hero-dw-wrap:hover{transform:rotateY(-2deg) translateZ(0)}
.hero-dw-wrap img,
.hero-dw-wrap .dw-canvas{
  transform:translateZ(0);
  backface-visibility:hidden;
}
/* Bottom fade overlay (NOT a mask — keeps the text rasterizer at full fidelity).
   Taller + earlier start so the dashboard cards beneath the headline stats
   don't cut off mid-row at a hard edge. */
.hero-dw-wrap::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:42%;
  pointer-events:none;z-index:3;
  background:linear-gradient(to bottom,
    transparent 0%,
    rgba(10,10,10,0.25) 30%,
    rgba(10,10,10,0.75) 65%,
    rgba(10,10,10,0.95) 88%,
    #0a0a0a 100%);
}
/* Soft outer halo behind the preview — anchors it to the page atmospherically.
   No blue this time (per earlier feedback) — just a faint dark shadow that
   bleeds outward, no rim glow. */
.hero-dw-wrap::before{
  content:"";position:absolute;inset:-30px -20px -60px -20px;
  border-radius:24px;pointer-events:none;z-index:-1;
  background:radial-gradient(ellipse 60% 50% at 50% 60%, rgba(0,0,0,0.55) 0%, transparent 70%);
  filter:blur(28px);
}
/* Halo removed — was casting blue tint over the top of the page */
@media(max-width:1100px){.hero-inner{perspective:none}.hero-dw-wrap{transform:none !important}}
.globe-aurora{position:absolute;inset:-120px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,rgba(34,171,148,0.18) 0%,rgba(34,171,148,0.08) 35%,transparent 65%);
  filter:blur(28px);animation:aurora-pulse 9s ease-in-out infinite;pointer-events:none}
@keyframes aurora-pulse{
  0%,100%{transform:scale(1) rotate(0deg);opacity:.85}
  50%{transform:scale(1.12) rotate(14deg);opacity:1}
}
/* V2: richer orbit layer with proper coin logos */
.globe-orbit-eth{position:absolute;inset:-52px;animation:orbit 5s linear infinite reverse;pointer-events:none}
.globe-orbit-sol{position:absolute;inset:-78px;animation:orbit 7s linear infinite;pointer-events:none}
.globe-orbit-bnb{position:absolute;inset:-20px;animation:orbit 4s linear infinite reverse;pointer-events:none}
.coin-logo{position:absolute;top:0;left:50%;transform:translateX(-50%) translateY(-50%);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 14px rgba(0,0,0,0.4)}
.coin-logo.btc{width:34px;height:34px;filter:drop-shadow(0 0 12px rgba(247,147,26,.6))}
.coin-logo.eth{filter:drop-shadow(0 0 12px rgba(98,126,234,.7))}
.coin-logo.sol{filter:drop-shadow(0 0 12px rgba(20,241,149,.7))}
.coin-logo.bnb{width:24px;height:24px;filter:drop-shadow(0 0 10px rgba(243,186,47,.75))}
.coin-logo svg{width:100%;height:100%;display:block}

/* V2: section-specific decorative glows — bounded inside each section, no edge seams */
#features,#proof,#dashboard,#versus,#whofor,#pricing,#faq{position:relative;overflow:hidden}
#features::before{content:"";position:absolute;top:0;right:0;width:70%;height:90%;background:radial-gradient(ellipse at 70% 30%,rgba(52,152,219,0.10),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#proof::before{content:"";position:absolute;top:10%;left:0;width:60%;height:80%;background:radial-gradient(ellipse at 30% 50%,rgba(34,171,148,0.10),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#dashboard::before{content:"";position:absolute;bottom:0;right:0;width:80%;height:100%;background:radial-gradient(ellipse at 70% 70%,rgba(52,152,219,0.08),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#versus::before{content:"";position:absolute;top:0;left:30%;width:60%;height:80%;background:radial-gradient(ellipse at 50% 30%,rgba(34,171,148,0.08),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#whofor::before{content:"";position:absolute;top:20%;right:0;width:60%;height:80%;background:radial-gradient(ellipse at 70% 50%,rgba(52,152,219,0.08),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#pricing::before{content:"";position:absolute;top:0;left:0;width:80%;height:100%;background:radial-gradient(ellipse at 30% 50%,rgba(46,204,113,0.09),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#faq::before{content:"";position:absolute;top:10%;right:0;width:60%;height:80%;background:radial-gradient(ellipse at 70% 50%,rgba(52,152,219,0.08),transparent 55%);pointer-events:none;z-index:0;filter:blur(10px)}
#features>*,#proof>*,#dashboard>*,#versus>*,#whofor>*,#pricing>*,#faq>*{position:relative;z-index:1}

/* V2: vs Free Tools — tight comparison rows with dramatic FREE vs HERE contrast */
.v2-vs-list{display:flex;flex-direction:column;margin-top:56px;border-top:1px solid rgba(255,255,255,0.06)}
.v2-vs-row{display:grid;grid-template-columns:minmax(180px,1fr) 3fr;gap:36px;padding:28px 0;border-bottom:1px solid rgba(255,255,255,0.06);opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);align-items:center;position:relative}
.v2-vs-row.in-view{opacity:1;transform:none}
.v2-vs-row:hover{background:linear-gradient(90deg,transparent 0%,rgba(34,171,148,0.02) 100%)}
.v2-vs-tool{display:flex;flex-direction:column;gap:8px;position:sticky;top:100px}
.v2-vs-num{font-size:11px;font-weight:800;color:#3498db;letter-spacing:.18em;font-variant-numeric:tabular-nums}
.v2-vs-name{font-size:24px;font-weight:800;color:#fff;margin:0;letter-spacing:-.01em;line-height:1.15;transition:color .3s}
.v2-vs-row:hover .v2-vs-name{color:#22AB94}
.v2-vs-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:stretch}
.v2-vs-arrow{display:flex;align-items:center;justify-content:center;font-size:18px;color:#3d5068;font-weight:300;transition:.4s;transform:translateX(0)}
.v2-vs-row.in-view .v2-vs-arrow{animation:vs-arrow-slide 1.2s ease-out .6s both}
@keyframes vs-arrow-slide{0%{opacity:0;transform:translateX(-6px)}60%{opacity:1;transform:translateX(2px);color:#22AB94}100%{opacity:1;transform:translateX(0);color:#3d5068}}
.v2-vs-row:hover .v2-vs-arrow{color:#22AB94;transform:translateX(4px)}
.v2-vs-side{padding:18px 22px;border-radius:12px;transition:.4s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}
.v2-vs-side.free{background:rgba(231,76,60,0.04);border:1px solid rgba(231,76,60,0.15);opacity:0.85}
.v2-vs-side.here{background:linear-gradient(135deg,rgba(34,171,148,0.08),rgba(34,171,148,0.03));border:1px solid rgba(34,171,148,0.25)}
.v2-vs-side.here::before{content:"";position:absolute;top:0;left:-50%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(34,171,148,0.12),transparent);animation:vs-shimmer 6s ease-in-out infinite;pointer-events:none}
@keyframes vs-shimmer{0%,100%{left:-50%}50%{left:110%}}
.v2-vs-row:hover .v2-vs-side.free{opacity:0.7}
.v2-vs-row:hover .v2-vs-side.here{background:linear-gradient(135deg,rgba(34,171,148,0.08),rgba(34,171,148,0.05));border-color:rgba(34,171,148,0.4);transform:translateY(-2px);box-shadow:0 14px 40px rgba(34,171,148,0.15)}
.v2-vs-tag{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.v2-vs-tag::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%}
.v2-vs-side.free .v2-vs-tag{color:#e74c3c}
.v2-vs-side.free .v2-vs-tag::before{background:#e74c3c;opacity:.6}
.v2-vs-side.here .v2-vs-tag{color:#22AB94}
.v2-vs-side.here .v2-vs-tag::before{background:#22AB94;box-shadow:0 0 8px #22AB94;animation:vs-dot-pulse 1.8s ease-in-out infinite}
@keyframes vs-dot-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}
.v2-vs-side p{font-size:13.5px;color:#9aafcc;line-height:1.65;margin:0}
.v2-vs-side.here p{color:#c8d8ec}
@media(max-width:900px){
  .v2-vs-row{grid-template-columns:1fr;gap:18px;padding:24px 0}
  .v2-vs-tool{position:static}
  .v2-vs-comparison{grid-template-columns:1fr;gap:10px}
  .v2-vs-arrow{display:none}
}

/* V2: Who For — typography-led, no boxes */
.v2-who-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:48px}
.v2-who-col{display:flex;flex-direction:column;gap:18px}
.v2-who-header{font-size:20px;font-weight:800;display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,0.08)}
.v2-who-col.yes .v2-who-header{color:#2ecc71}
.v2-who-col.no .v2-who-header{color:#e74c3c}
.v2-who-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;font-size:16px;font-weight:900;flex-shrink:0}
.v2-who-col.yes .v2-who-icon{background:rgba(46,204,113,0.15);color:#2ecc71;border:1px solid rgba(46,204,113,0.35);box-shadow:0 0 16px rgba(46,204,113,0.15)}
.v2-who-col.no .v2-who-icon{background:rgba(231,76,60,0.15);color:#e74c3c;border:1px solid rgba(231,76,60,0.35)}
.v2-who-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}
.v2-who-list li{font-size:14.5px;color:#9aafcc;line-height:1.65;padding-left:28px;position:relative;opacity:0;transform:translateX(-8px);transition:opacity .5s ease-out,transform .5s ease-out}
.v2-who-col.in-view .v2-who-list li{opacity:1;transform:none}
.v2-who-col.yes .v2-who-list li::before{content:"";position:absolute;left:4px;top:10px;width:14px;height:2px;background:#2ecc71;border-radius:1px}
.v2-who-col.no .v2-who-list li::before{content:"";position:absolute;left:4px;top:10px;width:14px;height:2px;background:#e74c3c;border-radius:1px;transform:rotate(45deg)}
.v2-who-col.no .v2-who-list li::after{content:"";position:absolute;left:4px;top:10px;width:14px;height:2px;background:#e74c3c;border-radius:1px;transform:rotate(-45deg)}
.v2-who-col.in-view .v2-who-list li:nth-child(1){transition-delay:.1s}
.v2-who-col.in-view .v2-who-list li:nth-child(2){transition-delay:.2s}
.v2-who-col.in-view .v2-who-list li:nth-child(3){transition-delay:.3s}
.v2-who-col.in-view .v2-who-list li:nth-child(4){transition-delay:.4s}
.v2-who-col.in-view .v2-who-list li:nth-child(5){transition-delay:.5s}
.v2-who-list li em{color:#c8d8ec;font-style:italic}
@media(max-width:900px){.v2-who-grid{grid-template-columns:1fr;gap:40px}}

/* V2: FAQ — native accordion, minimal dividers, no boxes */
.v2-faq-list{display:flex;flex-direction:column;margin-top:48px;max-width:860px;border-top:1px solid rgba(255,255,255,0.08)}
.v2-faq-item{border-bottom:1px solid rgba(255,255,255,0.08)}
.v2-faq-item summary{list-style:none;cursor:pointer;padding:22px 4px;display:flex;justify-content:space-between;align-items:center;font-size:16px;font-weight:600;color:#e0e8f5;transition:color .2s;gap:24px}
.v2-faq-item summary::-webkit-details-marker{display:none}
.v2-faq-item summary::marker{display:none}
.v2-faq-item:hover summary{color:#fff}
.v2-faq-toggle{font-size:22px;font-weight:300;color:#5bb3e8;transition:transform .3s;flex-shrink:0;line-height:1}
.v2-faq-item[open] .v2-faq-toggle{transform:rotate(45deg)}
.v2-faq-a{padding:2px 48px 26px 4px;font-size:14px;color:#9aafcc;line-height:1.7}
.v2-faq-item[open] .v2-faq-a{animation:v2-faq-in .35s ease-out}
@keyframes v2-faq-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* V2: editorial-style blog list — no boxes, horizontal dividers, big titles */
.blog-latest-grid{display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:0 !important;margin-top:40px !important;border-top:1px solid rgba(255,255,255,0.08)}
.blog-latest-card{background:transparent !important;border:none !important;border-right:1px solid rgba(255,255,255,0.06) !important;border-radius:0 !important;padding:28px 28px !important;position:relative;transition:background .3s !important}
.blog-latest-card:last-child{border-right:none !important}
.blog-latest-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#22AB94,transparent);transform:scaleX(0);transform-origin:center;transition:transform .4s ease-out}
.blog-latest-card:hover{background:rgba(34,171,148,0.03) !important;transform:none !important;border-color:rgba(255,255,255,0.06) !important}
.blog-latest-card:hover::before{transform:scaleX(1)}
.blog-latest-card h3{font-size:1.25rem !important;font-weight:800 !important;color:#e8eef7 !important;letter-spacing:-0.015em !important;line-height:1.25 !important;margin:0 0 12px 0 !important;transition:color .2s}
.blog-latest-card:hover h3{color:#fff !important}
.blog-latest-card p{color:#9aafcc !important;line-height:1.6 !important;font-size:.9rem !important;margin:0 0 16px 0 !important;flex:1 !important}
.blog-latest-card .meta{color:#5a7a9a !important;font-size:.75rem !important;font-weight:600 !important;letter-spacing:.04em !important;text-transform:uppercase !important;padding-top:12px !important;border-top:1px solid rgba(255,255,255,0.04) !important;margin-top:auto !important}
.blog-latest-read{display:inline-flex !important;align-items:center !important;gap:6px !important;padding:0 !important;margin-top:12px !important;border:none !important;background:transparent !important;color:#22AB94 !important;font-weight:700 !important;font-size:.85rem !important;letter-spacing:.01em !important;transition:gap .25s !important}
.blog-latest-card:hover .blog-latest-read{background:transparent !important;color:#22AB94 !important;gap:12px !important}
@media(max-width:900px){
  .blog-latest-grid{grid-template-columns:1fr !important}
  .blog-latest-card{border-right:none !important;border-bottom:1px solid rgba(255,255,255,0.06) !important;padding:24px 0 !important}
  .blog-latest-card:last-child{border-bottom:none !important}
}

/* V2: compact Fascia "nice mention" — after founder note */
.v2-fascia-card{display:flex;justify-content:space-between;align-items:center;gap:24px;max-width:900px;margin:8px auto 32px;padding:18px 26px;background:linear-gradient(135deg,rgba(52,152,219,0.08),rgba(52,152,219,0.02));border:1px solid rgba(52,152,219,0.22);border-radius:14px;text-decoration:none;transition:.25s}
.v2-fascia-card:hover{border-color:rgba(52,152,219,0.4);background:linear-gradient(135deg,rgba(52,152,219,0.12),rgba(52,152,219,0.04));transform:translateY(-1px)}
.v2-fascia-left{flex:1;min-width:0}
.v2-fascia-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#5bb3e8;background:rgba(52,152,219,0.08);padding:3px 10px;border-radius:12px;margin-bottom:8px}
.v2-fascia-title{font-size:17px;font-weight:800;color:#fff;margin:0 0 4px 0;letter-spacing:-.01em}
.v2-fascia-sub{font-size:13px;color:#8aa3c0;line-height:1.5;margin:0}
.v2-fascia-cta{display:inline-flex;align-items:center;padding:10px 18px;background:rgba(52,152,219,0.08);border:1px solid rgba(52,152,219,0.35);border-radius:8px;color:#b8dcf5;font-size:13px;font-weight:700;white-space:nowrap;flex-shrink:0}
.v2-fascia-card:hover .v2-fascia-cta{background:rgba(52,152,219,0.28);color:#fff}
@media(max-width:700px){.v2-fascia-card{flex-direction:column;align-items:flex-start;gap:14px;padding:18px 20px}.v2-fascia-cta{width:100%;justify-content:center}}

/* V2: top category nav — Block Pro style (7 items, tight) */
.nav-cat{display:flex;align-items:center;gap:0;margin-right:10px;padding-right:12px;border-right:1px solid rgba(255,255,255,0.08)}
.nav-cat a{padding:7px 9px;color:#9ab0cc;font-size:12.5px;font-weight:600;letter-spacing:.01em;transition:.2s;border-radius:6px;white-space:nowrap}
.nav-cat a:hover{color:#fff;background:rgba(255,255,255,0.04)}
.nav-cat a.pricing{color:#22AB94}
/* V2: on mobile, promote the category row to a sticky horizontal-scroll strip
   that sits directly under the fixed top nav — same pattern as the in-app
   .pv-mobile-nav. Keeps all 7 sections reachable without a hamburger. */
@media(max-width:1050px){
  .nav-cat{position:fixed;top:60px;left:0;right:0;z-index:99;margin:0;padding:6px 12px;border:0;border-top:1px solid rgba(255,255,255,0.04);border-bottom:1px solid rgba(255,255,255,0.08);background:rgba(10,10,10,0.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);overflow-x:auto;-webkit-overflow-scrolling:touch;gap:2px;scrollbar-width:none}
  .nav-cat::-webkit-scrollbar{display:none}
  .nav-cat a{padding:6px 12px;font-size:12px;flex:0 0 auto}
  .nav-cat a.pricing{background:rgba(34,171,148,0.1);border:1px solid rgba(34,171,148,0.25)}
  /* Push all anchor targets down so they don't land under the fixed nav */
  html{scroll-padding-top:72px}
}

/* V2: breathe life into the features section */
/* Entry fade-in on scroll */
.features-section .feat,.features-section .feat-hero{opacity:0;transform:translateY(24px);transition:opacity .7s ease-out,transform .7s ease-out}
.features-section.in-view .feat,.features-section.in-view .feat-hero{opacity:1;transform:translateY(0)}
.features-section.in-view .feat-hero{transition-delay:.05s}
.features-section.in-view .features-grid .feat:nth-child(1){transition-delay:.18s}
.features-section.in-view .features-grid .feat:nth-child(2){transition-delay:.30s}
.features-section.in-view .features-grid .feat:nth-child(3){transition-delay:.42s}

/* Live-pulse dot on each icon */
.features-section .feat{position:relative}
.features-section .feat-icon{position:relative;display:inline-flex;align-items:center;justify-content:center}
.features-section .feat-icon::after{content:"";position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:#2ecc71;box-shadow:0 0 10px #2ecc71;animation:pulse-dot 1.8s ease-in-out infinite}

/* Ambient shimmer sweep — per-box, randomized delays so it doesn't look like a cross-box sweep */
.features-section .feat::after{content:"";position:absolute;top:-20%;left:-60%;width:40%;height:140%;background:linear-gradient(115deg,transparent 0%,rgba(52,152,219,0.12) 50%,transparent 100%);transform:skewX(-20deg);animation:shimmer-sweep 14s ease-in-out infinite;pointer-events:none}
.features-section .features-grid .feat:nth-child(1)::after{animation-delay:0s}
.features-section .features-grid .feat:nth-child(2)::after{animation-delay:6.5s}
.features-section .features-grid .feat:nth-child(3)::after{animation-delay:2.5s}
.features-section .feat-hero::after{animation-duration:18s;animation-delay:9s;background:linear-gradient(115deg,transparent 0%,rgba(34,171,148,0.15) 50%,transparent 100%)}
@keyframes shimmer-sweep{0%{left:-60%}35%{left:160%}100%{left:160%}}

/* Live ticker in the signal card */
.feat-hero .feat-live{display:inline-flex;align-items:center;gap:6px;margin-left:12px;padding:3px 10px;border-radius:12px;background:rgba(46,204,113,0.12);border:1px solid rgba(46,204,113,0.3);font-size:10px;font-weight:700;letter-spacing:.08em;color:#2ecc71;text-transform:uppercase;vertical-align:middle}
.feat-hero .feat-live .dot{width:6px;height:6px;border-radius:50%;background:#2ecc71;box-shadow:0 0 6px #2ecc71;animation:pulse-dot 1.5s ease-in-out infinite}

/* V2: unify feature card backgrounds (feat-hero had a blue tint that clashed with the 3 below) */
.features-section .feat,.features-section .feat-hero{background:linear-gradient(135deg,#0d1218 0%,#0a0d12 100%) !important;border:1px solid rgba(255,255,255,0.07) !important}

/* V2: mini data visuals inside feature cards */

/* Section label live counter */
.features-section .section-label .lc-num{color:#2ecc71;font-weight:800;letter-spacing:.04em;font-variant-numeric:tabular-nums}
.features-section .section-label .lc-tail{color:#5a7090;font-weight:500;letter-spacing:.06em;text-transform:none}

/* Signal confluence gauge (hero card) */
@media(min-width:901px){.feat-hero{padding-right:300px !important}}
.v2-sig{position:absolute;top:32px;right:32px;width:248px;display:flex;flex-direction:column;align-items:center;gap:14px;pointer-events:none}
.v2-sig-score{position:relative;width:96px;height:96px}
.v2-sig-ring{width:100%;height:100%;animation:sig-ring-pulse 3s ease-in-out infinite}
@keyframes sig-ring-pulse{0%,100%{filter:drop-shadow(0 0 6px rgba(46,204,113,.4))}50%{filter:drop-shadow(0 0 16px rgba(46,204,113,.75))}}
.v2-sig-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0}
.v2-sig-num strong{font-size:26px;font-weight:900;color:#2ecc71;line-height:1}
.v2-sig-num span{font-size:10px;color:#7a8ea8;margin-top:2px}
.v2-sig-inputs{display:flex;gap:5px;align-items:flex-end;height:48px}
.v2-sig-inp{position:relative;display:flex;flex-direction:column;align-items:center;width:22px;height:100%;justify-content:flex-end}
.v2-sig-inp .bar{width:100%;background:linear-gradient(180deg,#2ecc71,#22AB94);border-radius:2px;animation:sig-bar 2s ease-in-out infinite;box-shadow:0 0 6px rgba(46,204,113,.3)}
.v2-sig-inp:nth-child(1) .bar{height:72%;animation-delay:0s}
.v2-sig-inp:nth-child(2) .bar{height:58%;animation-delay:.15s}
.v2-sig-inp:nth-child(3) .bar{height:82%;animation-delay:.3s}
.v2-sig-inp:nth-child(4) .bar{height:45%;animation-delay:.45s}
.v2-sig-inp:nth-child(5) .bar{height:68%;animation-delay:.6s}
.v2-sig-inp:nth-child(6) .bar{height:88%;animation-delay:.75s}
.v2-sig-inp:nth-child(7) .bar{height:55%;animation-delay:.9s}
@keyframes sig-bar{0%,100%{opacity:.45;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.08)}}
.v2-sig-label{font-size:10px;color:#8aa3c0;text-align:center;letter-spacing:.04em;line-height:1.4}
.v2-sig-label strong{color:#2ecc71;font-weight:700}
@media(max-width:900px){.v2-sig{display:none}}

/* Mini widgets inside feature cards — same font as rest of page (Satoshi) */
.v2-mini{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.06)}

/* Whale mini: 3 rows with coin, arrow, value */
.v2-whale{display:flex;flex-direction:column;gap:8px}
.v2-whale .v2-wrow{display:flex;align-items:center;gap:12px;font-size:12px;opacity:0;transform:translateX(-6px);transition:opacity .5s ease-out,transform .5s ease-out;font-variant-numeric:tabular-nums}
.features-section.in-view .v2-whale .v2-wrow{opacity:1;transform:none}
.features-section.in-view .v2-whale .v2-wrow:nth-child(1){transition-delay:.5s}
.features-section.in-view .v2-whale .v2-wrow:nth-child(2){transition-delay:.65s}
.features-section.in-view .v2-whale .v2-wrow:nth-child(3){transition-delay:.8s}
.v2-whale .v2-wcoin{width:38px;color:#e0e8f5;font-weight:700;font-size:11px;letter-spacing:.04em}
.v2-whale .v2-warr{font-weight:800;font-size:14px;width:12px;text-align:center}
.v2-whale .v2-wval{flex:1;font-size:12px;font-weight:600}
.v2-whale .v2-wrow.pos .v2-warr,.v2-whale .v2-wrow.pos .v2-wval{color:#2ecc71}
.v2-whale .v2-wrow.neg .v2-warr,.v2-whale .v2-wrow.neg .v2-wval{color:#e74c3c}
.v2-whale .v2-wrow .v2-wbar{height:3px;background:currentColor;border-radius:2px;opacity:.5}

/* AI mini: typing-style lines */
.v2-ai{display:flex;flex-direction:column;gap:6px}
.v2-ai .v2-aline{font-size:12px;color:#8aa3c0;line-height:1.7;opacity:0;transition:opacity .6s ease-out}
.features-section.in-view .v2-ai .v2-aline{opacity:1}
.features-section.in-view .v2-ai .v2-aline:nth-child(1){transition-delay:.5s}
.features-section.in-view .v2-ai .v2-aline:nth-child(2){transition-delay:1.3s}
.features-section.in-view .v2-ai .v2-aline:nth-child(3){transition-delay:2.1s}
.v2-ai .v2-aline::before{content:"> ";color:#3498db;font-weight:700}
.v2-ai .v2-bias{color:#2ecc71;font-weight:700}

/* Market pulse mini: EKG + stats */
.v2-pulse{display:block}
.v2-pulse .v2-ekg{width:100%;height:32px;margin-bottom:10px}
.v2-pulse .v2-ekg path{stroke:#2ecc71;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:400;stroke-dashoffset:400;animation:ekg-trace 3s ease-out infinite}
@keyframes ekg-trace{0%{stroke-dashoffset:400;filter:drop-shadow(0 0 2px rgba(46,204,113,.4))}60%{stroke-dashoffset:0;filter:drop-shadow(0 0 8px rgba(46,204,113,.9))}100%{stroke-dashoffset:0;opacity:0}}
.v2-pulse-stats{display:flex;justify-content:space-between;gap:8px;font-variant-numeric:tabular-nums}
.v2-pulse-stats span{display:flex;flex-direction:column;gap:3px;flex:1}
.v2-pulse-stats .lbl{color:#5a7090;font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}
.v2-pulse-stats .val{color:#e8eef7;font-weight:700;font-size:14px}
.v2-pulse-stats .val.pos{color:#2ecc71}

/* V2: mini widgets for extra feature cards — Satoshi, brand-consistent, subtle */

/* News sources — clean inline list, not flex chips */
.v2-sources{display:block;font-size:12px;line-height:1.7;color:#8aa3c0}
.v2-sources .more{color:#22AB94;font-weight:700;white-space:nowrap}

/* World map pulse row — compact, centered, sans-serif */
.v2-worldmap{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:10px;font-size:11px;padding:4px 0;flex-wrap:wrap}
.v2-worldmap .wm-region{display:inline-flex;align-items:center;gap:7px;color:#b0c4dc;font-weight:500}
.v2-worldmap .wm-dot{width:7px;height:7px;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}
.v2-worldmap .wm-dot.a{background:#22AB94;box-shadow:0 0 6px rgba(34,171,148,.7)}
.v2-worldmap .wm-dot.b{background:#3498db;box-shadow:0 0 6px rgba(52,152,219,.7);animation-delay:.3s}
.v2-worldmap .wm-dot.c{background:#f39c12;box-shadow:0 0 6px rgba(243,156,18,.7);animation-delay:.6s}
.v2-worldmap .wm-dot.d{background:#e74c3c;box-shadow:0 0 6px rgba(231,76,60,.7);animation-delay:.9s}

/* Token unlock rows */
.v2-unlocks{display:flex;flex-direction:column;gap:7px;font-size:12px;font-variant-numeric:tabular-nums}
.v2-unlocks .u-row{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:baseline}
.v2-unlocks .u-sym{color:#e0e8f5;font-weight:700;font-size:11px;letter-spacing:.02em}
.v2-unlocks .u-when{color:#8aa3c0;font-size:11px}
.v2-unlocks .u-amt{color:#f39c12;font-weight:700;font-size:12px}

/* Exchange reserves */
.v2-reserves{display:flex;flex-direction:column;gap:7px;font-size:12px;font-variant-numeric:tabular-nums}
.v2-reserves .r-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.v2-reserves .r-ex{color:#e0e8f5;font-weight:600;font-size:12px}
.v2-reserves .r-val{font-size:12px;font-weight:700}
.v2-reserves .r-val.up{color:#e74c3c}
.v2-reserves .r-val.dn{color:#2ecc71}

/* Risk assessment */
.v2-risk{display:flex;flex-direction:column;gap:12px;font-size:12px;color:#8aa3c0}
.v2-risk .rl-wrap{display:flex;justify-content:space-between;align-items:center}
.v2-risk .rl-label{font-size:11px;color:#8aa3c0;font-weight:500}
.v2-risk .rl-val{padding:4px 12px;border-radius:6px;font-size:10px;letter-spacing:.08em;font-weight:800;text-transform:uppercase}
.v2-risk .rl-val.elev{background:rgba(243,156,18,.14);color:#f39c12;border:1px solid rgba(243,156,18,.3)}
.v2-risk .rm-wrap{display:flex;gap:8px;justify-content:space-between;font-variant-numeric:tabular-nums}
.v2-risk .rm-wrap span{display:flex;flex-direction:column;gap:3px;text-align:center;flex:1}
.v2-risk .rm-tf{font-size:10px;color:#5a7090;letter-spacing:.04em;font-weight:500}
.v2-risk .rm-dir{font-size:13px;font-weight:800}
.v2-risk .rm-dir.up{color:#2ecc71}
.v2-risk .rm-dir.dn{color:#e74c3c}

/* Per-coin flows */
.v2-percoin{display:flex;flex-direction:column;gap:7px;font-size:12px;font-variant-numeric:tabular-nums}
.v2-percoin .pc-row{display:grid;grid-template-columns:38px 56px 1fr;gap:10px;align-items:baseline;color:#8aa3c0}
.v2-percoin .pc-sym{font-weight:700;color:#e0e8f5;font-size:11px;letter-spacing:.02em}
.v2-percoin .pc-txs{color:#5a7090;font-size:11px}
.v2-percoin .pc-net{font-weight:700;text-align:right;font-size:12px}
.v2-percoin .pc-net.pos{color:#2ecc71}
.v2-percoin .pc-net.neg{color:#e74c3c}

/* V2: Case study cards — chart + pill signals + animations */
.uc-v2-preamble{margin-bottom:24px;font-size:14px;color:#8aa3c0;line-height:1.65;font-style:italic}
.uc-v2-preamble strong{color:#c8d8ec;font-style:normal;font-weight:700}
.uc-v2-card{background:linear-gradient(135deg,#0d1218 0%,#0a0d12 100%);border:1px solid rgba(255,255,255,0.06);border-radius:20px;padding:30px 32px;margin-bottom:24px;opacity:0;transform:translateY(28px);transition:opacity .7s ease-out,transform .7s ease-out;position:relative;overflow:hidden}
.uc-v2-card.in-view{opacity:1;transform:none}
.uc-v2-card.bull{border-color:rgba(46,204,113,0.15)}
.uc-v2-card.bear{border-color:rgba(231,76,60,0.15)}
.uc-v2-card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(46,204,113,0.35),transparent)}
.uc-v2-card.bear::before{background:linear-gradient(90deg,transparent,rgba(231,76,60,0.35),transparent)}

.uc-v2-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:8px}
.uc-v2-coin{display:flex;flex-direction:column;gap:4px}
.uc-v2-sym{font-size:24px;font-weight:900;color:#fff;letter-spacing:-.01em;line-height:1}
.uc-v2-date{font-size:11px;color:#7a94b4;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.uc-v2-outcome-wrap{text-align:right}
.uc-v2-outcome{font-size:38px;font-weight:900;line-height:1;letter-spacing:-.02em}
.uc-v2-outcome.pos{color:#2ecc71}
.uc-v2-outcome.neg{color:#e74c3c}
.uc-v2-outcome-sub{font-size:10px;color:#5a7a9a;letter-spacing:.08em;text-transform:uppercase;margin-top:4px;font-weight:600}

.uc-v2-chart{width:100%;height:140px;margin:8px 0 28px;position:relative}
.uc-v2-chart svg{width:100%;height:100%;overflow:visible;display:block}
.uc-v2-area{opacity:0}
.uc-v2-card.in-view .uc-v2-area{animation:uc-area-in 1s ease-out .5s forwards}
@keyframes uc-area-in{to{opacity:1}}
.uc-v2-line{stroke-dasharray:1200;stroke-dashoffset:1200}
.uc-v2-card.in-view .uc-v2-line{animation:uc-line-draw 1.6s ease-out .2s forwards}
@keyframes uc-line-draw{to{stroke-dashoffset:0}}

/* V2: crisp dots with double-ring + ripple on final */
.uc-v2-dot{position:absolute;width:16px;height:16px;border-radius:50%;background:#3498db;box-shadow:0 0 0 3px #0a0d12,0 0 14px rgba(52,152,219,.6);transform:translate3d(-50%,-50%,0) scale(0);opacity:0;pointer-events:none;will-change:transform,opacity}
.uc-v2-dot.final{width:22px;height:22px;background:#2ecc71;box-shadow:0 0 0 4px #0a0d12,0 0 24px rgba(46,204,113,.9)}
.uc-v2-dot.final::before,.uc-v2-dot.final::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid #2ecc71;opacity:0;pointer-events:none}
.uc-v2-card.in-view .uc-v2-dot.final::before{animation:uc-ripple 2.4s ease-out 2.2s infinite}
.uc-v2-card.in-view .uc-v2-dot.final::after{animation:uc-ripple 2.4s ease-out 3.4s infinite}
@keyframes uc-ripple{0%{opacity:.8;transform:scale(.9)}100%{opacity:0;transform:scale(2.6)}}
.uc-v2-card.bear .uc-v2-dot{background:#e74c3c;box-shadow:0 0 0 3px #0a0d12,0 0 14px rgba(231,76,60,.6)}
.uc-v2-card.bear .uc-v2-dot.final{background:#e74c3c;box-shadow:0 0 0 4px #0a0d12,0 0 24px rgba(231,76,60,.9)}
.uc-v2-card.bear .uc-v2-dot.final::before,.uc-v2-card.bear .uc-v2-dot.final::after{border-color:#e74c3c}
.uc-v2-card.in-view .uc-v2-dot{animation:uc-dot-pop .5s cubic-bezier(.2,.8,.2,1) forwards}
.uc-v2-card.in-view .uc-v2-dot:nth-of-type(1){animation-delay:.8s}
.uc-v2-card.in-view .uc-v2-dot:nth-of-type(2){animation-delay:1.0s}
.uc-v2-card.in-view .uc-v2-dot:nth-of-type(3){animation-delay:1.2s}
.uc-v2-card.in-view .uc-v2-dot:nth-of-type(4){animation-delay:1.4s}
.uc-v2-card.in-view .uc-v2-dot.final{animation:uc-dot-pop-final .7s cubic-bezier(.2,.8,.2,1) 1.6s forwards}
@keyframes uc-dot-pop{from{opacity:0;transform:translate3d(-50%,-50%,0) scale(0)}to{opacity:1;transform:translate3d(-50%,-50%,0) scale(1)}}
@keyframes uc-dot-pop-final{0%{opacity:0;transform:translate3d(-50%,-50%,0) scale(0)}60%{opacity:1;transform:translate3d(-50%,-50%,0) scale(1.25)}100%{opacity:1;transform:translate3d(-50%,-50%,0) scale(1)}}

/* V2: candlestick chart — replaces smooth line, crypto-native feel */
.uc-v2-candle{opacity:0;transform-origin:bottom center;transform-box:fill-box}
.uc-v2-card.in-view .uc-v2-candle{animation:uc-candle-in .5s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes uc-candle-in{from{opacity:0;transform:translateY(12px) scaleY(.4)}to{opacity:1;transform:none}}
.uc-v2-body{filter:drop-shadow(0 0 3px currentColor)}
.uc-v2-wick{opacity:0.8}

/* V2: vertical beam under the final dot — marks the breakout */
.uc-v2-beam{position:absolute;bottom:0;width:2px;background:linear-gradient(180deg,rgba(46,204,113,.6) 0%,rgba(46,204,113,0) 100%);transform:translateX(-50%) scaleY(0);transform-origin:bottom;opacity:0;pointer-events:none}
.uc-v2-card.bear .uc-v2-beam{background:linear-gradient(180deg,rgba(231,76,60,.6) 0%,rgba(231,76,60,0) 100%)}
.uc-v2-card.in-view .uc-v2-beam{animation:uc-beam .9s ease-out 1.9s forwards}
@keyframes uc-beam{0%{opacity:0;transform:translateX(-50%) scaleY(0)}60%{opacity:1;transform:translateX(-50%) scaleY(1)}100%{opacity:.4;transform:translateX(-50%) scaleY(1)}}

.uc-v2-signals{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.uc-v2-sig{display:flex;flex-direction:column;gap:10px;padding:14px 18px;border-radius:10px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.04);opacity:0;transform:translateX(-10px);transition:opacity .5s ease-out,transform .5s ease-out}
.uc-v2-card.in-view .uc-v2-sig{opacity:1;transform:none}
.uc-v2-card.in-view .uc-v2-sig:nth-child(1){transition-delay:1.1s}
.uc-v2-card.in-view .uc-v2-sig:nth-child(2){transition-delay:1.25s}
.uc-v2-card.in-view .uc-v2-sig:nth-child(3){transition-delay:1.4s}
.uc-v2-card.in-view .uc-v2-sig:nth-child(4){transition-delay:1.55s}
.uc-v2-sig.result{background:rgba(46,204,113,0.07);border-color:rgba(46,204,113,0.22)}
.uc-v2-card.bear .uc-v2-sig.result{background:rgba(231,76,60,0.07);border-color:rgba(231,76,60,0.22)}

.uc-v2-sig-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.uc-v2-sig-body{font-size:13.5px;color:#9aafcc;line-height:1.65;padding-left:72px;margin-top:-2px}
.uc-v2-sig-body em{color:#c8d8ec;font-style:italic}
.uc-v2-sig-body strong{color:#e0e8f5;font-weight:700}
@media(max-width:700px){.uc-v2-sig-body{padding-left:0}}

.uc-v2-time{font-size:11px;color:#7a94b4;font-weight:700;letter-spacing:.04em;min-width:62px;font-variant-numeric:tabular-nums}
.uc-v2-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.01em;white-space:nowrap}
.uc-v2-pill.score{background:rgba(52,152,219,0.12);color:#5bb3e8;border:1px solid rgba(52,152,219,0.25)}
.uc-v2-pill.funding{background:rgba(155,89,182,0.12);color:#c8a9dd;border:1px solid rgba(155,89,182,0.25)}
.uc-v2-pill.whale{background:rgba(243,156,18,0.12);color:#f3ba2f;border:1px solid rgba(243,156,18,0.25)}
.uc-v2-pill.threat-high{background:rgba(231,76,60,0.15);color:#ff8078;border:1px solid rgba(231,76,60,0.3)}
.uc-v2-pill.warn{background:rgba(243,156,18,0.15);color:#f39c12;border:1px solid rgba(243,156,18,0.3);font-weight:800}
.uc-v2-pill.outcome-pos{background:rgba(46,204,113,0.15);color:#2ecc71;border:1px solid rgba(46,204,113,0.3);font-weight:800}
.uc-v2-pill.outcome-neg{background:rgba(231,76,60,0.15);color:#e74c3c;border:1px solid rgba(231,76,60,0.3);font-weight:800}
.uc-v2-note{font-size:12px;color:#8aa3c0;font-style:italic;margin-left:auto}

.uc-v2-quote{font-size:14px;color:#9aafcc;font-style:italic;line-height:1.65;padding:14px 20px;border-left:2px solid rgba(52,152,219,0.35);background:rgba(52,152,219,0.04);border-radius:0 8px 8px 0}
.uc-v2-card.bear .uc-v2-quote{border-left-color:rgba(231,76,60,0.35);background:rgba(231,76,60,0.04)}

@media(max-width:700px){
  .uc-v2-card{padding:24px 20px}
  .uc-v2-header{flex-direction:column;gap:12px}
  .uc-v2-outcome-wrap{text-align:left}
  .uc-v2-outcome{font-size:30px}
  .uc-v2-sig{padding:10px 12px;font-size:12px}
  .uc-v2-note{margin-left:0;width:100%;font-size:11px}
  .uc-v2-pill{font-size:10px;padding:2px 8px}
}

/* V2 indicator badge */
.v2-badge{position:fixed;bottom:20px;right:20px;z-index:999;padding:10px 16px;background:rgba(34,171,148,0.15);border:1px solid rgba(34,171,148,0.45);border-radius:8px;font-size:12px;color:#22AB94;font-weight:700;letter-spacing:.05em;backdrop-filter:blur(10px);text-transform:uppercase}
.v2-badge a{color:#22AB94;text-decoration:underline;margin-left:8px}

/* ── HERO LIVE WHOOSH STREAM ──────────────────────────
   Single-line dynamic stream that cycles through real product moments
   (news, whale flow, on-chain, signals, unlocks). Each item slides in
   from right with a blur/scale "whoosh", holds, slides out left.
   Typography-driven (no chips/pills) to match financial-terminal aesthetic. */
.hero-whoosh{
  position:relative;
  height:58px;
  margin:28px 0 24px;
  padding:0 4px 0 26px;
  border-top:1px solid rgba(255,255,255,0.05);
  border-bottom:1px solid rgba(255,255,255,0.05);
  background:linear-gradient(90deg,rgba(46,204,113,0.04) 0%,rgba(255,255,255,0) 18%,rgba(255,255,255,0) 82%,rgba(46,204,113,0.03) 100%);
  overflow:hidden;
  display:flex;align-items:center;
}
.hero-whoosh::before{
  content:"";position:absolute;left:6px;top:50%;transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;
  background:#2ecc71;
  box-shadow:0 0 12px #2ecc71,0 0 26px rgba(46,204,113,0.4);
  animation:pulse-dot 1.5s ease-in-out infinite;
}
.hero-whoosh-stage{
  position:relative;
  width:100%;
  height:100%;
}
.hw-item{
  position:absolute;inset:0;
  display:flex;align-items:baseline;gap:14px;
  opacity:0;
  transform:translateX(80px) scale(0.96);
  filter:blur(6px);
  pointer-events:none;
  transition:none;
}
.hw-item.hw-enter{
  animation:hw-whoosh-in .55s cubic-bezier(.16,1,.3,1) forwards;
}
.hw-item.hw-exit{
  animation:hw-whoosh-out .42s cubic-bezier(.7,0,.84,0) forwards;
}
@keyframes hw-whoosh-in{
  0%{opacity:0;transform:translateX(80px) scale(0.96);filter:blur(6px)}
  60%{opacity:1;filter:blur(0)}
  100%{opacity:1;transform:translateX(0) scale(1);filter:blur(0)}
}
@keyframes hw-whoosh-out{
  0%{opacity:1;transform:translateX(0) scale(1);filter:blur(0)}
  100%{opacity:0;transform:translateX(-80px) scale(0.96);filter:blur(6px)}
}
/* Tag: typography-only label, no pill/chip. Color-coded by category, separated
   from the data text by a subtle vertical hairline. */
.hw-tag{
  position:relative;
  font-size:10.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;
  white-space:nowrap;flex-shrink:0;
  padding-right:13px;
  align-self:center;
}
.hw-tag::after{
  content:"";position:absolute;right:0;top:18%;bottom:18%;
  width:1px;background:rgba(255,255,255,0.09);
}
.hw-tag.t-news    {color:#7a9ab8}
.hw-tag.t-alert   {color:#ff8a70;animation:pulse-dot 1.5s ease-in-out infinite}
.hw-tag.t-whale   {color:#b390cf}
.hw-tag.t-onchain {color:#5bb3e8}
.hw-tag.t-signal  {color:#f6c143}
.hw-tag.t-overview{color:#e87964}
.hw-tag.t-unlock  {color:#e67e22}
.hw-tag.t-mover   {color:#5bdea0}
.hw-tag.t-gov     {color:#b0b8d8}
.hw-text{
  font-size:16px;color:#c8d8ec;line-height:1.25;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  flex:1;min-width:0;
  font-variant-numeric:tabular-nums;
  letter-spacing:-0.005em;
  align-self:center;
}
.hw-text strong{
  color:#fff;font-weight:800;
  font-size:19px;
  letter-spacing:-0.015em;
}
.hw-text .hw-up{color:#2ecc71;font-weight:700}
.hw-text .hw-dn{color:#e74c3c;font-weight:700}
.hw-text .hw-src{color:#5a7a9a;font-size:12px;margin-left:6px;font-weight:500}
.hw-time{color:#5a7a9a;font-size:11.5px;margin-left:4px;font-variant-numeric:tabular-nums;white-space:nowrap;letter-spacing:0.02em;font-weight:500}
@media(max-width:600px){
  .hero-whoosh{height:auto;min-height:64px;padding:10px 4px 10px 26px;margin:22px 0 18px}
  .hw-item{flex-wrap:wrap;gap:6px 10px}
  .hw-text{white-space:normal;font-size:14.5px;line-height:1.3}
  .hw-text strong{font-size:16px}
  .hw-tag{padding-right:10px;font-size:10px}
}

/* ─────────────────────────────────────────────────────────────────────────
   V3 LANDING — multi-page architecture
   Nav dropdowns, page shell, stack-cost strip, sub-page styles
   ───────────────────────────────────────────────────────────────────────── */

/* Body shell */
.lv3-body{margin:0;background:#0a0a0a;color:#e0e6ed;font-family:'Satoshi',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}
.lv3-main{min-height:60vh;background:#0a0a0a}
/* Solid black hero (kill V2's faint white radial which reads as blue),
   but KEEP the subtle grid pattern from .hero::before (it gives texture). */
.lv3-hero{background:#0a0a0a !important}

/* Nav with dropdowns — landing-base.css has `nav { position:fixed; left:0; right:0 }`
   so we MUST keep position:fixed (not sticky) AND constrain width via padding instead
   of max-width (max-width on a fixed element with left:0 + right:0 has no effect). */
nav.lv3-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:14px max(80px, calc((100vw - 1320px) / 2 + 32px));background:rgba(8,12,20,0.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,0.04);max-width:none;margin:0}
.lv3-body{padding-top:72px}  /* offset for fixed nav */
@media(max-width:1480px){nav.lv3-nav{padding:14px clamp(20px,5vw,80px)}}
.lv3-nav .nav-logo{display:flex;align-items:center}
.lv3-nav .nav-actions{display:flex;align-items:center;gap:18px}
.navd-row{display:flex;align-items:center;gap:4px}
.navd-link{color:#c8d6e5;text-decoration:none;font-size:14px;font-weight:600;padding:8px 14px;border-radius:8px;transition:.15s}
@media(hover:hover){.navd-link:hover{color:#fff;background:rgba(255,255,255,0.04)}}
.lv3-nav .nav-x{display:flex;align-items:center;justify-content:center;width:34px;height:34px;color:#aac4e0;border-radius:8px;transition:.15s}
@media(hover:hover){.lv3-nav .nav-x:hover{color:#fff;background:rgba(255,255,255,0.04)}}
.lv3-nav .nav-x svg{width:16px;height:16px}
/* nav-login + nav-cta: keep V2's existing styles (blue CTA, cyan-outlined Log In). Don't override. */

/* Dropdown */
.navd{position:relative}
.navd-trigger{background:transparent;border:0;color:#c8d6e5;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;padding:8px 14px;border-radius:8px;display:inline-flex;align-items:center;gap:5px;transition:.15s}
.navd[data-open] .navd-trigger{color:#fff;background:rgba(255,255,255,0.04)}
@media(hover:hover){.navd-trigger:hover{color:#fff;background:rgba(255,255,255,0.04)}}
.navd-trigger.active{color:#22AB94}
.navd-caret{width:11px;height:11px;transition:transform .2s}
.navd[data-open] .navd-caret{transform:rotate(180deg)}
.navd-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);min-width:320px;padding:8px;background:rgba(14,20,32,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.06);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.6);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s,transform .18s,visibility .18s}
.navd[data-open] .navd-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
/* Mobula-style dropdown items: inline icon + text, no tile background */
.navd-item{display:grid;grid-template-columns:18px 1fr;column-gap:12px;row-gap:1px;align-items:start;padding:11px 14px;border-radius:8px;text-decoration:none;color:inherit;transition:background .15s ease}
@media(hover:hover){.navd-item:hover{background:rgba(255,255,255,0.04)}}
.navd-item-icon{grid-row:1/3;align-self:start;margin-top:2px;color:#7a94b4;display:flex;align-items:center;justify-content:center;transition:color .15s}
.navd-item-icon svg{width:16px;height:16px;display:block}
.navd-item:hover .navd-item-icon{color:#e8eef7}
.navd-item-title{grid-column:2;font-size:14.5px;font-weight:600;color:#e8eef7;line-height:1.3;letter-spacing:-0.005em}
.navd-item-sub{grid-column:2;font-size:12.5px;color:#7a94b4;line-height:1.4;font-weight:400}
.navd-item:hover .navd-item-title{color:#fff}

/* Page hero (sub-pages) */
.page-hero{padding:80px 0 32px;text-align:center}
.page-h1{font-size:54px;font-weight:900;letter-spacing:-0.02em;line-height:1.05;margin:8px 0 18px;color:#fff}
.page-lede{font-size:18px;line-height:1.55;color:#9aafcc;max-width:680px;margin:0 auto}
@media(max-width:700px){.page-h1{font-size:36px}.page-lede{font-size:16px}}

.section-label{display:inline-block;text-transform:uppercase;letter-spacing:0.16em;font-size:11px;color:#3498db;font-weight:700;margin-bottom:8px}
.cta-strip{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:48px}
.sub-h3{font-size:18px;font-weight:700;color:#c8d8ec;margin:36px 0 16px;letter-spacing:-0.005em}

/* ─── Stack-cost editorial: single sentence, premium voice ─── */
.sc-editorial{max-width:780px;margin:8px auto 36px;padding:0 24px;text-align:center;font-size:18px;line-height:1.65;color:#aac4e0;font-weight:500;letter-spacing:-0.005em}
.sc-num-them{color:#fff;font-weight:800;font-variant-numeric:tabular-nums;font-size:1.05em}
.sc-num-us{color:#22AB94;font-weight:800;font-variant-numeric:tabular-nums;font-size:1.05em}
@media(max-width:600px){
  .sc-editorial{font-size:16px;padding:0 12px;margin:8px auto 28px}
}

/* ─── Footer ─── */
.lv3-footer{margin-top:80px;padding:60px 32px 24px;background:rgba(6,10,18,0.7);border-top:1px solid rgba(255,255,255,0.04)}
.footer-inner{display:grid;grid-template-columns:1.2fr 2.5fr;gap:48px;max-width:1280px;margin:0 auto}
.footer-brand img{display:block;margin-bottom:14px}
.footer-tag{font-size:14px;color:#9aafcc;margin:0 0 10px;line-height:1.5}
.footer-co{font-size:12px;color:#5a7a9a;line-height:1.55;margin:0}
.footer-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.footer-col h4{font-size:11px;text-transform:uppercase;letter-spacing:0.14em;color:#7a94b4;margin:0 0 14px;font-weight:700}
.footer-col a{display:block;color:#aac4e0;text-decoration:none;font-size:13.5px;line-height:1.85;transition:.12s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;max-width:1280px;margin:48px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,0.04);font-size:11.5px;color:#5a7a9a}
@media(max-width:900px){
  .footer-inner{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:repeat(2,1fr)}
}

/* ─── Sub-page specific ─── */
.sig-inputs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px}
.sig-input{padding:18px;background:rgba(14,20,32,0.5);border:1px solid rgba(255,255,255,0.05);border-radius:12px}
.sig-input-name{font-size:13px;font-weight:700;color:#22AB94;margin-bottom:6px;letter-spacing:0.02em}
.sig-input-desc{font-size:13px;color:#9aafcc;line-height:1.5;margin:0}
@media(max-width:800px){.sig-inputs-grid{grid-template-columns:1fr}}

.tier-rules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.tier-rule{display:flex;flex-direction:column;gap:6px;padding:14px;background:rgba(14,20,32,0.4);border-radius:10px;border:1px solid rgba(255,255,255,0.04)}
.tier-pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:0.04em}
.tier-pill.tier-strong{background:rgba(46,204,113,0.15);color:#2ecc71;border:1px solid rgba(46,204,113,0.28)}
.tier-pill.tier-building{background:rgba(255,180,40,0.10);color:#f1b938;border:1px solid rgba(255,180,40,0.22)}
.tier-pill.tier-noise{background:rgba(120,140,160,0.10);color:#7a94b4;border:1px solid rgba(120,140,160,0.20)}
.tier-desc{font-size:13px;color:#9aafcc}
@media(max-width:700px){.tier-rules-grid{grid-template-columns:1fr}}

.dw-frame{border-radius:14px;overflow:hidden;border:1px solid rgba(52,152,219,0.10);box-shadow:0 30px 80px rgba(0,0,0,0.5),0 0 100px rgba(34,171,148,0.06);background:#060d16;margin-top:14px}
.dw-frame img{width:100%;display:block;transition:opacity .28s}
.dw-frame img.swapping{opacity:0.3}
.dw-caption{text-align:center;color:#9aafcc;font-size:14px;margin-top:18px}
.dw-caption strong{color:#fff}

.feat-hero-row{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;padding:32px;background:rgba(52,152,219,0.05);border:1px solid rgba(52,152,219,0.20);border-radius:16px;margin-bottom:24px}
.feat-hero-row .feat-icon{width:52px;height:52px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.feat-hero-row .feat-icon svg{width:26px;height:26px}
.feat-title-lg{font-size:20px;font-weight:800;color:#fff;margin-bottom:10px}

/* Founder quote (page-level) */
.founder-quote-section{padding:80px 0}
.fq-blockquote{max-width:780px;margin:0 auto;padding:0;text-align:center}
.fq-blockquote p{font-style:italic;font-size:18px;line-height:1.7;color:#c8d8ec;margin:0 0 24px}
.fq-footer{display:inline-flex;gap:8px;align-items:baseline;color:#7a94b4;font-style:normal}
.fq-name{font-weight:700;color:#fff;font-style:normal}
.fq-sep{color:#3d5268}
.fq-role{font-style:normal}

/* Pricing page-style tweaks (V3) */
/* Center the pricing-section heading + label so they line up with the intro/cards/stack-cost */
.pricing-section .section-label,
.pricing-section .section-title{text-align:center}
.pricing-section .section-label{display:block}
.pricing-section .section-title{max-width:840px;margin-left:auto;margin-right:auto}
.pricing-intro{text-align:center;color:#8a9eb8;font-size:1.05rem;margin:-6px auto 24px;max-width:640px;line-height:1.55}
.pricing-disclaimer{text-align:center;font-size:11.5px;color:#3a5060;margin-top:4px;line-height:2}

/* FAQ — single-column editorial list. Typographic dividers, no card chrome,
   subtle teal accent on hover/open, animated expand. Counters rendered via CSS. */
.faq-section .section-inner{max-width:840px}
.faq-section .faq-grid{display:block !important;grid-template-columns:1fr !important;gap:0 !important;margin-top:48px;border-top:1px solid rgba(255,255,255,0.06);counter-reset:faq}
details.faq-item{counter-increment:faq;background:transparent !important;border:0 !important;border-bottom:1px solid rgba(255,255,255,0.06) !important;border-radius:0 !important;padding:0 !important;margin:0 !important;position:relative;transition:background .25s}
details.faq-item::before{content:counter(faq, decimal-leading-zero);position:absolute;left:0;top:24px;font-family:ui-monospace,'SF Mono','Menlo',monospace;font-size:12px;font-weight:600;color:#3d5268;letter-spacing:0.05em;transition:color .25s}
details.faq-item[open]::before{color:#22AB94}
details.faq-item:hover{background:rgba(34,171,148,0.02)}
details.faq-item summary.faq-q{font-size:18px;font-weight:600;color:#e8eef7;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:24px 4px 24px 56px;letter-spacing:-0.01em;transition:color .2s}
details.faq-item:hover summary.faq-q,details.faq-item[open] summary.faq-q{color:#fff}
details.faq-item summary.faq-q::-webkit-details-marker{display:none}
details.faq-item summary.faq-q::after{content:"";flex-shrink:0;width:14px;height:14px;background:linear-gradient(currentColor,currentColor),linear-gradient(currentColor,currentColor);background-size:14px 1.5px,1.5px 14px;background-position:center;background-repeat:no-repeat;color:#7a94b4;transition:transform .35s cubic-bezier(.2,.8,.2,1),color .25s}
details.faq-item[open] summary.faq-q::after{transform:rotate(45deg);color:#22AB94}
details.faq-item .faq-a{font-size:15px;color:#aac4e0;line-height:1.7;padding:0 4px 28px 56px;max-width:680px;animation:faq-fade .35s ease-out}
details.faq-item .faq-a a{color:#22AB94;text-decoration:none;border-bottom:1px solid rgba(34,171,148,0.3);transition:.2s}
details.faq-item .faq-a a:hover{border-bottom-color:#22AB94}
@keyframes faq-fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:680px){
  details.faq-item summary.faq-q{font-size:16px;padding:20px 4px 20px 44px;gap:16px}
  details.faq-item::before{top:22px;font-size:11px}
  details.faq-item .faq-a{font-size:14px;padding:0 4px 24px 44px}
}

/* vs-Free row labels */
.v2-vs-side-label{font-size:10.5px;text-transform:uppercase;letter-spacing:0.14em;font-weight:800;margin-bottom:10px;opacity:0.7}
.v2-vs-side.free .v2-vs-side-label{color:#e74c3c}
.v2-vs-side.here .v2-vs-side-label{color:#22AB94}

/* /comparison page — receipt-style table */
.cmp-table{width:100%;max-width:640px;margin:0 auto;border-collapse:collapse;font-size:15.5px}
.cmp-table td{padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.05);font-variant-numeric:tabular-nums}
.cmp-name{color:#aac4e0}
.cmp-cost{text-align:right;color:#e8eef7;font-weight:600}
.cmp-mo{font-size:11px;color:#7a94b4;font-weight:500;margin-left:2px}
.cmp-table .cmp-total td{padding-top:18px;border-top:1px solid rgba(255,255,255,0.10);border-bottom:none;font-weight:800;color:#fff;font-size:16.5px}
.cmp-table .cmp-us td{padding-top:18px;border-top:1px dashed rgba(34,171,148,0.30);font-weight:800;color:#22AB94;font-size:18px}
.cmp-table .cmp-us .cmp-mo{color:#5fa089}
.cmp-foot{text-align:center;color:#7a94b4;font-size:13.5px;margin:32px auto 0;max-width:520px}

/* ─────────────────────────────────────────────────────────────────────────
   /signals — How it works section (animated whoosh reveal, teal accents)
   ───────────────────────────────────────────────────────────────────────── */
.sig-how{position:relative;background:#0a0a0a;padding:80px 0}
.sig-how::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:80%;max-width:760px;height:1px;background:linear-gradient(90deg,transparent,rgba(34,171,148,0.18),transparent)}
.sig-how-title{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:900;letter-spacing:-0.025em;line-height:1.04;margin:18px 0 18px;color:#fff;opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.sig-how-title.in-view{opacity:1;transform:none}
.sig-how-accent{color:#22AB94}
.sig-how-sub{font-size:17px;color:#9aafcc;line-height:1.6;max-width:680px;margin-bottom:56px}
.sig-how-sub strong{color:#e8eef7;font-weight:600}

.sig9-list{position:relative;max-width:840px;margin:0 auto}
.sig9-list::before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(34,171,148,0.20) 12%,rgba(34,171,148,0.20) 88%,transparent)}
.sig9-row{position:relative;display:grid;grid-template-columns:48px 1fr;gap:28px;padding:22px 0 22px 28px;border-bottom:1px solid rgba(255,255,255,0.04);opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1);transition-delay:calc(var(--i,0) * 70ms)}
.sig9-row:last-child{border-bottom:none}
.sig9-row.in-view{opacity:1;transform:none}
.sig9-num{font-family:ui-monospace,'SF Mono','Menlo',monospace;font-size:14px;font-weight:600;color:#3d5268;letter-spacing:0.05em;align-self:center;transition:color .8s ease calc(var(--i,0) * 70ms + 300ms)}
.sig9-row.in-view .sig9-num{color:#22AB94}
.sig9-body{display:flex;flex-direction:column;gap:6px}
.sig9-name{font-size:18px;font-weight:700;color:#e8eef7;letter-spacing:-0.01em}
.sig9-desc{font-size:14.5px;color:#9aafcc;line-height:1.6;max-width:640px}
.sig9-bar{position:absolute;left:0;top:50%;width:0;height:1px;background:linear-gradient(90deg,#22AB94,transparent);transform:translateY(-50%);transition:width 1s cubic-bezier(.2,.8,.2,1) calc(var(--i,0) * 70ms + 200ms)}
.sig9-row.in-view .sig9-bar{width:18px}

/* Tier rules — pills with stagger reveal */
.sig-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:840px;margin:48px auto 0}
.sig-tier{padding:22px;background:rgba(14,20,32,0.4);border:1px solid rgba(255,255,255,0.04);border-radius:14px;opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1),border-color .4s ease;transition-delay:calc(var(--i,0) * 100ms)}
.sig-tier.in-view{opacity:1;transform:none}
.sig-tier.strong.in-view{border-color:rgba(46,204,113,0.30);background:linear-gradient(180deg,rgba(46,204,113,0.06),rgba(14,20,32,0.4))}
.sig-tier.building.in-view{border-color:rgba(241,185,56,0.28)}
.sig-tier.noise.in-view{border-color:rgba(120,140,160,0.22)}
.sig-tier-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:8px}
.sig-tier-pill{font-size:11px;font-weight:800;letter-spacing:0.14em;text-transform:uppercase}
.sig-tier.strong .sig-tier-pill{color:#2ecc71}
.sig-tier.building .sig-tier-pill{color:#f1b938}
.sig-tier.noise .sig-tier-pill{color:#7a94b4}
.sig-tier-range{font-family:ui-monospace,'SF Mono','Menlo',monospace;font-size:13px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}
.sig-tier-desc{font-size:13.5px;color:#9aafcc;line-height:1.5}

/* First-snapshot pull-quote */
.sig-insight{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;max-width:840px;margin:48px auto 0;padding:28px 32px;background:linear-gradient(135deg,rgba(34,171,148,0.06),transparent 70%);border-left:2px solid #22AB94;opacity:0;transform:translateX(-20px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.sig-insight.in-view{opacity:1;transform:none}
.sig-insight-mark{font-size:28px;color:#22AB94;font-weight:700;line-height:1}
.sig-insight p{margin:0;font-size:15.5px;line-height:1.65;color:#c8d8ec}
.sig-insight p strong{color:#22AB94;font-weight:700}

@media(max-width:760px){
  .sig-tiers{grid-template-columns:1fr}
  .sig9-row{grid-template-columns:36px 1fr;gap:18px;padding:18px 0 18px 22px}
  .sig9-name{font-size:16px}
  .sig9-desc{font-size:13.5px}
  .sig-insight{padding:20px;gap:14px}
}

/* ─────────────────────────────────────────────────────────────────────────
   /who-for — same animated reveal treatment, two columns (yes / no)
   ───────────────────────────────────────────────────────────────────────── */
.wf-list{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:1080px;margin:48px auto 0;position:relative}
.wf-col{display:flex;flex-direction:column;gap:0;position:relative;padding-top:8px}
.wf-col-head{font-size:13px;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,0.06)}
.wf-col.yes .wf-col-head{color:#2ecc71}
.wf-col.no .wf-col-head{color:#e74c3c}
.wf-row{position:relative;display:grid;grid-template-columns:24px 1fr;gap:14px;align-items:start;padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.03);opacity:0;transform:translateY(20px);transition:opacity .65s cubic-bezier(.2,.8,.2,1),transform .65s cubic-bezier(.2,.8,.2,1);transition-delay:calc(var(--i,0) * 80ms)}
.wf-row:last-child{border-bottom:none}
.wf-row.in-view{opacity:1;transform:none}
.wf-mark{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:11px;font-weight:800;margin-top:1px;transition:transform .5s cubic-bezier(.34,1.56,.64,1) calc(var(--i,0) * 80ms + 200ms)}
.wf-col.yes .wf-mark{color:#2ecc71;background:rgba(46,204,113,0.10);border:1px solid rgba(46,204,113,0.25)}
.wf-col.no  .wf-mark{color:#e74c3c;background:rgba(231,76,60,0.08);border:1px solid rgba(231,76,60,0.22)}
.wf-row .wf-mark{transform:scale(0.6)}
.wf-row.in-view .wf-mark{transform:scale(1)}
.wf-text{font-size:14.5px;line-height:1.55;color:#c8d8ec}
.wf-text em{color:#9aafcc;font-style:italic}
@media(max-width:760px){
  .wf-list{grid-template-columns:1fr;gap:36px}
}

/* Oxford essays card — inline replacement for series-strip (which is position:fixed) */
.oxford-card{display:flex;align-items:center;gap:18px;max-width:780px;margin:0 auto;padding:18px 24px;background:linear-gradient(135deg,rgba(52,152,219,0.06),rgba(52,152,219,0.02));border:1px solid rgba(52,152,219,0.20);border-radius:14px;text-decoration:none;color:inherit;transition:.25s}
.oxford-card:hover{border-color:rgba(52,152,219,0.40);transform:translateY(-1px)}
.oxford-badge{flex-shrink:0;font-size:10px;font-weight:800;letter-spacing:0.10em;text-transform:uppercase;color:#5bb3e8;background:rgba(52,152,219,0.10);border:1px solid rgba(52,152,219,0.28);padding:5px 10px;border-radius:12px}
.oxford-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.oxford-label{font-size:11px;font-weight:700;color:#7ab8e8;letter-spacing:0.06em;text-transform:uppercase}
.oxford-title{font-size:15.5px;font-weight:700;color:#fff;letter-spacing:-0.005em}
.oxford-sub{font-size:13px;color:#9aafcc;line-height:1.5}
.oxford-arrow{color:#7ab8e8;font-size:18px;font-weight:700;transition:transform .25s}
.oxford-card:hover .oxford-arrow{transform:translateX(4px);color:#fff}
@media(max-width:600px){
  .oxford-card{flex-direction:column;align-items:flex-start;gap:12px}
}

/* ─────────────────────────────────────────────────────────────────────────
   /dashboard — interactive preview with side panel that swooshes in
   ───────────────────────────────────────────────────────────────────────── */
.dwp-tabs{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;padding:10px;background:rgba(8,14,26,0.6);border:1px solid rgba(255,255,255,0.04);border-radius:14px;margin-bottom:20px;overflow-x:auto;scrollbar-width:thin}
.dwp-tabs::-webkit-scrollbar{height:4px}
.dwp-tabs::-webkit-scrollbar-thumb{background:rgba(34,171,148,0.3);border-radius:2px}
.dwp-tab{background:transparent;border:1px solid rgba(255,255,255,0.06);color:#8aa3c0;padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.02em;cursor:pointer;white-space:nowrap;transition:all .2s;font-family:inherit}
.dwp-tab:hover{color:#c8d8ec;border-color:rgba(34,171,148,.3);background:rgba(34,171,148,.04)}
.dwp-tab.active{background:rgba(34,171,148,.12);border-color:#22AB94;color:#22AB94;box-shadow:0 0 14px rgba(34,171,148,.18)}

.dwp-stage{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:24px;align-items:stretch}
.dwp-frame{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(52,152,219,0.10);box-shadow:0 30px 80px rgba(0,0,0,0.55),0 0 100px rgba(34,171,148,0.06);background:#060d16}
.dwp-frame img{width:100%;display:block;transition:opacity .28s ease-out}
.dwp-frame img.swapping{opacity:0.25}

.dwp-panel{position:relative;border-radius:14px;background:linear-gradient(180deg,rgba(14,20,32,0.7),rgba(8,12,20,0.6));border:1px solid rgba(255,255,255,0.05);overflow:hidden}
.dwp-panel::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent,#22AB94,transparent);opacity:0.7}
.dwp-panel-inner{padding:32px 32px 28px;display:flex;flex-direction:column;gap:14px;height:100%}

.dwp-eyebrow{font-size:10.5px;font-weight:800;letter-spacing:0.18em;color:#22AB94;font-variant:all-small-caps}
.dwp-name{font-size:32px;font-weight:900;letter-spacing:-0.02em;color:#fff;line-height:1.05;margin:0}
.dwp-tagline{font-size:15.5px;color:#aac4e0;line-height:1.5;margin:0 0 6px;font-weight:500}
.dwp-bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.dwp-bullets li{position:relative;padding-left:18px;font-size:13.5px;color:#9aafcc;line-height:1.55}
.dwp-bullets li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:rgba(34,171,148,0.55)}
.dwp-stat{margin-top:auto;padding-top:18px;border-top:1px solid rgba(255,255,255,0.05);display:flex;align-items:baseline;gap:10px}
.dwp-stat-v{font-size:36px;font-weight:900;color:#22AB94;letter-spacing:-0.03em;font-variant-numeric:tabular-nums;line-height:1}
.dwp-stat-l{font-size:12px;color:#7a94b4;letter-spacing:0.02em}

/* ENTER / EXIT animations — content swooshes in from right when tab changes */
@keyframes dwp-enter-content{
  0%   {opacity:0;transform:translateX(36px) scale(0.985)}
  60%  {opacity:1}
  100% {opacity:1;transform:translateX(0) scale(1)}
}
@keyframes dwp-exit-content{
  0%   {opacity:1;transform:translateX(0)}
  100% {opacity:0;transform:translateX(-22px)}
}
@keyframes dwp-enter-bullets{
  from {opacity:0;transform:translateX(20px)}
  to   {opacity:1;transform:translateX(0)}
}
.dwp-panel.entering .dwp-panel-inner{animation:dwp-enter-content .55s cubic-bezier(.2,.8,.2,1) both}
.dwp-panel.exiting  .dwp-panel-inner{animation:dwp-exit-content .24s cubic-bezier(.2,.8,.2,1) both}
.dwp-panel.entering .dwp-bullets li{animation:dwp-enter-bullets .5s cubic-bezier(.2,.8,.2,1) both}
.dwp-panel.entering .dwp-bullets li:nth-child(1){animation-delay:.10s}
.dwp-panel.entering .dwp-bullets li:nth-child(2){animation-delay:.18s}
.dwp-panel.entering .dwp-bullets li:nth-child(3){animation-delay:.26s}
.dwp-panel.entering .dwp-bullets li:nth-child(4){animation-delay:.34s}

/* Teal accent line on left re-pulses on tab change */
.dwp-panel.entering::before{animation:dwp-pulse 1s ease-out both}
@keyframes dwp-pulse{
  0%   {opacity:0;transform:scaleY(0.4)}
  60%  {opacity:1;transform:scaleY(1.05)}
  100% {opacity:0.7;transform:scaleY(1)}
}

@media(max-width:900px){
  .dwp-stage{grid-template-columns:1fr;gap:16px}
  .dwp-panel-inner{padding:22px 22px 20px;gap:10px}
  .dwp-name{font-size:24px}
  .dwp-tagline{font-size:14px}
  .dwp-stat-v{font-size:28px}
}

/* /signals — Long / Short mode callout */
.sig-modes{padding:24px 0 8px}
.sig-modes-row{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:stretch;max-width:920px;margin:0 auto}
.sig-mode{padding:24px 28px;border-radius:14px;border:1px solid rgba(255,255,255,0.05);background:rgba(14,20,32,0.5);display:flex;flex-direction:column;gap:10px}
.sig-mode.long{border-color:rgba(46,204,113,0.25);background:linear-gradient(135deg,rgba(46,204,113,0.06),rgba(14,20,32,0.5))}
.sig-mode.short{border-color:rgba(231,76,60,0.25);background:linear-gradient(135deg,rgba(231,76,60,0.06),rgba(14,20,32,0.5))}
.sig-mode-pill{display:inline-block;font-size:11px;font-weight:800;letter-spacing:0.16em;padding:5px 11px;border-radius:999px;align-self:flex-start}
.sig-mode.long .sig-mode-pill{color:#2ecc71;background:rgba(46,204,113,0.12);border:1px solid rgba(46,204,113,0.32)}
.sig-mode.short .sig-mode-pill{color:#e74c3c;background:rgba(231,76,60,0.12);border:1px solid rgba(231,76,60,0.32)}
.sig-mode-desc{font-size:14.5px;color:#aac4e0;line-height:1.55}
.sig-mode-vs{display:flex;align-items:center;justify-content:center;font-size:24px;color:#3d5268;font-weight:700;min-width:32px}
.sig-modes-note{text-align:center;font-size:13px;color:#7a94b4;margin:18px auto 0;max-width:560px;font-style:italic}
@media(max-width:760px){
  .sig-modes-row{grid-template-columns:1fr;gap:14px}
  .sig-mode-vs{transform:rotate(90deg);padding:6px 0}
}

/* /sources page */
.src-page{max-width:980px;margin:0 auto}
.src-totals{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:8px 0 48px}
.src-total{padding:18px 14px;background:rgba(14,20,32,0.4);border:1px solid rgba(255,255,255,0.05);border-radius:12px;text-align:center}
.src-total-v{font-size:28px;font-weight:900;color:#22AB94;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;line-height:1}
.src-total-l{margin-top:6px;font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:#7a94b4}
@media(max-width:760px){.src-totals{grid-template-columns:repeat(2,1fr)}}

.src-h2{font-size:20px;font-weight:800;color:#fff;letter-spacing:-0.005em;margin:42px 0 14px;padding-bottom:10px;border-bottom:1px solid rgba(34,171,148,0.18)}
.src-pre{font-size:13.5px;color:#7a94b4;line-height:1.55;margin:0 0 14px}
.src-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.src-list li{font-size:13.5px;color:#aac4e0;line-height:1.5;padding-left:14px;position:relative}
.src-list li::before{content:"·";position:absolute;left:2px;color:#22AB94;font-weight:700}
.src-list li strong{color:#e8eef7;font-weight:700}
.src-list-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 24px}
@media(max-width:700px){.src-list-2col{grid-template-columns:1fr}}

details.src-group{border:1px solid rgba(255,255,255,0.05);border-radius:12px;background:rgba(14,20,32,0.35);margin-bottom:10px;overflow:hidden;transition:border-color .2s}
details.src-group[open]{border-color:rgba(34,171,148,0.22);background:rgba(14,20,32,0.55)}
details.src-group summary.src-group-head{cursor:pointer;display:flex;align-items:center;gap:14px;padding:14px 18px;list-style:none;user-select:none}
details.src-group summary.src-group-head::-webkit-details-marker{display:none}
.src-group-name{font-size:15px;font-weight:700;color:#e8eef7;flex:1}
.src-group-count{font-size:11.5px;font-weight:700;letter-spacing:0.06em;color:#22AB94;text-transform:uppercase}
.src-group-toggle{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(34,171,148,0.10);border:1px solid rgba(34,171,148,0.28);color:#22AB94;font-weight:700;font-size:14px;line-height:1;transition:transform .25s}
details.src-group[open] .src-group-toggle{transform:rotate(45deg)}
.src-group-body{padding:6px 18px 18px;border-top:1px solid rgba(255,255,255,0.04)}
.src-group-body .src-list{margin-top:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:4px 18px}
@media(max-width:760px){.src-group-body .src-list{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.src-group-body .src-list{grid-template-columns:1fr}}

.src-foot{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.04);font-size:13px;color:#7a94b4;line-height:1.6}
.src-foot code{background:rgba(34,171,148,0.08);color:#22AB94;padding:2px 7px;border-radius:4px;font-size:12px;font-family:ui-monospace,'SF Mono',Menlo,monospace}

/* /coins page — coin ticker pills */
.coin-pills{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 4px}
.coin-pill{display:inline-flex;align-items:center;justify-content:center;min-width:54px;height:30px;padding:0 12px;border-radius:8px;background:rgba(34,171,148,0.06);border:1px solid rgba(34,171,148,0.18);color:#e8eef7;font-size:12px;font-weight:700;letter-spacing:0.04em;font-family:ui-monospace,'SF Mono',Menlo,monospace;font-variant-numeric:tabular-nums;transition:.2s}
.coin-pill:hover{background:rgba(34,171,148,0.12);border-color:rgba(34,171,148,0.32);color:#fff;transform:translateY(-1px)}

/* /comparison page (V3 honest audit) — overrides earlier .cmp-table styling */
.cmp-h2{font-size:24px;font-weight:800;color:#fff;letter-spacing:-0.01em;margin:0 0 12px;padding-bottom:14px;border-bottom:1px solid rgba(34,171,148,0.18)}
.cmp-pre{font-size:14.5px;color:#9aafcc;line-height:1.6;margin:0 0 28px;max-width:760px}
.cmp-pre strong{color:#fff;font-weight:700}

.cmp-stack-table{width:100%;border-collapse:collapse;font-size:14px}
.cmp-stack-table thead th{text-align:left;font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:#7a94b4;padding:0 16px 12px;border-bottom:1px solid rgba(255,255,255,0.08)}
.cmp-stack-table thead th:nth-child(2){text-align:right}
.cmp-stack-table tbody td{padding:18px 16px;border-bottom:1px solid rgba(255,255,255,0.04);vertical-align:top;line-height:1.55}
.cmp-stack-table tbody tr:hover{background:rgba(34,171,148,0.02)}
.cmp-stack-table .cmp-svc{width:24%;color:#e8eef7;font-size:14.5px}
.cmp-stack-table .cmp-cost{width:14%;text-align:right;font-variant-numeric:tabular-nums;color:#e74c3c;font-weight:700;font-size:15px;white-space:nowrap}
.cmp-stack-table .cmp-cost-add{color:#f1b938}
.cmp-stack-table .cmp-mo{font-size:10.5px;color:#9c5a55;font-weight:500;margin-left:2px}
.cmp-stack-table .cmp-cost-add .cmp-mo{color:#a0773a}
.cmp-stack-table .cmp-covers{color:#aac4e0;width:31%}
.cmp-stack-table .cmp-misses{color:#7a94b4;font-style:italic}
.cmp-stack-table .cmp-why{color:#aac4e0}
.cmp-stack-table .cmp-total-row td{padding-top:22px;border-top:2px solid rgba(255,255,255,0.10);border-bottom:none}
.cmp-stack-table .cmp-total-row .cmp-cost{color:#fff;font-size:18px}
.cmp-stack-table .cmp-total-row .cmp-mo{color:#7a94b4}
.cmp-total-note{color:#7a94b4;font-style:italic;font-size:13px}

/* "Things no commercial service does" — graphic gap blocks */
.cmp-gaps{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:8px}
.cmp-gap{padding:22px 24px;background:linear-gradient(135deg,rgba(34,171,148,0.07),rgba(14,20,32,0.5));border:1px solid rgba(34,171,148,0.20);border-radius:12px}
.cmp-gap-name{font-size:15px;font-weight:700;color:#22AB94;margin-bottom:8px;letter-spacing:-0.005em}
.cmp-gap-why{font-size:13.5px;color:#aac4e0;line-height:1.6}

/* Final summary card */
.cmp-summary{margin:32px 0 24px;padding:0;border-radius:14px;overflow:hidden;background:linear-gradient(180deg,rgba(14,20,32,0.6),rgba(8,12,20,0.4));border:1px solid rgba(255,255,255,0.05)}
.cmp-summary-row{display:grid;grid-template-columns:1fr 1fr;gap:0}
.cmp-summary-side{padding:32px 36px;display:flex;flex-direction:column;gap:8px}
.cmp-summary-them{border-right:1px solid rgba(255,255,255,0.05)}
.cmp-summary-us{background:linear-gradient(135deg,rgba(34,171,148,0.08),transparent 80%)}
.cmp-summary-label{font-size:11px;font-weight:800;letter-spacing:0.16em;text-transform:uppercase;color:#7a94b4}
.cmp-summary-us .cmp-summary-label{color:#22AB94}
.cmp-summary-num{font-size:42px;font-weight:900;letter-spacing:-0.025em;line-height:1;font-variant-numeric:tabular-nums;color:#fff;margin:4px 0 6px}
.cmp-summary-us .cmp-summary-num{color:#22AB94}
.cmp-summary-mo{font-size:14px;font-weight:600;color:#7a94b4;margin-left:2px;letter-spacing:0}
.cmp-summary-note{font-size:13px;color:#9aafcc;line-height:1.55;margin:0}

@media(max-width:880px){
  .cmp-stack-table{display:block;overflow-x:auto;white-space:nowrap}
  .cmp-stack-table .cmp-covers,.cmp-stack-table .cmp-misses,.cmp-stack-table .cmp-why{white-space:normal}
  .cmp-gaps{grid-template-columns:1fr}
  .cmp-summary-row{grid-template-columns:1fr}
  .cmp-summary-them{border-right:0;border-bottom:1px solid rgba(255,255,255,0.05)}
  .cmp-summary-num{font-size:32px}
}

/* Mouse-follow tilt — JS sets inline transform; CSS just controls smoothness */
.hero-dw-wrap{transition:transform .25s cubic-bezier(.22,1,.36,1) !important}
.hero-dw-wrap:not(:hover){transition:transform .7s cubic-bezier(.2,.8,.2,1) !important}

/* Live ticker price-pulse — fires when the cell value changes from a real fetch */
@keyframes ticker-pulse-fade{
  0%   {background:rgba(34,171,148,0.32);box-shadow:inset 0 0 0 1px rgba(34,171,148,0.5)}
  100% {background:transparent;box-shadow:inset 0 0 0 1px transparent}
}
.ticker-pulse{
  animation:ticker-pulse-fade .9s ease-out;
  border-radius:6px;
}

/* /signals Tier rules — horizontal score ruler (replaces 3-card row) */
.sig-ruler{max-width:840px;margin:48px auto 0;padding:0}
.sig-ruler-track{position:relative;height:14px;border-radius:8px;background:rgba(255,255,255,0.04);overflow:visible;margin-top:6px}
.sig-ruler-zone{position:absolute;top:0;bottom:0;border-radius:0}
.sig-ruler-zone:first-of-type{border-top-left-radius:8px;border-bottom-left-radius:8px}
.sig-ruler-zone:last-of-type{border-top-right-radius:8px;border-bottom-right-radius:8px}
.zone-noise{background:linear-gradient(90deg, rgba(120,140,160,0.12), rgba(120,140,160,0.22))}
.zone-building{background:linear-gradient(90deg, rgba(241,185,56,0.30), rgba(241,185,56,0.45))}
.zone-strong{background:linear-gradient(90deg, rgba(46,204,113,0.40), rgba(46,204,113,0.65))}
.sig-ruler-tick{position:absolute;top:-6px;bottom:-6px;width:1.5px;background:rgba(255,255,255,0.35);transform:translateX(-50%)}
.sig-ruler-tick-label{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-family:ui-monospace,'SF Mono','Menlo',monospace;font-size:11px;font-weight:700;color:#aac4e0;letter-spacing:0.04em;font-variant-numeric:tabular-nums}
.sig-ruler-axis{display:flex;justify-content:space-between;margin-top:10px;font-family:ui-monospace,'SF Mono','Menlo',monospace;font-size:11px;font-weight:600;color:#3d5268;letter-spacing:0.04em;font-variant-numeric:tabular-nums}

.sig-ruler-key{display:flex;flex-direction:column;gap:0;margin-top:36px;border-top:1px solid rgba(255,255,255,0.05)}
.sig-ruler-keyrow{display:grid;grid-template-columns:14px 110px 90px 1fr;align-items:baseline;gap:14px;padding:14px 4px;border-bottom:1px solid rgba(255,255,255,0.04)}
.sig-ruler-keyrow:last-child{border-bottom:none}
.sig-ruler-dot{width:10px;height:10px;border-radius:50%;align-self:center}
.sig-ruler-keyrow.noise    .sig-ruler-dot{background:rgba(120,140,160,0.55);box-shadow:0 0 8px rgba(120,140,160,0.3)}
.sig-ruler-keyrow.building .sig-ruler-dot{background:#f1b938;box-shadow:0 0 10px rgba(241,185,56,0.5)}
.sig-ruler-keyrow.strong   .sig-ruler-dot{background:#2ecc71;box-shadow:0 0 12px rgba(46,204,113,0.6)}
.sig-ruler-tier{font-size:14px;font-weight:800;letter-spacing:0.02em}
.sig-ruler-keyrow.noise    .sig-ruler-tier{color:#7a94b4}
.sig-ruler-keyrow.building .sig-ruler-tier{color:#f1b938}
.sig-ruler-keyrow.strong   .sig-ruler-tier{color:#2ecc71}
.sig-ruler-range{font-family:ui-monospace,'SF Mono','Menlo',monospace;font-size:13px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}
.sig-ruler-desc{font-size:14px;color:#aac4e0;line-height:1.5}

@media(max-width:600px){
  .sig-ruler-keyrow{grid-template-columns:12px 90px 70px 1fr;gap:10px;font-size:13px}
  .sig-ruler-tier{font-size:13px}
  .sig-ruler-range{font-size:12px}
  .sig-ruler-desc{font-size:13px}
}

/* Score-ruler reveal animations */
.sig-ruler-track{opacity:0;transform:translateY(12px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.sig-ruler-track.in-view{opacity:1;transform:none}
.sig-ruler-zone{transform:scaleX(0);transform-origin:left center;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.sig-ruler-track.in-view .zone-noise{transform:scaleX(1);transition-delay:.1s}
.sig-ruler-track.in-view .zone-building{transform:scaleX(1);transition-delay:.45s}
.sig-ruler-track.in-view .zone-strong{transform:scaleX(1);transition-delay:.7s}
.sig-ruler-tick{opacity:0;transition:opacity .4s ease 1s}
.sig-ruler-track.in-view .sig-ruler-tick{opacity:1}
.sig-ruler-keyrow{opacity:0;transform:translateY(10px);transition:opacity .6s cubic-bezier(.2,.8,.2,1),transform .6s cubic-bezier(.2,.8,.2,1)}
.sig-ruler-keyrow.in-view{opacity:1;transform:none}
.sig-ruler-keyrow.noise.in-view   {transition-delay:.2s}
.sig-ruler-keyrow.building.in-view{transition-delay:.35s}
.sig-ruler-keyrow.strong.in-view  {transition-delay:.5s}

/* Hero dashboard preview — synced per-tab callouts */
.hero-dw-wrap .dw-canvas{position:relative}
.dwp-callout-layer{position:absolute;inset:0;pointer-events:none;z-index:4}
.dwp-callout{
  position:absolute;
  padding:7px 13px 7px 22px;
  background:rgba(11,15,24,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(34,171,148,0.40);
  border-radius:999px;
  color:#e8eef7;
  font-size:11.5px;
  font-weight:600;
  letter-spacing:0.02em;
  white-space:nowrap;
  box-shadow:0 6px 24px rgba(0,0,0,0.5),0 0 16px rgba(34,171,148,0.18);
  opacity:0;
  transform:translateY(-6px) scale(0.96);
  transition:opacity .45s cubic-bezier(.2,.8,.2,1),transform .45s cubic-bezier(.2,.8,.2,1);
}
.dwp-callout::before{
  content:"";
  position:absolute;
  left:9px;
  top:50%;
  transform:translateY(-50%);
  width:6px;height:6px;border-radius:50%;
  background:#22AB94;
  box-shadow:0 0 8px rgba(34,171,148,0.7);
  animation:dwp-callout-pulse 1.8s ease-in-out infinite;
}
@keyframes dwp-callout-pulse{
  0%,100%{transform:translateY(-50%) scale(1);box-shadow:0 0 8px rgba(34,171,148,0.7)}
  50%{transform:translateY(-50%) scale(1.25);box-shadow:0 0 14px rgba(34,171,148,1)}
}
.dwp-callout.show{opacity:1;transform:translateY(0) scale(1)}

/* Anchor corners — adjust the transform-origin so x/y refer to that corner */
.dwp-anchor-tr{transform-origin:top right;     transform:translate(-100%, 0) translateY(-6px) scale(0.96)}
.dwp-anchor-tr.show{transform:translate(-100%, 0) scale(1)}
.dwp-anchor-tl{transform-origin:top left;      transform:translate(0, 0) translateY(-6px) scale(0.96)}
.dwp-anchor-tl.show{transform:translate(0, 0) scale(1)}
.dwp-anchor-br{transform-origin:bottom right;  transform:translate(-100%, -100%) translateY(6px) scale(0.96)}
.dwp-anchor-br.show{transform:translate(-100%, -100%) scale(1)}
.dwp-anchor-bl{transform-origin:bottom left;   transform:translate(0, -100%) translateY(6px) scale(0.96)}
.dwp-anchor-bl.show{transform:translate(0, -100%) scale(1)}

@media(max-width:760px){
  .dwp-callout{font-size:10.5px;padding:5px 11px 5px 19px}
  .dwp-callout::before{left:7px;width:5px;height:5px}
}

/* ─────────────────────────────────────────────────────────────────────────
   MOBILE NAV + LAYOUT FIXES
   The lv3-nav with its 4 dropdowns (Product/Pricing/Resources/FAQ) plus
   Blog/X/LogIn is built for desktop. On mobile the row overflowed the
   viewport, pushing the page off-axis and clipping hero copy on the left.
   On phones, hide the dropdown row entirely; rely on in-page scroll for
   nav. Tablet (760-900) keeps a horizontally scrollable row.
   ───────────────────────────────────────────────────────────────────────── */
html{overflow-x:hidden;max-width:100vw}

/* ── Hamburger (mobile only) ─────────────────────────────────────────── */
.nav-burger{display:none;background:transparent;border:0;cursor:pointer;width:40px;height:40px;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:#c8d6e5;border-radius:8px;transition:background .15s}
@media(hover:hover){.nav-burger:hover{background:rgba(255,255,255,0.04)}}
.nav-burger-line{display:block;width:22px;height:2px;background:currentColor;border-radius:1px;transition:transform .25s ease,opacity .15s ease}
/* Backdrop: same containing-block trap as the drawer above. Must use
   viewport-relative sizing instead of inset:0, otherwise it collapses to
   the size of nav.lv3-nav (the backdrop-filter ancestor) and tap-to-close
   only works in the top 60px strip. */
.nav-sheet-backdrop{display:none;position:fixed;top:60px;left:0;width:100vw;height:calc(100vh - 60px);height:calc(100dvh - 60px);background:rgba(0,0,0,0.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:98;opacity:0;pointer-events:none;transition:opacity .25s}

@media(max-width:900px){
  .lv3-nav{padding:10px 16px}
  .lv3-nav .nav-actions{gap:6px}
  .nav-burger{display:flex}

  /* Sheet: navd-row becomes a right-side drawer that starts BELOW the nav bar.
     IMPORTANT: nav.lv3-nav has backdrop-filter, which makes it a containing
     block for position:fixed descendants. So height MUST be set with viewport
     units (vh/dvh), not bottom:0, otherwise the drawer collapses to ~0px and
     only the first menu item peeks through.
     Was top:0 with 72px top padding (read as a giant empty gap above items)
     then top:60px;bottom:0 (collapsed to 0 height inside containing block). */
  .lv3-nav .navd-row{
    position:fixed;top:60px;right:0;
    height:calc(100vh - 60px);
    height:calc(100dvh - 60px);
    width:min(82vw,340px);
    flex-direction:column;align-items:stretch;gap:0;
    background:rgba(8,12,20,0.98);
    -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
    border-left:1px solid rgba(255,255,255,0.06);
    border-top:1px solid rgba(255,255,255,0.04);
    padding:8px 8px 28px;
    overflow-y:auto;overflow-x:hidden;
    transform:translateX(100%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    z-index:99;
  }
  .lv3-nav[data-nav-open] .navd-row{transform:translateX(0)}
  .lv3-nav[data-nav-open] .nav-sheet-backdrop{display:block;opacity:1;pointer-events:auto}

  /* Burger → X transform when open */
  .lv3-nav[data-nav-open] .nav-burger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .lv3-nav[data-nav-open] .nav-burger-line:nth-child(2){opacity:0}
  .lv3-nav[data-nav-open] .nav-burger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* Sheet items: full-width accordions */
  .lv3-nav .navd-row .navd{width:100%}
  .lv3-nav .navd-trigger{width:100%;justify-content:space-between;font-size:15px;padding:14px 16px;border-radius:0;color:#dde6f5;font-weight:600}
  .lv3-nav .navd[data-open] .navd-trigger{background:rgba(255,255,255,0.03)}
  @media(hover:hover){.lv3-nav .navd-trigger:hover{background:rgba(255,255,255,0.03)}}

  /* Dropdown panels expand inline as accordions, not floating menus */
  .lv3-nav .navd-menu{
    position:relative !important;
    top:auto !important;left:auto !important;right:auto !important;bottom:auto !important;
    transform:none !important;
    background:transparent;border:0;box-shadow:none;
    padding:0 0 6px 8px;min-width:0;width:auto;max-width:none;
    opacity:1;visibility:visible;pointer-events:auto;
    display:none;
  }
  .lv3-nav .navd[data-open] .navd-menu{display:block}
  .lv3-nav .navd-item{padding:10px 14px}
  .lv3-nav .navd-item-sub{font-size:11.5px}

  /* Blog + X live in the sheet at the bottom */
  .lv3-nav .navd-link{display:block;padding:14px 16px;font-size:15px;color:#dde6f5;font-weight:600;border-top:1px solid rgba(255,255,255,0.04);text-decoration:none}
  .lv3-nav .nav-x{display:flex;width:auto;height:auto;padding:14px 16px;justify-content:flex-start;align-items:center;color:#aac4e0;border-top:1px solid rgba(255,255,255,0.04);border-radius:0;font-weight:600;font-size:15px}
  .lv3-nav .nav-x svg{width:16px;height:16px;margin-right:10px}
  .lv3-nav .nav-x::after{content:"X / Twitter"}

  /* Login stays visible in the bar, CTA hides on mobile */
  .lv3-nav .nav-login{padding:6px 12px;font-size:13px;white-space:nowrap}
  .lv3-nav .nav-cta{display:none}

  /* Lock body scroll when sheet open */
  body.nav-locked{overflow:hidden;touch-action:none}

  /* Hero copy: cap to actual container width so centered text doesn't
     overflow when desktop max-width:480px exceeds the parent */
  .hero-sub{max-width:100%}
}
@media(max-width:600px){
  .lv3-nav{padding:10px 12px}
  .lv3-nav .nav-login{padding:5px 10px;font-size:12.5px}
}

/* ── Visible HTML breadcrumb (round 21) ──────────────────────────────────── */
.page-breadcrumb{max-width:1240px;margin:18px auto 0;padding:0 20px;font-family:Satoshi,system-ui,sans-serif;font-size:13px}
.breadcrumb-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0;color:#5a7a9a}
.breadcrumb-list li{display:flex;align-items:center;gap:8px}
.breadcrumb-list li:not(:first-child)::before{content:"›";color:#3d5268;font-size:14px}
.breadcrumb-list a{color:#7ab8e8;text-decoration:none}
.breadcrumb-list a:hover{color:#22AB94;text-decoration:underline}
.breadcrumb-list li[aria-current="page"]{color:#e8eef7;font-weight:500}
@media (max-width:760px){.page-breadcrumb{font-size:12px;margin:12px auto 0}}

/* ── Respect prefers-reduced-motion (round 22 a11y) ─────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
