/* ============================================================
   CEL — Cambodia Esports League  |  Shared Stylesheet
   Brand: Dark Green #2f4a2b  +  Light Yellow #ebe285
   Type:  DAMN (display headlines)  +  Inter (everything else)
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:'DAMN';src:url('assets/fonts/DAMN.ttf') format('truetype');font-weight:400;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Light.ttf') format('truetype');font-weight:300;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Regular.ttf') format('truetype');font-weight:400;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Medium.ttf') format('truetype');font-weight:500;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-SemiBold.ttf') format('truetype');font-weight:600;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Bold.ttf') format('truetype');font-weight:700;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-ExtraBold.ttf') format('truetype');font-weight:800;font-display:swap;}
@font-face{font-family:'Inter';src:url('assets/fonts/Inter-Black.ttf') format('truetype');font-weight:900;font-display:swap;}

/* ---------- Tokens ---------- */
:root{
  --green:#2f4a2b;        /* brand dark green */
  --green-700:#26401f;
  --green-900:#16240f;
  --green-deep:#0f1a0c;   /* near-black green for hero bg */
  --yellow:#ebe285;       /* brand light yellow */
  --yellow-bright:#f2ec9d;
  --cream:#f7f7f1;        /* light section bg */
  --ink:#1c2417;          /* body text on light */
  --muted:#5d6b54;        /* muted text on light */
  --line:#e2e4d6;         /* hairline on light */
  --white:#ffffff;
  --maxw:1180px;
  --radius:14px;
  --shadow:0 18px 50px -22px rgba(15,26,12,.45);
  --ease:cubic-bezier(.16,.84,.44,1);
}

/* ---------- Base ---------- */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* Subtle film grain over the whole viewport for broadcast depth */
body::before{
  content:"";position:fixed;inset:0;z-index:40;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* Display type */
.display{font-family:'DAMN',sans-serif;font-weight:400;line-height:.92;letter-spacing:.5px;text-transform:uppercase;}
h1.display{font-size:clamp(2.8rem,7vw,6rem);}
h2.display{font-size:clamp(2rem,4.6vw,3.4rem);}
h3.display{font-size:clamp(1.4rem,2.4vw,2rem);}

.eyebrow{
  font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--green);display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--yellow);display:inline-block;}
.on-dark .eyebrow,.eyebrow.light{color:var(--yellow);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-weight:700;font-size:.95rem;letter-spacing:.02em;
  padding:.85rem 1.6rem;border-radius:999px;cursor:pointer;border:2px solid transparent;
  transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s;
}
.btn:hover{transform:translateY(-2px);}
.btn-yellow{background:var(--yellow);color:var(--green-900);box-shadow:0 10px 24px -12px rgba(235,226,133,.55);}
.btn-yellow:hover{background:var(--yellow-bright);box-shadow:0 16px 32px -12px rgba(235,226,133,.65);}
.btn-green{background:var(--green);color:var(--yellow);}
.btn-green:hover{background:var(--green-700);}
.btn-ghost{border-color:rgba(235,226,133,.5);color:var(--yellow);}
.btn-ghost:hover{border-color:var(--yellow);background:rgba(235,226,133,.08);}
.btn-ghost-dark{border-color:var(--green);color:var(--green);}
.btn-ghost-dark:hover{background:var(--green);color:var(--yellow);}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(15,26,12,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(235,226,133,.14);
  transition:background .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.site-header.scrolled{
  background:rgba(12,21,10,.95);box-shadow:0 12px 34px -20px rgba(0,0,0,.8);
  border-bottom-color:rgba(235,226,133,.22);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;transition:height .3s var(--ease);}
.site-header.scrolled .nav{height:62px;}
.site-header.scrolled .nav-logo img{height:32px;}
.nav-logo{display:flex;align-items:center;flex:0 0 auto;}
.nav-logo img{height:38px;width:auto;max-width:none;flex:0 0 auto;transition:height .3s var(--ease);}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;}
.nav-links a{
  color:#e9efe2;font-weight:500;font-size:.95rem;letter-spacing:.01em;position:relative;padding:4px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;background:var(--yellow);transition:width .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--yellow);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-cta{margin-left:.5rem;}
.nav-links a.nav-cta{color:var(--green-900);font-weight:600;padding:.6rem 1.4rem;font-size:.9rem;line-height:1;white-space:nowrap;} /* semi-bold pill, dark-green text on yellow */
.nav-links a.nav-cta:hover{color:var(--green-900);}
.nav-links a.nav-cta::after{display:none;}          /* no underline under the button */
.nav-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px;}
.nav-toggle span{width:26px;height:2.5px;background:var(--yellow);border-radius:2px;transition:.3s;}

/* ---------- Hero ---------- */
.hero{
  position:relative;background:var(--green-deep);color:#eef3e8;overflow:hidden;
  padding:clamp(4rem,11vw,8.5rem) 0 clamp(3.5rem,9vw,7rem);
}
.hero::before{ /* sharp diagonal energy field + top glow */
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;
  background:
    radial-gradient(120% 85% at 80% 4%, rgba(235,226,133,.16), transparent 55%),
    repeating-linear-gradient(115deg, transparent 0 40px, rgba(235,226,133,.05) 40px 41px);
  -webkit-mask-image:linear-gradient(180deg,#000 58%,transparent);
          mask-image:linear-gradient(180deg,#000 58%,transparent);
}
.hero::after{ /* warm depth glow, bottom-right */
  content:"";position:absolute;right:-15%;bottom:-32%;width:62vw;height:62vw;pointer-events:none;
  background:radial-gradient(circle, rgba(47,74,43,.85), transparent 64%);
}
.hero .wrap{position:relative;z-index:2;}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;}
.hero h1{margin:.4rem 0 1.3rem;color:#fff;}
.hero h1 .y{color:var(--yellow);position:relative;display:inline-block;}
.hero h1 .y::after{ /* kinetic underline draw-in */
  content:"";position:absolute;left:0;bottom:.02em;height:.09em;width:100%;border-radius:2px;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;
  animation:drawline .9s var(--ease) .4s forwards;
}
.hero p.lead{font-size:1.18rem;color:#cdd8c4;max-width:34rem;margin-bottom:2rem;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;}
.hero-emblem{position:relative;justify-self:center;width:min(380px,82%);
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.5));}
.hero-emblem img{width:100%;position:relative;z-index:1;animation:float 7s ease-in-out infinite;}
.hero-emblem::before{ /* radial glow halo */
  content:"";position:absolute;inset:-12%;border-radius:50%;z-index:0;
  background:radial-gradient(circle, rgba(235,226,133,.20), transparent 60%);
  animation:pulse 6s ease-in-out infinite;
}
.hero-emblem::after{ /* slow orbital ring */
  content:"";position:absolute;inset:1%;border-radius:50%;z-index:0;
  border:1.5px dashed rgba(235,226,133,.26);animation:spin 30s linear infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes pulse{0%,100%{opacity:.55;transform:scale(.98)}50%{opacity:1;transform:scale(1.05)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes drawline{to{transform:scaleX(1)}}

/* ---------- Stat band ---------- */
.statband{background:var(--yellow);color:var(--green-900);}
.statband .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2.4rem 28px;}
.stat{position:relative;text-align:center;}
.stat:not(:first-child)::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  height:56%;width:1px;background:rgba(22,36,15,.20);}
.stat .num{font-family:'DAMN',sans-serif;font-size:clamp(2.2rem,4.4vw,3.4rem);line-height:1;}
.stat .lbl{font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-top:.4rem;color:var(--green-700);}

/* ---------- Sections ---------- */
section{padding:clamp(3.5rem,8vw,6rem) 0;}
.section-head{max-width:42rem;margin-bottom:2.6rem;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{margin:.7rem 0 .8rem;color:var(--green);}
.section-head p{color:var(--muted);font-size:1.05rem;}
.bg-green{background:var(--green-deep);color:#e7eede;}
.bg-green .section-head h2{color:#fff;}
.bg-green .section-head p{color:#bccab1;}
.bg-cream{background:var(--cream);}
.bg-soft{background:#eef0e4;}

/* ---------- Cards: games ---------- */
.cards{display:grid;gap:1.4rem;}
.cards.c3{grid-template-columns:repeat(3,1fr);}
.cards.c4{grid-template-columns:repeat(4,1fr);}
.cards.c2{grid-template-columns:repeat(2,1fr);}

.game-card{
  position:relative;border-radius:var(--radius);overflow:hidden;min-height:230px;
  background:linear-gradient(160deg,var(--green-700),var(--green-deep));
  border:1px solid rgba(235,226,133,.16);display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.5rem;color:#eaf0e3;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
}
.game-card::before{ /* accent bar draws across on hover */
  content:"";position:absolute;top:0;left:0;right:0;height:3px;z-index:2;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
}
.game-card:hover{transform:translateY(-6px);border-color:var(--yellow);box-shadow:0 26px 54px -26px rgba(235,226,133,.28);}
.game-card:hover::before{transform:scaleX(1);}
.game-card .tag{font-family:'DAMN',sans-serif;font-size:clamp(2.1rem,2.7vw,2.55rem);line-height:1;letter-spacing:.5px;color:var(--yellow);position:relative;z-index:2;}
.game-card .meta{font-size:.9rem;color:#c2cfb8;margin-top:.45rem;position:relative;z-index:2;}
.game-card .corner{position:absolute;top:1rem;right:1.1rem;font-size:.7rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--green-900);background:var(--yellow);padding:.25rem .6rem;border-radius:999px;z-index:3;}

/* Custom per-game background art (drop-in): add class "has-bg" + a background-image.
   3:2 ratio so a 1200x800 design fills the card with no crop. Banners are green-tinted
   with the subject on the right, so the scrim is green (not black) to stay on-brand and
   layers a soft bottom + left wash to seat the bottom-left tag/meta text. */
.game-card.has-bg{aspect-ratio:3/2;min-height:0;background-size:cover;background-position:center;}
/* No CSS scrim: banners already fade to dark green at the bottom, so the
   yellow tag + meta text read cleanly straight on the artwork. */

/* ---------- Pillars ---------- */
.pillar{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;transition:transform .3s var(--ease),box-shadow .3s;}
.pillar:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.pillar .no{font-family:'DAMN',sans-serif;font-size:2.4rem;color:var(--green);}
.pillar h3{font-size:1.15rem;color:var(--green);margin:.4rem 0 .6rem;font-weight:800;}
.pillar p{color:var(--muted);font-size:.97rem;}

/* ---------- Tournament cards ---------- */
.tour-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s;
}
.tour-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--green);}
.tour-top{background:linear-gradient(150deg,var(--green),var(--green-deep));color:#eaf0e3;padding:1.3rem 1.4rem;position:relative;}
.tour-top .game{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);}
.tour-top h3{font-family:'DAMN',sans-serif;font-weight:400;font-size:1.45rem;line-height:1.18;letter-spacing:.045em;word-spacing:.06em;margin-top:.35rem;color:#fff;text-transform:uppercase;}
.tour-star{position:absolute;top:1rem;right:1.1rem;color:var(--yellow);font-size:1rem;}
.tour-body{padding:1.2rem 1.4rem 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:.9rem;}
.tour-body .f{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;}
.tour-body .v{font-size:1rem;font-weight:700;color:var(--green);}
.tpl{outline:2px dashed rgba(47,74,43,.28);outline-offset:-2px;}
.tpl-note{font-size:.78rem;color:var(--muted);background:#fffdf0;border:1px solid var(--line);border-left:3px solid var(--yellow);
  padding:.7rem 1rem;border-radius:8px;margin-top:1.4rem;}

/* ---------- Partners / logos ---------- */
.logo-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 2.2rem;}
.logo-chip{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.6rem;font-weight:800;
  color:var(--green);letter-spacing:.02em;min-width:150px;text-align:center;
  transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;}
.logo-chip:hover{transform:translateY(-4px);border-color:var(--green);box-shadow:0 16px 34px -20px rgba(47,74,43,.4);}
.logo-chip span{display:block;font-size:.68rem;font-weight:600;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;}

/* ---------- Offer list ---------- */
.offer{display:grid;gap:1.1rem;}
.offer .row{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:1.2rem 1.4rem;}
.offer .ic{flex:0 0 auto;width:46px;height:46px;border-radius:10px;background:var(--green);color:var(--yellow);
  display:grid;place-items:center;}
.offer .ic svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;}
.offer h4{color:var(--green);font-size:1.05rem;margin-bottom:.2rem;}
.offer p{color:var(--muted);font-size:.95rem;}

/* ---------- CTA band ---------- */
.cta{background:var(--green-deep);color:#eef3e8;text-align:center;position:relative;overflow:hidden;}
.cta::before{content:"";position:absolute;inset:0;opacity:.15;
  background:repeating-radial-gradient(circle at 50% 120%,transparent 0 70px,rgba(235,226,133,.2) 70px 72px);}
.cta .wrap{position:relative;z-index:2;}
.cta h2{color:#fff;margin-bottom:1rem;}
.cta p{color:#c4d2ba;max-width:34rem;margin:0 auto 2rem;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start;}
.contact-list{display:grid;gap:1rem;}
.contact-item{display:flex;gap:1rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.3rem;transition:border-color .25s,transform .25s;}
.contact-item:hover{border-color:var(--green);transform:translateX(4px);}
.contact-item .ic{width:44px;height:44px;border-radius:10px;background:var(--yellow);color:var(--green-900);display:grid;place-items:center;font-weight:800;flex:0 0 auto;}
.contact-item .ic svg{width:22px;height:22px;fill:currentColor;}
.contact-item .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;}
.contact-item .val{font-weight:700;color:var(--green);}
form .field{margin-bottom:1.1rem;}
form label{display:block;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.4rem;}
form input,form textarea{width:100%;font-family:inherit;font-size:1rem;padding:.85rem 1rem;border:1px solid var(--line);
  border-radius:10px;background:#fff;color:var(--ink);transition:border-color .2s;}
form input:focus,form textarea:focus{outline:none;border-color:var(--green);}

/* ---------- Footer ---------- */
.site-footer{background:#0c150a;color:#a9b8a0;padding:3.5rem 0 2rem;}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:2.5rem;margin-bottom:1.6rem;}
.footer-connect{display:flex;flex-direction:column;align-items:flex-start;gap:.9rem;margin-bottom:1.5rem;}
.site-footer img.flogo{height:40px;margin-bottom:1rem;}
.site-footer h5{color:var(--yellow);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem;}
.site-footer a{display:block;color:#a9b8a0;padding:.25rem 0;transition:color .2s;}
.site-footer a:hover{color:var(--yellow);}
.footer-bottom{border-top:1px solid rgba(235,226,133,.12);padding-top:1.5rem;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:.6rem;font-size:.85rem;color:#7d8c74;}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:var(--green-deep);color:#eef3e8;padding:clamp(3rem,7vw,5.5rem) 0 clamp(2.5rem,5vw,4rem);position:relative;overflow:hidden;}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.12;
  background:radial-gradient(circle at 85% 20%,rgba(235,226,133,.5),transparent 40%);}
.page-hero .wrap{position:relative;z-index:2;}
.page-hero h1{color:#fff;margin:.5rem 0 .8rem;}
.page-hero p{color:#c4d2ba;max-width:38rem;font-size:1.08rem;}
.breadcrumb{font-size:.82rem;color:#9fb094;}
.breadcrumb a:hover{color:var(--yellow);}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;text-align:center;}
  .hero-emblem{order:-1;width:210px;}
  .hero p.lead{margin-left:auto;margin-right:auto;}
  .hero-actions{justify-content:center;}
  .cards.c4{grid-template-columns:repeat(2,1fr);}
  .cards.c3{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .statband .wrap{grid-template-columns:repeat(2,1fr);gap:1.6rem;}
  .stat:not(:first-child)::before{display:none;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:680px){
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:rgba(12,21,10,.98);flex-direction:column;gap:0;
    padding:1rem 0;transform:translateY(-130%);transition:transform .35s var(--ease);border-bottom:1px solid rgba(235,226,133,.14);
  }
  .nav-links.open{transform:translateY(0);}
  .nav-links li{width:100%;text-align:center;}
  .nav-links a{display:block;padding:.9rem 0;}
  .nav-links .nav-cta{margin:.6rem auto;display:inline-flex;}
  .nav-toggle{display:flex;}
  .cards.c4,.cards.c3,.cards.c2{grid-template-columns:1fr;}
  .tour-body{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;}
}

/* ---------- Pillar icons (value props) ---------- */
.pillar .pic{width:54px;height:54px;border-radius:12px;background:var(--green);color:var(--yellow);
  display:grid;place-items:center;margin-bottom:1rem;}
.pillar .pic svg{width:27px;height:27px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;}

/* ---------- Footer social icons ---------- */
.social-icons{display:flex;gap:.7rem;}
.social-icons a{width:42px;height:42px;border-radius:10px;border:1px solid rgba(235,226,133,.2);
  display:grid;place-items:center;color:#a9b8a0;padding:0;
  transition:color .2s,border-color .2s,background .2s,transform .2s;}
.social-icons a:hover{color:var(--green-900);background:var(--yellow);border-color:var(--yellow);transform:translateY(-3px);}
.social-icons svg{width:20px;height:20px;fill:currentColor;}
.footer-email{display:inline-block;color:#a9b8a0;font-size:.9rem;}
.footer-email:hover{color:var(--yellow);}

/* ---------- Gallery ---------- */
.gallery-album{margin-bottom:3.2rem;}
.gallery-album:last-child{margin-bottom:0;}
.album-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-bottom:1.2rem;padding-bottom:.8rem;border-bottom:1px solid var(--line);}
.album-head h3{font-family:'DAMN',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.045em;
  word-spacing:.06em;font-size:1.75rem;line-height:1.1;color:var(--green);}
.album-head .album-game{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green);
  background:var(--yellow);padding:.25rem .7rem;border-radius:999px;margin-right:.6rem;}
.album-head .album-meta{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.gallery-tile{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;
  background:linear-gradient(160deg,var(--green-700),var(--green-deep));
  border:1px solid rgba(235,226,133,.14);display:grid;place-items:center;color:rgba(235,226,133,.42);}
.gallery-tile img{width:100%;height:100%;object-fit:cover;}
.gallery-tile .ph{display:flex;flex-direction:column;align-items:center;gap:.55rem;
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;}
.gallery-tile .ph svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.5;}
a.gallery-tile{cursor:pointer;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;}
a.gallery-tile:hover{transform:translateY(-4px);border-color:var(--yellow);box-shadow:0 22px 46px -26px rgba(235,226,133,.3);}
.gallery-note{font-size:.82rem;color:var(--muted);background:#fffdf0;border:1px solid var(--line);border-left:3px solid var(--yellow);
  padding:.8rem 1.1rem;border-radius:8px;margin-bottom:2.4rem;}
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,12,6,.93);display:flex;align-items:center;justify-content:center;padding:4vw;}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;border:1px solid rgba(235,226,133,.25);}
.lightbox-close{position:absolute;top:1rem;right:1.4rem;background:none;border:0;color:var(--yellow);font-size:2.6rem;line-height:1;cursor:pointer;}

/* ---------- Accessibility ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:100;
  background:var(--yellow);color:var(--green-900);font-weight:700;
  padding:.7rem 1.3rem;border-radius:0 0 10px 0;
}
.skip-link:focus{left:0;}
.hidden-field{position:absolute !important;left:-9999px;width:1px;height:1px;overflow:hidden;}
:focus-visible{outline:3px solid var(--green);outline-offset:2px;}
.site-header :focus-visible,.hero :focus-visible,.page-hero :focus-visible,
.bg-green :focus-visible,.cta :focus-visible,.site-footer :focus-visible{
  outline-color:var(--yellow);
}
/* ============================================================
   BRAND REFRESH — leaf pattern texture, founders, 3D layer
   ============================================================ */

/* ---- Three.js ambient particle canvas (sits behind hero content) ---- */
.hero .wrap,.page-hero .wrap{position:relative;z-index:3;}
.hero canvas.fx,.page-hero canvas.fx{
  position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;
}

/* ---- Founders (circular headshot, details below) ---- */
.founders{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;}
.founder{
  position:relative;border-radius:var(--radius);background:#fff;text-align:center;
  border:1px solid var(--line);box-shadow:0 10px 30px -22px rgba(15,26,12,.4);
  padding:2.2rem 1.6rem 2rem;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;
}
.founder:hover{transform:translateY(-6px);border-color:var(--green);box-shadow:var(--shadow);}
.founder-ava{width:150px;height:150px;border-radius:50%;margin:0 auto 1.2rem;overflow:hidden;
  background:var(--cream);border:3px solid var(--green);
  box-shadow:0 12px 26px -14px rgba(15,26,12,.5);}
.founder-ava img{width:100%;height:100%;object-fit:cover;object-position:top center;
  transition:transform .5s var(--ease);}
.founder:hover .founder-ava img{transform:scale(1.05);}
.founder .alias{font-family:'DAMN',sans-serif;font-weight:400;font-size:1.85rem;line-height:1;
  letter-spacing:.5px;text-transform:uppercase;color:var(--green);}
.founder .fname{font-size:.9rem;font-weight:600;color:var(--muted);margin-top:.35rem;}
.founder .role{display:inline-block;margin-top:.9rem;font-size:.64rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--green-900);background:var(--yellow);padding:.32rem .8rem;border-radius:999px;}
.founder .desc{color:var(--muted);font-size:.92rem;line-height:1.55;margin-top:.95rem;}

@media(max-width:880px){.founders{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.founders{grid-template-columns:1fr;}}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  .hero-emblem img,.hero-emblem::before,.hero-emblem::after{animation:none;}
  .hero h1 .y::after{animation:none;transform:scaleX(1);}
  .reveal{opacity:1;transform:none;transition:none;}
  .btn,.game-card,.pillar,.tour-card,.contact-item,.nav-links,.founder,.founder-ava img{transition:none;}
  .btn:hover,.game-card:hover,.pillar:hover,.tour-card:hover,.contact-item:hover,.founder:hover{transform:none;}
  .founder:hover .founder-ava img{transform:none;}
}
