/* ============================================================
   MAVRIX MEDIA — base.css
   Design tokens, reset, typography, layout utilities,
   atmospheric background and custom cursor.
   Edit colors / fonts here in one place.
   ============================================================ */

:root{
  /* --- Surfaces --- */
  --black:#050507;
  --charcoal:#0b0b11;
  --charcoal-2:#101019;
  --charcoal-3:#16161f;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);

  /* --- Brand accents --- */
  --purple:#8b3dff;
  --purple-bright:#a855f7;
  --purple-glow:#b06bff;
  --blue:#2e7bff;
  --blue-neon:#1ec8ff;

  /* --- Text --- */
  --white:#f6f6f9;
  --grey:#a6a6b3;
  --grey-2:#6f6f7e;

  /* --- Gradients --- */
  --grad:linear-gradient(120deg,var(--purple) 0%,var(--blue) 100%);
  --grad-soft:linear-gradient(120deg,var(--purple-glow),var(--blue-neon));

  /* --- Glass --- */
  --glass:rgba(255,255,255,.045);
  --glass-2:rgba(255,255,255,.07);

  /* --- System --- */
  --maxw:1240px;
  --ease:cubic-bezier(.16,1,.3,1);
  --font-display:"Bricolage Grotesque",sans-serif;
  --font-serif:"Instrument Serif",serif;
  --font-body:"Hanken Grotesk",sans-serif;
}

/* --- Reset --- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:var(--font-body);
  background:var(--black);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
@media (hover:none){ body{cursor:auto} }
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ol,ul{list-style:none}
button{font:inherit}
::selection{background:var(--purple);color:#fff}

/* --- Typography --- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.02;letter-spacing:-.02em}
.serif{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.01em}
.gt{background:var(--grad-soft);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--grey);font-weight:600;margin-bottom:22px}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--grad)}
.sec-title{font-size:clamp(2.2rem,5vw,4.1rem);max-width:20ch}
.lead{color:var(--grey);font-size:clamp(1rem,1.4vw,1.18rem);max-width:54ch}

/* --- Layout utilities --- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{position:relative;padding:120px 0}
.head-block{margin-bottom:64px}
.head-block .lead{margin-top:18px}

/* --- Scroll reveal --- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.40s}.reveal.d6{transition-delay:.48s}

/* --- Atmospheric background --- */
.bg-fx{position:fixed;inset:0;z-index:-2;overflow:hidden;background:var(--black)}
.bg-fx canvas{position:absolute;inset:0;width:100%;height:100%}
.blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;will-change:transform}
.blob.b1{width:46vw;height:46vw;background:radial-gradient(circle,rgba(139,61,255,.9),transparent 65%);top:-12vw;left:-8vw}
.blob.b2{width:42vw;height:42vw;background:radial-gradient(circle,rgba(30,124,255,.85),transparent 65%);bottom:-14vw;right:-10vw}
.blob.b3{width:30vw;height:30vw;background:radial-gradient(circle,rgba(30,200,255,.5),transparent 65%);top:40%;left:55%}
.grid-overlay{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 30%,transparent 80%);
  mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 30%,transparent 80%);opacity:.5}
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* --- Custom cursor --- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:screen}
.cursor-dot{width:6px;height:6px;background:var(--white)}
.cursor-ring{width:42px;height:42px;border:1px solid rgba(176,107,255,.6);transition:width .25s var(--ease),height .25s var(--ease),background .25s,border-color .25s}
.cursor-ring.active{width:70px;height:70px;background:rgba(139,61,255,.12);border-color:rgba(30,200,255,.7)}
@media (hover:none){ .cursor-dot,.cursor-ring{display:none} }

/* --- Font-load gate (prevents hero font-swap reflow) --- */
.fonts-loading .hero-title .ln i{animation:none}
.fonts-loading .hero-sub,
.fonts-loading .hero-cta,
.fonts-loading .trust,
.fonts-loading .scroll-cue{animation:none;opacity:0}
