 *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

  :root{
    --bg:#f0f0ed;
    --fg:#1a1a2e;
    --blue:#3B4286;
    --red:#EE5340;
    --orange:#EE5340;
    --muted:rgba(43,58,142,.08);
    --edge:1.6rem;
    --top-h:calc(var(--edge) + 45px);
    --bot-h:calc(var(--edge) + 70px);
  }

  body{
    background:var(--bg);
    color:var(--fg);
    font-family:'Space Mono',monospace;
    min-height:100vh;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    padding-top:var(--top-h);
    padding-bottom:var(--bot-h);
    position:relative;
  }

  /* — subtle grain — */
  body::before{
    content:'';
    position:fixed;inset:0;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
    background-size:128px;
    pointer-events:none;
    z-index:100;
  }
  
  h1 {
    position:fixed;
    color:#f0f0ed;
  }

  /* — ambient glow blobs — */
  .glow{
    position:fixed;
    border-radius:50%;
    filter:blur(130px);
    opacity:.12;
    pointer-events:none;
    animation:drift 18s ease-in-out infinite alternate;
  }
  .glow--1{
    width:45vw;height:45vw;
    background:radial-gradient(circle,var(--blue),transparent 70%);
    top:-10%;left:-8%;
    animation-delay:-3s;
  }
  .glow--2{
    width:35vw;height:35vw;
    background:radial-gradient(circle,var(--red),transparent 70%);
    bottom:-12%;right:-5%;
    animation-delay:-9s;
    animation-duration:22s;
  }
  .glow--3{
    width:22vw;height:22vw;
    background:radial-gradient(circle,var(--blue),transparent 70%);
    top:55%;left:60%;
    transform:translate(-50%,-50%);
    animation-delay:-14s;
    animation-duration:25s;
    opacity:.07;
  }

  @keyframes drift{
    0%{transform:translate(0,0) scale(1)}
    33%{transform:translate(3vw,-2vw) scale(1.08)}
    66%{transform:translate(-2vw,4vw) scale(.94)}
    100%{transform:translate(1vw,-3vw) scale(1.03)}
  }

  /* — logo fixed top center — */
  .logo{
    position:fixed;
    top:var(--edge);
    left:50%;
    transform:translateX(-50%);
    width:clamp(32px,4vw,48px);
    z-index:20;
    opacity:0;
    animation:fadeScaleIn .8s cubic-bezier(.22,1,.36,1) .05s forwards;
  }
  .logo svg{
    width:100%;
    height:auto;
    fill:var(--orange);
  }

  @keyframes fadeScaleIn{
    0%{opacity:0;transform:translateX(-50%) scale(.85)}
    100%{opacity:1;transform:translateX(-50%) scale(1)}
  }

  /* — main content — */
  .stage{
    text-align:center;
    position:relative;
    z-index:10;
    padding:2rem;
  }

  /* — headline — */
  .headline{
    font-family:'Instrument Serif',serif;
    font-weight:400;
    font-size:clamp(3rem,10vw,9rem);
    line-height:1.05;
    letter-spacing:-.03em;
    position:relative;
  }

  .headline .word{
    display:inline-block;
    overflow:hidden;
    vertical-align:bottom;
  }

  .headline .word span{
    display:inline-block;
    transform:translateY(115%);
    animation:revealWord 1s cubic-bezier(.22,1,.36,1) forwards;
  }

  .headline .word:nth-child(1) span{animation-delay:.15s}
  .headline .word:nth-child(2) span{animation-delay:.3s}
  .headline .word:nth-child(3) span{animation-delay:.45s}

  .headline .dot{
    display:inline-block;
    color:var(--orange);
    transform:scale(0);
    animation:popDot .5s cubic-bezier(.34,1.56,.64,1) .95s forwards;
  }

  .headline em{
    font-style:italic;
    background:linear-gradient(135deg,var(--orange),var(--red));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
  }

  @keyframes revealWord{to{transform:translateY(0)}}
  @keyframes popDot{to{transform:scale(1)}}

  /* — subtitle — */
  .sub{
    margin-top:2.5rem;
    font-size:.75rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--blue);
    opacity:0;
    transform:translateY(14px);
    animation:fadeSlideUp .8s cubic-bezier(.22,1,.36,1) 1.2s forwards;
  }
  .sub .bar{
    display:inline-block;
    width:2.5rem;height:1px;
    background:var(--blue);opacity:.3;
    vertical-align:middle;margin:0 1rem;
  }

  /* — bottom bar — */
  .bottom{
    position:fixed;
    bottom:0;left:0;right:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    padding-bottom:var(--edge);
    z-index:20;
    opacity:0;
    transform:translateY(10px);
    animation:fadeSlideUp .7s cubic-bezier(.22,1,.36,1) 1.6s forwards;
  }

  .social{
    display:flex;
    gap:1rem;
    margin-bottom:.75rem;
  }

  .sbtn{
    display:flex;
    align-items:center;
    justify-content:center;
    width:38px;height:38px;
    border-radius:50%;
    border:1px solid rgba(43,58,142,.15);
    background:transparent;
    color:var(--fg);
    text-decoration:none;
    transition:all .3s cubic-bezier(.22,1,.36,1);
  }
  .sbtn:hover{
    border-color:var(--orange);
    color:var(--orange);
    transform:translateY(-2px);
    box-shadow:0 4px 16px rgba(232,99,42,.12);
  }
  .sbtn svg{
    width:15px;height:15px;
    fill:currentColor;
  }

  .copyright{
    font-size:.6rem;
    letter-spacing:.15em;
    text-transform:uppercase;
    color:rgba(26,26,46,.35);
  }

  .sr{
    position:absolute;
    width:1px;height:1px;
    padding:0;margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
  }

  /* — drips — */
  .drips{position:fixed;inset:0;pointer-events:none;z-index:5}
  .drip{
    position:absolute;top:-6%;width:2px;
    border-radius:0 0 2px 2px;opacity:0;
    animation:fall var(--dur) var(--delay) ease-in infinite;
  }
  .drip--red{background:linear-gradient(to bottom,transparent,var(--red))}
  .drip--blue{background:linear-gradient(to bottom,transparent,var(--blue))}

  @keyframes fall{
    0%{opacity:0;height:0;top:-2%}
    10%{opacity:.45}
    70%{opacity:.18}
    100%{opacity:0;height:30vh;top:108%}
  }

  @keyframes fadeSlideUp{to{opacity:1;transform:translateY(0)}}

  @media(max-width:600px){
    :root{
      --edge:1.2rem;
      --top-h:calc(var(--edge) + 38px);
      --bot-h:calc(var(--edge) + 60px);
    }
    .headline{font-size:clamp(2.4rem,12vw,4.5rem)}
    .logo{width:28px}
    .sub{font-size:.6rem}
    .sbtn{width:34px;height:34px}
    .sbtn svg{width:13px;height:13px}
    .social{gap:.6rem}
    .copyright{font-size:.5rem}
  }