:root {
  --bg-0: #03060f;
  --bg-1: #061029;
  --bg-2: #0a1a44;
  --blue: #1659c8;
  --blue-light: #3aa0ff;
  --cyan: #29e3ff;
  --green: #8bc34a;
  --green-dark: #4f7a1f;
  --text: #e9efff;
  --muted: #93a3c4;
  --card: rgba(255,255,255,0.04);
  --border: rgba(120,170,255,0.18);
  --shadow-glow: 0 10px 60px rgba(41,227,255,0.18);
  --grad: linear-gradient(120deg, var(--cyan), var(--blue-light) 45%, var(--green) 100%);
  --radius: 14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:150px}
section[id]{scroll-margin-top:150px}
@media (max-width:680px){
  html{scroll-padding-top:115px}
  section[id]{scroll-margin-top:115px}
}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text);
  background:radial-gradient(ellipse at top, #0b1e52 0%, var(--bg-1) 35%, var(--bg-0) 100%);
  min-height:100vh;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--cyan);text-decoration:none;transition:color .2s}
a:hover{color:var(--blue-light)}
h1,h2,h3{font-family:'Orbitron',sans-serif;line-height:1.15;letter-spacing:-.01em;overflow-wrap:break-word;word-break:break-word;hyphens:auto}
h1{font-size:clamp(1.9rem,5vw,3.8rem);font-weight:900}
h2{font-size:clamp(1.5rem,3.5vw,2.6rem);font-weight:700;margin-bottom:.5em}
h3{font-size:1.2rem;font-weight:700;margin-bottom:.4em}
p{color:#cfd8ee}
.container{max-width:1180px;margin:0 auto;padding:0 1.25rem}

/* Background FX */
.bg-grid{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background-image:
    linear-gradient(rgba(58,160,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(58,160,255,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);
}
.bg-glow{
  position:fixed;z-index:-1;width:520px;height:520px;border-radius:50%;
  filter:blur(120px);opacity:.45;pointer-events:none;
}
.bg-glow-1{background:#1659c8;top:-100px;left:-150px;animation:float 14s ease-in-out infinite}
.bg-glow-2{background:#29e3ff;bottom:-200px;right:-150px;animation:float 18s ease-in-out infinite reverse;opacity:.25}
@keyframes float{50%{transform:translate(40px,40px) scale(1.1)}}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(3,6,15,0.75);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.25rem}
.brand img{height:120px;width:auto;filter:drop-shadow(0 0 14px rgba(41,227,255,.35));transition:transform .3s}
.brand:hover img{transform:scale(1.04)}
.primary-nav ul{display:flex;gap:.25rem;list-style:none}
.primary-nav a{
  display:inline-block;color:var(--text);padding:.6rem 1rem;border-radius:10px;
  font-weight:500;font-size:.95rem;transition:background .2s,color .2s;
}
.primary-nav a:hover{background:rgba(58,160,255,.1);color:var(--cyan)}
.primary-nav .cta-link{
  background:var(--grad);color:#001028;font-weight:700;margin-left:.5rem;
}
.primary-nav .cta-link:hover{filter:brightness(1.15);color:#ffffff}
.nav-toggle{
  display:none;background:transparent;border:1px solid var(--border);
  padding:.5rem;border-radius:8px;cursor:pointer;flex-direction:column;gap:4px;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Buttons */
.btn{
  display:inline-block;padding:.85rem 1.6rem;border-radius:999px;font-weight:700;
  font-size:.95rem;cursor:pointer;border:none;transition:transform .2s,box-shadow .2s,filter .2s;
  text-align:center;
}
.btn-primary{background:var(--grad);color:#001028;box-shadow:var(--shadow-glow)}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.08);color:#001028}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{background:rgba(58,160,255,.1);color:var(--cyan)}
.btn-block{width:100%}

/* HERO */
.hero{padding:5rem 0 4rem;position:relative}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.eyebrow{
  display:inline-block;font-family:'Orbitron',sans-serif;font-size:.78rem;letter-spacing:.18em;
  color:var(--cyan);text-transform:uppercase;margin-bottom:1rem;
}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:1.15rem;color:#bcc8e8;margin:1.2rem 0 2rem;max-width:540px}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-stats{list-style:none;display:flex;gap:2rem;flex-wrap:wrap}
.hero-stats li{display:flex;flex-direction:column}
.hero-stats strong{font-family:'Orbitron',sans-serif;font-size:1.6rem;color:var(--cyan)}
.hero-stats span{font-size:.85rem;color:var(--muted)}

.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:460px;perspective:1000px}
.mascot-wrap{
  position:relative;z-index:2;width:100%;max-width:400px;
  transform-style:preserve-3d;
  transform:perspective(900px) rotateX(calc(var(--ry,0) * -8deg)) rotateY(calc(var(--rx,0) * 10deg)) translate3d(calc(var(--rx,0)*14px),calc(var(--ry,0)*14px),0);
  transition:transform .25s cubic-bezier(.2,.8,.2,1);
}
.mascot-hero{
  width:100%;height:auto;
  filter:drop-shadow(0 20px 50px rgba(41,227,255,.35));
  transform-origin:50% 70%;
}
/* Stack the 3 frames perfectly aligned */
.mascot-wrap .frame{position:absolute;inset:0;}
.mascot-wrap .frame-idle{position:relative;animation:bob 4s ease-in-out infinite}
.mascot-wrap .frame-a,
.mascot-wrap .frame-b{opacity:0;animation:bob 4s ease-in-out infinite;transition:opacity .05s linear}
/* While typing: hide idle, alternate A/B */
.mascot-wrap.is-typing .frame-idle{opacity:0}
.mascot-wrap.is-typing .frame-a{opacity:1;animation:bob 4s ease-in-out infinite, frameSwapA .22s steps(1) infinite}
.mascot-wrap.is-typing .frame-b{opacity:0;animation:bob 4s ease-in-out infinite, frameSwapB .22s steps(1) infinite}
.mascot-wrap.is-talking .frame-idle{animation:bob 4s ease-in-out infinite, talk .35s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(-14px)}}
@keyframes frameSwapA{0%,49%{opacity:1}50%,100%{opacity:0}}
@keyframes frameSwapB{0%,49%{opacity:0}50%,100%{opacity:1}}
@keyframes talk{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-3px) scale(1.015)}
}
.type-spark{
  position:absolute;left:46%;top:62%;width:8px;height:8px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 12px var(--cyan);
  opacity:0;pointer-events:none;
}
.mascot-wrap.is-typing .type-spark{animation:spark 1s ease-out infinite}
.mascot-wrap.is-typing .type-spark.s2{left:52%;top:64%;background:var(--green);box-shadow:0 0 12px var(--green);animation-delay:.25s}
.mascot-wrap.is-typing .type-spark.s3{left:58%;top:60%;background:var(--blue-light);box-shadow:0 0 12px var(--blue-light);animation-delay:.5s}
@keyframes spark{
  0%{opacity:0;transform:translate(0,0) scale(.6)}
  30%{opacity:1}
  100%{opacity:0;transform:translate(calc(var(--rx,0)*-20px - 4px),-30px) scale(1.4)}
}
.orbit{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1}
.ring{position:absolute;border-radius:50%;border:1px solid rgba(58,160,255,.25)}
.ring-1{width:380px;height:380px;animation:spin 30s linear infinite}
.ring-2{width:460px;height:460px;border-color:rgba(41,227,255,.18);animation:spin 50s linear infinite reverse}
.ring-3{width:540px;height:540px;border-color:rgba(139,195,74,.15);animation:spin 70s linear infinite}
.ring::before{
  content:"";position:absolute;width:10px;height:10px;border-radius:50%;
  background:var(--cyan);top:-5px;left:50%;box-shadow:0 0 16px var(--cyan);
}
.ring-2::before{background:var(--green);box-shadow:0 0 16px var(--green)}
.ring-3::before{background:var(--blue-light);box-shadow:0 0 16px var(--blue-light)}
@keyframes spin{to{transform:rotate(360deg)}}
.speech{
  position:absolute;bottom:4%;left:4%;z-index:3;max-width:78%;
  background:rgba(10,26,68,.92);border:1px solid var(--border);
  padding:.75rem 1rem;border-radius:14px;font-size:.92rem;
  box-shadow:0 8px 30px rgba(0,0,0,.4);
  backdrop-filter:blur(8px);
  transform-origin:bottom left;
  animation:speechIn .35s ease-out;
}
.speech::after{
  content:"";position:absolute;right:-8px;top:18px;width:14px;height:14px;
  background:rgba(10,26,68,.92);border-right:1px solid var(--border);border-top:1px solid var(--border);
  transform:rotate(45deg);
}
.speech.pulse{animation:speechIn .35s ease-out, speechPulse .5s ease-out}
@keyframes speechIn{from{opacity:0;transform:translateY(8px) scale(.9)}to{opacity:1;transform:none}}
@keyframes speechPulse{50%{transform:scale(1.04)}}
.speech strong{color:var(--green)}
.caret{display:inline-block;width:2px;background:var(--cyan);margin-left:2px;animation:caret .7s steps(1) infinite;vertical-align:-2px;height:1em}
@keyframes caret{50%{opacity:0}}

/* Sections */
.section{padding:5rem 0;position:relative}
.section-alt{
  background:linear-gradient(180deg,transparent,rgba(10,26,68,.4),transparent);
}
.section-head{text-align:center;max-width:720px;margin:0 auto 3rem}
.section-head p{color:var(--muted)}
.two-col{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:center}
.mascot-col{display:flex;justify-content:center}
.mascot-side{
  filter:drop-shadow(0 10px 40px rgba(139,195,74,.3));
}
.mascot-mini{position:relative;display:inline-block;cursor:pointer}
.mascot-mini .frame{position:absolute;inset:0;width:100%;height:auto}
.mascot-mini .frame-idle{position:relative;animation:bob 5s ease-in-out infinite}
.mascot-mini .frame-a,
.mascot-mini .frame-b{opacity:0;animation:bob 5s ease-in-out infinite;transition:opacity .05s linear}
.mascot-mini:hover .frame-idle{opacity:0}
.mascot-mini:hover .frame-a{opacity:1;animation:bob 5s ease-in-out infinite, frameSwapA .22s steps(1) infinite}
.mascot-mini:hover .frame-b{opacity:0;animation:bob 5s ease-in-out infinite, frameSwapB .22s steps(1) infinite}
.mascot-mini .type-spark{position:absolute;left:46%;top:62%;width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan);opacity:0;pointer-events:none}
.mascot-mini:hover .type-spark{animation:spark 1s ease-out infinite}
.mascot-mini:hover .type-spark.s2{left:52%;top:64%;background:var(--green);box-shadow:0 0 12px var(--green);animation-delay:.25s}
.mascot-mini:hover .type-spark.s3{left:58%;top:60%;background:var(--blue-light);box-shadow:0 0 12px var(--blue-light);animation-delay:.5s}

/* Features */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.feature{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.6rem;transition:transform .25s,border-color .25s,box-shadow .25s;
}
.feature:hover{transform:translateY(-6px);border-color:var(--cyan);box-shadow:var(--shadow-glow)}
.feat-icon{font-size:2rem;margin-bottom:.8rem}
.feature p{color:var(--muted);font-size:.95rem}

/* Services */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.service-card{
  position:relative;background:linear-gradient(160deg,rgba(22,89,200,.22),rgba(10,26,68,.4));
  border:1px solid var(--border);border-radius:18px;padding:2rem;overflow:hidden;
  transition:transform .25s,border-color .25s;
}
.service-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px circle at var(--mx,50%) var(--my,0%),rgba(41,227,255,.12),transparent 40%);
  pointer-events:none;transition:opacity .3s;opacity:0;
}
.service-card:hover{transform:translateY(-4px);border-color:var(--cyan)}
.service-card:hover::before{opacity:1}
.service-card.highlight{border-color:rgba(139,195,74,.45)}
.svc-num{
  font-family:'Orbitron',sans-serif;font-size:2.4rem;font-weight:900;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:.5rem;
}
.service-card ul{list-style:none;margin-top:1rem;padding:0}
.service-card li{
  padding:.4rem 0 .4rem 1.4rem;position:relative;color:var(--muted);font-size:.92rem;
  border-top:1px dashed rgba(120,170,255,.12);
}
.service-card li:first-child{border-top:none}
.service-card li::before{
  content:"";position:absolute;left:0;top:50%;width:8px;height:8px;border-radius:50%;
  background:var(--green);box-shadow:0 0 8px var(--green);transform:translateY(-50%);
}

/* Contact */
.contact-grid{align-items:start}
.contact-list{list-style:none;margin:1.5rem 0;padding:0}
.contact-list li{padding:.5rem 0;color:var(--text)}
.contact-list span{margin-right:.5rem}
.mascot-contact{margin-top:1.5rem;filter:drop-shadow(0 10px 30px rgba(41,227,255,.3))}

.contact-form{
  background:var(--card);border:1px solid var(--border);border-radius:18px;padding:2rem;
  backdrop-filter:blur(10px);
}
.field{margin-bottom:1.1rem;display:flex;flex-direction:column}
.field label{font-size:.85rem;color:var(--muted);margin-bottom:.4rem;font-weight:500}
.field input,.field select,.field textarea{
  background:rgba(3,6,15,.6);border:1px solid var(--border);color:var(--text);
  padding:.8rem 1rem;border-radius:10px;font-family:inherit;font-size:1rem;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(41,227,255,.15);
}
.field textarea{resize:vertical;min-height:110px}
.field select option{background:#061029;color:var(--text)}
.form-status{margin-top:1rem;font-size:.9rem;min-height:1.2em}
.form-status.success{color:var(--green)}
.form-status.error{color:#ff7a7a}

/* Footer */
.site-footer{
  border-top:1px solid var(--border);padding:2.5rem 0;margin-top:3rem;
  background:rgba(3,6,15,.5);
}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem;align-items:center}
.footer-grid img{height:60px;width:auto}
.footer-grid nav{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap}
.footer-grid nav a{color:var(--muted);font-size:.92rem}
.footer-grid nav a:hover{color:var(--cyan)}
.muted{color:var(--muted)}
.small{font-size:.85rem;text-align:right}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:none}

/* Responsive */
@media (max-width:960px){
  .hero-grid,.two-col{grid-template-columns:1fr;gap:2rem}
  .hero-visual{min-height:300px;order:-1}
  .mascot-hero{max-width:260px}
  .ring-1{width:260px;height:260px}
  .ring-2{width:310px;height:310px}
  .ring-3{width:360px;height:360px}
  .features{grid-template-columns:repeat(2,1fr)}
  .services{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;text-align:center}
  .footer-grid nav{justify-content:center}
  .small{text-align:center}
}
@media (max-width:680px){
  .nav-toggle{display:flex}
  .brand img{height:90px}
  .primary-nav{
    position:absolute;top:100%;left:0;right:0;
    background:rgba(3,6,15,.98);border-bottom:1px solid var(--border);
    max-height:0;overflow:hidden;transition:max-height .3s ease;
  }
  .primary-nav.is-open{max-height:400px}
  .primary-nav ul{flex-direction:column;padding:1rem;gap:.25rem}
  .primary-nav .cta-link{margin:.5rem 0 0}
  .hero{padding:3rem 0 2rem}
  .section{padding:3.5rem 0}
  .features{grid-template-columns:1fr}
  .hero-stats{gap:1.2rem}
  .speech{font-size:.8rem;padding:.5rem .8rem}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}
