/* Paris Grand Cercle — style.css */

/* ===========================
   CSS VARIABLES
   =========================== */
:root {
  --bg-primary:    #06091a;
  --bg-secondary:  #0c1228;
  --bg-card:       #101830;
  --bg-card-hover: #152040;

  --border:        rgba(201,168,76,.15);
  --border-hover:  rgba(201,168,76,.45);

  --gold:          #c9a84c;
  --gold-light:    #e8c96e;
  --gold-dark:     #9a7830;
  --gold-bg:       rgba(201,168,76,.08);
  --gold-glow:     0 0 40px rgba(201,168,76,.25);

  --text-primary:  #edf2ff;
  --text-secondary:#8a9bc4;
  --text-muted:    #4a5a80;

  --success:  #22c55e;
  --error:    #ef4444;

  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  22px;
  --r-xl:  32px;

  --sh-sm:   0 2px 10px rgba(0,0,0,.35);
  --sh-md:   0 6px 24px rgba(0,0,0,.45);
  --sh-lg:   0 12px 48px rgba(0,0,0,.55);
  --sh-gold: 0 6px 36px rgba(201,168,76,.22);

  --ease: cubic-bezier(.4,0,.2,1);
  --nav-h: 72px;
}

/* ===========================
   RESET & BASE
   =========================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg-primary);
  color:var(--text-primary);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--gold);text-decoration:none;transition:color .2s var(--ease);}
a:hover{color:var(--gold-light);}
ul{list-style:none;}
button{cursor:pointer;font-family:inherit;border:none;outline:none;background:none;}

/* ===========================
   TYPOGRAPHY
   =========================== */
h1,h2,h3,h4{
  font-family:'Playfair Display',Georgia,serif;
  font-weight:700;line-height:1.2;color:var(--text-primary);
}
h1{font-size:clamp(2.2rem,5vw,3.8rem);}
h2{font-size:clamp(1.6rem,3vw,2.4rem);}
h3{font-size:clamp(1.15rem,2vw,1.55rem);}
p{color:var(--text-secondary);line-height:1.75;}

.text-gold{color:var(--gold);}
.text-center{text-align:center;}

.section-eyebrow{
  display:inline-block;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);
  background:var(--gold-bg);
  border:1px solid rgba(201,168,76,.3);
  border-radius:100px;padding:.3em 1em;margin-bottom:1rem;
}
.section-desc{max-width:640px;margin:0 auto 3rem;}

/* ===========================
   LAYOUT
   =========================== */
.container{max-width:1180px;margin:0 auto;padding:0 24px;}
section{padding:96px 0;}

/* ===========================
   AGE GATE
   =========================== */
#age-gate{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(4,6,16,.93);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  transition:opacity .4s var(--ease);
}
#age-gate.hidden{opacity:0;pointer-events:none;}

.age-gate-card,
.access-denied-card{
  border-radius:var(--r-xl);
  padding:52px 44px;max-width:480px;width:90%;text-align:center;
  box-shadow:var(--sh-lg),var(--sh-gold);
  animation:cardIn .5s var(--ease) both;
}
.age-gate-card{
  background:linear-gradient(145deg,#101a38,#0c1428);
  border:1px solid rgba(201,168,76,.3);
}
.access-denied-card{
  display:none;
  background:linear-gradient(145deg,#1a0808,#120909);
  border:1px solid rgba(239,68,68,.35);
}
.access-denied-card.visible{display:block;}

@keyframes cardIn{
  from{opacity:0;transform:translateY(22px) scale(.96);}
  to  {opacity:1;transform:translateY(0) scale(1);}
}

.age-gate-icon{
  width:68px;height:68px;
  background:var(--gold-bg);border:2px solid rgba(201,168,76,.4);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.5rem;
}
.age-gate-icon svg{width:34px;height:34px;}
.age-gate-card h2{margin-bottom:.75rem;}
.age-gate-card p{margin-bottom:2rem;font-size:.93rem;}
.access-denied-card h2{color:var(--error);margin-bottom:.75rem;}
.access-denied-card p{font-size:.93rem;}

.age-gate-actions{display:flex;flex-direction:column;gap:12px;}

.btn-age-accept{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#060918;font-weight:800;font-size:1rem;
  padding:15px 32px;border-radius:var(--r-md);
  transition:all .25s var(--ease);letter-spacing:.02em;
}
.btn-age-accept:hover{
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  transform:translateY(-2px);box-shadow:var(--sh-gold);
}
.btn-age-refuse{
  background:transparent;color:var(--text-muted);font-size:.88rem;
  padding:11px 24px;border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-md);transition:all .2s;
}
.btn-age-refuse:hover{border-color:rgba(255,255,255,.22);color:var(--text-secondary);}
.age-gate-legal{margin-top:1.5rem;font-size:.72rem;color:var(--text-muted);}

/* ===========================
   COOKIE CONSENT
   =========================== */
#cookie-consent{
  position:fixed;bottom:24px;left:24px;right:24px;
  z-index:8888;
  background:linear-gradient(145deg,#0f1a38,#0a1228);
  border:1px solid rgba(201,168,76,.25);
  border-radius:var(--r-lg);
  padding:20px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  box-shadow:var(--sh-lg);
  max-width:960px;margin:0 auto;
  transform:translateY(130px);opacity:0;
  transition:transform .5s var(--ease),opacity .5s var(--ease);
}
#cookie-consent.show{transform:translateY(0);opacity:1;}
#cookie-consent.hide{transform:translateY(130px);opacity:0;}

.cookie-text{flex:1;min-width:240px;font-size:.875rem;color:var(--text-secondary);}
.cookie-text strong{color:var(--text-primary);}
.cookie-actions{display:flex;gap:10px;flex-shrink:0;}

.btn-cookie-accept{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#060918;font-weight:700;font-size:.875rem;
  padding:10px 22px;border-radius:var(--r-md);transition:all .2s;
}
.btn-cookie-accept:hover{filter:brightness(1.1);transform:translateY(-1px);}
.btn-cookie-settings{
  background:transparent;color:var(--text-secondary);font-size:.875rem;
  padding:10px 16px;border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-md);transition:all .2s;
}
.btn-cookie-settings:hover{border-color:rgba(201,168,76,.4);color:var(--gold);}

/* ===========================
   NAVBAR
   =========================== */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
  border-bottom:1px solid transparent;
}
#site-header.scrolled{
  background:rgba(6,9,26,.9);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom-color:rgba(201,168,76,.12);
  box-shadow:0 4px 32px rgba(0,0,0,.4);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--nav-h);max-width:1180px;margin:0 auto;padding:0 24px;
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.nav-logo svg{width:38px;height:38px;}
.nav-logo-text{
  font-family:'Playfair Display',serif;font-size:1.1rem;
  font-weight:700;color:var(--text-primary);letter-spacing:-.01em;
}
.nav-logo-text span{color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links a{
  font-size:.88rem;font-weight:500;color:var(--text-secondary);
  padding:8px 14px;border-radius:var(--r-sm);
  transition:all .2s;letter-spacing:.01em;
}
.nav-links a:hover{color:var(--text-primary);background:rgba(255,255,255,.06);}
.nav-links a.nav-cta{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#060918!important;font-weight:700;margin-left:8px;
  padding:9px 20px;border-radius:var(--r-md);
}
.nav-links a.nav-cta:hover{filter:brightness(1.12);transform:translateY(-1px);box-shadow:var(--sh-gold);background:linear-gradient(135deg,var(--gold),var(--gold-dark));}
.nav-badge{
  font-size:.68rem;font-weight:700;
  background:var(--error);color:#fff;
  padding:2px 7px;border-radius:4px;margin-left:8px;letter-spacing:.04em;
}

.nav-hamburger{
  display:none;flex-direction:column;gap:5px;
  width:36px;height:36px;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);
}
.nav-hamburger span{
  display:block;width:20px;height:2px;
  background:var(--text-primary);border-radius:2px;
  transition:all .3s var(--ease);
}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.nav-mobile{
  display:none;
  position:fixed;top:var(--nav-h);left:0;right:0;
  background:rgba(6,9,26,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,168,76,.15);
  padding:20px 24px 28px;z-index:999;
}
.nav-mobile.open{display:block;animation:slideDown .3s var(--ease) both;}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-10px);}
  to  {opacity:1;transform:translateY(0);}
}
.nav-mobile a{
  display:block;padding:13px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  color:var(--text-secondary);font-size:1rem;font-weight:500;transition:color .2s;
}
.nav-mobile a:hover{color:var(--gold);}
.nav-mobile a:last-child{border-bottom:none;}

/* ===========================
   HERO
   =========================== */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;padding:0;text-align:center;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 55% at 50% 0%,  rgba(201,168,76,.13) 0%,transparent 70%),
    radial-gradient(ellipse 55% 45% at 15% 80%, rgba(59,130,246,.1)  0%,transparent 60%),
    radial-gradient(ellipse 65% 55% at 85% 90%, rgba(201,168,76,.08) 0%,transparent 60%),
    linear-gradient(180deg,#06091a 0%,#090e22 100%);
}
.hero-grid{
  position:absolute;inset:0;z-index:1;
  background-image:
    linear-gradient(rgba(201,168,76,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 50% 40%,black 20%,transparent 68%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 40%,black 20%,transparent 68%);
}
.hero-particles{position:absolute;inset:0;z-index:1;overflow:hidden;}
.particle{
  position:absolute;width:2px;height:2px;
  background:var(--gold);border-radius:50%;opacity:0;
  animation:floatParticle var(--dur,6s) var(--delay,0s) infinite ease-in-out;
}
@keyframes floatParticle{
  0%,100%{opacity:0;transform:translateY(0) scale(1);}
  10%,90%{opacity:var(--op,.4);}
  50%{transform:translateY(-90px) scale(1.5);opacity:var(--op,.6);}
}
.hero-content{
  position:relative;z-index:2;max-width:860px;
  padding:calc(var(--nav-h) + 48px) 24px 64px;
}
.hero-title{margin-bottom:1.25rem;}
.hero-title em{
  font-style:normal;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-desc{font-size:1.08rem;max-width:600px;margin:0 auto 2.5rem;}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#060918;font-weight:800;font-size:1rem;
  padding:16px 36px;border-radius:var(--r-lg);
  transition:all .3s var(--ease);letter-spacing:.02em;
}
.btn-primary:hover{
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  transform:translateY(-3px);box-shadow:var(--sh-gold);color:#060918;
}
.btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--text-secondary);font-size:1rem;font-weight:500;
  padding:16px 32px;border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r-lg);transition:all .3s var(--ease);
}
.btn-secondary:hover{border-color:rgba(201,168,76,.4);color:var(--gold);transform:translateY(-2px);}

.hero-stats{
  display:flex;gap:48px;justify-content:center;flex-wrap:wrap;
  margin-top:4rem;padding-top:3rem;
  border-top:1px solid rgba(201,168,76,.12);
}
.hero-stat{text-align:center;}
.hero-stat-value{
  font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;
  color:var(--gold);display:block;
}
.hero-stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;}

.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--text-muted);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  animation:scrollBounce 2.5s infinite;
}
@keyframes scrollBounce{
  0%,100%{transform:translateX(-50%) translateY(0);}
  50%{transform:translateX(-50%) translateY(8px);}
}

/* ===========================
   PLATFORMS
   =========================== */
.platforms{background:var(--bg-secondary);}
.platforms-header{text-align:center;margin-bottom:3.5rem;}
.platforms-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;align-items:start;
}

.platform-card{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.platform-card:hover{
  transform:translateY(-6px);
  border-color:var(--border-hover);
  box-shadow:var(--sh-lg),var(--sh-gold);
}
.platform-card.featured{
  border-color:rgba(201,168,76,.35);
  box-shadow:var(--sh-md),0 0 60px rgba(201,168,76,.1);
}

.rank-ribbon{position:absolute;top:0;right:0;width:78px;height:78px;overflow:hidden;z-index:2;}
.rank-ribbon-inner{
  position:absolute;top:18px;right:-20px;width:86px;
  text-align:center;font-size:.68rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;
  padding:4px 0;transform:rotate(45deg);
}
.rank-1 .rank-ribbon-inner{background:#ffd700;color:#0a0c18;}
.rank-2 .rank-ribbon-inner{background:#c0c0c0;color:#0a0c18;}
.rank-3 .rank-ribbon-inner{background:#cd7f32;color:#fff;}

.card-rank-badge{
  position:absolute;top:16px;left:16px;
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.82rem;z-index:2;border:2px solid;
}
.rank-1 .card-rank-badge{background:rgba(255,215,0,.15);border-color:#ffd700;color:#ffd700;}
.rank-2 .card-rank-badge{background:rgba(192,192,192,.15);border-color:#c0c0c0;color:#c0c0c0;}
.rank-3 .card-rank-badge{background:rgba(205,127,50,.15);border-color:#cd7f32;color:#cd7f32;}

.card-img-wrap{
  width:100%;height:176px;
  background:linear-gradient(135deg,#0e1830,#1a2a50);
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--border);overflow:hidden;
  padding:20px 32px;
}
.card-img-wrap img{
  width:100%;height:100%;
  object-fit:contain;
  object-position:center;
  display:block;
}
/* NetBet — transparent logo, light neutral bg */
.card-img-netbet{
  background:linear-gradient(135deg,#eef2f8,#dce4f0);
}
/* PMU — white text on black bg */
.card-img-pmu{
  background:#000;
}
/* Winamax — red on black */
.card-img-winamax{
  background:#0d0d0d;
}
.card-img-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:.72rem;}
.card-img-placeholder svg{opacity:.35;}

.card-body{padding:22px;}

.card-score-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.card-score{
  font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;color:var(--gold);
}
.card-score sub{font-size:.9rem;color:var(--text-muted);font-family:'Inter',sans-serif;}
.card-stars{display:flex;gap:2px;}
.star{color:var(--gold);font-size:1rem;}

.card-name{font-size:1.2rem;font-weight:700;margin-bottom:2px;font-family:'Playfair Display',serif;}
.card-category{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;}

.card-bonus{
  background:var(--gold-bg);border:1px solid rgba(201,168,76,.25);
  border-radius:var(--r-md);padding:13px 15px;margin-bottom:16px;
}
.card-bonus-label{font-size:.68rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px;}
.card-bonus-value{font-size:.92rem;font-weight:600;color:var(--text-primary);line-height:1.45;}

.card-payments{display:flex;align-items:center;gap:7px;margin-bottom:18px;flex-wrap:wrap;}
.pay-badge{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:6px;padding:4px 9px;
  font-size:.68rem;font-weight:700;color:var(--text-secondary);
  letter-spacing:.04em;display:flex;align-items:center;gap:4px;
}

.card-cta{
  display:block;width:100%;text-align:center;
  font-weight:800;font-size:.9rem;
  padding:14px 24px;border-radius:var(--r-md);
  transition:all .3s var(--ease);letter-spacing:.04em;text-transform:uppercase;
}
.rank-1 .card-cta{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#060918;
}
.rank-1 .card-cta:hover{background:linear-gradient(135deg,var(--gold-light),var(--gold));transform:translateY(-2px);box-shadow:var(--sh-gold);color:#060918;}
.rank-2 .card-cta,.rank-3 .card-cta{
  background:rgba(255,255,255,.06);color:var(--text-primary);border:1px solid rgba(255,255,255,.14);
}
.rank-2 .card-cta:hover,.rank-3 .card-cta:hover{
  background:rgba(201,168,76,.12);border-color:rgba(201,168,76,.4);color:var(--gold);transform:translateY(-2px);
}
.card-disclaimer{margin-top:10px;text-align:center;font-size:.68rem;color:var(--text-muted);}

/* ===========================
   WHY US
   =========================== */
.why-us{background:var(--bg-primary);}
.why-header{text-align:center;margin-bottom:4rem;}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}

.why-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:32px 26px;
  transition:all .3s var(--ease);
}
.why-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--sh-md);}
.why-icon{
  width:52px;height:52px;
  background:var(--gold-bg);border:1px solid rgba(201,168,76,.25);
  border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;
  margin-bottom:1.2rem;
}
.why-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.why-card h3{font-size:1.1rem;margin-bottom:.6rem;}
.why-card p{font-size:.88rem;}

/* ===========================
   RESPONSIBLE BANNER
   =========================== */
.responsible{
  background:linear-gradient(135deg,#190808,#120a0a);
  border-top:1px solid rgba(239,68,68,.2);
  border-bottom:1px solid rgba(239,68,68,.2);
  padding:52px 0;
}
.responsible-inner{
  display:flex;align-items:center;gap:28px;flex-wrap:wrap;
  max-width:980px;margin:0 auto;padding:0 24px;
}
.responsible-icon{
  flex-shrink:0;width:60px;height:60px;
  background:rgba(239,68,68,.12);border:2px solid rgba(239,68,68,.3);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
}
.responsible-icon svg{width:28px;height:28px;stroke:var(--error);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.responsible-content{flex:1;min-width:260px;}
.responsible-content h3{color:var(--error);margin-bottom:.5rem;font-size:1.25rem;}
.responsible-content p{font-size:.88rem;margin-bottom:.4rem;}
.responsible-links{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;}
.responsible-links a{
  font-size:.82rem;font-weight:600;color:var(--error);
  opacity:.8;border-bottom:1px solid rgba(239,68,68,.3);transition:opacity .2s;
}
.responsible-links a:hover{opacity:1;color:var(--error);}

/* ===========================
   FAQ
   =========================== */
.faq{background:var(--bg-secondary);}
.faq-header{text-align:center;margin-bottom:3rem;}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px;}

.faq-item{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:border-color .25s;
}
.faq-item.open{border-color:rgba(201,168,76,.35);}

.faq-question{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 26px;background:none;
  color:var(--text-primary);font-size:.97rem;font-weight:600;
  text-align:left;gap:14px;transition:color .2s;
}
.faq-question:hover,.faq-item.open .faq-question{color:var(--gold);}

.faq-icon{
  flex-shrink:0;width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease);
}
.faq-item.open .faq-icon{
  background:var(--gold-bg);border-color:rgba(201,168,76,.4);transform:rotate(45deg);
}
.faq-icon svg{width:13px;height:13px;stroke:var(--text-secondary);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.faq-item.open .faq-icon svg{stroke:var(--gold);}

.faq-answer{max-height:0;overflow:hidden;transition:max-height .45s var(--ease);}
.faq-answer-inner{padding:0 26px 20px;}
.faq-answer-inner p{font-size:.9rem;}

/* ===========================
   FOOTER
   =========================== */
#site-footer{
  background:#040610;
  border-top:1px solid rgba(201,168,76,.1);
  padding:64px 0 32px;
}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:44px;margin-bottom:44px;
}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:1.2rem;text-decoration:none;}
.footer-logo svg{width:34px;height:34px;}
.footer-logo-text{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--text-primary);}
.footer-logo-text span{color:var(--gold);}
.footer-brand p{font-size:.86rem;line-height:1.75;margin-bottom:.75rem;}
.footer-disclaimer{
  font-size:.76rem;color:var(--text-muted);
  background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15);
  border-radius:var(--r-sm);padding:10px 13px;line-height:1.65;
}
.footer-col-title{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--gold);margin-bottom:1.2rem;
}
.footer-col a{
  display:block;font-size:.86rem;color:var(--text-secondary);
  padding:4px 0;transition:color .2s;
}
.footer-col a:hover{color:var(--text-primary);}
hr.footer-divider{border:none;border-top:1px solid rgba(255,255,255,.06);margin-bottom:26px;}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:14px;
}
.footer-copy{font-size:.78rem;color:var(--text-muted);}
.footer-badges{display:flex;gap:8px;flex-wrap:wrap;}
.f-badge{
  font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:4px;letter-spacing:.06em;
}
.badge-18{background:rgba(239,68,68,.15);color:var(--error);border:1px solid rgba(239,68,68,.3);}
.badge-anj{background:rgba(59,130,246,.1);color:#60a5fa;border:1px solid rgba(59,130,246,.22);}

/* ===========================
   BACK TO HOME BAR (sub-pages)
   =========================== */
.back-bar{
  background:rgba(201,168,76,.06);
  border-bottom:1px solid rgba(201,168,76,.12);
  padding:11px 24px;
}
.back-bar a{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.86rem;font-weight:600;color:var(--gold);
}
.back-bar a:hover{color:var(--gold-light);}
.back-bar svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}

/* ===========================
   SUBPAGE LAYOUT
   =========================== */
.subpage-hero{
  padding:calc(var(--nav-h) + 60px) 0 52px;
  text-align:center;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%,rgba(201,168,76,.1) 0%,transparent 70%),
    linear-gradient(180deg,#06091a,#0c1228);
  border-bottom:1px solid var(--border);
}
.subpage-content{max-width:820px;margin:0 auto;padding:64px 24px;}
.subpage-content h2{margin:2.5rem 0 .9rem;font-size:1.35rem;}
.subpage-content h3{margin:1.8rem 0 .7rem;font-size:1.1rem;color:var(--gold);}
.subpage-content p{margin-bottom:1rem;font-size:.93rem;}
.subpage-content ul{margin:1rem 0 1.5rem 1.4rem;list-style:disc;}
.subpage-content li{color:var(--text-secondary);font-size:.93rem;margin-bottom:.45rem;}
.info-box{
  background:var(--gold-bg);border:1px solid rgba(201,168,76,.25);
  border-radius:var(--r-md);padding:18px 22px;margin:1.5rem 0;
}
.info-box p{color:var(--text-primary);font-size:.9rem;margin:0;}
.warning-box{
  background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.2);
  border-radius:var(--r-md);padding:18px 22px;margin:1.5rem 0;
}
.warning-box p{color:#fca5a5;font-size:.9rem;margin:0;}
.org-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:1.25rem 0;}
.org-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:18px;
}
.org-card h4{font-family:'Playfair Display',serif;font-size:.97rem;margin-bottom:.35rem;color:var(--text-primary);}
.org-card p{font-size:.82rem;margin-bottom:.65rem;}
.org-card a{font-size:.82rem;font-weight:600;}

/* ===========================
   REVEAL ANIMATIONS
   =========================== */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .65s var(--ease),transform .65s var(--ease);
}
.reveal.visible{opacity:1;transform:translateY(0);}
.rd1{transition-delay:.1s;} .rd2{transition-delay:.2s;} .rd3{transition-delay:.3s;}
.rd4{transition-delay:.4s;} .rd5{transition-delay:.5s;}

/* ===========================
   RESPONSIVE
   =========================== */
@media(max-width:1024px){
  .platforms-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  :root{--nav-h:64px;}
  section{padding:64px 0;}
  .nav-links,.nav-badge{display:none;}
  .nav-hamburger{display:flex;}
  .platforms-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto;}
  .why-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .hero-stats{gap:28px;}
  .responsible-inner{flex-direction:column;text-align:center;}
  .org-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .age-gate-card,.access-denied-card{padding:34px 22px;}
  .hero-actions{flex-direction:column;align-items:center;}
  .btn-primary,.btn-secondary{width:100%;justify-content:center;}
  #cookie-consent{left:12px;right:12px;bottom:12px;}
  .card-body{padding:16px;}
}
