/* ═══════════════════════════════════════════════════════════════
   ESPARTANOS ACADEMY — academy.css
   Fuente: Barlow + Barlow Condensed
   Tema: Negro absoluto / Oro / Glass
   ═══════════════════════════════════════════════════════════════ */

/* ─── VARIABLES ────────────────────────────────────────────────── */
:root {
  --black:      #000000;
  --surface:    #0a0a0a;
  --panel:      rgba(14,14,16,0.75);

  --gold:       #FFD54A;
  --gold-glow:  rgba(255,213,74,0.35);
  --gold-dim:   rgba(255,213,74,0.08);
  --gold-hi:    #FFE580;

  --green:      #2EFF94;
  --green-dim:  rgba(46,255,148,0.1);

  --red:        #FF4A4A;
  --blue:       #2997FF;

  --text:       #FFFFFF;
  --muted:      #6b6b72;
  --soft:       #a0a0a8;

  --border:     rgba(255,255,255,0.07);
  --border-hi:  rgba(255,255,255,0.16);

  --blur:       20px;
  --r-sm:       12px;
  --r-md:       20px;
  --r-lg:       28px;

  --ease:       cubic-bezier(0.25,1,0.5,1);
  --elastic:    cubic-bezier(0.175,0.885,0.32,1.275);
  --expo:       cubic-bezier(0.16,1,0.3,1);
}

/* ─── RESET ─────────────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background: var(--black);
  color: var(--text);
  font-family: 'Barlow', system-ui, sans-serif;
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3 { font-family:'Barlow Condensed',sans-serif; letter-spacing:-0.01em; line-height:1; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; display:block; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }

/* ─── LAYOUT ─────────────────────────────────────────────────────── */
.container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 28px;
}
.hidden { display:none !important; }

/* ─── BACKGROUND ─────────────────────────────────────────────────── */
.bg {
  position:fixed; inset:0;
  z-index:-1; overflow:hidden;
  background: var(--black);
  pointer-events:none;
}
.bg-noise {
  position:absolute; 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.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  mix-blend-mode:overlay; opacity:0.7;
}
.bg-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.014) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.014) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 40%,transparent 100%);
}
.bg-glow {
  position:absolute; border-radius:50%;
  filter:blur(160px); pointer-events:none;
}
.bg-glow-gold {
  top:-20%; left:5%;
  width:700px; height:700px;
  background:radial-gradient(circle,rgba(255,213,74,0.12),transparent 70%);
  animation:glowPulse 14s infinite alternate ease-in-out;
}
.bg-glow-blue {
  bottom:-15%; right:-5%;
  width:550px; height:550px;
  background:radial-gradient(circle,rgba(41,151,255,0.1),transparent 70%);
  animation:glowPulse 18s infinite alternate-reverse ease-in-out;
}

/* ─── COOKIE BANNER ──────────────────────────────────────────────── */
.cookie {
  position:fixed; bottom:20px; left:50%; transform:translateX(-50%);
  z-index:9000; width:calc(100% - 40px); max-width:680px;
  background:rgba(12,12,14,0.97);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  backdrop-filter:blur(var(--blur));
  padding:16px 20px;
  transition:transform 0.4s var(--expo), opacity 0.4s;
}
.cookie.hide { transform:translateX(-50%) translateY(120%); opacity:0; pointer-events:none; }
.cookie-box {
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
}
.cookie-box svg { flex-shrink:0; color:var(--gold); }
.cookie-box p { flex:1; font-size:0.85rem; color:var(--soft); min-width:200px; }
.cookie-box p a { color:var(--gold); text-decoration:underline; }
.cookie-btns { display:flex; gap:10px; flex-shrink:0; }
.cookie-btns button {
  padding:8px 18px; border-radius:100px; font-size:0.82rem; font-weight:600;
  border:1px solid var(--border); color:var(--muted);
  transition:all 0.25s var(--ease);
}
.cookie-ok {
  background:var(--gold) !important; color:#000 !important;
  border-color:var(--gold) !important;
}
.cookie-btns button:hover { opacity:0.85; }

/* ─── AUTH OVERLAY ───────────────────────────────────────────────── */
.overlay {
  position:fixed; inset:0; z-index:8000;
  background:rgba(0,0,0,0.85);
  backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity 0.35s var(--ease);
}
.overlay.open { opacity:1; pointer-events:all; }

.modal {
  background:rgba(10,10,12,0.98);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:44px 40px;
  width:100%; max-width:440px;
  position:relative;
  transform:translateY(16px) scale(0.98);
  transition:transform 0.4s var(--expo);
}
.overlay.open .modal { transform:translateY(0) scale(1); }

.modal-close {
  position:absolute; top:18px; right:18px;
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  color:var(--muted);
  display:flex; align-items:center; justify-content:center;
  transition:all 0.2s;
}
.modal-close:hover { background:rgba(255,255,255,0.09); color:#fff; }

.modal-logo { width:48px; margin-bottom:20px; }
.modal-logo img { width:100%; }

.modal-title {
  font-size:1.9rem; font-weight:900; margin-bottom:8px;
  color:#fff; letter-spacing:-0.5px;
}
.modal-sub { font-size:0.95rem; color:var(--soft); margin-bottom:30px; }

.google-btn {
  display:flex; align-items:center; justify-content:center; gap:12px;
  width:100%; padding:15px 20px;
  background:#fff; color:#1a1a1a;
  border-radius:100px; font-weight:700; font-size:0.95rem;
  transition:all 0.3s var(--elastic);
  border:none;
}
.google-btn:hover { transform:translateY(-2px) scale(1.02); box-shadow:0 12px 32px rgba(255,255,255,0.18); }
.google-btn:active { transform:scale(0.98); }

.modal-terms { font-size:0.78rem; color:var(--muted); margin-top:18px; text-align:center; }
.modal-terms a { color:var(--gold); }

.modal-msg {
  margin-top:16px; font-size:0.88rem; text-align:center;
  min-height:20px; border-radius:8px; padding:0;
  transition:all 0.3s;
}
.modal-msg.ok  { color:var(--green); }
.modal-msg.err { color:var(--red); }

/* ─── NAVBAR ──────────────────────────────────────────────────────── */
.nav {
  position:fixed; top:0; left:0; width:100%;
  z-index:500; padding:22px 0;
  transition:padding 0.4s var(--ease), background 0.4s, border-color 0.4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled {
  padding:13px 0;
  background:rgba(0,0,0,0.82);
  backdrop-filter:blur(var(--blur)) saturate(180%);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(180%);
  border-color:var(--border);
}
.nav-wrap {
  max-width:1240px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.nav-brand {
  display:flex; align-items:center; gap:12px; flex-shrink:0;
}
.nav-logo { height:40px; width:auto; }
.nav-name {
  display:block; font-family:'Barlow Condensed',sans-serif;
  font-weight:900; font-size:1.1rem; letter-spacing:1px; line-height:1.1;
}
.nav-tag {
  display:block; font-size:0.58rem; color:var(--gold);
  letter-spacing:3px; font-weight:700; text-transform:uppercase;
}
.nav-links {
  display:flex; align-items:center; gap:4px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);
  border-radius:100px; padding:5px;
}
.nav-link {
  font-size:0.88rem; font-weight:500; color:var(--muted);
  padding:8px 20px; border-radius:100px;
  transition:all 0.25s var(--ease);
}
.nav-link:hover { color:#fff; background:rgba(255,255,255,0.06); }

.nav-end { display:flex; align-items:center; gap:14px; }

.nav-sign-btn {
  display:flex; align-items:center; gap:8px;
  padding:9px 20px; border-radius:100px;
  font-size:0.86rem; font-weight:600; color:#fff;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  transition:all 0.3s var(--ease);
}
.nav-sign-btn:hover {
  background:rgba(255,255,255,0.09); border-color:var(--border-hi);
}

.nav-user { position:relative; cursor:pointer; }
.nav-avatar {
  width:36px; height:36px; border-radius:50%;
  border:2px solid var(--gold);
  object-fit:cover; display:block;
  transition:transform 0.3s;
}
.nav-user:hover .nav-avatar { transform:scale(1.05); }

.nav-dropdown {
  position:absolute; top:calc(100% + 10px); right:0;
  background:rgba(10,10,12,0.98);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:8px;
  min-width:210px;
  box-shadow:0 20px 48px rgba(0,0,0,0.8);
  opacity:0; pointer-events:none;
  transform:translateY(-6px) scale(0.97);
  transition:all 0.25s var(--ease);
}
.nav-user:hover .nav-dropdown,
.nav-dropdown.open { opacity:1; pointer-events:all; transform:translateY(0) scale(1); }

.drop-info { padding:8px 10px 12px; }
.drop-info strong { display:block; font-size:0.9rem; color:#fff; }
.drop-info span   { display:block; font-size:0.78rem; color:var(--muted); margin-top:2px; }
.drop-sep { border:none; border-top:1px solid var(--border); margin:4px 0; }
.drop-item {
  display:flex; align-items:center; gap:10px;
  width:100%; padding:9px 10px; border-radius:10px;
  font-size:0.85rem; font-weight:500; color:var(--soft);
  transition:all 0.2s;
}
.drop-item:hover { background:rgba(255,255,255,0.05); color:#fff; }

.nav-burger {
  display:none; flex-direction:column; gap:5px;
  padding:4px; background:none; border:none; cursor:pointer;
}
.nav-burger span {
  width:22px; height:2px; background:#fff; border-radius:2px;
  display:block; transition:all 0.3s var(--ease);
  transform-origin:center;
}
.nav-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { transform:translateY(-7px) rotate(-45deg); }

/* ─── MOBILE MENU ────────────────────────────────────────────────── */
.mob-menu {
  position:fixed; inset:0; z-index:490;
  background:rgba(0,0,0,0.97);
  backdrop-filter:blur(24px);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:12px;
  opacity:0; pointer-events:none;
  transform:scale(1.04);
  transition:all 0.4s var(--expo);
}
.mob-menu.open { opacity:1; pointer-events:all; transform:scale(1); }
.mob-menu ul { display:flex; flex-direction:column; gap:8px; text-align:center; }
.mob-menu ul a {
  font-family:'Barlow Condensed',sans-serif;
  font-size:2.8rem; font-weight:800; letter-spacing:-0.5px;
  color:var(--muted); display:block; padding:6px 24px;
  transition:color 0.25s, transform 0.25s var(--elastic);
}
.mob-menu ul a:hover { color:var(--gold); transform:translateX(8px); }
.mob-sign-btn {
  display:flex; align-items:center; gap:10px;
  padding:14px 32px; border-radius:100px;
  font-size:0.95rem; font-weight:700; color:#fff;
  border:1px solid var(--border);
  margin-top:16px;
  transition:all 0.3s var(--ease);
}
.mob-sign-btn:hover { background:rgba(255,255,255,0.06); border-color:var(--border-hi); }

/* ─── HERO ───────────────────────────────────────────────────────── */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding-top:100px; padding-bottom:80px;
  position:relative;
}
.hero-inner {
  display:grid; grid-template-columns:1.1fr 0.9fr;
  align-items:center; gap:64px;
}
.hero-text { display:flex; flex-direction:column; }

/* Pill */
.hero-pill {
  display:inline-flex; align-items:center; gap:10px;
  padding:7px 16px; border-radius:100px; width:fit-content;
  background:var(--gold-dim);
  border:1px solid rgba(255,213,74,0.22);
  font-size:0.73rem; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:28px;
  animation:fadeUp 0.7s var(--expo) 0.1s both;
}
.h-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--gold); flex-shrink:0;
  box-shadow:0 0 0 3px rgba(255,213,74,0.2), 0 0 10px var(--gold);
  animation:blink 2.5s infinite;
}
.h-live {
  background:rgba(255,213,74,0.15);
  border:1px solid rgba(255,213,74,0.3);
  border-radius:4px; padding:1px 6px;
  font-size:0.58rem; letter-spacing:2px;
}

/* Title */
.hero-h1 {
  font-size:clamp(3.4rem,6.5vw,6.5rem);
  font-weight:900; 
  letter-spacing:2px;
  line-height:1.05; 
  margin-bottom:24px;
  animation:fadeUp 0.8s var(--expo) 0.25s both;
}

.hero-h1 em {
  font-style:normal;
  background:linear-gradient(135deg,var(--gold-hi) 0%,var(--gold) 55%,#FF9F1C 100%);
  -webkit-background-clip:text; 
  -webkit-text-fill-color:transparent;
  background-clip:text;
  filter:drop-shadow(0 0 24px rgba(255,213,74,0.25));
  -webkit-text-stroke: 1.5px #000000;
}

/* Desc */
.hero-p {
  font-size:1.1rem; color:var(--soft); font-weight:300;
  max-width:86%; line-height:1.7; margin-bottom:36px;
  animation:fadeUp 0.8s var(--expo) 0.4s both;
}
.hero-p strong {
  color:#fff; font-weight:600;
}

/* Buttons */
.hero-btns {
  display:flex; gap:14px; align-items:center; flex-wrap:wrap;
  margin-bottom:44px;
  animation:fadeUp 0.8s var(--expo) 0.52s both;
}
.btn-gold {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 32px; border-radius:100px;
  background:#fff; color:#000;
  font-weight:700; font-size:0.95rem;
  transition:all 0.35s var(--elastic);
  position:relative; overflow:hidden;
}
.btn-gold::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,var(--gold-hi),#fff 60%);
  opacity:0; transition:opacity 0.3s;
}
.btn-gold:hover { transform:translateY(-3px) scale(1.02); box-shadow:0 16px 36px rgba(255,255,255,0.2); }
.btn-gold:hover::after { opacity:1; }
.btn-gold svg,
.btn-gold span { position:relative; z-index:1; }

.btn-ghost {
  display:inline-flex; align-items:center;
  padding:15px 32px; border-radius:100px;
  background:transparent; color:rgba(255,255,255,0.7);
  font-weight:500; font-size:0.95rem;
  border:1px solid var(--border);
  transition:all 0.3s var(--ease);
}
.btn-ghost:hover { background:rgba(255,255,255,0.05); border-color:var(--border-hi); color:#fff; transform:translateY(-2px); }

/* Stats */
.hero-stats {
  display:flex; align-items:center; gap:28px;
  animation:fadeUp 0.8s var(--expo) 0.65s both;
}
.hs { display:flex; flex-direction:column; gap:2px; }
.hs strong {
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.6rem; font-weight:900; letter-spacing:-0.5px;
  line-height:1;
}
.hs span { font-size:0.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.hs-sep { width:1px; height:32px; background:var(--border); flex-shrink:0; }

/* Mockup */
.hero-vis { animation:fadeIn 1s var(--expo) 0.4s both; }
.mockup {
  position:relative; border-radius:22px;
  background:#0a0a0a;
  border:1px solid var(--border);
  padding:8px;
  box-shadow:0 60px 120px -20px rgba(0,0,0,0.95);
  transition:transform 0.6s var(--ease);
}
.mockup:hover { transform:translateY(-8px); }
.mockup-shine {
  position:absolute; inset:0; border-radius:22px;
  background:linear-gradient(135deg,rgba(255,255,255,0.07) 0%,transparent 50%);
  pointer-events:none; z-index:2;
}
.mockup-img {
  width:100%; border-radius:16px; display:block;
  min-height:200px; background:#111;
}

/* Notification */
.notif {
  position:absolute; bottom:24px; left:-24px;
  background:rgba(8,8,10,0.95);
  border:1px solid rgba(255,213,74,0.18);
  backdrop-filter:blur(24px);
  border-radius:16px; padding:14px 18px;
  display:flex; align-items:center; gap:14px;
  z-index:5;
  box-shadow:0 20px 48px rgba(0,0,0,0.9);
  animation:floatY 7s ease-in-out infinite;
}
.notif-icon {
  width:40px; height:40px; flex-shrink:0;
  background:rgba(255,74,74,0.08);
  border:1px solid rgba(255,74,74,0.15);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
}
.notif-text { display:flex; flex-direction:column; gap:2px; }
.notif-top { font-size:0.68rem; color:var(--muted); text-transform:uppercase; font-weight:700; letter-spacing:0.8px; }
.notif-bot { font-size:0.92rem; font-weight:700; color:#fff; }
.notif-ping {
  position:absolute; top:-4px; right:-4px;
  width:11px; height:11px; border-radius:50%;
  background:var(--gold);
  animation:ping 2s infinite;
}

/* Float badge */
.float-badge {
  position:absolute; top:18px; right:-14px;
  background:rgba(46,255,148,0.08);
  border:1px solid rgba(46,255,148,0.22);
  padding:7px 14px; border-radius:100px;
  font-size:0.72rem; font-weight:700; color:var(--green);
  display:flex; align-items:center; gap:8px;
  backdrop-filter:blur(14px); z-index:5;
  animation:floatY2 5s ease-in-out infinite;
  white-space:nowrap;
}
.fb-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px var(--green);
  animation:blink 1.8s infinite;
}

/* ─── ECOSYSTEM ──────────────────────────────────────────────────── */
.eco {
  padding:140px 0 100px;
  position:relative;
}

/* Section header */
.sec-head { margin-bottom:64px; }
.sec-head.center { text-align:center; }

.sec-eye {
  display:block; font-size:0.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:3px;
  color:var(--gold); opacity:0.8; margin-bottom:14px;
}
.sec-h2 {
  font-size:clamp(2.6rem,4.5vw,4.8rem); font-weight:900;
  letter-spacing:-1.5px; margin-bottom:14px;
}
.sec-h2 em {
  font-style:normal;
  background:linear-gradient(135deg,var(--gold-hi),var(--gold));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.sec-p { font-size:1.05rem; color:var(--muted); font-weight:300; }

/* Bento grid */
.bento {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:400px 220px;
  gap:16px;
}

/* Card base */
.card {
  position:relative; overflow:hidden;
  border-radius:var(--r-lg);
  border:1px solid var(--border);
  background:rgba(10,10,12,0.9);
  backdrop-filter:blur(16px);
  display:flex; flex-direction:column;
  transition:border-color 0.4s, box-shadow 0.4s, transform 0.5s var(--elastic);
  cursor:pointer;
}
.card:hover {
  border-color:var(--border-hi);
  box-shadow:0 28px 60px rgba(0,0,0,0.85);
  transform:translateY(-6px);
}

.card-bg {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  opacity:0.28; z-index:1;
  filter:saturate(0.6) contrast(1.2);
  transition:opacity 0.7s, transform 0.7s var(--ease), filter 0.7s;
}
.card:hover .card-bg {
  opacity:0.45; transform:scale(1.06);
  filter:saturate(0.9) contrast(1.1);
}

.card-fog {
  position:absolute; inset:0; z-index:2;
  background:linear-gradient(to top, rgba(0,0,0,0.96) 0%, rgba(0,0,0,0.45) 55%, rgba(0,0,0,0.15) 100%);
}

.card-cnt {
  position:relative; z-index:3;
  padding:28px 32px; height:100%;
  display:flex; flex-direction:column;
}
.card-cnt-row {
  flex-direction:row;
  align-items:center; justify-content:space-between;
  gap:24px;
}
.card-row {
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:auto;
}
.card h3 {
  font-size:2.1rem; font-weight:900; letter-spacing:-0.5px;
  color:#fff; margin:20px 0 10px;
  text-shadow:0 4px 20px rgba(0,0,0,0.9);
}
.card p {
  font-size:0.95rem; color:rgba(255,255,255,0.6); font-weight:300;
  line-height:1.6; text-shadow:0 2px 8px rgba(0,0,0,0.8);
  max-width:88%;
}
.c-arrow {
  display:block; margin-top:20px;
  font-size:1.3rem; color:rgba(255,255,255,0.25);
  transition:all 0.3s var(--ease);
}
.card:hover .c-arrow { color:var(--gold); transform:translateX(6px); }

/* Deco SVG */
.c-deco {
  position:absolute; bottom:-20px; right:-20px;
  width:160px; height:160px; z-index:2; pointer-events:none;
  color:rgba(255,255,255,0.6);
  opacity:0.2; transition:opacity 0.5s, transform 0.7s var(--elastic);
}
.c-deco-r {
  top:50%; right:20px; bottom:auto;
  transform:translateY(-50%);
  width:120px; height:120px;
}
.c-deco svg { width:100%; height:100%; }
.card:hover .c-deco { opacity:0.6; transform:scale(1.12) rotate(-5deg); }
.c-scanner:hover .c-deco { color:var(--gold); }
.c-bot:hover .c-deco { color:var(--green); }
.card:hover .c-deco-r { transform:translateY(-50%) scale(1.1); }

/* Badges */
.cbadge {
  font-size:0.65rem; font-weight:800; text-transform:uppercase;
  letter-spacing:1.2px; padding:5px 11px; border-radius:7px;
  border:1px solid var(--border); background:rgba(0,0,0,0.5);
  color:var(--muted); backdrop-filter:blur(6px);
}
.cbadge-green { color:var(--green); border-color:rgba(46,255,148,0.3); background:rgba(46,255,148,0.04); }
.cbadge-gold  { color:var(--gold);  border-color:rgba(255,213,74,0.3);  background:rgba(255,213,74,0.04); }
.cbadge-dim   { color:rgba(255,255,255,0.7); border-color:rgba(255,255,255,0.14); background:rgba(255,255,255,0.04); }

/* Radar ping */
.radar {
  width:11px; height:11px; border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 3px rgba(255,213,74,0.15), 0 0 14px rgba(255,213,74,0.5);
  animation:ping 2s infinite;
  flex-shrink:0;
}

/* Promo pill */
.promo-pill {
  position:absolute; top:0; right:28px; z-index:10;
  background:var(--gold); color:#000;
  padding:7px 16px; border-radius:0 0 12px 12px;
  font-size:0.7rem; font-weight:800; letter-spacing:0.8px;
  display:flex; align-items:center; gap:6px;
  box-shadow:0 6px 20px rgba(255,213,74,0.4);
  animation:badgePulse 3s infinite;
}

/* Grid positions */
.c-scanner { grid-column:span 2; grid-row:span 1; }
.c-bot     { grid-column:span 1; grid-row:span 1; }
.c-campus  { grid-column:span 1; grid-row:span 1; }
.c-capital { grid-column:span 2; grid-row:span 1; }
.c-scanner .card-h3 { font-size:2.6rem; }

/* Capital card */
.cap-text h3 { font-size:1.7rem; margin:12px 0 8px; text-shadow:none; }
.cap-text p  { font-size:0.9rem; color:var(--muted); text-shadow:none; max-width:100%; }
.cap-btns { display:flex; gap:12px; flex-shrink:0; }
.pill {
  padding:12px 26px; border-radius:100px;
  border:1px solid var(--border); background:rgba(255,255,255,0.02);
  color:rgba(255,255,255,0.7); font-weight:600; font-size:0.9rem;
  transition:all 0.3s var(--ease); display:inline-block;
  white-space:nowrap;
}
.pill:hover { background:#fff; color:#000; border-color:#fff; transform:translateY(-2px); }
.pill-gold  { border-color:rgba(255,213,74,0.38); color:var(--gold); background:rgba(255,213,74,0.04); }
.pill-gold:hover { background:var(--gold); color:#000; border-color:var(--gold); box-shadow:0 8px 24px rgba(255,213,74,0.25); }

/* ─── COMMUNITY ──────────────────────────────────────────────────── */
.comm { padding:20px 0 100px; }
.comm-card {
  background:linear-gradient(135deg,rgba(8,20,14,0.9) 0%,rgba(0,0,0,0.95) 100%);
  border:1px solid rgba(46,255,148,0.1);
  border-radius:var(--r-lg); padding:60px 56px;
  position:relative; overflow:hidden;
  box-shadow:0 20px 50px rgba(0,0,0,0.5);
  transition:border-color 0.4s;
}
.comm-card:hover { border-color:rgba(46,255,148,0.2); }
.comm-glow {
  position:absolute; top:-40%; left:-10%;
  width:55%; height:160%;
  background:radial-gradient(ellipse,rgba(46,255,148,0.06) 0%,transparent 60%);
  pointer-events:none;
  animation:glowPulse 10s infinite alternate ease-in-out;
}
.comm-row {
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; position:relative; z-index:2;
}
.comm-live {
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.7rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px;
  color:var(--green); margin-bottom:14px; opacity:0.85;
}
.dot-g {
  width:7px; height:7px; border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px var(--green);
  animation:blink 2s infinite;
}
.comm-info h3 {
  font-size:clamp(1.8rem,3vw,2.6rem); font-weight:900;
  letter-spacing:-0.5px; color:#fff; margin-bottom:10px;
}
.comm-info p { font-size:1rem; color:var(--muted); font-weight:300; max-width:75%; }
.btn-wa {
  display:inline-flex; align-items:center; gap:10px;
  padding:17px 36px; border-radius:100px;
  background:#25d366; color:#fff;
  font-weight:700; font-size:1rem;
  box-shadow:0 10px 28px rgba(37,211,102,0.2);
  transition:all 0.4s var(--elastic);
  white-space:nowrap; flex-shrink:0;
}
.btn-wa:hover { transform:translateY(-4px) scale(1.03); box-shadow:0 20px 40px rgba(37,211,102,0.35); }

/* ─── FOOTER ─────────────────────────────────────────────────────── */
.footer {
  border-top:1px solid var(--border);
  padding:64px 0 36px;
  background:#000;
}
.footer-row {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:32px;
}
.footer-l { display:flex; flex-direction:column; }
.footer-logo { width:42px; margin-bottom:16px; opacity:0.85; }
.footer-l p  { font-size:0.88rem; color:#555; }
.footer-l span { font-size:0.75rem; color:#3a3a3a; margin-top:8px; max-width:360px; line-height:1.5; }
.footer-r { display:flex; gap:32px; align-items:center; }
.footer-r a {
  color:var(--muted); font-size:0.88rem; font-weight:500;
  transition:color 0.25s;
  position:relative;
}
.footer-r a::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1px; background:var(--gold);
  transition:width 0.3s var(--ease);
}
.footer-r a:hover { color:#fff; }
.footer-r a:hover::after { width:100%; }

/* ─── REVEAL ANIMATION ───────────────────────────────────────────── */
[data-reveal] {
  opacity:0; transform:translateY(24px);
  transition:opacity 0.8s var(--expo), transform 0.8s var(--expo);
}
[data-reveal].visible { opacity:1; transform:translateY(0); }

/* ─── KEYFRAMES ──────────────────────────────────────────────────── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
  from { opacity:0; transform:translateX(20px); }
  to   { opacity:1; transform:translateX(0); }
}
@keyframes blink {
  0%,100% { opacity:1; }
  50%     { opacity:0.3; }
}
@keyframes ping {
  75%,100% { transform:scale(2.5); opacity:0; }
}
@keyframes floatY {
  0%,100% { transform:translateY(0) rotate(-1deg); }
  50%     { transform:translateY(-14px) rotate(0deg); }
}
@keyframes floatY2 {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-10px); }
}
@keyframes glowPulse {
  from { transform:translate(0,0) scale(1); }
  to   { transform:translate(30px,-20px) scale(1.12); }
}
@keyframes badgePulse {
  0%,100% { box-shadow:0 6px 20px rgba(255,213,74,0.4); }
  50%     { box-shadow:0 8px 28px rgba(255,213,74,0.65); }
}

/* ─── RESPONSIVE ─────────────────────────────────────────────────── */

/* Tablet */
@media (max-width:1100px) {
  .bento {
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:auto;
  }
  .c-scanner { grid-column:span 2; min-height:340px; }
  .c-bot     { grid-column:span 1; min-height:280px; }
  .c-campus  { grid-column:span 1; min-height:280px; }
  .c-capital { grid-column:span 2; }
  .c-deco-r  { right:16px; width:100px; height:100px; }
}

/* Mobile layout break */
@media (max-width:900px) {
  .hero-inner {
    grid-template-columns:1fr; gap:56px; text-align:center;
  }
  .hero-text { align-items:center; }
  .hero-p { max-width:100%; }
  .hero-btns { justify-content:center; }
  .hero-stats { justify-content:center; }
  .hero-pill { justify-content:center; }

  .hero-vis { width:88%; margin:0 auto; }
  .notif {
    left:50%; transform:translateX(-50%);
    bottom:-30px; width:max-content; max-width:90vw;
    animation:none;
  }
  .float-badge {
    right:auto; left:50%; transform:translateX(-50%);
    top:-16px; animation:none;
  }

  .nav-links { display:none; }
  .nav-burger { display:flex; }
}

/* Mobile small */
@media (max-width:768px) {
  .container { padding:0 18px; }

  .bento { grid-template-columns:1fr; gap:12px; }
  .c-scanner,.c-bot,.c-campus,.c-capital { grid-column:span 1; }
  .c-scanner { min-height:300px; }
  .c-bot,.c-campus { min-height:260px; }
  .c-capital { min-height:auto; }

  .card-cnt { padding:22px 24px; }
  .card-cnt-row { flex-direction:column; align-items:flex-start; gap:20px; }
  .card h3 { font-size:1.7rem; margin:16px 0 8px; }
  .card p  { font-size:0.88rem; max-width:100%; }

  .cap-btns { flex-direction:row; width:100%; }
  .pill { flex:1; text-align:center; padding:11px 14px; font-size:0.85rem; }

  .c-deco { width:110px; height:110px; bottom:-15px; right:-15px; }
  .c-deco-r { display:none; }

  .comm-card { padding:36px 24px; }
  .comm-row { flex-direction:column; text-align:center; gap:28px; }
  .comm-info p { max-width:100%; margin:0 auto; }

  .footer-row { flex-direction:column; align-items:center; text-align:center; gap:28px; }
  .footer-r   { gap:24px; }

  .promo-pill { right:20px; font-size:0.65rem; padding:6px 13px; }

  /* Disable hover tilt on mobile */
  .card:hover { transform:none; }
  .card:active { transform:scale(0.99); }

  .hero { padding-top:90px; padding-bottom:60px; }
  .eco  { padding:100px 0 70px; }

  .sec-h2 { font-size:2.4rem; }
}

@media (max-width:480px) {
  .hero-h1 { font-size:3rem; letter-spacing:1.5px; }
  .hero-btns {
    flex-direction:column; align-items:stretch; gap:10px;
    width:100%; max-width:300px;
  }
  .btn-gold,.btn-ghost {
    justify-content:center; text-align:center; padding:14px 24px;
  }
  .hero-vis { width:100%; }
  .modal { padding:32px 24px; }
  .modal-title { font-size:1.6rem; }
}
.btn-tg {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 17px 36px;
  border-radius: 100px;
  background: #0088cc;
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  box-shadow: 0 10px 28px rgba(0, 136, 204, 0.2);
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  white-space: nowrap;
  flex-shrink: 0;
}

.btn-tg:hover {
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 20px 40px rgba(0, 136, 204, 0.35);
}

.btn-tg svg {
  fill: currentColor;
}
@media (max-width: 480px) {
    .comm-btns {
        flex-direction: column;
        width: 100%;
    }
    .btn-wa, .btn-tg {
        width: 100%;
        justify-content: center;
    }
}