/* =============================================================
   NetSoloWeb · Futuristic theme
   Dark mode, neon accents, glass cards, animated grid
   ============================================================= */

:root{
  --bg:           #05060d;
  --bg-2:         #0a0d1a;
  --surface:      rgba(255,255,255,.04);
  --surface-2:    rgba(255,255,255,.06);
  --border:       rgba(255,255,255,.08);
  --border-hi:    rgba(0,229,255,.45);
  --text:         #e6eaf2;
  --text-dim:     #b5bccf;
  --muted:        #7a8095;

  --cyan:         #00e5ff;
  --magenta:      #ff2bd6;
  --purple:       #7c5cff;
  --lime:         #b6ff39;

  --grad:         linear-gradient(135deg,var(--cyan),var(--magenta));
  --grad-soft:    linear-gradient(135deg,rgba(0,229,255,.18),rgba(255,43,214,.18));

  --glow-cyan:    0 0 24px rgba(0,229,255,.45),0 0 60px rgba(0,229,255,.18);
  --glow-pink:    0 0 24px rgba(255,43,214,.45),0 0 60px rgba(255,43,214,.18);
  --glow-purple:  0 0 28px rgba(124,92,255,.45);

  --radius:       12px;
  --radius-lg:    20px;
  --shadow-lg:    0 20px 80px rgba(0,0,0,.5);

  --max:          1180px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--cyan);color:#000}

/* Custom scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:#06080f}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--cyan),var(--magenta));border-radius:10px}

img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s ease}
a:hover{color:var(--cyan)}

h1,h2,h3,h4{
  font-family:'Space Grotesk','Inter',sans-serif;
  line-height:1.08;
  margin:0 0 .5em;
  letter-spacing:-.02em;
  color:#fff;
}
h1{font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:700}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:600}
h3{font-size:1.2rem;font-weight:600}
p{margin:0 0 1em;color:var(--text-dim)}
ul{padding:0;list-style:none;margin:0}

.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem;position:relative;z-index:2}
.center{text-align:center}
.muted{color:var(--muted)}

/* Gradient/neon helpers */
.grad{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 200%;
  animation:grad-shift 8s ease infinite;
}
@keyframes grad-shift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.accent{color:var(--cyan)}

/* Terminal-style eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:.72rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:1rem;
  padding:.4rem .8rem;
  border:1px solid rgba(0,229,255,.3);
  border-radius:999px;
  background:rgba(0,229,255,.05);
  backdrop-filter:blur(8px);
}
.eyebrow::before{
  content:"";
  width:6px;height:6px;border-radius:50%;
  background:var(--cyan);
  box-shadow:var(--glow-cyan);
  animation:pulse 2s ease infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Skip link */
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;background:var(--cyan);color:#000;padding:.5rem 1rem;z-index:100;border-radius:6px}

/* =================== Animated background =================== */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--cyan),var(--magenta));
  box-shadow:var(--glow-cyan);
  transition:width .1s ease;
}
.grid-bg{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(0,229,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,229,255,.045) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at 50% 30%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 30%,#000 30%,transparent 80%);
  animation:grid-drift 30s linear infinite;
}
@keyframes grid-drift{0%{transform:translate(0,0)}100%{transform:translate(60px,60px)}}

.scanlines{
  position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  background:repeating-linear-gradient(0deg,#fff 0,#fff 1px,transparent 1px,transparent 3px);
}

.orb{
  position:fixed;border-radius:50%;filter:blur(100px);opacity:.4;pointer-events:none;z-index:0;
}
.orb-a{width:560px;height:560px;background:var(--cyan);top:-200px;right:-180px;animation:float-a 18s ease-in-out infinite}
.orb-b{width:520px;height:520px;background:var(--magenta);bottom:-220px;left:-160px;animation:float-b 22s ease-in-out infinite}
@keyframes float-a{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,40px)}}
@keyframes float-b{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-40px)}}

/* =================== Buttons =================== */
.btn{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.95rem 1.5rem;font-weight:600;font-size:.95rem;
  border-radius:999px;border:1px solid transparent;cursor:pointer;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  letter-spacing:.05em;text-transform:uppercase;font-size:.78rem;
  transition:all .25s cubic-bezier(.4,.0,.2,1);white-space:nowrap;
  isolation:isolate;
}
.btn-primary{
  background:var(--grad);
  color:#02030a;
  box-shadow:var(--glow-cyan);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:var(--glow-cyan),var(--glow-pink);
  color:#02030a;
}
.btn-ghost{
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.15);
  color:var(--text);
  backdrop-filter:blur(8px);
}
.btn-ghost:hover{
  border-color:var(--cyan);
  color:var(--cyan);
  box-shadow:0 0 0 1px var(--cyan) inset,var(--glow-cyan);
}
.btn-lg{padding:1.1rem 1.85rem;font-size:.85rem}
.btn-block{width:100%}

/* =================== Header / Nav =================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(5,6,13,.65);
  backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem}

.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{flex:none;border-radius:10px;box-shadow:var(--glow-cyan)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:'Space Grotesk';font-weight:700;font-size:1.2rem;color:#fff}
.brand-sub{font-family:'JetBrains Mono';font-size:.68rem;color:var(--cyan);letter-spacing:.15em}

.primary-nav ul{display:flex;gap:.25rem;align-items:center}
.nav-link{
  padding:.55rem .95rem;
  font-family:'JetBrains Mono';font-size:.78rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;
  border-radius:6px;color:var(--text-dim);
  position:relative;
}
.nav-link::before{
  content:"";position:absolute;left:50%;bottom:.2rem;width:0;height:1px;
  background:var(--cyan);transition:all .25s ease;
  box-shadow:var(--glow-cyan);
}
.nav-link:hover{color:#fff}
.nav-link:hover::before{left:1rem;width:calc(100% - 2rem)}
.nav-link.active{color:var(--cyan)}
.nav-link.active::before{left:1rem;width:calc(100% - 2rem)}

.nav-cta{
  margin-left:.5rem;padding:.65rem 1.2rem;
  border-radius:999px;background:var(--grad);
  color:#02030a;font-family:'JetBrains Mono';font-weight:600;font-size:.78rem;
  letter-spacing:.08em;text-transform:uppercase;
  box-shadow:var(--glow-cyan);transition:all .25s ease;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:var(--glow-cyan),var(--glow-pink);color:#02030a}

.nav-toggle{display:none;background:none;border:0;padding:.5rem;cursor:pointer;flex-direction:column;gap:5px}
.nav-toggle span{width:22px;height:2px;background:var(--cyan);border-radius:2px;box-shadow:var(--glow-cyan);transition:.3s}

@media (max-width:860px){
  .nav-toggle{display:flex}
  .primary-nav{
    position:absolute;top:100%;left:0;right:0;
    background:rgba(5,6,13,.95);backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
    overflow:hidden;max-height:0;transition:max-height .35s ease;
  }
  .primary-nav.open{max-height:560px}
  .primary-nav ul{flex-direction:column;align-items:stretch;padding:1rem 1.5rem 1.5rem;gap:.25rem}
  .nav-cta{text-align:center;margin:.75rem 0 0}
}

/* =================== Hero =================== */
.hero{
  position:relative;padding:6rem 0 7rem;
  overflow:hidden;
}
.hero-bg{display:none} /* legacy, replaced by body-level background */

/* Aurora layer — slow rotating conic gradient */
.aurora{
  position:absolute;inset:-20%;z-index:0;pointer-events:none;
  background:conic-gradient(from 0deg at 50% 50%,
    transparent 0deg,rgba(0,229,255,.22) 60deg,transparent 120deg,
    rgba(255,43,214,.22) 200deg,transparent 260deg,
    rgba(124,92,255,.22) 320deg,transparent 360deg);
  filter:blur(60px);opacity:.7;
  animation:aurora-spin 26s linear infinite;
}
@keyframes aurora-spin{to{transform:rotate(360deg)}}

/* Giant ghost wordmark behind hero */
.ghost-wordmark{
  position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(8rem,22vw,22rem);font-weight:700;letter-spacing:-.06em;
  background:linear-gradient(180deg,rgba(0,229,255,.18),rgba(255,43,214,0));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  white-space:nowrap;z-index:0;pointer-events:none;opacity:.5;
  text-shadow:0 0 0 transparent;
  animation:ghost-pulse 8s ease-in-out infinite;
}
@keyframes ghost-pulse{0%,100%{opacity:.5}50%{opacity:.25}}

/* Status pill (LIVE • NOW BOOKING) */
.status-pill{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'JetBrains Mono';font-size:.7rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);
  padding:.4rem .85rem;
  background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.3);
  border-radius:999px;backdrop-filter:blur(8px);
  margin-bottom:1.5rem;
  animation:fade-up .8s cubic-bezier(.4,0,.2,1) both;
}
.status-pill .dot{
  width:8px;height:8px;border-radius:50%;background:var(--cyan);
  box-shadow:var(--glow-cyan);
  animation:pulse 1.8s ease-in-out infinite;
}

/* Terminal line above H1 */
.terminal-line{
  font-family:'JetBrains Mono';font-size:.85rem;color:var(--muted);
  margin-bottom:1rem;display:flex;align-items:center;gap:.4rem;
  animation:fade-up .8s .15s cubic-bezier(.4,0,.2,1) both;
}
.terminal-line .prompt{color:var(--cyan);font-weight:700;text-shadow:var(--glow-cyan)}
.terminal-line .typed{color:var(--text-dim)}
.terminal-line .caret{
  display:inline-block;width:8px;height:14px;background:var(--cyan);
  box-shadow:var(--glow-cyan);
  animation:blink 1s steps(2) infinite;
}
@keyframes blink{0%,50%{opacity:1}51%,100%{opacity:0}}
@keyframes fade-up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* Animated H1 reveal — line by line, word by word */
.hero-title{
  font-size:clamp(2.6rem,5.8vw,4.8rem);
  margin-bottom:1.5rem;line-height:1.05;font-weight:700;
}
.reveal-line{display:block;overflow:hidden}
.reveal-line .r{
  display:inline-block;opacity:0;transform:translateY(110%);
  animation:word-rise .9s cubic-bezier(.2,.7,.2,1) both;
  animation-delay:var(--d,0s);
}
@keyframes word-rise{to{opacity:1;transform:translateY(0)}}

.hero-inner{display:grid;grid-template-columns:1.15fr 1fr;gap:4rem;align-items:center;position:relative;z-index:2}

.hero-copy h1{margin-bottom:1.2rem;font-weight:700}
.lede{font-size:1.15rem;color:var(--text-dim);max-width:34em;line-height:1.6}
.hero-cta{display:flex;gap:.85rem;flex-wrap:wrap;margin:2rem 0}

.hero-proof{display:flex;gap:2.5rem;margin-top:2.5rem;flex-wrap:wrap;padding-top:2rem;border-top:1px solid var(--border)}
.hero-proof li{display:flex;flex-direction:column}
.hero-proof strong{
  font-family:'Space Grotesk';font-size:2rem;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-proof span{font-family:'JetBrains Mono';font-size:.72rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.25rem}

.hero-visual{position:relative;min-height:400px}
.floating-card{
  position:absolute;background:rgba(10,13,26,.7);
  border:1px solid var(--border);border-radius:14px;
  padding:.85rem 1.1rem;backdrop-filter:blur(12px);
  display:flex;flex-direction:column;min-width:180px;
  box-shadow:var(--shadow-lg);
}
.floating-card::before{
  content:"";position:absolute;inset:0;border-radius:14px;padding:1px;
  background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.5;pointer-events:none;
}
.floating-card strong{font-family:'Space Grotesk';font-size:1.5rem;color:var(--cyan);text-shadow:var(--glow-cyan)}
.floating-card small{font-family:'JetBrains Mono';color:var(--text-dim);font-size:.72rem;letter-spacing:.05em}
.card-seo{top:-12px;left:-20px;animation:float-card 6s ease-in-out infinite}
.card-ig{bottom:-12px;right:-12px;animation:float-card 7s ease-in-out infinite reverse}
.card-ig strong{color:var(--magenta);text-shadow:var(--glow-pink)}
.card-deploy{top:42%;right:-30px;animation:float-card 8s ease-in-out infinite}
.card-deploy strong{font-family:'JetBrains Mono';font-size:.95rem;color:var(--lime);text-shadow:0 0 18px rgba(182,255,57,.5)}
.card-deploy .live-dot{
  position:absolute;top:.8rem;right:.85rem;width:8px;height:8px;border-radius:50%;
  background:var(--lime);box-shadow:0 0 12px var(--lime);
  animation:pulse 1.4s ease-in-out infinite;
}
@keyframes float-card{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

@media (max-width:860px){
  .hero{padding:4rem 0 4rem}
  .hero-inner{grid-template-columns:1fr;gap:3rem}
}

/* =================== Marquee band =================== */
.marquee-band{
  padding:2rem 0 2.5rem;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:rgba(10,13,26,.4);position:relative;z-index:2;overflow:hidden;
}
.marquee-label{
  margin:0 0 1.25rem;text-align:center;
  font-family:'JetBrains Mono';font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);
}
.marquee{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{
  display:flex;align-items:center;gap:2.5rem;width:max-content;
  animation:marquee-scroll 38s linear infinite;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.1rem;
  color:var(--text-dim);
}
.marquee-track span{white-space:nowrap}
.marquee-track .dot-sep{color:var(--cyan);font-size:.6rem;opacity:.6}
@keyframes marquee-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Legacy (some pages may still reference) */
.logos{padding:2.5rem 1.5rem;text-align:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(10,13,26,.4);position:relative;z-index:2}
.logos p{margin:0 0 1.25rem;font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.logo-row{display:flex;gap:3.5rem;flex-wrap:wrap;justify-content:center;color:var(--text-dim);font-family:'Space Grotesk';font-weight:600;font-size:1.05rem}
.logo-row span{opacity:.55}

/* =================== Stat counter band =================== */
.stat-band{
  padding:4rem 0;position:relative;z-index:2;
  background:linear-gradient(180deg,transparent,rgba(0,229,255,.04),transparent);
  border-bottom:1px solid var(--border);
}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat{
  position:relative;padding:1rem;
}
.stat::after{
  content:"";position:absolute;right:0;top:20%;bottom:20%;width:1px;
  background:linear-gradient(180deg,transparent,var(--border),transparent);
}
.stat:last-child::after{display:none}
.stat strong{
  display:block;font-family:'Space Grotesk';font-weight:700;
  font-size:clamp(2.4rem,4.5vw,3.6rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:.5rem;letter-spacing:-.02em;
}
.stat span{font-family:'JetBrains Mono';font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
@media (max-width:760px){.stat-grid{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2)::after{display:none}}

/* =================== Sections =================== */
.section{padding:6rem 0;position:relative;z-index:2}
.section-alt{
  background:linear-gradient(180deg,rgba(10,13,26,.6),rgba(5,6,13,.3));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.section-head{max-width:760px;margin:0 auto 3.5rem;text-align:center}
.section-head h2{margin-bottom:1rem}
.section-head p{color:var(--text-dim);font-size:1.05rem}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.two-col.reverse > div:first-child{order:2}
@media (max-width:860px){.two-col{grid-template-columns:1fr;gap:3rem}.two-col.reverse > div:first-child{order:0}}

.grid{display:grid;gap:1.5rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media (max-width:860px){.grid-3{grid-template-columns:1fr}}

/* =================== Cards (glass + gradient border) =================== */
.card{
  position:relative;display:block;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.9rem;
  backdrop-filter:blur(12px);
  transition:transform .3s cubic-bezier(.4,0,.2,1),border-color .3s ease,background .3s ease;
  overflow:hidden;
  isolation:isolate;
}
.card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,0%),rgba(0,229,255,.15),transparent 60%);
  opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:-1;
}
.card:hover{
  transform:translateY(-6px);
  border-color:var(--border-hi);
  background:var(--surface-2);
}
.card:hover::before{opacity:1}
.card h3{color:#fff}
.card p{color:var(--text-dim)}
.card.featured{
  background:linear-gradient(135deg,rgba(0,229,255,.08),rgba(255,43,214,.08));
  border-color:rgba(0,229,255,.25);
}
.card-icon{font-size:2rem;margin-bottom:.75rem}
.card-icon-svg{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,rgba(0,229,255,.18),rgba(255,43,214,.18));
  border:1px solid rgba(0,229,255,.3);
  display:grid;place-items:center;margin-bottom:1.1rem;
  box-shadow:inset 0 0 20px rgba(0,229,255,.08);
}
.card-icon-svg svg{width:28px;height:28px;stroke:var(--cyan)}
.card-icon-svg svg [stroke]{stroke:var(--cyan)}
.card-icon-svg svg [fill]:not([fill="none"]){fill:var(--cyan)}
.card-icon-svg svg circle[fill="#ff2e63"],
.card-icon-svg svg rect[fill="#ff6a3d"],
.card-icon-svg svg path[fill="#ff6a3d"]{fill:var(--magenta)}
.card-icon-svg svg rect[fill="#ffd0c0"]{fill:rgba(0,229,255,.3)}
.card-link{
  display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;
  font-family:'JetBrains Mono';font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;
  color:var(--cyan);font-weight:600;
}

/* =================== Check list =================== */
.check-list{display:grid;gap:.8rem;margin:1.25rem 0}
.check-list li{
  position:relative;padding-left:2rem;color:var(--text-dim);
}
.check-list li::before{
  content:"";position:absolute;left:0;top:.5em;width:14px;height:14px;
  border-radius:3px;
  background:var(--grad);
  box-shadow:var(--glow-cyan);
}
.check-list li::after{
  content:"";position:absolute;left:3px;top:.75em;width:8px;height:5px;
  border-left:2px solid #02030a;border-bottom:2px solid #02030a;
  transform:rotate(-45deg);
}

/* =================== Process / steps =================== */
.process{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2.5rem;backdrop-filter:blur(12px);
  position:relative;
}
.process::before{
  content:"";position:absolute;top:-1px;left:1rem;right:1rem;height:1px;
  background:var(--grad);
}
.process h3{color:#fff}
.steps{counter-reset:step;display:grid;gap:1.25rem;margin:0;padding:0}
.steps li{position:relative;padding-left:3rem;counter-increment:step}
.steps li::before{
  content:"0" counter(step);position:absolute;left:0;top:-.15em;
  font-family:'JetBrains Mono';font-weight:700;font-size:1.1rem;
  color:var(--cyan);text-shadow:var(--glow-cyan);
}
.steps li strong{display:block;font-weight:600;color:#fff;margin-bottom:.2rem}
.steps li span{color:var(--text-dim);font-size:.95rem}
.steps-lg li{padding:.4rem 0 .4rem 3rem}

/* =================== Quotes =================== */
.quote{
  position:relative;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:1.9rem;margin:0;backdrop-filter:blur(12px);
}
.quote::before{
  content:""";position:absolute;top:.5rem;left:1.5rem;
  font-family:'Space Grotesk';font-size:4rem;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  opacity:.4;
}
.quote blockquote{margin:0 0 1rem;font-size:1.02rem;line-height:1.55;color:var(--text);padding-top:1rem}
.quote figcaption{color:var(--cyan);font-family:'JetBrains Mono';font-size:.78rem;letter-spacing:.05em}

/* =================== Features (restaurant grid) =================== */
.feature{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.4rem;backdrop-filter:blur(12px);
  transition:border-color .25s ease,transform .25s ease;
}
.feature:hover{border-color:var(--border-hi);transform:translateY(-3px)}
.feature h3{font-size:1rem;margin-bottom:.4rem;color:#fff;font-family:'JetBrains Mono';letter-spacing:.02em}
.feature p{margin:0;color:var(--text-dim);font-size:.92rem}

/* =================== Page hero (sub-pages) =================== */
.page-hero{padding:5rem 0 3rem;position:relative;z-index:2}
.page-hero h1{max-width:18em}
.page-hero .lede{max-width:42em}

/* =================== Pricing =================== */
.pricing-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(12px);
}
.pricing-card h3{text-align:center;margin-bottom:1.25rem;color:#fff}
.tier{
  padding:1.15rem;border:1px solid var(--border);
  border-radius:var(--radius);margin-bottom:.85rem;
  background:rgba(255,255,255,.02);position:relative;
}
.tier.highlight{
  border-color:var(--cyan);background:linear-gradient(180deg,rgba(0,229,255,.06),rgba(255,43,214,.04));
  box-shadow:0 0 0 1px var(--cyan) inset,0 8px 30px rgba(0,229,255,.15);
}
.tier strong{display:block;font-family:'JetBrains Mono';font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan)}
.tier .price{
  display:block;font-family:'Space Grotesk';font-size:1.85rem;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin:.3rem 0 .5rem;
}
.tier p{margin:0;font-size:.9rem;color:var(--text-dim)}

/* =================== Portfolio =================== */
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:3rem}
.chip{
  padding:.6rem 1.2rem;border-radius:999px;
  border:1px solid var(--border);background:var(--surface);color:var(--text-dim);
  font-family:'JetBrains Mono';font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;
  font-weight:500;cursor:pointer;transition:all .25s ease;backdrop-filter:blur(8px);
}
.chip:hover{border-color:var(--cyan);color:var(--cyan)}
.chip.active{
  background:var(--grad);color:#02030a;border-color:transparent;
  box-shadow:var(--glow-cyan);
}

.project{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;backdrop-filter:blur(12px);
  transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;
}
.project:hover{
  transform:translateY(-6px);
  border-color:var(--border-hi);
  box-shadow:0 20px 60px rgba(0,229,255,.15);
}
.project-cover{aspect-ratio:16/10;display:grid;place-items:center;padding:1.2rem;position:relative}
.project-cover .mock-svg{width:100%;height:100%;filter:drop-shadow(0 14px 35px rgba(0,0,0,.5))}
.project-emoji{font-size:3.5rem;filter:drop-shadow(0 6px 12px rgba(0,0,0,.4))}
.project-body{padding:1.4rem 1.6rem 1.7rem}
.project-body h3{margin-bottom:.15rem;color:#fff}
.project-body small.muted{font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.06em;color:var(--cyan)}
.project-body p{margin:.85rem 0 1rem;color:var(--text-dim);font-size:.95rem}
.tags{display:flex;flex-wrap:wrap;gap:.4rem}
.tags li{
  font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.3rem .7rem;background:rgba(0,229,255,.08);
  border:1px solid rgba(0,229,255,.25);border-radius:999px;color:var(--cyan);
}

/* =================== About =================== */
.about-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(12px);
}
.about-card h3{color:#fff}
.facts{display:grid;grid-template-columns:auto 1fr;gap:.65rem 1.25rem;margin:0 0 1.5rem}
.facts dt{color:var(--muted);font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;align-self:center}
.facts dd{margin:0;font-weight:600;color:#fff}

/* =================== Contact =================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:3.5rem;align-items:start}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;gap:2.5rem}}
.contact-info h2{color:#fff}
.contact-list{display:grid;gap:1rem;margin:1rem 0 2rem}
.contact-list li{
  display:grid;grid-template-columns:140px 1fr;gap:1rem;
  padding:.9rem 0;border-bottom:1px solid var(--border);
}
.contact-list strong{
  font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
}

.contact-form-wrap{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(12px);
}
.contact-form{display:grid;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{
  font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);font-weight:500;
}
.field input,.field select,.field textarea{
  width:100%;padding:.9rem 1.1rem;
  border:1px solid var(--border);border-radius:10px;
  font:inherit;color:#fff;background:rgba(0,0,0,.3);
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--cyan);background:rgba(0,229,255,.04);
  box-shadow:0 0 0 3px rgba(0,229,255,.15);
}
.field textarea{resize:vertical;min-height:130px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:600px){.row{grid-template-columns:1fr}}
.err{color:#ff6b8a;font-size:.85rem}
.hp{position:absolute;left:-9999px;opacity:0;pointer-events:none;height:0;overflow:hidden}

.notice{padding:1.1rem 1.3rem;border-radius:var(--radius);margin-bottom:1.25rem;border:1px solid}
.notice.success{background:rgba(0,229,255,.08);border-color:var(--cyan);color:#aef0ff}
.notice.success h3{color:var(--cyan)}
.notice.error{background:rgba(255,43,214,.06);border-color:var(--magenta);color:#ffc8f3}

/* =================== FAQ =================== */
.faq-wrap{max-width:840px;margin:0 auto}
.faq{display:grid;gap:.8rem}
.faq details{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.2rem 1.5rem;backdrop-filter:blur(8px);
  transition:border-color .25s ease;
}
.faq details[open]{border-color:var(--border-hi)}
.faq summary{
  font-weight:600;font-size:1.05rem;cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;color:#fff;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:1.5rem;font-weight:300;color:var(--cyan);
  transition:transform .25s ease;text-shadow:var(--glow-cyan);
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:.9rem 0 0;color:var(--text-dim)}

/* =================== Cities =================== */
.cities{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;max-width:920px;margin:0 auto}
.cities span{
  padding:.6rem 1.2rem;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(8px);
  font-family:'JetBrains Mono';font-size:.78rem;letter-spacing:.04em;color:var(--text-dim);
  transition:all .25s ease;
}
.cities span:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}

/* =================== Device mockups (hero) =================== */
.device-desktop{
  background:#0a0d1a;border-radius:18px;
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(0,229,255,.2);
  overflow:hidden;border:1px solid var(--border);
  transform:rotate(-1.5deg) perspective(1000px) rotateY(-5deg);
}
.device-bar{display:flex;align-items:center;gap:.4rem;padding:.55rem .8rem;background:#06080f;border-bottom:1px solid var(--border);font-size:.78rem;color:var(--muted);font-family:'JetBrains Mono'}
.device-bar span{width:10px;height:10px;border-radius:50%;background:#222}
.device-bar span:nth-child(1){background:#ff5f57}.device-bar span:nth-child(2){background:#febc2e}.device-bar span:nth-child(3){background:#28c840}
.device-bar em{margin-left:.6rem;font-style:normal}
.device-screen{display:block;width:100%}
.device-screen svg{display:block;width:100%;height:auto}

.device-phone{
  position:absolute;right:-30px;bottom:-40px;width:160px;
  background:#0a0d1a;border-radius:28px;padding:8px;
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,43,214,.3);
  transform:rotate(8deg);
}
.device-phone .device-screen{border-radius:20px;overflow:hidden;background:#fff}
.phone-notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:50px;height:14px;background:#0a0d1a;border-radius:0 0 12px 12px;z-index:2}
@media (max-width:860px){.device-phone{right:0;bottom:-20px;width:130px}}

/* =================== CTA band =================== */
.cta-band{
  position:relative;padding:5rem 0;margin:5rem 0 0;
  background:linear-gradient(135deg,rgba(0,229,255,.08),rgba(255,43,214,.08),rgba(124,92,255,.08));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  z-index:2;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px circle at 50% 50%,rgba(0,229,255,.12),transparent 60%);
  pointer-events:none;
}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2.5rem;flex-wrap:wrap;position:relative}
.cta-inner h2{color:#fff;margin-bottom:.4rem;font-size:clamp(1.6rem,2.6vw,2.2rem)}
.cta-inner p{color:var(--text-dim);margin:0}
.cta-inner p a{color:var(--cyan)!important}

/* =================== Footer =================== */
.site-footer{
  background:#02030a;color:var(--text-dim);
  padding:4rem 0 1.5rem;margin-top:0;
  border-top:1px solid var(--border);
  position:relative;z-index:2;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;
  padding-bottom:2.5rem;border-bottom:1px solid var(--border);
}
.site-footer h4{
  color:#fff;font-family:'JetBrains Mono';font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  margin:0 0 1.2rem;
}
.site-footer ul{display:grid;gap:.6rem}
.site-footer a{color:var(--text-dim);font-size:.92rem}
.site-footer a:hover{color:var(--cyan)}
.footer-brand p{margin-top:1rem;max-width:30em;font-size:.92rem;color:var(--muted)}
.footer-brand .brand{color:#fff;font-family:'Space Grotesk';font-size:1.1rem}
.footer-bottom{
  display:flex;justify-content:space-between;padding-top:1.5rem;flex-wrap:wrap;gap:.5rem;
  font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.06em;color:var(--muted);
}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* =================== Custom cursor =================== */
.cursor{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  width:10px;height:10px;border-radius:50%;
  background:var(--cyan);box-shadow:var(--glow-cyan);
  transform:translate(-50%,-50%);
  transition:width .25s ease,height .25s ease,background .25s ease,box-shadow .25s ease,opacity .25s ease;
  mix-blend-mode:screen;
}
.cursor-ring{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9998;
  width:34px;height:34px;border-radius:50%;
  border:1px solid rgba(0,229,255,.5);
  transform:translate(-50%,-50%);
  transition:width .35s cubic-bezier(.4,0,.2,1),height .35s cubic-bezier(.4,0,.2,1),border-color .35s ease,opacity .35s ease;
}
body.cursor-on-link .cursor{width:6px;height:6px;background:var(--magenta);box-shadow:var(--glow-pink)}
body.cursor-on-link .cursor-ring{width:48px;height:48px;border-color:var(--magenta)}
@media (hover:none),(pointer:coarse){.cursor,.cursor-ring{display:none}}

/* =================== Click ripple =================== */
.btn{position:relative;overflow:hidden}
.ripple{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.4);
  transform:translate(-50%,-50%) scale(0);
  animation:ripple-out .65s ease-out forwards;pointer-events:none;
}
@keyframes ripple-out{to{transform:translate(-50%,-50%) scale(4);opacity:0}}

/* =================== Tilt smoothing =================== */
.card,.project,.feature,.pricing-card,.process,.about-card{
  transform-style:preserve-3d;
  will-change:transform;
}
.tilt-inner{transform:translateZ(20px)}

/* =================== Visitor chip =================== */
.visitor-chip{
  position:fixed;left:1.25rem;bottom:1.25rem;z-index:48;
  display:flex;align-items:center;gap:.6rem;
  padding:.6rem 1rem;border-radius:999px;
  background:rgba(5,6,13,.85);border:1px solid rgba(0,229,255,.35);
  backdrop-filter:blur(14px);
  font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.06em;color:var(--text-dim);
  box-shadow:0 12px 36px rgba(0,0,0,.5),0 0 0 1px rgba(0,229,255,.1) inset;
  opacity:0;transform:translateY(20px);
  transition:opacity .5s ease,transform .5s ease;
  max-width:calc(100vw - 2.5rem);
}
.visitor-chip.show{opacity:1;transform:translateY(0)}
.visitor-chip .ldot{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 12px var(--lime);animation:pulse 1.4s ease-in-out infinite;flex:none}
.visitor-chip strong{color:#fff;font-weight:500}
@media (max-width:600px){.visitor-chip{left:.75rem;bottom:.75rem;font-size:.66rem;padding:.5rem .85rem}}

/* =================== Keyboard hint =================== */
.kbd-hint{
  position:fixed;right:1.25rem;bottom:1.25rem;z-index:48;
  display:flex;align-items:center;gap:.5rem;
  padding:.5rem .9rem;border-radius:999px;
  background:rgba(5,6,13,.7);border:1px solid var(--border);
  backdrop-filter:blur(10px);
  font-family:'JetBrains Mono';font-size:.7rem;letter-spacing:.06em;color:var(--muted);
  opacity:0;animation:fade-up .8s 1.8s cubic-bezier(.4,0,.2,1) forwards;
}
.kbd-hint kbd{
  display:inline-grid;place-items:center;min-width:22px;height:22px;
  padding:0 .35rem;border-radius:5px;
  background:rgba(0,229,255,.1);border:1px solid rgba(0,229,255,.4);
  font-family:'JetBrains Mono';font-size:.7rem;color:var(--cyan);
}
@media (max-width:600px){.kbd-hint{display:none}}

/* =================== Magnetic / parallax helpers =================== */
.magnetic{transition:transform .25s cubic-bezier(.4,0,.2,1)}
.parallax{will-change:transform;transition:transform .12s linear}

/* =================== Reduced motion =================== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
