/*
Theme Name: Eldi Games
Theme URI: https://eldigames.com
Author: Eldi Games
Author URI: https://eldigames.com
Description: Premium dark gaming portfolio theme with particle FX, animated game cards, and direct Google Play links. Showcases all Eldi Games titles.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: eldigames
*/

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ─────────────────────────────────────────────
   TOKENS
───────────────────────────────────────────── */
:root {
  --ink:        #0a0a14;
  --ink2:       #12121f;
  --ink3:       #1a1a2e;
  --surface:    rgba(255,255,255,.04);
  --surface2:   rgba(255,255,255,.07);
  --rim:        rgba(255,255,255,.09);
  --rim2:       rgba(255,255,255,.15);

  --blue:       #38bdf8;
  --blue-deep:  #0ea5e9;
  --violet:     #a78bfa;
  --pink:       #f472b6;
  --teal:       #2dd4bf;
  --amber:      #fbbf24;
  --emerald:    #34d399;
  --rose:       #fb7185;

  --text:       #f1f1f8;
  --muted:      #6b6b8a;
  --faint:      #3a3a5c;

  --mono: 'JetBrains Mono', monospace;
  --sans: 'Space Grotesk', sans-serif;
  --display: 'Outfit', sans-serif;

  --ease: cubic-bezier(.22,.68,0,1.2);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --r: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
}

/* ─────────────────────────────────────────────
   RESET
───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.7;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}

/* scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--blue-deep);border-radius:3px}

/* ─────────────────────────────────────────────
   UTILITIES
───────────────────────────────────────────── */
.container{max-width:1160px;margin-inline:auto;padding-inline:clamp(1.25rem,4vw,2.5rem)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* ─────────────────────────────────────────────
   CANVAS PARTICLES LAYER
───────────────────────────────────────────── */
#particles-canvas{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  opacity:.5;
}

/* ─────────────────────────────────────────────
   HEADER
───────────────────────────────────────────── */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:.9rem 0;
  transition:background .4s,box-shadow .4s;
}
#site-header.pinned{
  background:rgba(10,10,20,.88);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  box-shadow:0 1px 0 var(--rim);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem}

.logo{
  font-family:var(--display);font-weight:900;font-size:1.3rem;
  letter-spacing:-.02em;display:flex;align-items:center;gap:.25rem;
  position:relative;z-index:1;
}
.logo-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--blue);
  box-shadow:0 0 12px var(--blue);
  display:inline-block;
  animation:pulse-dot 2.5s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 8px var(--blue)}50%{box-shadow:0 0 20px var(--blue),0 0 40px rgba(56,189,248,.3)}}

.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-links a{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);padding:.45rem .85rem;border-radius:6px;
  transition:color .25s,background .25s;
}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--surface2)}

.nav-pill{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.5rem 1.25rem;border-radius:100px;
  background:var(--blue);color:var(--ink);font-weight:500;
  transition:box-shadow .25s,transform .2s;
  white-space:nowrap;
}
.nav-pill:hover{box-shadow:0 0 0 4px rgba(56,189,248,.25);transform:scale(1.03)}

.ham{display:none;flex-direction:column;gap:4.5px;padding:6px;border-radius:6px}
.ham span{width:22px;height:1.5px;background:var(--text);border-radius:2px;display:block;transition:.3s}

/* ─────────────────────────────────────────────
   HERO
───────────────────────────────────────────── */
#hero{
  position:relative;min-height:100svh;
  display:grid;place-items:center;
  padding:120px 0 80px;overflow:hidden;
}

/* Vignette mesh background */
.hero-mesh{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 90% 70% at 50% 20%, rgba(56,189,248,.07) 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 10% 80%, rgba(167,139,250,.07) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 60%, rgba(244,114,182,.05) 0%, transparent 60%);
}

/* horizontal scan line */
.hero-scan{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(56,189,248,.3),transparent);
  animation:scan 6s linear infinite;z-index:0;pointer-events:none;
}
@keyframes scan{from{top:-2%}to{top:102%}}

.hero-inner{position:relative;z-index:1;text-align:center;max-width:820px;margin:0 auto}

.hero-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--blue);border:1px solid rgba(56,189,248,.3);
  background:rgba(56,189,248,.06);
  padding:.3rem .9rem;border-radius:100px;margin-bottom:2rem;
  animation:fadeUp .8s var(--ease-out) both;
}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);animation:pulse-dot 2.5s ease-in-out infinite}

.hero-h1{
  font-family:var(--display);font-weight:900;
  font-size:clamp(3.2rem,8.5vw,7.5rem);
  line-height:.95;letter-spacing:-.04em;
  margin-bottom:1.5rem;
  animation:fadeUp .8s .1s var(--ease-out) both;
}
.hero-h1 em{
  font-style:normal;
  background:linear-gradient(135deg,var(--blue) 0%,var(--violet) 50%,var(--pink) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-sub{
  font-size:1.1rem;color:var(--muted);max-width:520px;margin:0 auto 2.5rem;
  animation:fadeUp .8s .18s var(--ease-out) both;
}

.hero-btns{
  display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;
  animation:fadeUp .8s .26s var(--ease-out) both;
}

.btn-glow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--display);font-weight:700;font-size:.875rem;letter-spacing:.02em;
  padding:.85rem 2rem;border-radius:100px;
  background:linear-gradient(135deg,var(--blue-deep),#2563eb);
  color:#fff;
  box-shadow:0 0 0 1px rgba(56,189,248,.3),inset 0 1px 0 rgba(255,255,255,.15);
  transition:transform .2s,box-shadow .2s;
}
.btn-glow:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 32px rgba(14,165,233,.4),0 0 0 1px rgba(56,189,248,.5)}

.btn-rim{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--display);font-weight:600;font-size:.875rem;letter-spacing:.02em;
  padding:.85rem 2rem;border-radius:100px;
  border:1px solid var(--rim2);color:var(--text);
  transition:border-color .2s,background .2s,transform .2s;
}
.btn-rim:hover{border-color:var(--rim2);background:var(--surface2);transform:translateY(-2px)}

/* hero scroll cue */
.scroll-cue{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  opacity:.4;animation:fadeIn 1s 1s both;
}
.scroll-cue-track{width:1px;height:48px;background:linear-gradient(var(--text),transparent);animation:scrollTrack 2s ease-in-out infinite}
@keyframes scrollTrack{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.scroll-cue span{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase}

/* hero stats bar */
.hero-stats{
  display:flex;gap:0;margin-top:4rem;
  border:1px solid var(--rim);border-radius:var(--r-lg);
  overflow:hidden;background:var(--surface);
  backdrop-filter:blur(12px);
  animation:fadeUp .8s .34s var(--ease-out) both;
}
.hstat{
  flex:1;padding:1.5rem;text-align:center;
  border-right:1px solid var(--rim);
  position:relative;
}
.hstat:last-child{border-right:none}
.hstat-num{
  font-family:var(--display);font-weight:900;font-size:2rem;
  display:block;margin-bottom:.15rem;
  background:linear-gradient(135deg,var(--text),var(--muted));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hstat-label{font-family:var(--mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ─────────────────────────────────────────────
   SECTION WRAPPER
───────────────────────────────────────────── */
.section{padding:7rem 0;position:relative}

.eyebrow{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue);margin-bottom:.75rem;display:block;
}

.section-h2{
  font-family:var(--display);font-weight:900;
  font-size:clamp(2rem,4vw,3rem);line-height:1.05;letter-spacing:-.03em;
  margin-bottom:.6rem;
}

.section-lead{color:var(--muted);font-size:1rem;max-width:480px}

/* ─────────────────────────────────────────────
   TICKER
───────────────────────────────────────────── */
.ticker{
  overflow:hidden;border-top:1px solid var(--rim);border-bottom:1px solid var(--rim);
  padding:.8rem 0;background:var(--surface);
}
.ticker-inner{display:flex;gap:3rem;white-space:nowrap;animation:scroll-left 35s linear infinite}
.ticker-inner:hover{animation-play-state:paused}
@keyframes scroll-left{to{transform:translateX(-50%)}}
.ticker-item{
  display:flex;align-items:center;gap:.75rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
  flex-shrink:0;
}
.ticker-sep{width:4px;height:4px;border-radius:50%;background:var(--blue);opacity:.5}

/* ─────────────────────────────────────────────
   FEATURED GAME SPOTLIGHT
───────────────────────────────────────────── */
#featured{padding:5rem 0 0}
.featured-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
  background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-xl);
  padding:3rem;overflow:hidden;position:relative;
}
.featured-inner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 70% at 80% 50%,rgba(56,189,248,.05),transparent);
  pointer-events:none;
}
.featured-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--amber);background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25);
  padding:.25rem .7rem;border-radius:100px;margin-bottom:1.25rem;
}
.featured-title{
  font-family:var(--display);font-weight:900;font-size:clamp(2rem,3.5vw,3rem);
  line-height:1.05;letter-spacing:-.03em;margin-bottom:1rem;
}
.featured-desc{color:var(--muted);font-size:.95rem;line-height:1.75;margin-bottom:2rem}
.featured-meta{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.meta-tag{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.25rem .65rem;border-radius:6px;background:var(--surface2);border:1px solid var(--rim);
  color:var(--muted);
}
.featured-visual{position:relative;border-radius:var(--r-lg);overflow:hidden}
.featured-icon{
  width:100%;aspect-ratio:1;border-radius:var(--r-lg);object-fit:cover;
  box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 0 1px var(--rim);
  transition:transform .4s var(--ease-out);
}
.featured-inner:hover .featured-icon{transform:scale(1.03)}
.featured-glow{
  position:absolute;inset:-20px;
  background:radial-gradient(circle,rgba(56,189,248,.15),transparent 60%);
  filter:blur(30px);pointer-events:none;z-index:-1;
}

/* ─────────────────────────────────────────────
   FILTER TABS
───────────────────────────────────────────── */
.filter-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.45rem 1rem;border-radius:100px;
  border:1px solid var(--rim);background:transparent;color:var(--muted);
  transition:all .2s;
}
.filter-btn:hover{border-color:var(--rim2);color:var(--text);background:var(--surface)}
.filter-btn.active{background:var(--blue);border-color:var(--blue);color:var(--ink);font-weight:600}

/* ─────────────────────────────────────────────
   GAMES GRID
───────────────────────────────────────────── */
.games-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.25rem;
}

/* ── Game Card ── */
.game-card{
  background:var(--surface);
  border:1px solid var(--rim);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease-out),border-color .3s,box-shadow .3s;
  position:relative;
  will-change:transform;
}
.game-card:hover{transform:translateY(-5px);border-color:var(--rim2)}

/* card accent bar top */
.game-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--card-accent,var(--blue));opacity:0;
  transition:opacity .3s;
}
.game-card:hover::after{opacity:1}

.card-top{padding:1.25rem 1.25rem 0;display:flex;align-items:flex-start;gap:.85rem}
.card-icon{
  width:60px;height:60px;border-radius:12px;object-fit:cover;flex-shrink:0;
  box-shadow:0 4px 16px rgba(0,0,0,.3);
}
.card-icon-ph{
  width:60px;height:60px;border-radius:12px;flex-shrink:0;
  background:var(--ink3);border:1px solid var(--rim);
  display:grid;place-items:center;font-size:1.5rem;
}
.card-info{flex:1;min-width:0}
.card-name{
  font-family:var(--display);font-weight:700;font-size:.95rem;line-height:1.2;
  margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.card-cat{font-family:var(--mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.card-rating{
  display:inline-flex;align-items:center;gap:.25rem;margin-top:.25rem;
  font-family:var(--mono);font-size:.7rem;color:var(--amber);
}
.star-icon{font-size:.7rem}

.card-body{padding:1rem 1.25rem;flex:1}
.card-body p{font-size:.875rem;color:var(--muted);line-height:1.65;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

.card-footer{
  padding:1rem 1.25rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--rim);margin-top:auto;
}
.card-chip{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.2rem .6rem;border-radius:6px;border:1px solid;
}
.chip-blue  {color:var(--blue);  border-color:rgba(56,189,248,.3); background:rgba(56,189,248,.07)}
.chip-violet{color:var(--violet);border-color:rgba(167,139,250,.3);background:rgba(167,139,250,.07)}
.chip-pink  {color:var(--pink);  border-color:rgba(244,114,182,.3);background:rgba(244,114,182,.07)}
.chip-teal  {color:var(--teal);  border-color:rgba(45,212,191,.3); background:rgba(45,212,191,.07)}
.chip-amber {color:var(--amber); border-color:rgba(251,191,36,.3); background:rgba(251,191,36,.07)}
.chip-green {color:var(--emerald);border-color:rgba(52,211,153,.3);background:rgba(52,211,153,.07)}

.dl-btn{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;
  padding:.42rem .9rem;border-radius:8px;
  border:1px solid var(--card-accent,var(--blue));
  color:var(--card-accent,var(--blue));
  transition:all .2s;
  font-weight:500;
}
.dl-btn:hover{
  background:var(--card-accent,var(--blue));
  color:var(--ink);
  box-shadow:0 4px 20px rgba(var(--card-accent-rgb,56 189 248),.35);
}
.dl-icon{width:13px;height:13px;flex-shrink:0}

/* ─────────────────────────────────────────────
   ABOUT SECTION
───────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}

.about-visual-wrap{position:relative}

/* big number backdrop */
.about-bg-num{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--display);font-weight:900;font-size:18rem;line-height:1;
  color:rgba(255,255,255,.02);letter-spacing:-.1em;pointer-events:none;user-select:none;
  white-space:nowrap;
}

.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;position:relative;z-index:1}
.about-card{
  background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-lg);
  padding:1.5rem;transition:border-color .2s,background .2s;
}
.about-card:hover{border-color:var(--rim2);background:var(--surface2)}
.about-card-icon{font-size:1.5rem;margin-bottom:.75rem}
.about-card h4{font-family:var(--display);font-weight:700;font-size:.9rem;margin-bottom:.35rem}
.about-card p{font-size:.8rem;color:var(--muted);line-height:1.6}

/* tall accent card */
.about-card.tall{grid-column:span 2}

.about-text h2{font-family:var(--display);font-weight:900;font-size:clamp(2rem,3vw,2.8rem);line-height:1.1;letter-spacing:-.03em;margin-bottom:1.25rem}
.about-text p{color:var(--muted);font-size:.95rem;line-height:1.8;margin-bottom:1rem}

.pillars{margin-top:2rem;display:flex;flex-direction:column;gap:.6rem}
.pillar{
  display:flex;align-items:center;gap:.75rem;
  font-size:.875rem;padding:.65rem .85rem;
  border-radius:10px;border:1px solid var(--rim);background:var(--surface);
  transition:border-color .2s,background .2s;
}
.pillar:hover{border-color:var(--rim2);background:var(--surface2)}
.pillar-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* ─────────────────────────────────────────────
   CTA SECTION
───────────────────────────────────────────── */
#cta{padding:5rem 0 8rem}
.cta-box{
  background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-xl);
  padding:clamp(3rem,6vw,5rem) clamp(2rem,5vw,4rem);
  text-align:center;position:relative;overflow:hidden;
}
.cta-box::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 60% at 30% 50%,rgba(167,139,250,.06),transparent),
    radial-gradient(ellipse 60% 60% at 70% 50%,rgba(56,189,248,.06),transparent);
  pointer-events:none;
}
.cta-box h2{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;letter-spacing:-.03em;margin-bottom:1rem}
.cta-box p{color:var(--muted);font-size:1rem;max-width:440px;margin:0 auto 2.5rem}

/* ─────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────── */
#site-footer{
  border-top:1px solid var(--rim);padding:2.5rem 0;
}
.footer-wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:var(--display);font-weight:900;font-size:1.1rem;letter-spacing:-.02em}
.footer-nav{display:flex;gap:1.25rem;list-style:none}
.footer-nav a{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.footer-nav a:hover{color:var(--text)}
.footer-copy{font-family:var(--mono);font-size:.68rem;color:var(--muted);letter-spacing:.05em}

/* ─────────────────────────────────────────────
   FLOATING DOWNLOAD FAB
───────────────────────────────────────────── */
.fab{
  position:fixed;bottom:2rem;right:2rem;z-index:150;
  display:flex;align-items:center;gap:.6rem;
  font-family:var(--display);font-weight:700;font-size:.8rem;letter-spacing:.02em;
  padding:.7rem 1.4rem;border-radius:100px;
  background:linear-gradient(135deg,var(--blue-deep),#4f46e5);
  color:#fff;
  box-shadow:0 8px 32px rgba(14,165,233,.4),0 0 0 1px rgba(56,189,248,.2);
  transition:transform .2s,box-shadow .2s,opacity .3s;
  opacity:0;pointer-events:none;
}
.fab.show{opacity:1;pointer-events:auto}
.fab:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 12px 40px rgba(14,165,233,.55)}
.fab svg{width:16px;height:16px;flex-shrink:0}

/* ─────────────────────────────────────────────
   ANIMATIONS
───────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}

/* Card stagger */
.game-card{opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out),border-color .3s,box-shadow .3s}
.game-card.in{opacity:1;transform:translateY(0)}
.game-card.hidden{opacity:0!important;transform:scale(.95)!important;pointer-events:none;position:absolute!important}

/* ─────────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────────── */
@media(max-width:860px){
  .about-grid,.featured-inner{grid-template-columns:1fr}
  .featured-visual{order:-1}
  .hero-stats{flex-wrap:wrap}
  .hstat{flex:1 1 45%;border-bottom:1px solid var(--rim)}
}
@media(max-width:640px){
  .nav-links,.nav-pill{display:none}
  .ham{display:flex}
  .about-cards{grid-template-columns:1fr}
  .about-card.tall{grid-column:span 1}
  .footer-wrap{flex-direction:column;text-align:center}
  .fab{bottom:1rem;right:1rem;font-size:.75rem;padding:.6rem 1.1rem}
}

/* Mobile menu open */
.nav-links.open{
  display:flex;flex-direction:column;
  position:fixed;inset:0;z-index:100;
  background:rgba(10,10,20,.97);backdrop-filter:blur(20px);
  align-items:center;justify-content:center;gap:2rem;
}
.nav-links.open a{font-size:1.2rem;padding:.75rem 2rem}

/* ─────────────────────────────────────────────
   FEATURED — TEXT ONLY VARIANT
───────────────────────────────────────────── */
.featured-text-only {
  grid-template-columns: auto 1fr;
  gap: 3rem;
  align-items: center;
}

.featured-emoji-block {
  width: 140px;
  height: 140px;
  border-radius: var(--r-xl);
  background: rgba(56,189,248,.07);
  border: 1px solid rgba(56,189,248,.18);
  display: grid;
  place-items: center;
  font-size: 4.5rem;
  flex-shrink: 0;
  box-shadow: 0 24px 64px rgba(0,0,0,.35), 0 0 0 1px var(--rim);
  transition: transform .4s var(--ease-out), box-shadow .4s;
}
.featured-inner:hover .featured-emoji-block {
  transform: scale(1.06) rotate(-3deg);
  box-shadow: 0 32px 80px rgba(0,0,0,.45);
}

/* Card emoji icon – colored background */
.card-icon-ph {
  width: 60px;
  height: 60px;
  border-radius: 14px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  font-size: 1.6rem;
}

@media(max-width:640px){
  .featured-text-only { grid-template-columns: 1fr; }
  .featured-emoji-block { width: 90px; height: 90px; font-size: 3rem; }
}
