:root{
  --bg:          #030409;
  --bg-2:        #07091a;
  --panel:       #0a0d1f;
  --panel-2:     #10142e;
  --ink:         #eef1fb;
  --ink-dim:     #b7bdd4;
  --muted:       #6e7494;
  --line:        rgba(255,255,255,0.06);
  --line-hot:    rgba(124,92,255,0.35);
  --cyan:        #00e5ff;
  --blue:        #3b82f6;
  --blue-hot:    #4f8bff;
  --violet:      #7c5cff;
  --violet-deep: #5b3dff;
  --magenta:     #e84df0;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{
  background:var(--bg);color:var(--ink);
  font-family:'Unbounded',sans-serif;font-weight:300;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
body{
  background:
    radial-gradient(1400px 800px at 85% -10%, rgba(124,92,255,0.18), transparent 60%),
    radial-gradient(1000px 600px at 15% 110%, rgba(0,229,255,0.10), transparent 60%),
    var(--bg);
  min-height:100vh;
  overflow-x:hidden;
}

/* Grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:100;opacity:0.28;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.05 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:99;
  background:repeating-linear-gradient(180deg,transparent 0 3px,rgba(255,255,255,0.012) 3px 4px);
}

/* ============================================
   SHARED LOGO ANIMATIONS
   ============================================ */
@keyframes core-breathe{
  0%,100% { transform: scale(1);    filter: drop-shadow(0 0 18px rgba(124,92,255,0.8)) }
  50%     { transform: scale(1.08); filter: drop-shadow(0 0 42px rgba(232,77,240,1.0)) }
}
@keyframes stroke-flow{ to { stroke-dashoffset: -900 } }
@keyframes stroke-flow-rev{ to { stroke-dashoffset: 900 } }
@keyframes orbit-particle{ to { offset-distance: 100% } }
@keyframes ambient-breathe{
  0%,100% { opacity: 0.5; transform: scale(1) }
  50%     { opacity: 0.9; transform: scale(1.06) }
}
@keyframes slow-spin{ to { transform: rotate(360deg) } }

.nvx-mark .core{
  transform-origin: 100px 100px;
  animation: core-breathe 4s ease-in-out infinite;
}
.nvx-mark .flow-a{
  stroke-dasharray: 900;
  animation: stroke-flow 14s linear infinite;
}
.nvx-mark .flow-b{
  stroke-dasharray: 300 600;
  animation: stroke-flow-rev 20s linear infinite;
}
.nvx-mark .particle{
  offset-path: path("M 100 100 C 58 56, 28 78, 30 100 C 32 122, 62 144, 100 100 C 138 56, 168 78, 170 100 C 172 122, 142 144, 100 100 Z");
  offset-rotate: auto;
  animation: orbit-particle 8s linear infinite;
}
.nvx-mark .particle.p2 { animation-delay: -4s }
.nvx-mark .particle.p3 { animation-delay: -2s; animation-duration: 10s }
.nvx-mark .particle.p4 { animation-delay: -6s; animation-duration: 10s }
.nvx-mark .ambient-glow{
  transform-origin: 100px 100px;
  animation: ambient-breathe 6s ease-in-out infinite;
}

.nvx-mark.hero .core{ animation-duration: 3.4s }
.nvx-mark.hero .flow-a{ animation-duration: 14s }
.nvx-mark.mini .core{ animation-duration: 3s }
.nvx-mark.mini .flow-a{ animation-duration: 8s; stroke-dasharray: 400 100 }
.nvx-mark.card{ animation: slow-spin 60s linear infinite }
.nvx-mark.card .core{ animation-duration: 3.2s }

/* ============================================
   NAV
   ============================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:20px 40px;
  display:flex;justify-content:space-between;align-items:center;
  background:linear-gradient(180deg,rgba(3,4,9,0.9) 0%,rgba(3,4,9,0.5) 70%,transparent 100%);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-brand{ display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink) }
.nav-brand svg{
  width:36px;height:36px;flex:none;
  animation:nav-logo-glow 3.5s ease-in-out infinite;
}
@keyframes nav-logo-glow{
  0%,100%{filter:drop-shadow(0 0 10px rgba(124,92,255,0.75))}
  50%    {filter:drop-shadow(0 0 30px rgba(0,229,255,1.0))}
}
.nav-brand-text{
  font-family:'Unbounded',sans-serif;font-weight:600;
  font-size:18px;letter-spacing:-0.02em;
}
.nav-brand-text .ai{
  background:linear-gradient(120deg,var(--cyan),var(--violet),var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  margin-left:4px;
}
.nav-links{ display:flex;gap:32px;align-items:center }
.nav-links a{
  color:var(--muted);text-decoration:none;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.2em;text-transform:uppercase;
  transition:color .3s;
}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  padding:10px 20px;
  background:rgba(124,92,255,0.12);border:1px solid var(--line-hot);
  border-radius:100px;
  color:var(--ink);text-decoration:none;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.2em;text-transform:uppercase;
  transition:background .3s,border-color .3s;
}
.nav-cta:hover{background:rgba(124,92,255,0.25);border-color:rgba(124,92,255,0.7)}
@media (max-width:820px){
  .nav{padding:16px 20px}
  .nav-links a:not(.nav-cta){display:none}
}

/* ============================================
   HERO
   ============================================ */
section.hero{
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:120px 80px 80px;
  position:relative;text-align:center;
  overflow:hidden;
}
@media (max-width:960px){
  section.hero{padding:120px 24px 80px}
}

/* Background animated logo — sits behind hero text */
.hero-bg-logo{
  position:absolute;inset:0;
  display:grid;place-items:center;
  pointer-events:none;z-index:0;
  opacity:0;
  animation:hero-logo-in 1.8s cubic-bezier(.2,.8,.2,1) .3s forwards;
}
.nvx-mark.hero-bg{
  width:min(96vw,960px);height:min(96vw,960px);
  opacity:0.16;
  animation:hero-bg-pulse 9s ease-in-out infinite;
}
.nvx-mark.hero-bg .core{ animation-duration:5s }
.nvx-mark.hero-bg .flow-a{ animation-duration:22s }
.nvx-mark.hero-bg .flow-b{ animation-duration:18s }
.nvx-mark.hero-bg .particle{ animation-duration:12s }
.nvx-mark.hero-bg .ambient-glow{ animation-duration:7s }
@keyframes hero-bg-pulse{
  0%,100%{opacity:0.16;transform:scale(1)}
  50%    {opacity:0.26;transform:scale(1.03)}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.3em;color:var(--violet);text-transform:uppercase;
  padding:8px 16px;border-radius:100px;
  background:rgba(124,92,255,0.08);border:1px solid var(--line-hot);
}
.hero-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--violet);
  box-shadow:0 0 10px var(--violet);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{50%{opacity:0.3}}
.hero h1{
  margin-top:24px;
  font-family:'Unbounded',sans-serif;font-weight:300;
  font-size:clamp(44px,7vw,88px);line-height:0.95;letter-spacing:-0.04em;
  text-shadow:0 0 60px rgba(0,0,0,1),0 4px 24px rgba(0,0,0,0.85);
}
.hero h1 .i{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400}
.hero h1 .gradient{
  background:linear-gradient(110deg,var(--cyan) 0%,var(--blue-hot) 35%,var(--violet) 65%,var(--magenta) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  margin-top:32px;max-width:520px;
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(18px,2.2vw,22px);line-height:1.5;color:var(--ink);
  margin-left:auto;margin-right:auto;
  text-shadow:0 2px 20px rgba(0,0,0,0.9),0 0 40px rgba(0,0,0,0.7);
}
.hero-cta{ margin-top:40px;display:flex;gap:16px;flex-wrap:wrap;justify-content:center }

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;border-radius:100px;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.25em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s, background .3s;
  border:none;
}
.btn-primary{
  background:linear-gradient(110deg,var(--cyan),var(--violet) 50%,var(--magenta));
  color:#000;font-weight:500;
  box-shadow:0 0 0 1px rgba(255,255,255,0.1), 0 10px 40px rgba(124,92,255,0.35);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 0 1px rgba(255,255,255,0.2), 0 20px 60px rgba(232,77,240,0.4);
}
.btn-ghost{
  background:transparent;
  border:1px solid var(--line-hot);
  color:var(--ink);
}
.btn-ghost:hover{ background:rgba(124,92,255,0.1);border-color:rgba(124,92,255,0.7) }
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}

.hero-text{
  position:relative;z-index:1;
  max-width:900px;
}
.hero-text::before{
  content:"";
  position:absolute;inset:-60px -80px;
  background:radial-gradient(ellipse at center,rgba(3,4,9,0.72) 35%,transparent 78%);
  pointer-events:none;z-index:-1;
}
.hero-metrics{ margin-top:48px;display:flex;gap:48px;flex-wrap:wrap;justify-content:center }
.metric{ display:flex;flex-direction:column }
.metric .num{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:40px;line-height:1;letter-spacing:-0.02em;
  background:linear-gradient(120deg,var(--cyan),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.metric .lbl{
  margin-top:8px;font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.25em;color:var(--muted);text-transform:uppercase;
}

/* ============================================
   SECTION SHELL — centered titles
   ============================================ */
.section{ padding:120px 80px;position:relative }
@media (max-width:960px){.section{padding:80px 24px}}
.section-head{
  max-width:1100px;margin:0 auto 72px;
  text-align:center;
  padding-bottom:32px;border-bottom:1px solid var(--line);
}
.section-num{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.3em;color:var(--muted);text-transform:uppercase;
  padding:6px 14px;border-radius:100px;
  background:rgba(124,92,255,0.06);border:1px solid var(--line-hot);
  margin-bottom:24px;
}
.section-title{
  font-family:'Unbounded',sans-serif;font-weight:300;
  font-size:clamp(36px,5vw,64px);line-height:1.05;letter-spacing:-0.03em;
  margin-bottom:16px;
}
.section-title em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(90deg,var(--cyan),var(--violet),var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-tag{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.3em;color:var(--muted);text-transform:uppercase;
}

/* ============================================
   SERVICES
   ============================================ */
.services-grid{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media (max-width:960px){.services-grid{grid-template-columns:1fr}}
.service{
  position:relative;padding:40px;
  border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg,rgba(20,24,50,0.45),rgba(8,10,22,0.4));
  overflow:hidden;
  transition:border-color .4s, transform .4s;
}
.service:hover{border-color:var(--line-hot);transform:translateY(-4px)}
.service::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(96,165,250,0.5),transparent 40%,transparent 60%,rgba(232,77,240,0.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .5s;pointer-events:none;
}
.service:hover::before{opacity:1}
.service-icon{ width:56px;height:56px;margin-bottom:24px }
.service h3{
  font-family:'Unbounded',sans-serif;font-weight:500;
  font-size:22px;letter-spacing:-0.02em;margin-bottom:12px;
}
.service h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400}
.service p{ font-size:14px;color:var(--ink-dim);line-height:1.7 }
.service-features{
  margin-top:24px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:10px;
}
.service-features span{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--ink-dim);display:flex;align-items:center;gap:10px;
}
.service-features span::before{
  content:"";width:16px;height:1px;background:var(--violet);
}

/* ============================================
   PROCESS — numbered steps
   ============================================ */
.process{ background:linear-gradient(180deg,transparent,rgba(10,13,31,0.6) 30%,rgba(10,13,31,0.6) 70%,transparent) }
.process-loop{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  position:relative;
}
@media (max-width:900px){.process-loop{grid-template-columns:1fr 1fr;gap:40px 20px}}
@media (max-width:600px){.process-loop{grid-template-columns:1fr}}
.process-line{
  position:absolute;top:70px;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),var(--violet),var(--magenta),transparent);
  opacity:0.3;z-index:0;
}
@media (max-width:900px){.process-line{display:none}}
.step{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:0 20px;
}
.step-circle{
  width:140px;height:140px;border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%,rgba(124,92,255,0.2),transparent 60%),
    radial-gradient(circle,rgba(10,13,31,1) 40%,rgba(124,92,255,0.1) 80%);
  border:1px solid var(--line-hot);
  display:grid;place-items:center;
  margin-bottom:28px;position:relative;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05),0 10px 40px rgba(124,92,255,0.12);
  transition:border-color .4s, transform .4s;
}
.step:hover .step-circle{ border-color:rgba(124,92,255,0.7);transform:translateY(-4px) }
.step-circle::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:1px solid var(--line);opacity:0.4;
}
.step-circle::after{
  content:"";position:absolute;inset:-14px;border-radius:50%;
  border:1px dashed var(--line);opacity:0.25;
  animation:slow-spin 60s linear infinite;
}
.step-number{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:72px;line-height:1;letter-spacing:-0.04em;
  background:linear-gradient(160deg,var(--cyan),var(--violet) 50%,var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 20px rgba(124,92,255,0.5));
}
.step-label{
  position:absolute;top:-10px;right:-10px;
  font-family:'JetBrains Mono',monospace;font-size:9px;
  letter-spacing:0.2em;color:var(--violet);text-transform:uppercase;
  padding:4px 10px;background:var(--bg);
  border:1px solid var(--line-hot);border-radius:100px;
}
.step h3{
  font-family:'Unbounded',sans-serif;font-weight:500;
  font-size:20px;letter-spacing:-0.02em;margin-bottom:10px;
}
.step h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400}
.step p{font-size:13px;color:var(--muted);line-height:1.6;max-width:200px}

/* ============================================
   PORTFOLIO
   ============================================ */
.portfolio-grid{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media (max-width:960px){.portfolio-grid{grid-template-columns:1fr}}
.project{
  position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/5;
  border:1px solid var(--line);
  background:linear-gradient(135deg,var(--panel) 0%,var(--panel-2) 100%);
  cursor:pointer;
  transition:transform .5s cubic-bezier(.2,.8,.2,1),border-color .4s;
  text-decoration:none;color:var(--ink);display:block;
}
.project:hover{transform:translateY(-8px);border-color:var(--line-hot)}
.project::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,transparent 30%,rgba(3,4,9,0.4) 55%,rgba(3,4,9,0.97) 100%);
}
.project-bg{
  position:absolute;inset:0;z-index:0;
  display:flex;align-items:center;justify-content:center;
}
.project-bg svg.showcase-svg{width:100%;height:100%;display:block}
.project-tag{
  position:absolute;top:24px;left:24px;z-index:2;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.3em;color:var(--violet);text-transform:uppercase;
  padding:6px 12px;background:rgba(3,4,9,0.7);backdrop-filter:blur(8px);
  border:1px solid var(--line-hot);border-radius:100px;
}
.project-rating{
  position:absolute;top:24px;right:24px;z-index:2;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.15em;color:#ffd700;
  padding:6px 12px;background:rgba(3,4,9,0.7);backdrop-filter:blur(8px);
  border:1px solid rgba(255,215,0,0.3);border-radius:100px;
}
.project-body{ position:absolute;bottom:0;left:0;right:0;z-index:2;padding:32px }
.project h3{
  font-family:'Unbounded',sans-serif;font-weight:500;
  font-size:24px;letter-spacing:-0.02em;margin-bottom:8px;
}
.project h3 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400}
.project p{font-size:13px;color:var(--ink-dim);line-height:1.6}
.project-meta{ margin-top:20px;display:flex;gap:10px;flex-wrap:wrap }
.project-meta span{
  font-family:'JetBrains Mono',monospace;font-size:9px;
  letter-spacing:0.2em;color:var(--muted);text-transform:uppercase;
  padding:4px 10px;background:rgba(255,255,255,0.04);
  border:1px solid var(--line);border-radius:100px;
}
.project-visit{
  display:inline-flex;align-items:center;gap:6px;margin-top:16px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.25em;color:var(--violet);text-transform:uppercase;
}
.project.lxl .project-bg{
  background:
    radial-gradient(circle at 30% 20%,rgba(220,38,38,0.25),transparent 55%),
    radial-gradient(circle at 80% 80%,rgba(251,146,60,0.2),transparent 55%),
    linear-gradient(135deg,#1a0a0a 0%,#0a0a0a 50%,#0a0614 100%);
}
.project.ashh .project-bg{
  background:
    radial-gradient(circle at 70% 30%,rgba(236,72,153,0.25),transparent 55%),
    radial-gradient(circle at 20% 80%,rgba(168,85,247,0.2),transparent 55%),
    linear-gradient(135deg,#1a0a1f 0%,#0a0a1a 50%,#140a1a 100%);
}
.project.pho .project-bg{
  background:
    radial-gradient(circle at 50% 40%,rgba(34,197,94,0.2),transparent 55%),
    radial-gradient(circle at 20% 90%,rgba(251,191,36,0.15),transparent 55%),
    linear-gradient(135deg,#0a1a10 0%,#0a1414 50%,#0a0a0f 100%);
}

/* ============================================
   PRICING
   ============================================ */
.pricing-grid{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:960px){.pricing-grid{grid-template-columns:1fr;gap:20px}}
.tier{
  position:relative;padding:48px 36px;
  border:1px solid var(--line);border-radius:24px;
  background:linear-gradient(180deg,rgba(20,24,50,0.55),rgba(8,10,22,0.5));
  display:flex;flex-direction:column;
  transition:border-color .4s, transform .4s;
}
.tier:hover{border-color:var(--line-hot);transform:translateY(-4px)}
.tier.featured{
  border-color:rgba(124,92,255,0.6);
  background:linear-gradient(180deg,rgba(124,92,255,0.12),rgba(232,77,240,0.06) 50%,rgba(8,10,22,0.5));
  box-shadow:0 20px 60px rgba(124,92,255,0.15);
}
.tier-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  padding:6px 16px;border-radius:100px;
  background:linear-gradient(110deg,var(--cyan),var(--violet),var(--magenta));
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.3em;color:#000;font-weight:500;text-transform:uppercase;
}
.tier-name{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:28px;letter-spacing:-0.01em;margin-bottom:8px;
}
.tier-desc{ font-size:13px;color:var(--muted);margin-bottom:32px }
.tier-price{ display:flex;align-items:baseline;gap:6px;margin-bottom:4px }
.tier-price .currency{
  font-family:'Unbounded',sans-serif;font-weight:400;font-size:20px;color:var(--ink-dim);
}
.tier-price .amount{
  font-family:'Unbounded',sans-serif;font-weight:600;
  font-size:56px;letter-spacing:-0.04em;line-height:1;
}
.tier-price .unit{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);
  letter-spacing:0.1em;
}
.tier.featured .tier-price .amount{
  background:linear-gradient(110deg,var(--cyan),var(--violet),var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.tier-setup{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--cyan);letter-spacing:0.15em;text-transform:uppercase;
  padding:4px 10px;background:rgba(0,229,255,0.08);
  border:1px solid rgba(0,229,255,0.3);border-radius:100px;
  margin-top:8px;
}
.tier-note{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);
  letter-spacing:0.15em;text-transform:uppercase;margin-top:16px;margin-bottom:32px;
}
.tier-features{
  list-style:none;display:flex;flex-direction:column;gap:14px;
  margin-bottom:40px;flex:1;
  padding-top:28px;border-top:1px solid var(--line);
}
.tier-features li{
  font-size:13px;color:var(--ink-dim);display:flex;align-items:flex-start;gap:12px;line-height:1.5;
}
.tier-features li::before{
  content:"";width:16px;height:16px;flex:none;margin-top:2px;
  border-radius:50%;background:radial-gradient(circle,var(--violet) 25%,transparent 26%);
  border:1px solid var(--line-hot);
}
.tier.featured .tier-features li::before{
  background:radial-gradient(circle,var(--magenta) 25%,transparent 26%);
  border-color:var(--magenta);
}
.tier-cta{
  display:flex;justify-content:center;align-items:center;padding:14px;
  border-radius:100px;background:transparent;border:1px solid var(--line-hot);
  color:var(--ink);text-decoration:none;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.25em;text-transform:uppercase;transition:background .3s;
}
.tier.featured .tier-cta{
  background:linear-gradient(110deg,var(--cyan),var(--violet) 50%,var(--magenta));
  color:#000;font-weight:500;border-color:transparent;
}
.tier-cta:hover{background:rgba(124,92,255,0.2)}
.tier.featured .tier-cta:hover{opacity:0.9}

/* ============================================
   CTA BANNER — no bg logo, keep blue glow
   ============================================ */
.cta-banner{
  max-width:1320px;margin:0 auto;position:relative;
  padding:100px 60px;border-radius:32px;
  background:
    radial-gradient(circle at 20% 30%,rgba(0,229,255,0.28),transparent 45%),
    radial-gradient(circle at 80% 70%,rgba(79,139,255,0.25),transparent 45%),
    radial-gradient(circle at 50% 50%,rgba(124,92,255,0.15),transparent 60%),
    linear-gradient(135deg,rgba(0,229,255,0.10),rgba(79,139,255,0.12),rgba(124,92,255,0.08));
  border:1px solid rgba(0,229,255,0.25);
  overflow:hidden;text-align:center;
  box-shadow:0 30px 100px rgba(0,229,255,0.1);
}
@media (max-width:820px){.cta-banner{padding:60px 24px;border-radius:24px}}
.cta-banner .eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.3em;color:var(--cyan);text-transform:uppercase;
}
.cta-banner h2{
  margin-top:20px;
  font-family:'Unbounded',sans-serif;font-weight:300;
  font-size:clamp(36px,5.5vw,72px);line-height:1;letter-spacing:-0.03em;
  max-width:860px;margin-left:auto;margin-right:auto;
}
.cta-banner h2 em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(110deg,var(--cyan),var(--blue-hot),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-banner p{
  margin-top:24px;color:var(--ink-dim);font-size:16px;max-width:520px;
  margin-left:auto;margin-right:auto;
}
.cta-banner .cta-buttons{
  margin-top:44px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
}

/* ============================================
   SOCIALS SECTION
   ============================================ */
.socials{ padding:80px 80px }
@media (max-width:960px){.socials{padding:60px 24px}}
.socials-inner{ max-width:1100px;margin:0 auto;text-align:center }
.socials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  max-width:820px;margin:48px auto 0;
}
@media (max-width:700px){.socials-grid{grid-template-columns:1fr}}
.social-card{
  padding:32px 28px;border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg,rgba(20,24,50,0.45),rgba(8,10,22,0.4));
  display:flex;flex-direction:column;align-items:center;gap:16px;
  text-decoration:none;color:var(--ink);
  transition:border-color .4s,transform .4s,background .4s;
}
.social-card:hover{
  border-color:var(--line-hot);transform:translateY(-4px);
  background:linear-gradient(180deg,rgba(124,92,255,0.12),rgba(8,10,22,0.5));
}
.social-card .icon-wrap{
  width:56px;height:56px;border-radius:50%;
  background:rgba(124,92,255,0.1);border:1px solid var(--line-hot);
  display:grid;place-items:center;
}
.social-card .handle{ font-family:'Unbounded',sans-serif;font-weight:500;font-size:16px }
.social-card .platform{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.3em;color:var(--muted);text-transform:uppercase;
}

/* ============================================
   FOOTER
   ============================================ */
footer{ padding:80px 80px 40px;border-top:1px solid var(--line);position:relative }
@media (max-width:960px){footer{padding:60px 24px 30px}}
.footer-grid{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px;
}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
.footer-brand{ display:flex;align-items:center;gap:12px;margin-bottom:20px }
.footer-brand svg{width:44px;height:44px}
.footer-brand-text{
  font-family:'Unbounded',sans-serif;font-weight:600;
  font-size:22px;letter-spacing:-0.02em;
}
.footer-brand-text .ai{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(120deg,var(--cyan),var(--violet),var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-left:4px;
}
.footer-col h4{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.3em;color:var(--muted);text-transform:uppercase;
  margin-bottom:20px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col ul a{
  color:var(--ink-dim);text-decoration:none;font-size:14px;transition:color .3s;
}
.footer-col ul a:hover{color:var(--ink)}
.footer-tagline{
  font-family:'Instrument Serif',serif;font-style:italic;
  color:var(--ink-dim);font-size:14px;line-height:1.7;max-width:320px;margin-bottom:24px;
}
.footer-bottom{
  max-width:1320px;margin:0 auto;padding-top:32px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.2em;color:var(--muted);text-transform:uppercase;
}
.footer-socials{display:flex;gap:10px}
.footer-socials a{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--muted);text-decoration:none;
  transition:border-color .3s,color .3s;
}
.footer-socials a:hover{border-color:var(--line-hot);color:var(--ink)}

/* ============================================
   REVEALS
   ============================================ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}
.reveal.d4{transition-delay:.4s}

@keyframes fade-rise{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-text > *{opacity:0;animation:fade-rise 1s cubic-bezier(.2,.7,.2,1) forwards}
.hero-text .hero-eyebrow{animation-delay:.3s}
.hero-text h1{animation-delay:.5s}
.hero-text .hero-sub{animation-delay:.8s}
.hero-text .hero-cta{animation-delay:1s}
.hero-text .hero-metrics{animation-delay:1.2s}

@keyframes hero-logo-in{
  from{opacity:0;transform:scale(0.8)}
  to{opacity:1;transform:scale(1)}
}
/* hero-bg-logo entrance handled above */

/* ============================================
   CONTACT PAGE specific
   ============================================ */
.contact-hero{
  padding:140px 40px 80px;
  text-align:center;
  position:relative;
  min-height:60vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.contact-hero .stage-small{
  width:160px;height:160px;margin-bottom:32px;
  position:relative;
}
.contact-hero .stage-small svg{
  width:100%;height:100%;
  animation:hero-logo-in 1.2s cubic-bezier(.2,.8,.2,1) forwards;
}
.contact-hero .stage-small::before{
  content:"";position:absolute;inset:-20%;border-radius:50%;
  background:radial-gradient(circle,rgba(124,92,255,0.3),transparent 70%);
  filter:blur(30px);z-index:-1;
}
.contact-hero h1{
  font-family:'Unbounded',sans-serif;font-weight:300;
  font-size:clamp(44px,6.5vw,80px);line-height:0.95;letter-spacing:-0.04em;
  max-width:900px;
}
.contact-hero h1 em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(110deg,var(--cyan),var(--violet),var(--magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.contact-hero p{
  margin-top:28px;max-width:580px;
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(17px,2vw,21px);color:var(--ink-dim);line-height:1.5;
}

.contact-main{ padding:60px 40px 120px }
@media (max-width:960px){.contact-main{padding:40px 24px 80px}}
.contact-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.2fr;gap:40px;
}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:32px}}

.contact-methods{
  display:flex;flex-direction:column;gap:16px;
}
.method-card{
  padding:28px;border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg,rgba(20,24,50,0.45),rgba(8,10,22,0.4));
  display:flex;align-items:flex-start;gap:20px;
  text-decoration:none;color:var(--ink);
  transition:border-color .4s,transform .4s,background .4s;
}
.method-card:hover{
  border-color:var(--line-hot);transform:translateY(-2px);
  background:linear-gradient(180deg,rgba(124,92,255,0.1),rgba(8,10,22,0.5));
}
.method-card .icon{
  width:52px;height:52px;flex:none;border-radius:14px;
  background:rgba(124,92,255,0.15);border:1px solid var(--line-hot);
  display:grid;place-items:center;
}
.method-card .icon svg{width:22px;height:22px}
.method-card .txt{flex:1}
.method-card .lbl{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.3em;color:var(--violet);text-transform:uppercase;
  margin-bottom:6px;
}
.method-card .val{
  font-family:'Unbounded',sans-serif;font-weight:500;font-size:18px;
  letter-spacing:-0.01em;margin-bottom:4px;
}
.method-card .desc{ font-size:13px;color:var(--muted);line-height:1.5 }
.method-card .arrow-icon{
  margin-left:auto;margin-top:8px;color:var(--muted);
  transition:color .3s,transform .3s;
}
.method-card:hover .arrow-icon{color:var(--violet);transform:translateX(4px)}

/* Form */
.contact-form{
  padding:40px;border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg,rgba(20,24,50,0.55),rgba(8,10,22,0.5));
}
@media (max-width:820px){.contact-form{padding:28px 20px}}
.form-header{ margin-bottom:32px }
.form-header h3{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:28px;letter-spacing:-0.01em;margin-bottom:8px;
}
.form-header p{ font-size:13px;color:var(--muted);line-height:1.5 }
.form-row{ display:grid;grid-template-columns:1fr 1fr;gap:14px }
@media (max-width:600px){.form-row{grid-template-columns:1fr}}
.form-field{ display:flex;flex-direction:column;gap:8px;margin-bottom:18px }
.form-field label{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.25em;color:var(--muted);text-transform:uppercase;
}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:14px 16px;
  background:rgba(3,4,9,0.5);
  border:1px solid var(--line);border-radius:12px;
  color:var(--ink);
  font-family:'Unbounded',sans-serif;font-weight:300;font-size:14px;
  transition:border-color .3s,background .3s;outline:none;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted)}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  border-color:var(--violet);background:rgba(3,4,9,0.8);
}
.form-field textarea{resize:vertical;min-height:120px;font-family:inherit}
.form-field select{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%237c5cff' stroke-width='1.5' fill='none'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;
}
.form-submit{
  width:100%;margin-top:8px;padding:18px;
  border-radius:12px;border:none;cursor:pointer;
  background:linear-gradient(110deg,var(--cyan),var(--violet) 50%,var(--magenta));
  color:#000;font-weight:500;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.3em;text-transform:uppercase;
  transition:transform .3s,box-shadow .3s;
}
.form-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 15px 40px rgba(124,92,255,0.4);
}
.form-submit:disabled{opacity:0.6;cursor:wait}
.form-note{
  margin-top:16px;text-align:center;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:0.2em;color:var(--muted);text-transform:uppercase;
}
