/* ===========================================================
   Mind Your Biz — v2 (radical upgrade)
   =========================================================== */

/* ---------- Tokens ---------- */
:root{
  /* brand */
  --blue-900:#001129;
  --blue-800:#001f4d;
  --blue-700:#003ab5;
  --blue-600:#0d4ff8;
  --blue-500:#1d6dff;
  --blue-300:#7ca9ff;
  --blue-100:#cfdcff;

  /* tool accents */
  --c-games:#025df7;
  --c-visit:#025df7;
  --c-knowledge:#025df7;
  --c-info:#025df7;

  /* neutrals */
  --cream:#f4ede0;
  --cream-2:#ece3d2;
  --ink:#0a0f1f;
  --white:#fff;

  /* alphas on dark */
  --w-90:rgba(255,255,255,.9);
  --w-72:rgba(255,255,255,.72);
  --w-55:rgba(255,255,255,.55);
  --w-30:rgba(255,255,255,.3);
  --w-14:rgba(255,255,255,.14);
  --w-08:rgba(255,255,255,.08);
  --w-04:rgba(255,255,255,.04);

  /* alphas on cream */
  --k-90:rgba(10,15,31,.9);
  --k-70:rgba(10,15,31,.7);
  --k-50:rgba(10,15,31,.5);
  --k-15:rgba(10,15,31,.15);
  --k-08:rgba(10,15,31,.08);

  /* layout */
  --r-sm:10px;
  --r-md:16px;
  --r-lg:22px;
  --r-xl:30px;
  --r-2xl:42px;
  --max:1280px;
  --pad:clamp(20px,4vw,44px);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --section-pad:clamp(80px,12vw,160px);

  /* fonts */
  --f-sans:'Bricolage Grotesque','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-serif:'Instrument Serif',Georgia,serif;
  --f-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

/* ---------- Reset ---------- */
.grecaptcha-badge { visibility: hidden !important; }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-sans);
  font-feature-settings:"ss02","cv11";
  background:var(--blue-900);
  color:var(--white);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit}
h1,h2,h3,h4{font-weight:700;line-height:1.02;letter-spacing:-.025em}
::selection{background:var(--c-games);color:#fff}
:focus-visible{outline:2px solid #fff;outline-offset:3px;border-radius:6px}

.container{
  width:100%;max-width:var(--max);
  margin:0 auto;
  padding-left:var(--pad);padding-right:var(--pad);
}

.serif-italic{font-family:var(--f-serif);font-style:italic;font-weight:400;letter-spacing:-.02em}

/* tiny eyebrow label */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--w-72);
}
.eyebrow::before{content:"";display:block;width:24px;height:1px;background:currentColor;opacity:.6}

/* ===========================================================
   Nav
   =========================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(0,17,41,.4);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,.05);
  transition:background .25s var(--ease),border-color .25s;
}
.nav.scrolled{background:rgba(0,17,41,.92);border-bottom-color:rgba(255,255,255,.08)}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  padding:14px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand .logo-mark{width:40px;height:auto;color:#fff;flex-shrink:0}
.brand{flex-shrink:0}
.brand .wordmark{font-size:17px;font-weight:600;letter-spacing:-.015em;white-space:nowrap}
.brand .wordmark em{font-family:var(--f-serif);font-style:italic;font-weight:400;margin:0 1px}

.nav-links{display:flex;gap:6px;font-size:14.5px;font-weight:500}
.nav-links a{
  color:var(--w-72);
  padding:8px 12px;border-radius:999px;
  transition:color .2s,background .2s;
}
.nav-links a:hover{color:#fff;background:var(--w-08)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--blue-700);
  font-weight:600;font-size:14px;
  padding:11px 18px 11px 20px;border-radius:999px;
  transition:transform .25s var(--ease),box-shadow .25s,background .25s,color .25s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(13,109,255,.35)}
.nav-cta::after{content:"";font-family:var(--f-serif);font-style:italic;font-size:18px;line-height:0;transform:translateY(1px)}

.burger{
  display:none;width:42px;height:42px;border-radius:12px;
  background:var(--w-08);
  flex-direction:column;align-items:center;justify-content:center;gap:4px;
  transition:background .2s;
}
.burger:hover{background:var(--w-14)}
.burger span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.mobile-menu{
  display:none;
  background:rgba(0,17,41,.98);
  border-top:1px solid var(--w-08);
  flex-direction:column;
  padding:16px var(--pad) 24px;gap:4px;
}
.mobile-menu.is-open{display:flex;animation:menuIn .22s var(--ease)}
@keyframes menuIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.mobile-menu a{padding:14px 8px;font-size:16px;font-weight:500;border-bottom:1px solid var(--w-08)}
.mobile-menu a:last-of-type{border-bottom:none}
.mobile-menu .m-cta{
  margin-top:12px;background:#fff;color:var(--blue-700);
  border-radius:999px;padding:14px;text-align:center;font-weight:700;border:none;
}
@media (max-width:920px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
}
@media (min-width:921px){
  .mobile-menu,.mobile-menu.is-open{display:none}
}
body.menu-open{overflow:hidden}

/* ===========================================================
   Hero
   =========================================================== */
.hero{
  position:relative;
  min-height:100vh;
  padding:clamp(110px,16vh,160px) var(--pad) 0;
  overflow:hidden;
  background:
    radial-gradient(ellipse 80% 50% at 80% 20%, rgba(124,169,255,.28), transparent 65%),
    radial-gradient(ellipse 60% 40% at 10% 90%, rgba(13,109,255,.32), transparent 65%),
    linear-gradient(180deg, var(--blue-900) 0%, var(--blue-800) 60%, var(--blue-700) 100%);
}
.hero-grid{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:center;
  min-height:calc(100vh - 200px);
}
.hero-left{display:flex;flex-direction:column;gap:32px}
.hero-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-meta .dot{width:8px;height:8px;border-radius:50%;background:var(--c-visit);box-shadow:0 0 0 6px rgba(255,107,71,.22);animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 6px rgba(255,107,71,.22)}50%{box-shadow:0 0 0 12px rgba(255,107,71,0)}}
.hero-meta .meta-text{font-size:13px;color:var(--w-72);letter-spacing:.06em;text-transform:uppercase;font-weight:500}

.hero h1{
  font-size:clamp(46px,8.4vw,124px);
  font-weight:700;
  letter-spacing:-.04em;
  line-height:.94;
}
.hero h1 .serif{
  font-family:var(--f-serif);
  font-weight:400;
  font-style:italic;
  letter-spacing:-.025em;
  color:var(--blue-100);
}
.hero h1 .marker{
  display:inline-block;
  position:relative;
  padding:0 4px;
}
.hero h1 .marker::before{
  content:"";position:absolute;inset:auto -8px -4px -8px;height:.45em;
  background:var(--c-games);
  z-index:-1;
  transform:skewX(-6deg);
  border-radius:4px;
}

.hero-sub{
  font-size:clamp(16px,1.4vw,19px);
  color:var(--w-72);
  max-width:46ch;
  line-height:1.55;
}
.hero-sub strong{font-weight:600;color:var(--w-90)}

.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;color:var(--blue-700);
  font-weight:600;font-size:15px;
  padding:15px 24px;border-radius:999px;
  transition:transform .25s var(--ease),box-shadow .25s;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(255,255,255,.2)}
.btn-primary .arrow{font-family:var(--f-serif);font-style:italic;font-size:20px;line-height:0;transform:translateY(2px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  color:#fff;font-weight:500;font-size:15px;
  padding:15px 22px;border-radius:999px;
  background:var(--w-08);
  border:1px solid var(--w-14);
  transition:background .2s,border-color .2s;
}
.btn-ghost:hover{background:var(--w-14);border-color:var(--w-30)}

/* hero right: animated logo collage */
.hero-right{
  position:relative;
  aspect-ratio:1/1;
  max-width:560px;
  width:100%;
  justify-self:end;
}
.collage{position:absolute;inset:0}
.collage .tile{
  position:absolute;
  border-radius:32px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 30px 60px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.15);
  transition:transform .6s var(--ease);
}
.collage .tile img{width:auto;height:50%;color:#fff}
.collage .t-games{top:0;left:0;width:46%;height:46%;background:var(--c-games);animation:floatA 9s ease-in-out infinite}
.collage .t-visit{top:8%;right:0;width:38%;height:38%;background:#0a2a6b;animation:floatB 11s ease-in-out infinite;animation-delay:-2s}
.collage .t-knowledge{bottom:0;left:14%;width:42%;height:42%;background:#0a2a6b;color:var(--c-knowledge);animation:floatC 10s ease-in-out infinite;animation-delay:-4s}
.collage .t-knowledge svg{color:var(--c-knowledge)}
.collage .t-info{bottom:6%;right:6%;width:40%;height:40%;background:var(--c-games);color:var(--blue-700);animation:floatA 12s ease-in-out infinite;animation-delay:-6s}
.collage .t-info svg{color:var(--blue-700)}
.collage .badge{
  position:absolute;
  background:#fff;color:var(--ink);
  padding:10px 16px;border-radius:14px;
  font-size:12px;font-weight:600;letter-spacing:-.01em;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
  display:flex;align-items:baseline;gap:10px;
  animation:floatB 8s ease-in-out infinite;animation-delay:-1s;
  white-space:nowrap;
}
.collage .badge .b-num{font-family:var(--f-serif);font-style:italic;font-size:20px;line-height:1;color:var(--c-visit);padding-right:2px}
.collage .b-top{top:46%;left:38%;transform:translate(-50%,-50%) rotate(-4deg)}
.collage .b-bot{bottom:-6%;left:30%;transform:rotate(2deg);background:var(--ink);color:#fff;animation-delay:-3s}
.collage .b-bot .b-num{color:var(--c-games)}

@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(-8px,-14px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(10px,-12px)}}
@keyframes floatC{0%,100%{transform:translate(0,0)}50%{transform:translate(-6px,10px)}}

@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:48px;min-height:auto}
  .hero{padding-bottom:60px}
  .hero-right{max-width:420px;justify-self:start;margin-top:8px}
  .hero h1{font-size:clamp(44px,12vw,82px)}
}

/* ===========================================================
   Marquee
   =========================================================== */
.marquee{
  position:relative;z-index:3;
  background:rgba(0,0,0,.35);
  border-block:1px solid var(--w-08);
  padding:18px 0;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee-track{
  display:flex;gap:64px;
  animation:scroll 38s linear infinite;
  width:max-content;
  align-items:center;
}
.marquee-track span{
  display:inline-flex;align-items:center;gap:18px;
  font-size:clamp(20px,3vw,32px);
  font-weight:500;
  color:var(--w-72);
  letter-spacing:-.02em;
  white-space:nowrap;
}
.marquee-track .num{font-family:var(--f-serif);font-style:italic;color:#fff;font-weight:400}
.marquee-track .dot{width:6px;height:6px;border-radius:50%;background:var(--c-visit)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===========================================================
   Manifesto strip
   =========================================================== */
.manifesto{
  padding:clamp(80px,12vw,140px) 0 clamp(40px,6vw,60px);
}
.manifesto p{
  font-size:clamp(28px,4.4vw,56px);
  line-height:1.05;
  letter-spacing:-.03em;
  font-weight:600;
  max-width:18ch;
}
.manifesto p .serif-italic{color:var(--w-55);font-weight:400}
.manifesto p .underline{
  position:relative;display:inline-block;
}
.manifesto p .underline::after{
  content:"";position:absolute;left:0;right:0;bottom:.05em;height:4px;
  background:var(--c-visit);
  border-radius:2px;
}

/* ===========================================================
   Section heads (shared)
   =========================================================== */
.section{padding:var(--section-pad) 0;position:relative}
.section-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:end;
  margin-bottom:64px;
}
.section-head h2{
  font-size:clamp(36px,5.4vw,76px);
  font-weight:600;
  letter-spacing:-.035em;
  line-height:1;
  max-width:18ch;
}
.section-head h2 .serif-italic{font-weight:400}
.section-head .meta{
  color:var(--w-72);
  font-size:16px;line-height:1.55;
  max-width:42ch;
}
@media (max-width:880px){
  .section-head{grid-template-columns:1fr;gap:20px}
}

/* ===========================================================
   Tool cards (4 differentiators)
   =========================================================== */
.tools{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:18px;
}
.tool-card{
  position:relative;
  grid-column:span 6;
  background:var(--w-04);
  border:1px solid var(--w-14);
  border-radius:var(--r-2xl);
  padding:clamp(28px,3vw,42px);
  min-height:380px;
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:transform .5s var(--ease),background .35s,border-color .35s;
}
.tool-card:hover{transform:translateY(-6px);background:var(--w-08);border-color:var(--w-30)}
.tool-card .tc-art{
  position:absolute;
  top:16px;right:16px;
  width:220px;
  height:220px;
  opacity:.92;
  transform:rotate(0deg);
  transform-origin:top right;
  transition:transform .6s var(--ease);
}
.tool-card:hover .tc-art{transform:rotate(-8deg) scale(1.05)}
.tool-card .tc-art img{width:auto;height:auto;float:right;display:block;max-height:50%}
.tool-card .tc-num{
  font-family:var(--f-serif);font-style:italic;
  font-size:18px;color:var(--w-55);font-weight:400;
}
.tool-card .tc-eyebrow{
  margin-top:auto;
  font-size:13px;color:var(--w-90);
  font-style:italic;font-family:var(--f-serif);
  margin-bottom:8px;
}
.tool-card h3{
  font-size:clamp(36px,3.6vw,52px);
  font-weight:600;
  letter-spacing:-.035em;
  line-height:1;
}
.tool-card .tc-desc{
  margin-top:14px;
  color:var(--w-72);font-size:15px;line-height:1.55;
  max-width:36ch;
}
.tool-card .tc-desc strong{color:#fff;font-weight:500}
.tool-card .tc-link{
  margin-top:22px;
  font-size:14px;font-weight:500;
  display:inline-flex;align-items:center;gap:8px;
  color:#fff;width:fit-content;
  border-bottom:1px solid var(--w-30);
  padding-bottom:4px;
  transition:gap .25s,border-color .25s;
}
.tool-card .tc-link:hover{gap:14px;border-color:#fff}
.tool-card .tc-link em{font-family:var(--f-serif);font-style:italic;line-height:0;font-size:18px;transform:translateY(2px)}

/* per-tool accents */
.tool-card.c-games .tc-art{color:var(--c-games)}
.tool-card.c-visit .tc-art{color:var(--c-visit)}
.tool-card.c-knowledge .tc-art{color:var(--c-knowledge)}
.tool-card.c-info .tc-art{color:var(--c-info)}
.tool-card.c-games:hover{box-shadow:0 30px 80px -20px rgba(2, 93, 247, 0.4)}
.tool-card.c-visit:hover{box-shadow:0 30px 80px -20px rgba(2, 93, 247, 0.4)}
.tool-card.c-knowledge:hover{box-shadow:0 30px 80px -20px rgba(2, 93, 247, 0.4)}
.tool-card.c-info:hover{box-shadow:0 30px 80px -20px rgba(2, 93, 247, 0.4)}

@media (max-width:820px){
  .tool-card{grid-column:span 12;min-height:340px}
}

/* ===========================================================
   Deep-dive tool sections (shared structure)
   =========================================================== */
.tool-section{
  padding:var(--section-pad) 0;
  position:relative;
  border-top:1px solid var(--w-08);
}
.tool-section .anchor-label{
  position:absolute;top:0;left:var(--pad);
  transform:translateY(-50%);
  background:var(--blue-900);
  padding:8px 16px;border:1px solid var(--w-14);border-radius:999px;
  font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--w-72);
  display:inline-flex;align-items:center;gap:10px;
}
.tool-section .anchor-label svg{width:18px;height:18px}

.ts-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:center;
  margin-bottom:80px;
}
.ts-text .ts-num{
  font-family:var(--f-serif);font-style:italic;
  font-size:clamp(64px,9vw,120px);
  font-weight:400;
  color:var(--w-30);
  letter-spacing:-.04em;line-height:.9;
  margin-bottom:18px;
}
.ts-text h2{
  font-size:clamp(46px,6vw,88px);
  font-weight:600;
  letter-spacing:-.04em;
  line-height:.95;
  margin-bottom:14px;
}
.ts-text h2 .kicker{
  display:block;
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:clamp(20px,2vw,28px);
  color:var(--w-72);
  letter-spacing:-.015em;
  margin-bottom:8px;
}
.ts-claim{
  font-size:clamp(18px,1.6vw,22px);
  color:var(--w-90);
  font-weight:500;
  letter-spacing:-.01em;
  line-height:1.4;
  margin:24px 0 18px;
  max-width:38ch;
}
.ts-desc{
  font-size:15.5px;line-height:1.6;color:var(--w-72);max-width:46ch;
}
.ts-desc strong{color:#fff;font-weight:500}

.ts-tag{
  display:inline-block;margin-top:24px;
  font-family:var(--f-serif);font-style:italic;
  font-size:clamp(20px,2.4vw,30px);
  background:var(--c-games);color:#fff;
  padding:4px 16px 6px;border-radius:10px;
  letter-spacing:-.02em;
}

/* per-tool tag colors */
#games .ts-tag{background:var(--c-games)}
#visit .ts-tag{background:var(--c-visit)}
#knowledge .ts-tag{background:var(--c-knowledge);}
#info .ts-tag{background:var(--c-info);}

/* ---------- pillars ---------- */
.pillars{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-bottom:24px;
}
.pillars.info-pillars{grid-template-columns:repeat(3,1fr)}
.pillar{
  background:var(--w-04);
  border:1px solid var(--w-14);
  border-radius:var(--r-lg);
  padding:22px;
  transition:transform .3s var(--ease),background .3s,border-color .3s;
}
.pillar:hover{transform:translateY(-4px);background:var(--w-08);border-color:var(--w-30)}
.pillar .p-ico{
  width:38px;height:38px;border-radius:11px;
  background:var(--c-games);
  border:1px solid var(--c-games);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.pillar .p-ico svg{width:18px;height:18px}
.pillar h4{font-size:15.5px;font-weight:600;margin-bottom:8px;line-height:1.2;letter-spacing:-.015em}
.pillar p{font-size:13.5px;color:var(--w-72);line-height:1.5}

#games .pillar .p-ico{background: rgb(from var(--c-games) r g b / 20%);border-color:rgb(from var(--c-games) r g b / 40%);color:#fff}
#visit .pillar .p-ico{background: rgb(from var(--c-games) r g b / 20%);border-color:rgb(from var(--c-games) r g b / 40%);color:#fff}
#knowledge .pillar .p-ico{background: rgb(from var(--c-games) r g b / 20%);border-color:rgb(from var(--c-games) r g b / 40%);color:#fff}
#info .pillar .p-ico{background: rgb(from var(--c-games) r g b / 20%);border-color:rgb(from var(--c-games) r g b / 40%);color:#fff}

/* ---------- features grid ---------- */
.features{
  margin-top:8px;
  background:var(--w-04);
  border:1px solid var(--w-14);
  border-radius:var(--r-xl);
  padding:clamp(24px,3vw,36px);
}
.features-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;
  border-bottom:1px solid var(--w-08);
  padding-bottom:18px;
}
.features-head .eyebrow{margin:0;color:var(--w-72)}
.features-head .count{font-family:var(--f-serif);font-style:italic;color:var(--w-55);font-size:14px}
.features-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.feat{display:flex;flex-direction:column;gap:10px}
.feat .f-ico{
  width:20px;height:20px;
  color:var(--w-72);
}
.feat h5{font-size:15px;font-weight:600;letter-spacing:-.015em}
.feat p{font-size:13.5px;color:var(--w-55);line-height:1.5}

@media (max-width:980px){
  .ts-grid{grid-template-columns:1fr;gap:48px}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .pillars.info-pillars{grid-template-columns:repeat(2,1fr)}
  .features-list{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:540px){
  .pillars,.pillars.info-pillars{grid-template-columns:1fr}
  .features-list{grid-template-columns:1fr}
}

/* ===========================================================
   Product mockups (per tool)
   =========================================================== */
.mock{
  position:relative;
  aspect-ratio:1/1.05;
  max-width:560px;
  width:100%;
  justify-self:end;
}
.mock .mock-pane{
  position:absolute;
  background:var(--ink);
  border:1px solid var(--w-14);
  border-radius:var(--r-xl);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03) inset;
  overflow:hidden;
}
.mock-bar{
  display:flex;align-items:center;gap:6px;
  padding:12px 16px;
  border-bottom:1px solid var(--w-08);
  background:rgba(0,0,0,.3);
  font-size:11px;color:var(--w-55);
  letter-spacing:.05em;text-transform:uppercase;
}
.mock-bar .dots{display:flex;gap:5px;margin-right:8px}
.mock-bar .dots span{width:9px;height:9px;border-radius:50%;background:var(--w-14)}
.mock-bar .ttl{flex:1;font-family:var(--f-mono);font-size:10.5px;text-transform:none;letter-spacing:.04em}

/* --- Games mock: leaderboard --- */
.mock-games .mg-img-lead{
  position:absolute;
  top:0;left:0;right:14%;bottom:30%;
  width:calc(86%);height:70%;
  object-fit:cover;
  border-radius:var(--r-xl);
}
.mock-games .lb-body{padding:16px 18px;display:flex;flex-direction:column;gap:8px}
.mock-games .lb-row{
  display:grid;grid-template-columns:24px 32px 1fr auto auto;
  gap:12px;align-items:center;
  padding:10px 12px;border-radius:12px;
  background:var(--w-04);
  transition:background .3s;
}
.mock-games .lb-row.lb-1{background:rgba(29,109,255,.18);border:1px solid rgba(29,109,255,.4)}
.mock-games .lb-rank{font-family:var(--f-serif);font-style:italic;font-size:18px;color:var(--w-55)}
.mock-games .lb-row.lb-1 .lb-rank{color:var(--c-games)}
.mock-games .lb-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--c-visit),var(--c-games));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}
.mock-games .lb-av.av-2{background:linear-gradient(135deg,#9be7c4,#1d6dff)}
.mock-games .lb-av.av-3{background:linear-gradient(135deg,#f3d27a,#ff6b47)}
.mock-games .lb-av.av-4{background:linear-gradient(135deg,#c5a8ff,#0d4ff8)}
.mock-games .lb-name{font-size:13px;font-weight:500;color:#fff}
.mock-games .lb-sub{font-size:11px;color:var(--w-55);margin-top:2px}
.mock-games .lb-bar{
  width:80px;height:4px;background:var(--w-08);border-radius:99px;overflow:hidden;position:relative;
}
.mock-games .lb-bar i{
  position:absolute;inset:0;
  background:linear-gradient(90deg,var(--c-visit),var(--c-games));
  border-radius:99px;
  transform-origin:left;
  animation:fill 2.6s var(--ease-out) infinite;
}
.mock-games .lb-row.lb-2 .lb-bar i{animation-delay:.3s;width:78%}
.mock-games .lb-row.lb-1 .lb-bar i{width:96%}
.mock-games .lb-row.lb-3 .lb-bar i{animation-delay:.6s;width:62%}
.mock-games .lb-row.lb-4 .lb-bar i{animation-delay:.9s;width:48%}
.mock-games .lb-pts{font-family:var(--f-mono);font-size:12px;color:#fff;font-weight:600}
@keyframes fill{0%{transform:scaleX(0);opacity:.3}30%,70%{transform:scaleX(1);opacity:1}100%{transform:scaleX(1);opacity:.85}}

.mock-games .mg-img-battle{
  position:absolute;
  bottom:0;right:0;left:18%;top:62%;
  width:82%;height:38%;
  object-fit:cover;
  border-radius:var(--r-xl);
}
.mock-games .battle-body{padding:18px 20px;display:flex;flex-direction:column;gap:10px;height:100%;justify-content:center}
.mock-games .battle-ttl{font-family:var(--f-serif);font-style:italic;font-size:14px;color:var(--c-knowledge)}
.mock-games .battle-q{font-size:15px;font-weight:600;color:#fff;line-height:1.25;letter-spacing:-.015em}
.mock-games .battle-opts{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
.mock-games .battle-opt{
  font-size:11px;padding:8px 10px;border-radius:8px;
  background:rgba(255,255,255,.08);color:var(--w-90);
  border:1px solid rgba(255,255,255,.1);
}
.mock-games .battle-opt.correct{background:var(--c-knowledge);color:var(--ink);font-weight:600;border-color:var(--c-knowledge)}

.mock-games .floating-badge{
  position:absolute;top:38%;right:-8%;
  background:var(--c-visit);color:#fff;
  padding:10px 14px;border-radius:14px;
  font-size:12px;font-weight:600;letter-spacing:-.01em;
  box-shadow:0 14px 30px rgba(255,107,71,.4);
  transform:rotate(6deg);
  display:flex;align-items:center;gap:8px;
  z-index:3;
}
.mock-games .floating-badge .bn{font-family:var(--f-serif);font-style:italic;font-size:18px}

/* --- Visit mock: map + calendar --- */
.mock-visit .mv-img-map{
  position:absolute;
  top:0;left:0;right:0;bottom:36%;
  width:86%;height:64%;
  object-fit:contain;
  border-radius:var(--r-xl);
}
.mock-visit .map-body{
  position:relative;height:calc(100% - 38px);
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:24px 24px;
}
.mock-visit .road{
  position:absolute;
  border-radius:99px;
  background:rgba(255,255,255,.08);
}
.mock-visit .road-1{top:30%;left:-5%;right:-5%;height:14px;transform:rotate(-3deg)}
.mock-visit .road-2{top:62%;left:-5%;right:-5%;height:10px;transform:rotate(2deg)}
.mock-visit .road-3{left:48%;top:-5%;bottom:-5%;width:10px;transform:rotate(3deg)}
.mock-visit .pin{
  position:absolute;
  width:30px;height:30px;border-radius:50% 50% 50% 0;
  background:var(--c-visit);
  transform:rotate(-45deg);
  box-shadow:0 6px 18px rgba(255,107,71,.5),0 0 0 4px rgba(255,107,71,.18);
  display:flex;align-items:center;justify-content:center;
}
.mock-visit .pin::after{content:"";width:10px;height:10px;border-radius:50%;background:#fff;transform:rotate(45deg)}
.mock-visit .pin.p-1{top:24%;left:22%}
.mock-visit .pin.p-2{top:52%;left:62%;background:#fff;box-shadow:0 6px 18px rgba(255,255,255,.3),0 0 0 4px rgba(255,255,255,.18)}
.mock-visit .pin.p-2::after{background:var(--c-visit)}
.mock-visit .pin.p-3{top:72%;left:30%;animation:pinPulse 2s ease-in-out infinite}
@keyframes pinPulse{0%,100%{transform:rotate(-45deg) scale(1)}50%{transform:rotate(-45deg) scale(1.12)}}

.mock-visit .mv-img-cal{
  position:absolute;
  top:54%;bottom:0;right:0;
  width:62%;
  object-fit:cover;
  border-radius:var(--r-xl);
}
.mock-visit .cal-body{padding:14px 16px}
.mock-visit .cal-ttl{font-size:12px;color:var(--w-72);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.mock-visit .cal-ttl strong{color:#fff;font-weight:600}
.mock-visit .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.mock-visit .cal-d{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:10px;color:var(--w-55);border-radius:6px;background:var(--w-04);
}
.mock-visit .cal-d.has{background:rgba(255,107,71,.2);color:#fff;font-weight:600;border:1px solid rgba(255,107,71,.5)}
.mock-visit .cal-d.today{background:var(--c-visit);color:#fff;font-weight:700}

.mock-visit .floating-card{
  position:absolute;bottom:32%;left:-6%;
  background:#fff;color:var(--ink);
  padding:12px 14px;border-radius:14px;
  font-size:12px;font-weight:500;
  box-shadow:0 18px 40px rgba(0,0,0,.35);
  z-index:3;max-width:180px;
  transform:rotate(-3deg);
}
.mock-visit .floating-card .fc-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.mock-visit .floating-card .fc-row svg{width:14px;height:14px;color:var(--c-visit)}
.mock-visit .floating-card strong{font-weight:600;display:block;font-size:12.5px}
.mock-visit .floating-card em{font-style:normal;color:var(--k-70);font-size:11px}

/* --- Knowledge mock: live quiz --- */
.mock-knowledge .mk-img-quiz{
  position:absolute;
  top:0;left:6%;right:0;bottom:18%;
  width:94%;height:82%;
  object-fit:cover;
  border-radius:var(--r-xl);
}
.mock-knowledge .q-body{padding:24px 24px 20px;height:calc(100% - 38px);display:flex;flex-direction:column;gap:14px}
.mock-knowledge .q-step{
  font-family:var(--f-mono);font-size:11px;color:var(--c-knowledge);
  letter-spacing:.1em;text-transform:uppercase;
}
.mock-knowledge .q-question{font-size:17px;font-weight:600;line-height:1.25;color:#fff;letter-spacing:-.015em}
.mock-knowledge .q-opts{display:flex;flex-direction:column;gap:8px;margin-top:auto}
.mock-knowledge .q-opt{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:12px;
  background:var(--w-04);
  border:1px solid var(--w-14);
  font-size:13px;color:var(--w-90);
  position:relative;overflow:hidden;
}
.mock-knowledge .q-opt .q-pct{
  position:absolute;inset:0;background:var(--w-08);
  transform-origin:left;border-radius:12px;z-index:0;
}
.mock-knowledge .q-opt .q-text{position:relative;z-index:1;display:flex;align-items:center;gap:10px;width:100%}
.mock-knowledge .q-opt .q-bull{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--w-30);flex-shrink:0;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--w-72)}
.mock-knowledge .q-opt .q-val{margin-left:auto;font-family:var(--f-mono);font-size:11px;color:var(--w-72);font-weight:600}
.mock-knowledge .q-opt.is-correct{border-color:var(--c-knowledge)}
.mock-knowledge .q-opt.is-correct .q-pct{background:rgba(155,231,196,.18);width:72%}
.mock-knowledge .q-opt.is-correct .q-bull{background:var(--c-knowledge);color:var(--ink);border-color:var(--c-knowledge)}
.mock-knowledge .q-opt.is-correct .q-val{color:var(--c-knowledge)}
.mock-knowledge .q-opt.opt-b .q-pct{width:18%}
.mock-knowledge .q-opt.opt-c .q-pct{width:8%}
.mock-knowledge .q-opt.opt-d .q-pct{width:2%}

.mock-knowledge .mk-img-live{
  position:absolute;
  bottom:0;left:0;right:38%;height:22%;
  width:62%;
  object-fit:cover;
  border-radius:var(--r-xl);
}
.mock-knowledge .live-dot{width:8px;height:8px;border-radius:50%;background:#ff3b3b;animation:pulse 1.6s ease-in-out infinite}
.mock-knowledge .live-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:#fff}
.mock-knowledge .live-stat{margin-left:auto;text-align:right}
.mock-knowledge .live-stat .ls-n{font-family:var(--f-serif);font-style:italic;font-size:22px;color:var(--c-knowledge);line-height:1}
.mock-knowledge .live-stat .ls-l{font-size:10px;color:var(--w-55);text-transform:uppercase;letter-spacing:.08em}

/* --- Info mock: dashboard --- */
.mock-info .mi-img-dash{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  width:100%;height:100%;
  object-fit:contain;
  border-radius:var(--r-xl);
}
.mock-info .dash-body{padding:18px 20px;display:flex;flex-direction:column;gap:14px;height:calc(100% - 38px)}
.mock-info .dash-head{display:flex;align-items:center;justify-content:space-between}
.mock-info .dash-ttl{font-size:15px;font-weight:600;letter-spacing:-.015em;color:#fff}
.mock-info .dash-ttl em{font-family:var(--f-serif);font-style:italic;color:var(--c-info);font-weight:400}
.mock-info .dash-tag{font-family:var(--f-mono);font-size:10px;color:var(--w-72);padding:4px 8px;border-radius:6px;background:var(--w-04);border:1px solid var(--w-14);letter-spacing:.08em;text-transform:uppercase}
.mock-info .dash-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.mock-info .dash-kpi{padding:12px;background:var(--w-04);border:1px solid var(--w-08);border-radius:12px}
.mock-info .dash-kpi .k-l{font-size:10px;color:var(--w-55);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.mock-info .dash-kpi .k-v{font-family:var(--f-serif);font-style:italic;font-size:24px;line-height:1;color:#fff}
.mock-info .dash-kpi .k-d{font-size:10px;color:var(--c-knowledge);margin-top:6px;display:flex;align-items:center;gap:4px}
.mock-info .dash-kpi.kpi-2 .k-v{color:var(--c-info)}
.mock-info .dash-kpi.kpi-3 .k-d{color:var(--c-visit)}
.mock-info .dash-chart{
  flex:1;
  background:var(--w-04);
  border:1px solid var(--w-08);
  border-radius:14px;
  padding:16px;
  position:relative;
  min-height:120px;
}
.mock-info .chart-label{font-size:10px;color:var(--w-55);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.mock-info .chart-bars{display:flex;align-items:flex-end;gap:8px;height:calc(100% - 24px);padding-bottom:8px}
.mock-info .bar{
  flex:1;border-radius:6px 6px 0 0;
  background:linear-gradient(180deg,var(--c-info) 0%, rgba(243,210,122,.15) 100%);
  position:relative;
  transform-origin:bottom;
  animation:barRise 1.4s var(--ease-out) backwards;
}
.mock-info .bar:nth-child(1){height:35%;animation-delay:.05s}
.mock-info .bar:nth-child(2){height:55%;animation-delay:.15s}
.mock-info .bar:nth-child(3){height:42%;animation-delay:.25s}
.mock-info .bar:nth-child(4){height:78%;animation-delay:.35s;background:linear-gradient(180deg,var(--c-visit) 0%, rgba(255,107,71,.15) 100%)}
.mock-info .bar:nth-child(5){height:62%;animation-delay:.45s}
.mock-info .bar:nth-child(6){height:85%;animation-delay:.55s}
.mock-info .bar:nth-child(7){height:92%;animation-delay:.65s;background:linear-gradient(180deg,var(--c-games) 0%, rgba(29,109,255,.15) 100%)}
@keyframes barRise{from{transform:scaleY(0)}to{transform:scaleY(1)}}

.mock-info .floating-note{
  position:absolute;top:18%;right:-6%;
  background:var(--cream);color:var(--ink);
  padding:12px 14px;border-radius:14px;
  font-size:12px;font-weight:500;
  box-shadow:0 18px 40px rgba(0,0,0,.35);
  z-index:3;max-width:200px;
  transform:rotate(3deg);
}
.mock-info .floating-note strong{display:block;font-family:var(--f-serif);font-style:italic;font-weight:400;font-size:18px;color:var(--blue-700)}
.mock-info .floating-note em{font-style:normal;color:var(--k-70);font-size:11px;line-height:1.4;display:block;margin-top:2px}

@media (max-width:980px){
  .mock{justify-self:center;max-width:520px}
  .mock-games .floating-badge,
  .mock-visit .floating-card,
  .mock-info .floating-note{right:0;left:auto}
}

/* ===========================================================
   Cream inverted section — Alcance / Stats
   =========================================================== */
.section--cream{
  background:var(--cream);
  color:var(--ink);
  position:relative;
  overflow:hidden;
}
.section--cream::before{
  content:"";position:absolute;
  inset:auto -10% -50% -10%;height:60%;
  background:radial-gradient(ellipse at center, rgba(255,107,71,.08), transparent 60%);
  z-index:0;
}
.section--cream > *{position:relative;z-index:1}
.section--cream .section-head h2{color:var(--ink)}
.section--cream .section-head .meta{color:var(--k-70)}
.section--cream .eyebrow{color:var(--k-50)}
.section--cream .eyebrow::before{background:currentColor}

.stats-editorial{
  display:flex;flex-direction:column;
  border-top:1px solid var(--k-15);
}
.stat-row{
  display:grid;
  grid-template-columns:200px 1fr auto;
  align-items:center;
  gap:clamp(20px,4vw,60px);
  padding:clamp(24px,4vw,40px) 0;
  border-bottom:1px solid var(--k-15);
  transition:padding-left .4s var(--ease);
  position:relative;
}
.stat-row:hover{padding-left:12px}
.stat-row .sr-num{
  font-family:var(--f-serif);font-style:italic;
  font-size:clamp(72px,11vw,160px);
  font-weight:400;
  letter-spacing:-.05em;line-height:.85;
  color:var(--ink);
}
.stat-row .sr-num small{
  font-size:.5em;color:var(--c-visit);
  font-style:italic;
  vertical-align:top;
  margin-left:-.08em;
}
.stat-row .sr-text{
  font-size:clamp(18px,2vw,26px);
  line-height:1.3;
  letter-spacing:-.015em;
  color:var(--ink);
  font-weight:500;
  max-width:32ch;
}
.stat-row .sr-tag{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--k-50);
  white-space:nowrap;
}
@media (max-width:780px){
  .stat-row{grid-template-columns:1fr;gap:12px}
  .stat-row .sr-tag{order:-1}
}

/* ===========================================================
   Impacto strip — light again, 3-up editorial
   =========================================================== */
.impact-strip{
  background:var(--ink);
  color:#fff;
  padding:var(--section-pad) 0;
  position:relative;
  overflow:hidden;
}
.impact-strip::before{
  content:"";position:absolute;
  inset:-10% -10% auto auto;width:60%;height:60%;
  background:radial-gradient(ellipse at center, rgba(29,109,255,.18), transparent 60%);
  z-index:0;
}
.impact-strip > *{position:relative;z-index:1}
.impact-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,3vw,40px);
  margin-top:48px;
}
.impact-card{
  padding:32px 28px;
  border:1px solid var(--w-14);
  border-radius:var(--r-xl);
  background:var(--w-04);
  display:flex;flex-direction:column;gap:14px;
  transition:transform .3s var(--ease),background .3s,border-color .3s;
}
.impact-card:hover{transform:translateY(-6px);background:var(--w-08);border-color:var(--w-30)}
.impact-card .ic-num{
  font-family:var(--f-serif);font-style:italic;
  font-size:32px;font-weight:400;color:var(--c-visit);
  line-height:1;letter-spacing:-.025em;
}
.impact-card h4{font-size:20px;font-weight:600;letter-spacing:-.02em;line-height:1.15}
.impact-card p{font-size:14.5px;color:var(--w-72);line-height:1.55}
.impact-card p strong{color:#fff;font-weight:500}
@media (max-width:880px){.impact-grid{grid-template-columns:1fr}}

/* ===========================================================
   CTA / Contact
   =========================================================== */
.cta{
  padding:var(--section-pad) 0;
  position:relative;overflow:hidden;
  border-top:1px solid var(--w-08);
  background:
    radial-gradient(ellipse 60% 50% at 80% 0%, rgba(2,93,247,.18), transparent 60%),
    radial-gradient(ellipse 70% 50% at 10% 90%, rgba(2,93,247,.22), transparent 60%),
    var(--blue-900);
}
.cta-grid{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:start;
}
.cta-text h2{
  font-size:clamp(48px,7vw,108px);
  font-weight:600;
  letter-spacing:-.04em;line-height:.95;
  margin-bottom:28px;
}
.cta-text h2 .serif-italic{font-weight:400}
.cta-text h2 .marker{
  display:inline-block;position:relative;padding:0 6px;
}
.cta-text h2 .marker::before{
  content:"";position:absolute;inset:auto -10px -4px -10px;height:.4em;
  background:var(--c-visit);
  z-index:-1;
  transform:skewX(-6deg);
  border-radius:4px;
}
.cta-sub{
  font-size:17px;color:var(--w-72);line-height:1.55;
  max-width:46ch;margin-bottom:40px;
}

.next-steps{
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid var(--w-14);
}
.next-step{
  display:grid;grid-template-columns:64px 1fr;
  gap:20px;align-items:center;
  padding:20px 0;
  border-bottom:1px solid var(--w-14);
}
.next-step .ns-num{
  font-family:var(--f-serif);font-style:italic;
  font-size:36px;font-weight:400;
  color:var(--c-visit);
  line-height:1;letter-spacing:-.025em;
}
.next-step h5{font-size:16px;font-weight:600;letter-spacing:-.015em;margin-bottom:4px}
.next-step p{font-size:13.5px;color:var(--w-72);line-height:1.5}

form{
  background:var(--w-04);
  border:1px solid var(--w-14);
  border-radius:var(--r-2xl);
  padding:clamp(28px,3.5vw,40px);
  backdrop-filter:blur(16px);
  box-shadow:0 30px 80px rgba(0,0,0,.25);
}
.form-hd{
  display:flex;align-items:center;gap:12px;
  margin-bottom:24px;
  padding-bottom:18px;
  border-bottom:1px solid var(--w-08);
}
.form-hd svg{width:24px;height:24px;color:var(--c-visit)}
.form-hd h4{font-size:18px;font-weight:600;letter-spacing:-.015em}
.form-hd h4 em{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--w-72)}
.field{margin-bottom:14px;position:relative}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.row2 .field{margin-bottom:0}
.field label{
  display:block;font-size:11.5px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--w-72);margin-bottom:6px;
}
.field input,.field textarea,.field select{
  width:100%;
  background:rgba(0,0,0,.25);
  border:1px solid var(--w-14);
  color:#fff;padding:13px 16px;border-radius:12px;
  font-size:14.5px;
  font-family:var(--f-sans);
  transition:border-color .2s,background .2s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--w-30)}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--c-visit);background:rgba(0,0,0,.4);
}
.field select{color:var(--w-90)}
.field select option{background:var(--blue-900);color:#fff}
.field textarea{resize:vertical;min-height:90px}
.submit{
  width:100%;background:var(--c-visit);color:#fff;
  padding:16px;border-radius:12px;font-weight:600;font-size:15px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  letter-spacing:-.01em;
  transition:transform .25s var(--ease),background .25s,box-shadow .25s;
}
.submit:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgb(from var(--c-games) r g b / 40%);}
.submit em{font-family:var(--f-serif);font-style:italic;font-size:20px;line-height:0;transform:translateY(2px)}
.note{text-align:center;font-size:12px;color:var(--w-55);margin-top:14px}
.success{margin-top:14px;padding:14px;background:rgba(155,231,196,.12);border:1px solid rgba(155,231,196,.35);border-radius:12px;font-size:14px;color:#fff;text-align:center}
@media (max-width:880px){.cta-grid{grid-template-columns:1fr;gap:48px}}
@media (max-width:480px){.row2{grid-template-columns:1fr}}

/* ===========================================================
   Footer
   =========================================================== */
footer{
  background:#000a1f;
  border-top:1px solid var(--w-08);
  padding:60px 0 30px;
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:48px;
}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.foot-brand .logo-mark{width:60px;height:auto;color:#fff}
.foot-brand .wordmark{font-size:17px;font-weight:600;letter-spacing:-.015em}
.foot-brand .wordmark em{font-family:var(--f-serif);font-style:italic;font-weight:400}
.foot-tag{font-size:14px;color:var(--w-55);line-height:1.55;max-width:32ch}
.foot-col h6{
  font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--w-55);font-weight:600;margin-bottom:18px;
}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{color:var(--w-72);font-size:14px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bot{
  padding-top:24px;border-top:1px solid var(--w-08);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  font-size:12.5px;color:var(--w-55);
}
.foot-bot a{transition:color .2s}
.foot-bot a:hover{color:#fff}
@media (max-width:880px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media (max-width:520px){
  .foot-grid{grid-template-columns:1fr}
}

/* ===========================================================
   Reveal
   =========================================================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal.r-delay-1{transition-delay:.08s}
.reveal.r-delay-2{transition-delay:.16s}
.reveal.r-delay-3{transition-delay:.24s}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .collage .tile,.collage .badge,.marquee-track,.hero-meta .dot,
  .mock-games .lb-bar i,.mock-knowledge .live-dot,
  .mock-info .bar,.mock-visit .pin.p-3{animation:none}
  html{scroll-behavior:auto}
}
