:root{
      --bg0:#15284b;
      --bg1:#213b67;
      --card: rgba(255,255,255,.12);
      --card2: rgba(255,255,255,.16);
      --stroke: rgba(255,255,255,.22);
      --text: rgba(255,255,255,.94);
      --muted: rgba(255,255,255,.76);
      --muted2: rgba(255,255,255,.62);
      --accent1:#6EE7FF;
      --accent2:#A78BFA;
      --accent3:#FF6FB1;
      --shadow: 0 18px 70px rgba(7,14,32,.36);
      --shadow2: 0 10px 40px rgba(10,18,40,.26);
      --radius: 22px;
      --radius2: 16px;
      --max: 1160px;
      --ease: cubic-bezier(.2,.9,.2,1);
    }

    *{ box-sizing:border-box; }
    html,body{ height:100%; }
    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
      color: var(--text);
      background:
        radial-gradient(1200px 800px at 20% 10%, rgba(110,231,255,.22), transparent 55%),
        radial-gradient(900px 700px at 70% 0%, rgba(167,139,250,.24), transparent 52%),
        radial-gradient(900px 900px at 60% 80%, rgba(255,111,177,.16), transparent 55%),
        linear-gradient(180deg, var(--bg0), var(--bg1) 55%, #1e345f);
      background-attachment: fixed;
      overflow-x:hidden;
    }
    .skip-link{
      position: fixed;
      left: 16px;
      top: -48px;
      z-index: 120;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(24,40,74,.94);
      border: 1px solid rgba(255,255,255,.28);
      color: rgba(255,255,255,.94);
      font-size: 12px;
      letter-spacing: .03em;
      transition: top .2s var(--ease);
    }
    .skip-link:focus-visible{
      top: 14px;
    }

    /* Subtle grain for “premium” texture */
    body::before{
      content:"";
      position:fixed; inset:0;
      pointer-events:none;
      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='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
      mix-blend-mode: overlay;
      opacity:.06;
    }

    /* Canvas particle layer */
    #fx{
      position:fixed; inset:0;
      width:100%; height:100%;
      z-index:0;
      opacity:.68;
      filter: blur(.0px);
    }

    /* Page transition overlay */
    .page-transition{
      position:fixed; inset:0;
      z-index:80;
      pointer-events:none;
      opacity:0;
      background:
        radial-gradient(800px 500px at 20% 10%, rgba(110,231,255,.18), transparent 60%),
        radial-gradient(900px 700px at 70% 0%, rgba(167,139,250,.20), transparent 55%),
        radial-gradient(900px 900px at 60% 80%, rgba(255,111,177,.14), transparent 60%),
        linear-gradient(180deg, rgba(7,10,18,.4), rgba(7,10,18,.95));
      transform: scale(1.02);
      filter: blur(0px);
      transition: opacity .85s var(--ease), transform .85s var(--ease), filter .85s var(--ease);
    }
    .page-transition.active{
      opacity:1;
      transform: scale(1);
      filter: blur(1px);
      pointer-events:auto;
    }
    .page-enter .page-transition{
      opacity:1;
      transform: scale(1);
      filter: blur(2px);
    }
    .page-enter .wrap{
      opacity:0;
      transform: translateY(12px) scale(.985);
      filter: blur(3px);
    }
    body.page-leave .wrap{
      opacity:0;
      transform: translateY(6px) scale(.995);
      filter: blur(1px);
      transition: opacity .55s var(--ease), transform .55s var(--ease), filter .55s var(--ease);
    }

    a{ color:inherit; text-decoration:none; }
    a:focus-visible{
      outline: 2px solid rgba(110,231,255,.7);
      outline-offset: 3px;
    }
    .wrap{
      position:relative;
      z-index:1;
      padding-bottom: 60px;
    }

    /* Top nav */
    .nav{
      position:sticky; top:10px;
      z-index:50;
      padding: 0 16px;
    }
    .nav-inner{
      max-width: var(--max);
      margin:0 auto;
      padding: 12px 18px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:14px;
      border-radius: 999px;
      backdrop-filter: blur(12px) saturate(1.25);
      -webkit-backdrop-filter: blur(12px) saturate(1.25);
      background: linear-gradient(90deg, rgba(32,48,84,.46), rgba(45,52,96,.42), rgba(28,40,74,.46));
      border: 1px solid rgba(255,255,255,.24);
      box-shadow: 0 12px 34px rgba(8,16,36,.22);
    }
    .brand{
      display:flex; align-items:center; gap:10px;
      min-width: 220px;
    }
    .logo{
      width:34px; height:34px;
      border-radius: 12px;
      display:block;
      object-fit: contain;
      box-shadow: 0 10px 24px rgba(0,0,0,.35);
    }
    @keyframes sheen{
      0%{ transform: translateX(-30%) rotate(20deg); opacity:0; }
      12%{ opacity:.75; }
      28%{ opacity:.25; }
      42%{ transform: translateX(30%) rotate(20deg); opacity:0; }
      100%{ opacity:0; }
    }
    .brand h1{
      margin:0;
      font-size: clamp(16px, 1.2vw, 22px);
      font-weight: 700;
      line-height: 1.04;
      letter-spacing:.06em;
      text-transform: uppercase;
      color: rgba(255,255,255,.92);
      text-shadow: 0 6px 16px rgba(110,231,255,.12);
    }
    .brand span{
      display:block;
      font-size: clamp(10px, .72vw, 13px);
      letter-spacing:.01em;
      color: rgba(255,255,255,.55);
      margin-top:2px;
    }

    .nav-links{
      display:flex; align-items:center; gap:10px;
      flex-wrap:wrap;
      justify-content:center;
    }
    .nav-links a{
      font-size: 12px;
      color: var(--muted);
      padding: 10px 12px;
      border-radius: 999px;
      transition: background .25s var(--ease), color .25s var(--ease), transform .25s var(--ease);
    }
    .nav-links a:hover{
      background: rgba(255,255,255,.07);
      color: rgba(255,255,255,.86);
      transform: translateY(-1px);
    }
    @media (max-width: 1100px){
      .nav-links{ display:none; }
    }

    .nav-cta{
      display:flex; align-items:center; gap:10px;
      min-width: 220px;
      justify-content:flex-end;
    }

    /* Birthday banner */
    .birthday-banner{
      max-width: var(--max);
      margin: 12px auto 0;
      padding: 0 18px;
      position: relative;
      z-index: 10;
      display:flex;
      justify-content:center;
      pointer-events:none;
      transition: opacity .6s var(--ease), transform .6s var(--ease);
    }
    .birthday-banner.fade{
      opacity: 0;
      transform: translateY(-8px);
    }
    .lanterns{
      display:flex;
      gap: 18px;
      align-items:flex-start;
      padding: 8px 6px 14px;
    }
    .lantern{
      width: 54px;
      display:flex;
      flex-direction:column;
      align-items:center;
      gap:8px;
      transform-origin: 50% 0%;
      animation: lanternSway 2.8s ease-in-out infinite;
    }
    .lantern:nth-child(2){ animation-delay: .35s; }
    .lantern:nth-child(3){ animation-delay: .7s; }
    .lantern:nth-child(4){ animation-delay: 1.05s; }
    .lantern::before{
      content:"";
      width:2px; height:18px;
      background: linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.12));
      box-shadow: 0 0 12px rgba(255,255,255,.15);
    }
    .lantern-core{
      width: 44px; height: 44px;
      border-radius: 999px;
      background:
        radial-gradient(12px 12px at 35% 35%, rgba(255,255,255,.75), transparent 60%),
        radial-gradient(circle at 60% 60%, rgba(255,153,0,.35), transparent 55%),
        radial-gradient(circle at 50% 50%, rgba(255,130,130,.28), rgba(140,40,0,.35));
      border: 1px solid rgba(255,255,255,.2);
      box-shadow:
        0 0 22px rgba(255,140,40,.45),
        inset 0 0 12px rgba(255,255,255,.25);
      position:relative;
      display:flex;
      align-items:center;
      justify-content:center;
      color:#fff2cf;
      font-weight:700;
      letter-spacing:.08em;
      text-shadow: 0 0 8px rgba(255,200,120,.8);
    }
    .lantern-core::after{
      content:"";
      position:absolute;
      width: 16px; height: 16px;
      border-radius: 50%;
      background: rgba(0,0,0,.28);
      box-shadow: inset 0 0 6px rgba(0,0,0,.6);
      opacity:.45;
    }
    .lantern b{
      font-size: 18px;
      z-index:1;
    }

    /* Falling cake */
    .cake-drop{
      position: absolute;
      top: -152px;
      right: 6%;
      width: 120px; height: 120px;
      pointer-events:none;
      animation: cakeFall 2.8s var(--ease) forwards;
      z-index: 12;
    }
    .cake-drop::before{
      content:"";
      position:absolute; inset:-24px;
      background:
        radial-gradient(16px 16px at 18% 22%, rgba(255,255,255,.6), transparent 60%),
        radial-gradient(14px 14px at 78% 28%, rgba(160,220,255,.55), transparent 60%),
        radial-gradient(18px 18px at 70% 78%, rgba(255,170,210,.5), transparent 60%),
        radial-gradient(10px 10px at 30% 70%, rgba(255,230,150,.5), transparent 60%);
      opacity:.7;
      animation: sparkle 2.6s ease-in-out infinite;
      pointer-events:none;
    }
    .cake-drop::after{
      content:"";
      position:absolute; left:50%; top:70px;
      width: 140px; height: 40px;
      transform: translateX(-50%);
      background: radial-gradient(70px 18px at 50% 50%, rgba(255,160,210,.35), transparent 70%);
      filter: blur(6px);
      opacity:.8;
      animation: glowPulse 2.4s ease-in-out infinite;
      pointer-events:none;
    }
    .cake-img{
      width: 120px;
      height: auto;
      display:block;
      filter: drop-shadow(0 14px 26px rgba(0,0,0,.35));
      animation: cakeFloat 2.8s ease-in-out infinite;
    }

    @keyframes cakeFall{
      0%{ transform: translateY(0) rotate(-2deg); opacity:0; }
      10%{ opacity:1; }
      100%{ transform: translateY(240px) rotate(2deg); opacity:1; }
    }
    @keyframes lanternSway{
      0%,100%{ transform: rotate(-4deg); }
      50%{ transform: rotate(4deg); }
    }
    @keyframes sparkle{
      0%,100%{ opacity:.35; transform: scale(0.98); }
      50%{ opacity:.9; transform: scale(1.03); }
    }
    @keyframes glowPulse{
      0%,100%{ opacity:.55; transform: translateX(-50%) scale(0.95); }
      50%{ opacity:1; transform: translateX(-50%) scale(1.05); }
    }
    @keyframes cakeFloat{
      0%,100%{ transform: translateY(0px); }
      50%{ transform: translateY(-6px); }
    }

    /* Buttons */
    .btn{
      border: 1px solid rgba(255,255,255,.22);
      background: rgba(255,255,255,.12);
      color: rgba(255,255,255,.94);
      padding: 10px 14px;
      border-radius: 999px;
      font-size: 12px;
      letter-spacing:.03em;
      display:inline-flex;
      align-items:center;
      gap:10px;
      box-shadow: 0 10px 30px rgba(10,18,40,.24);
      transition: transform .22s var(--ease), background .22s var(--ease), border-color .22s var(--ease);
      user-select:none;
    }
    .btn:hover{
      transform: translateY(-2px);
      border-color: rgba(255,255,255,.34);
      background: rgba(255,255,255,.2);
    }
    .nav-cta .btn-liquid:hover:not(.is-holding):not(.is-ready){
      transform: none;
    }
    .btn:active{
      transform: translateY(0px) scale(.98);
    }
    .btn:focus-visible{
      border-color: rgba(110,231,255,.6);
      box-shadow: 0 0 0 4px rgba(110,231,255,.15), 0 10px 30px rgba(0,0,0,.22);
    }

    .btn-primary{
      border: 1px solid rgba(255,255,255,.18);
      background: #7b3ff2;
      color: #ffffff;
      box-shadow: 0 18px 50px rgba(123,63,242,.25), 0 18px 70px rgba(0,0,0,.45);
    }
    .btn-primary:hover{
      background: #6a32e6;
    }

    /* Liquid long-press launch button */
    .btn-liquid{
      --hold-progress: 0;
      position: relative;
      z-index: 0;
      overflow: hidden;
      border: 0.15em solid #8f5dff;
      background: linear-gradient(180deg, #8f5dff 0%, #7a44f2 100%);
      color: #f4eeff;
      min-width: 176px;
      justify-content: center;
      font-weight: 600;
      font-size: 13px;
      letter-spacing: .04em;
      box-shadow: 0 18px 44px rgba(84, 39, 191, .35), 0 10px 30px rgba(0,0,0,.28);
      transition: transform .22s var(--ease), box-shadow .22s var(--ease), color .22s var(--ease);
      touch-action: none;
      isolation: isolate;
    }
    .btn-liquid span{
      position: relative;
      z-index: 3;
    }
    .btn-liquid .btn-hold-chip{
      position: relative;
      overflow: visible;
      font-size: 10px;
      letter-spacing: .08em;
      text-transform: uppercase;
      line-height: 1;
      padding: 4px 7px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,.44);
      background: rgba(255,255,255,.16);
      color: rgba(255,255,255,.95);
    }
    .btn-liquid .btn-hold-chip::before,
    .btn-liquid .btn-hold-chip::after{
      content:"";
      position:absolute;
      width: 9px;
      height: 9px;
      border-radius: 50%;
      pointer-events:none;
      opacity:0;
      background: radial-gradient(circle, rgba(255,255,255,.95) 0%, rgba(255,205,244,.85) 42%, rgba(255,255,255,0) 72%);
    }
    .btn-liquid .btn-hold-chip::before{
      left: -6px;
      top: 50%;
      transform: translate3d(0,-50%,0) scale(.3);
    }
    .btn-liquid .btn-hold-chip::after{
      right: -6px;
      top: 50%;
      transform: translate3d(0,-50%,0) scale(.3);
    }
    .btn-liquid::before,
    .btn-liquid::after{
      content: "";
      position: absolute;
      top: -1.5em;
      z-index: 1;
      width: 200%;
      aspect-ratio: 1;
      border-radius: 40%;
      background-color: rgba(166, 128, 255, .36);
      transition: transform .2s linear, background-color .2s linear;
      pointer-events: none;
      will-change: transform;
    }
    .btn-liquid::before{
      left: -80%;
      transform: translate3d(0, calc((1 - var(--hold-progress)) * 5em), 0) rotate(-340deg);
    }
    .btn-liquid::after{
      right: -80%;
      transform: translate3d(0, calc((1 - var(--hold-progress)) * 5em), 0) rotate(390deg);
    }
    .btn-liquid::selection,
    .btn-liquid *::selection{
      background: transparent;
    }
    .btn-liquid:hover,
    .btn-liquid:focus-visible,
    .btn-liquid.is-holding,
    .btn-liquid.is-ready{
      background: linear-gradient(180deg, #8a56ff 0%, #733de9 100%);
      color: #ffffff;
      border-color: #a173ff;
      box-shadow: 0 20px 48px rgba(84, 39, 191, .42), 0 10px 32px rgba(0,0,0,.34);
    }
    .btn-liquid.is-holding::before,
    .btn-liquid.is-holding::after,
    .btn-liquid.is-ready::before,
    .btn-liquid.is-ready::after{
      background-color: rgba(166, 128, 255, .74);
    }
    .btn-liquid.is-holding{
      animation: holdPulse 820ms ease-in-out infinite;
      transform: translateY(-2px) scale(1.035);
      background: linear-gradient(180deg, #b877ff 0%, #8d4fff 56%, #7639ee 100%);
      border-color: #cfb0ff;
      filter: brightness(1.12) saturate(1.18);
    }
    .btn-liquid.is-holding .btn-hold-chip{
      animation: holdChipGlow 620ms ease-in-out infinite;
    }
    .btn-liquid.is-holding span:nth-of-type(2){
      animation: holdTextPulse 560ms ease-in-out infinite;
      text-shadow: 0 0 10px rgba(255,255,255,.38), 0 0 24px rgba(194,142,255,.35);
    }
    .btn-liquid.is-holding .btn-hold-chip::before{
      animation: holdSparkLeft 900ms ease-out infinite;
    }
    .btn-liquid.is-holding .btn-hold-chip::after{
      animation: holdSparkRight 1020ms ease-out infinite;
    }
    .btn-liquid.is-holding span[aria-hidden="true"]{
      animation: holdArrowNudge 560ms ease-in-out infinite;
    }
    .btn-liquid.is-holding::before,
    .btn-liquid.is-holding::after{
      opacity: .98;
      filter: blur(.5px) saturate(1.3);
    }
    .btn-liquid.is-ready{
      transform: scale(.99);
    }

    @keyframes holdPulse{
      0%,100%{
        box-shadow: 0 22px 54px rgba(84, 39, 191, .5), 0 12px 36px rgba(0,0,0,.36), 0 0 0 0 rgba(173,130,255,.0);
      }
      50%{
        box-shadow: 0 28px 72px rgba(122, 69, 255, .62), 0 16px 48px rgba(0,0,0,.38), 0 0 0 9px rgba(173,130,255,.24);
      }
    }
    @keyframes holdChipGlow{
      0%,100%{
        background: rgba(255,255,255,.16);
        border-color: rgba(255,255,255,.44);
      }
      50%{
        background: rgba(255,255,255,.42);
        border-color: rgba(255,255,255,.88);
      }
    }
    @keyframes holdTextPulse{
      0%,100%{ transform: translateY(0) scale(1); }
      50%{ transform: translateY(-1px) scale(1.04); }
    }
    @keyframes holdSparkLeft{
      0%{
        opacity:0;
        transform: translate3d(0,-50%,0) scale(.2);
      }
      20%{
        opacity:.95;
      }
      100%{
        opacity:0;
        transform: translate3d(-20px,-18px,0) scale(1.2);
      }
    }
    @keyframes holdSparkRight{
      0%{
        opacity:0;
        transform: translate3d(0,-50%,0) scale(.2);
      }
      18%{
        opacity:.95;
      }
      100%{
        opacity:0;
        transform: translate3d(20px,16px,0) scale(1.2);
      }
    }
    @keyframes holdArrowNudge{
      0%,100%{ transform: translateX(0); }
      50%{ transform: translateX(5px) scale(1.08); }
    }

    @media (max-width: 520px){
      .btn-liquid{ min-width: auto; }
    }
    @media (prefers-reduced-motion: reduce){
      .btn-liquid.is-holding,
      .btn-liquid.is-holding .btn-hold-chip,
      .btn-liquid.is-holding span:nth-of-type(2),
      .btn-liquid.is-holding .btn-hold-chip::before,
      .btn-liquid.is-holding .btn-hold-chip::after,
      .btn-liquid.is-holding span[aria-hidden="true"]{
        animation: none;
      }
    }

    .dot{
      width:8px; height:8px;
      border-radius: 50%;
      background: #ff3fcf;
      box-shadow: 0 0 20px rgba(255,63,207,.72);
    }

    /* Sections */
    section{
      max-width: var(--max);
      margin:0 auto;
      padding: 58px 18px;
    }
    .hero{
      padding-top: 54px;
      display:grid;
      grid-template-columns: 1.25fr .85fr;
      gap: 22px;
      align-items:stretch;
    }
    @media (max-width: 980px){
      .hero{ grid-template-columns: 1fr; padding-top: 26px; }
      .nav-cta{ min-width:auto; }
      .brand{ min-width:auto; }
    }

    .card{
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.11));
      border: 1px solid rgba(255,255,255,.24);
      box-shadow: var(--shadow);
      overflow:hidden;
      position:relative;
      display:flex;
    }

    .card::before{
      content:"";
      position:absolute; inset:-2px;
      background:
        radial-gradient(500px 240px at var(--mx,50%) var(--my,30%), rgba(110,231,255,.15), transparent 60%),
        radial-gradient(420px 240px at calc(var(--mx,50%) + 20%) calc(var(--my,30%) + 30%), rgba(167,139,250,.14), transparent 60%),
        radial-gradient(520px 300px at calc(var(--mx,50%) - 25%) calc(var(--my,30%) + 45%), rgba(255,111,177,.10), transparent 60%);
      opacity: var(--glow, 0);
      pointer-events:none;
      transition: opacity .3s var(--ease);
    }

    .card-inner{
      position:relative;
      padding: 28px 26px;
      backdrop-filter: blur(12px);
      width:100%;
      min-height:100%;
    }
    .tilt{
      transform-style: preserve-3d;
      will-change: transform;
      transition: transform .24s var(--ease), box-shadow .24s var(--ease), filter .24s var(--ease), border-color .24s var(--ease), background .24s var(--ease);
    }
    .tilt > *{
      transform: translateZ(0);
      transform-style: preserve-3d;
      transition: transform .26s var(--ease);
    }
    .tilt.is-tilting > *{
      transform: translateZ(28px);
    }
    .card.tilt.is-tilting{
      box-shadow: 0 30px 82px rgba(6,12,28,.46), 0 14px 34px rgba(8,16,36,.34);
      filter: saturate(1.08);
    }
    .tile.tilt.is-tilting,
    .person.tilt.is-tilting{
      box-shadow: 0 24px 58px rgba(8,14,34,.34), 0 8px 24px rgba(0,0,0,.26);
      border-color: rgba(255,255,255,.42);
      background: rgba(255,255,255,.22);
    }
    .tile.tilt.is-tilting .icon{
      transform: translateZ(46px);
    }
    .person.tilt.is-tilting .person-top,
    .person.tilt.is-tilting .roles{
      transform: translateZ(34px);
    }
    .hero-main{
      cursor:pointer;
    }
    .hero-main .card-inner{
      display:flex;
      flex-direction:column;
      gap: 12px;
      padding: 28px 26px 26px;
    }
    .hero-copy{
      display:grid;
      gap: 18px;
      margin: auto 0;
    }
    .hero-eyebrow{
      margin: 0;
      font-size: 11px;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: rgba(255,255,255,.68);
    }

    .image-card .card-inner{
      padding:0;
      isolation:isolate;
      background: linear-gradient(145deg, rgba(35,68,126,.28), rgba(82,76,146,.24));
    }
    .image-card .card-inner::before{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      background:
        radial-gradient(120% 90% at 20% 18%, rgba(102,190,255,.22), transparent 58%),
        radial-gradient(100% 88% at 80% 76%, rgba(171,139,255,.24), transparent 62%),
        linear-gradient(135deg, rgba(26,58,116,.36), rgba(72,70,142,.30) 55%, rgba(32,88,136,.30));
      mix-blend-mode: soft-light;
      opacity: 1;
      transition: opacity .62s cubic-bezier(.22,.61,.36,1);
      z-index: 2;
    }
    .image-card .card-inner::after{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      background: linear-gradient(180deg, rgba(8,18,44,.08), rgba(8,18,44,.22));
      opacity: 1;
      transition: opacity .62s cubic-bezier(.22,.61,.36,1);
      z-index: 3;
    }
    .image-card img{
      width:100%;
      height:100%;
      display:block;
      object-fit:cover;
      border-radius: inherit;
      min-height: 420px;
      filter: saturate(.62) brightness(.9) contrast(1.1) hue-rotate(14deg);
      transition: filter .62s cubic-bezier(.22,.61,.36,1);
    }
    .image-card:hover .card-inner::before,
    .image-card:focus-within .card-inner::before,
    .image-card:hover .card-inner::after,
    .image-card:focus-within .card-inner::after{
      opacity: 0;
    }
    .image-card:hover img,
    .image-card:focus-within img{
      filter: none;
    }
    .hero-main .click-guide{
      position:absolute;
      right: 25px;
      top: 100px;
      background: none;
      color: #ffd84d;
      font-weight:700;
      font-size: 20px;
      letter-spacing:.18em;
      text-transform: uppercase;
      padding: 0;
      border-radius: 0;
      border: none;
      backdrop-filter: none;
      transform: rotate(35deg);
      box-shadow: none;
      text-shadow: 0 2px 10px rgba(0,0,0,.45);
      pointer-events:none;
      transform-origin: right center;
      animation: clickGuideFloat 2.4s ease-in-out infinite;
    }
    @keyframes clickGuideFloat{
      0%,100%{ transform: rotate(35deg) translate3d(0,-6px,0); }
      50%{ transform: rotate(35deg) translate3d(0,6px,0); }
    }

    /* Card modal */
    .card-modal{
      position:fixed; inset:0;
      display:flex; align-items:center; justify-content:center;
      background: rgba(20,32,58,.32);
      backdrop-filter: blur(14px);
      opacity:0;
      pointer-events:none;
      transition: opacity .55s var(--ease);
      z-index:75;
    }
    .card-modal.active{
      opacity:1;
      pointer-events:auto;
    }
    .card-modal .modal-card{
      width:min(900px, 92vw);
      max-height: 88vh;
      transform: translateY(10px) scale(.97);
      transition: transform .55s var(--ease);
      overflow:hidden;
    }
    .card-modal.active .modal-card{
      transform: translateY(0) scale(1);
    }
    .card-modal .modal-card .card-inner{
      max-height: 88vh;
      overflow:auto;
      opacity:0;
      transform: translateY(6px);
      transition: opacity .45s var(--ease), transform .45s var(--ease);
    }
    .card-modal.active .modal-card .card-inner{
      opacity:1;
      transform: translateY(0);
    }
    body.modal-open{
      overflow:hidden;
    }

    .hero h2{
      margin: 0;
      font-size: 56px;
      line-height: 1.01;
      letter-spacing: -0.03em;
      max-width: none;
    }
    @media (max-width: 520px){
      .hero h2{ font-size: 40px; }
    }

    .lead{
      color: rgba(255,255,255,.82);
      font-size: 15px;
      line-height: 1.72;
      margin: 0;
      max-width: 60ch;
    }
    .lead-sub{
      color: rgba(255,255,255,.68);
      max-width: 62ch;
    }
    .hero-actions{
      display:flex;
      gap: 12px;
      flex-wrap: wrap;
      margin-top: 8px;
      align-items:center;
    }
    .hero-main .hero-actions{
      margin-top: 0;
      padding-top: 0;
    }
    #play .card-inner{
      padding-bottom: 26px;
    }
    #play .hero-actions{
      margin-top: 30px;
    }
    @media (max-width: 760px){
      #play .hero-actions{
        margin-top: 24px;
      }
    }
    #play .play-url-reveal{
      max-height: 0;
      opacity: 0;
      transform: translateY(-10px);
      margin-top: 0;
      overflow: hidden;
      pointer-events: none;
      will-change: max-height, opacity, transform, margin-top;
      transition:
        max-height .34s cubic-bezier(.4,0,.2,1),
        opacity .22s ease-in,
        transform .24s cubic-bezier(.4,0,.2,1),
        margin-top .24s cubic-bezier(.4,0,.2,1);
    }
    #play .play-url-tile{
      min-height: 0;
      overflow: hidden;
      background: rgba(255,255,255,.08);
      border-color: rgba(255,255,255,.2);
      box-shadow: none;
      transform: none;
      transition: border-color .25s var(--ease), background .25s var(--ease);
    }
    #play .play-url-tile:hover{
      transform: none;
      background: rgba(255,255,255,.08);
      border-color: rgba(255,255,255,.2);
    }
    #play .play-card:hover .play-url-reveal,
    #play .play-card:focus-within .play-url-reveal{
      transition:
        max-height .72s cubic-bezier(.22,.61,.36,1),
        opacity .46s ease-out .04s,
        transform .62s cubic-bezier(.2,.85,.2,1),
        margin-top .62s cubic-bezier(.22,.61,.36,1);
      max-height: 160px;
      opacity: 1;
      transform: translateY(0);
      margin-top: 16px;
      pointer-events: auto;
    }
    @media (hover: none){
      #play .play-url-reveal{
        max-height: 160px;
        opacity: 1;
        transform: none;
        margin-top: 16px;
        pointer-events: auto;
      }
    }

    .play-right-actions{
      margin-left: auto;
      display:flex;
      gap: 12px;
      align-items:center;
      flex-wrap: wrap;
      justify-content: flex-end;
    }
    .play-right-actions .mini{
      margin-top: 0;
      margin-left: 2px;
    }
    @media (max-width: 760px){
      .play-right-actions{
        margin-left: 0;
        width: 100%;
        justify-content: flex-start;
      }
    }

    .mini{
      font-size: 12px;
      color: var(--muted2);
      margin-top: 10px;
    }

    /* Side panel */
    .panel{
      height:100%;
      display:flex;
      flex-direction:column;
      justify-content:flex-start;
      gap: 16px;
    }

    .stat-grid{
      display:grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 14px;
      margin-top: 10px;
    }
    .stat.wide{
      grid-column: 1 / -1;
    }
    .stat{
      padding: 14px 14px;
      border-radius: 16px;
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.22);
      box-shadow: var(--shadow2);
      position:relative;
      overflow:hidden;
    }
    .stat b{
      display:block;
      font-size: 18px;
      letter-spacing:-0.01em;
      margin-bottom: 6px;
      color: rgba(255,255,255,.88);
    }
    .stat span{
      display:block;
      font-size: 12px;
      color: var(--muted2);
      line-height:1.35;
    }
    .stat::after{
      content:none;
    }

    /* Headings */
    .kicker{
      display:flex;
      align-items:center;
      gap:10px;
      color: rgba(255,255,255,.78);
      letter-spacing:.18em;
      font-size: 11px;
      text-transform: uppercase;
      margin:0 0 14px;
    }

    .section-title{
      margin:0 0 10px;
      font-size: 28px;
      letter-spacing:-0.02em;
    }

    .section-desc{
      margin:0 0 22px;
      color: var(--muted);
      line-height:1.7;
      max-width: 78ch;
      font-size: 14px;
    }

    /* Feature cards */
    .grid{
      display:grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 14px;
    }
    #features .feature-carousel{
      --feature-gap: 14px;
      margin-top: 16px;
      overflow: hidden;
      width: 100%;
      background: transparent;
    }
    #features .feature-track{
      display:flex;
      gap: var(--feature-gap);
      width:max-content;
      will-change: transform;
      animation: featureMarquee 14s linear infinite;
      background: transparent;
    }
    #features .feature-set{
      display:flex;
      gap: var(--feature-gap);
      background: transparent;
    }
    #features .feature-set .tile{
      flex: 0 0 clamp(280px, 31vw, 380px);
      box-shadow: none;
      transition: border-color .26s var(--ease), background .26s var(--ease), filter .26s var(--ease);
    }
    #features .feature-set .tile:hover,
    #features .feature-set .tile:focus-within{
      transform: none;
      border-color: rgba(255,255,255,.34);
      background: rgba(255,255,255,.19);
      filter: saturate(1.08) brightness(1.04);
    }
    #features .feature-set .tile.tilt.is-tilting{
      transform: none !important;
      box-shadow: none;
      filter: saturate(1.08) brightness(1.04);
    }
    #features .feature-set .tile.tilt.is-tilting .icon{
      transform: none;
    }
    @keyframes featureMarquee{
      from{ transform: translate3d(0,0,0); }
      to{ transform: translate3d(calc(-50% - (var(--feature-gap) / 2)),0,0); }
    }
    @media (max-width: 980px){
      .grid{ grid-template-columns: 1fr; }
      .stat-grid{ grid-template-columns: 1fr; }
      #features .feature-track{
        animation-duration: 12s;
      }
      #features .feature-set .tile{
        flex-basis: min(84vw, 420px);
      }
    }

    .tile{
      padding: 18px 18px;
      border-radius: var(--radius2);
      border: 1px solid rgba(255,255,255,.22);
      background: rgba(255,255,255,.12);
      box-shadow: var(--shadow2);
      transition: transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
      position:relative;
      overflow:hidden;
      min-height: 120px;
    }
    .tile:hover{
      transform: translateY(-4px);
      border-color: rgba(255,255,255,.32);
      background: rgba(255,255,255,.2);
    }
    .tile h4{
      margin:0 0 8px;
      font-size: 14px;
      letter-spacing:.01em;
      color: rgba(255,255,255,.88);
    }
    .tile p{
      margin:0;
      color: var(--muted2);
      font-size: 13px;
      line-height:1.6;
    }
    .icon{
      width: 34px; height: 34px;
      border-radius: 14px;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      margin-bottom: 12px;
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.22);
      box-shadow: 0 10px 22px rgba(0,0,0,.25);
      position:relative;
      overflow:hidden;
    }
    .icon::before{
      content:"";
      position:absolute; inset:-60%;
      background: radial-gradient(circle at 30% 30%, rgba(110,231,255,.22), transparent 58%),
                  radial-gradient(circle at 60% 60%, rgba(167,139,250,.18), transparent 62%);
      pointer-events:none;
    }
    .icon svg{ position:relative; opacity:.9; }

    /* Team */
    #team .team-carousel{
      --team-card-w: clamp(230px, 24vw, 320px);
      --team-card-h: clamp(126px, 13vw, 158px);
      --team-radius: clamp(190px, 24vw, 280px);
      margin-top: 16px;
      position: relative;
      overflow: hidden;
      width: 100%;
      height: clamp(178px, 22vw, 236px);
      background: transparent;
      perspective: 1200px;
      transform-origin: center;
    }
    #team .team-track{
      position: absolute;
      left: 50%;
      top: 50%;
      width: var(--team-card-w);
      height: var(--team-card-h);
      transform-style: preserve-3d;
      transform: translate3d(-50%, -50%, calc(var(--team-radius) * -1)) rotateY(0deg);
      will-change: transform;
      animation: teamSpin 9.5s infinite linear;
    }
    #team .team-track .person{
      position: absolute;
      inset: 0;
      width: var(--team-card-w);
      height: var(--team-card-h);
      min-height: 0;
      padding: 14px 16px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      text-align: center;
      gap: 10px;
      box-shadow: none;
      backface-visibility: hidden;
    }
    #team .team-track .person:nth-child(1){
      --team-face-transform: rotateY(0deg) translateZ(var(--team-radius));
      transform: var(--team-face-transform);
    }
    #team .team-track .person:nth-child(2){
      --team-face-transform: rotateY(72deg) translateZ(var(--team-radius));
      transform: var(--team-face-transform);
    }
    #team .team-track .person:nth-child(3){
      --team-face-transform: rotateY(144deg) translateZ(var(--team-radius));
      transform: var(--team-face-transform);
    }
    #team .team-track .person:nth-child(4){
      --team-face-transform: rotateY(216deg) translateZ(var(--team-radius));
      transform: var(--team-face-transform);
    }
    #team .team-track .person:nth-child(5){
      --team-face-transform: rotateY(288deg) translateZ(var(--team-radius));
      transform: var(--team-face-transform);
    }
    @keyframes teamSpin{
      0%{
        transform: translate3d(-50%, -50%, calc(var(--team-radius) * -1)) rotateY(0deg);
      }
      100%{
        transform: translate3d(-50%, -50%, calc(var(--team-radius) * -1)) rotateY(-360deg);
      }
    }
    @media (max-width: 980px){
      #team .team-track{
        animation-duration: 8.5s;
      }
      #team .team-carousel{
        --team-card-w: min(72vw, 320px);
        --team-card-h: clamp(116px, 28vw, 146px);
        --team-radius: clamp(160px, 42vw, 230px);
        height: clamp(170px, 42vw, 220px);
      }
    }

    .person{
      padding: 18px 18px;
      border-radius: var(--radius2);
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.22);
      box-shadow: var(--shadow2);
      transition: transform .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease);
      position:relative;
      overflow:hidden;
    }
    .person:hover{
      transform: translateY(-4px);
      border-color: rgba(255,255,255,.32);
      background: rgba(255,255,255,.2);
    }
    #team .team-track .person:hover,
    #team .team-track .person:focus-within{
      transform: var(--team-face-transform);
      border-color: rgba(255,255,255,.32);
      background: rgba(255,255,255,.2);
      filter: saturate(1.08) brightness(1.04);
    }
    #team .team-track .person.tilt.is-tilting{
      transform: var(--team-face-transform) !important;
      box-shadow: none;
      filter: saturate(1.08) brightness(1.04);
    }
    #team .team-track .person.tilt.is-tilting .person-top,
    #team .team-track .person.tilt.is-tilting .roles{
      transform: none;
    }

    .avatar{
      width: 44px; height:44px;
      border-radius: 16px;
      border: 1px solid rgba(255,255,255,.14);
      background:
        radial-gradient(16px 16px at 30% 30%, rgba(255,255,255,.26), transparent 58%),
        linear-gradient(135deg, rgba(110,231,255,.45), rgba(167,139,250,.42), rgba(255,111,177,.35));
      box-shadow: 0 12px 28px rgba(0,0,0,.35);
      flex:0 0 auto;
    }

    .person-top{
      display:flex;
      gap: 12px;
      align-items:center;
      margin-bottom: 12px;
    }
    .person h4{
      margin:0;
      font-size: 15px;
      letter-spacing:.01em;
      color: rgba(255,255,255,.9);
    }
    #team .team-track .person h4{
      font-size: clamp(22px, 2vw, 30px);
      line-height: 1.05;
      letter-spacing: .01em;
    }
    #team .team-track .person-top{
      margin-bottom: 0;
      justify-content: center;
    }
    #team .team-track .person-top > div{
      width: 100%;
    }
    #team .team-track .roles{
      margin-top: 0;
      justify-content: center;
    }
    .person small{
      display:block;
      margin-top: 4px;
      color: var(--muted2);
      font-size: 12px;
      letter-spacing:.01em;
    }
    .roles{
      display:flex;
      flex-wrap:wrap;
      gap: 8px;
      margin-top: 10px;
    }
    .tag{
      font-size: 11px;
      color: rgba(255,255,255,.84);
      border: 1px solid rgba(255,255,255,.24);
      background: rgba(255,255,255,.12);
      padding: 7px 10px;
      border-radius: 999px;
    }

    /* Fixed footer pill */
    .footer-pill{
      position: fixed;
      left: 50%;
      bottom: 16px;
      transform: translateX(-50%);
      overflow: hidden;
      padding: 10px 16px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,.18);
      background: rgba(24,36,66,.42);
      color: var(--muted2);
      font-size: 12px;
      letter-spacing: .02em;
      text-align: center;
      backdrop-filter: blur(12px);
      box-shadow: 0 10px 30px rgba(0,0,0,.35);
      z-index: 60;
      max-width: calc(100% - 32px);
      white-space: nowrap;
      transition: box-shadow .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease), padding .4s var(--ease), background .4s var(--ease), color .24s var(--ease);
    }
    .footer-pill::after{
      content: "I LOVE TEAM SUNRISE";
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, calc(-50% + 8px)) scale(.96);
      opacity: 0;
      color: rgba(255,255,255,.95);
      font-weight: 700;
      font-size: 16px;
      letter-spacing: .14em;
      pointer-events: none;
      transition: opacity .34s var(--ease), transform .42s var(--ease);
    }
    .footer-pill:hover{
      transform: translateX(-50%) translateY(-2px);
      padding: 16px 82px;
      border-color: rgba(255,255,255,.36);
      background: linear-gradient(180deg, rgba(126,94,255,.18), rgba(96,66,220,.22));
      box-shadow: 0 16px 44px rgba(44,26,116,.48);
      color: transparent;
    }
    .footer-pill:hover::after{
      opacity: 1;
      transform: translate(-50%, -50%) scale(1);
    }
    @media (max-width: 520px){
      .footer-pill{ font-size: 11px; padding: 9px 12px; }
      .footer-pill:hover{ padding: 13px 52px; }
      .footer-pill::after{
        font-size: 14px;
        letter-spacing: .11em;
      }
    }

    /* Scroll reveal */
    .reveal{
      opacity:0;
      transform: translateY(12px);
      filter: blur(6px);
      transition: opacity .8s var(--ease), transform .8s var(--ease), filter .8s var(--ease);
    }
    .reveal.in{
      opacity:1;
      transform: translateY(0);
      filter: blur(0);
    }

    /* Reduced motion */
    @media (prefers-reduced-motion: reduce){
      *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
      #fx{ display:none; }
      .meteors{ display:none; }
      .page-transition{ display:none; }
      #features .feature-set[aria-hidden="true"]{ display:none; }
      #team .team-carousel{
        perspective: 1200px;
        overflow: hidden;
      }
      #team .team-track{
        position: absolute;
        left: 50%;
        top: 50%;
        width: var(--team-card-w);
        height: var(--team-card-h);
        display: block;
        transform-style: preserve-3d;
        transform: translate3d(-50%, -50%, calc(var(--team-radius) * -1)) rotateY(0deg) !important;
        animation: teamSpin 9.5s infinite linear !important;
      }
      #team .team-track .person{
        position: absolute;
        inset: 0;
        width: var(--team-card-w);
        height: var(--team-card-h);
        min-height: 0;
        transform: var(--team-face-transform) !important;
      }
    }
