/* =============================================
   PENALTY SHOOT-OUT — style.css
   penaltyshootout-it.it.com
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Barlow:wght@300;400;500;600&display=swap');

/* ---- CSS Variables ---- */
:root {
  --green-dark:   #062a0e;
  --green-deep:   #0a3d14;
  --green-mid:    #145a22;
  --green-main:   #1e8a35;
  --green-light:  #28c048;
  --green-neon:   #39ff72;
  --green-glow:   rgba(57,255,114,.18);
  --gold:         #f5c518;
  --gold-dark:    #c49a10;
  --white:        #f0fff4;
  --grey-light:   #b8d4be;
  --grey-mid:     #5a7a60;
  --black:        #020c04;
  --card-bg:      rgba(10,61,20,.75);
  --card-border:  rgba(57,255,114,.15);
  --radius-sm:    6px;
  --radius-md:    12px;
  --radius-lg:    20px;
  --shadow-green: 0 0 30px rgba(30,138,53,.35);
  --shadow-neon:  0 0 18px rgba(57,255,114,.5);
  --transition:   .3s cubic-bezier(.4,0,.2,1);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Barlow',sans-serif;
  background:var(--green-dark);
  color:var(--white);
  line-height:1.65;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---- Utility ---- */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.section-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(2rem,4vw,3rem);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--white);
  line-height:1.1;
}
.section-title span{color:var(--green-neon)}
.section-subtitle{
  font-size:1.05rem;
  color:var(--grey-light);
  margin-top:.5rem;
}
.tag{
  display:inline-block;
  background:var(--green-glow);
  border:1px solid var(--card-border);
  color:var(--green-neon);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:4px 14px;
  border-radius:30px;
  margin-bottom:1rem;
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:14px 32px;
  border-radius:var(--radius-sm);
  border:none;
  cursor:pointer;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
  text-decoration:none;
}
.btn::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(255,255,255,.08);
  opacity:0;
  transition:var(--transition);
}
.btn:hover::after{opacity:1}
.btn:active{transform:scale(.97)}

.btn-primary{
  background:linear-gradient(135deg,var(--green-light),var(--green-main));
  color:var(--black);
  box-shadow:0 4px 20px rgba(40,192,72,.4);
}
.btn-primary:hover{
  box-shadow:0 6px 30px rgba(40,192,72,.6);
  transform:translateY(-2px);
}

.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--black);
  box-shadow:0 4px 20px rgba(245,197,24,.35);
}
.btn-gold:hover{
  box-shadow:0 6px 30px rgba(245,197,24,.55);
  transform:translateY(-2px);
}

.btn-outline{
  background:transparent;
  color:var(--green-neon);
  border:2px solid var(--green-neon);
  box-shadow:0 0 0 rgba(57,255,114,0);
}
.btn-outline:hover{
  background:var(--green-glow);
  box-shadow:var(--shadow-neon);
  transform:translateY(-2px);
}

.btn-ghost{
  background:rgba(255,255,255,.06);
  color:var(--white);
  border:1px solid rgba(255,255,255,.15);
}
.btn-ghost:hover{
  background:rgba(255,255,255,.12);
  transform:translateY(-2px);
}

/* ============================================================
   HEADER
   ============================================================ */
#header{
  position:sticky;top:0;z-index:999;
  background:rgba(6,42,14,.92);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--card-border);
  padding:12px 0;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.logo{
  display:flex;align-items:center;gap:12px;
  flex-shrink:0;
}
.logo-icon{
  width:46px;height:46px;
  background:linear-gradient(135deg,var(--green-light),var(--green-main));
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;
  box-shadow:var(--shadow-green);
  flex-shrink:0;
}
.logo-text{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:1.35rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  line-height:1.1;
}
.logo-text span{
  display:block;
  font-size:.7rem;
  font-weight:600;
  color:var(--green-neon);
  letter-spacing:.18em;
}
.header-nav{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.header-badge{
  background:linear-gradient(90deg,var(--green-main),var(--green-light));
  color:var(--black);
  font-size:.72rem;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;
  padding:3px 10px;border-radius:20px;
  animation:pulse-badge 2.5s ease-in-out infinite;
}
@keyframes pulse-badge{
  0%,100%{box-shadow:0 0 0 0 rgba(40,192,72,.6)}
  50%{box-shadow:0 0 0 8px rgba(40,192,72,0)}
}

/* ============================================================
   HERO
   ============================================================ */
#hero{
  min-height:92vh;
  display:flex;align-items:center;
  position:relative;
  overflow:hidden;
  padding:20px 0 60px;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 60% 40%,rgba(30,138,53,.22) 0%,transparent 70%),
    radial-gradient(ellipse 60% 80% at 10% 90%,rgba(57,255,114,.07) 0%,transparent 60%),
    linear-gradient(175deg,var(--black) 0%,var(--green-dark) 100%);
  z-index:0;
}
.hero-field-lines{
  position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(90deg,rgba(57,255,114,.04) 0,rgba(57,255,114,.04) 1px,transparent 0,transparent 12%),
    repeating-linear-gradient(0deg,rgba(57,255,114,.04) 0,rgba(57,255,114,.04) 1px,transparent 0,transparent 10%);
  z-index:0;
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.hero-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:.82rem;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--green-neon);
  margin-bottom:1rem;
  display:flex;align-items:center;gap:8px;
}
.hero-label::before{content:'';width:32px;height:2px;background:var(--green-neon)}
.hero-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(2.8rem,6vw,5.5rem);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.02em;
  line-height:.95;
  color:var(--white);
}
.hero-title .accent{
  color:var(--green-neon);
  text-shadow:0 0 40px rgba(57,255,114,.4);
}
.hero-title .gold{color:var(--gold)}
.hero-desc{
  margin-top:1.4rem;
  font-size:1.1rem;
  color:var(--grey-light);
  max-width:480px;
  line-height:1.7;
}
.hero-actions{
  margin-top:2rem;
  display:flex;gap:14px;flex-wrap:wrap;
}
.hero-stats{
  margin-top:2.5rem;
  display:flex;gap:28px;flex-wrap:wrap;
}
.hero-stat{
  display:flex;flex-direction:column;
}
.hero-stat-val{
  font-family:'Barlow Condensed',sans-serif;
  font-size:2rem;font-weight:900;
  color:var(--green-neon);
  line-height:1;
}
.hero-stat-lbl{
  font-size:.78rem;font-weight:600;
  color:var(--grey-mid);
  text-transform:uppercase;letter-spacing:.1em;
  margin-top:2px;
}
/* Hero visual */
.hero-visual{
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.hero-ball-wrap{
  position:relative;width:320px;height:320px;
  flex-shrink:0;
}
.hero-ring{
  position:absolute;inset:0;
  border-radius:50%;
  border:2px solid rgba(57,255,114,.2);
  animation:spin-ring 18s linear infinite;
}
.hero-ring:nth-child(2){
  inset:20px;
  border-color:rgba(57,255,114,.12);
  animation-duration:12s;animation-direction:reverse;
}
@keyframes spin-ring{to{transform:rotate(360deg)}}
.hero-ball{
  position:absolute;inset:40px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#fff 0%,#ddd 30%,#888 70%,#222 100%);
  box-shadow:0 0 60px rgba(57,255,114,.3),inset 0 0 30px rgba(0,0,0,.6);
  animation:float-ball 4s ease-in-out infinite;
}
@keyframes float-ball{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-16px) rotate(10deg)}
}
.hero-goal-post{
  position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);
  width:200px;height:100px;
  border:4px solid rgba(255,255,255,.25);
  border-bottom:none;
}

/* ============================================================
   MARQUEE STRIP
   ============================================================ */
.marquee-strip{
  background:var(--green-main);
  padding:12px 0;
  overflow:hidden;
  border-top:1px solid rgba(57,255,114,.2);
  border-bottom:1px solid rgba(57,255,114,.2);
}
.marquee-track{
  display:flex;gap:0;
  animation:marquee 22s linear infinite;
  white-space:nowrap;
}
.marquee-track span{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--black);
  padding:0 32px;
  opacity:.85;
}
.marquee-track span::before{content:'⚽ '}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   GAME SECTION
   ============================================================ */
#game-section{padding:80px 0}
.game-grid{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:32px;
  align-items:start;
}
/* Demo frame */
.demo-wrap{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--black);
  border:2px solid var(--card-border);
  box-shadow:var(--shadow-green),inset 0 0 40px rgba(0,0,0,.8);
}
.demo-aspect{
  position:relative;
  width:100%;
  padding-top:56.25%; /* 16:9 */
}
.demo-screen{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:18px;
  background:#000;
}
.demo-screen iframe{
  position:absolute;inset:0;
  width:100%;height:100%;
  border:none;
  display:none;
}
.demo-screen.playing iframe{display:block}
.demo-screen.playing .demo-overlay{display:none}
.demo-overlay{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:18px;
  padding:24px;
  text-align:center;
  width:100%;
}
.demo-overlay-icon{
  font-size:4rem;
  opacity:.4;
}
.demo-overlay-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.4rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--grey-light);
}
.demo-btns{
  display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px;
}
.demo-btns .btn{
  width:100%;
  justify-content:center;
  font-size:1rem;
  padding:13px 20px;
}
/* Info table card */
.info-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--radius-lg);
  padding:28px 24px;
  backdrop-filter:blur(10px);
}
.info-card-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.25rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--green-neon);
  margin-bottom:20px;
  padding-bottom:12px;
  border-bottom:1px solid var(--card-border);
}
.info-table{width:100%;border-collapse:collapse}
.info-table tr:not(:last-child) td{
  border-bottom:1px solid rgba(57,255,114,.08);
}
.info-table td{
  padding:10px 6px;
  font-size:.9rem;
}
.info-table td:first-child{
  color:var(--grey-light);
  font-weight:600;
  width:48%;
}
.info-table td:last-child{
  color:var(--white);
  font-weight:500;
  text-align:right;
}
.info-table td .badge-green{
  background:rgba(40,192,72,.2);
  color:var(--green-neon);
  font-size:.75rem;font-weight:700;
  padding:2px 8px;border-radius:20px;
}
/* RTP meter */
.rtp-bar-wrap{margin-top:18px}
.rtp-bar-label{
  display:flex;justify-content:space-between;
  font-size:.8rem;font-weight:600;
  color:var(--grey-light);
  margin-bottom:6px;
}
.rtp-bar-track{
  height:8px;background:rgba(255,255,255,.08);
  border-radius:4px;overflow:hidden;
}
.rtp-bar-fill{
  height:100%;width:96%;
  background:linear-gradient(90deg,var(--green-main),var(--green-neon));
  border-radius:4px;
  animation:rtp-load 1.2s ease-out forwards;
  transform-origin:left;
}
@keyframes rtp-load{from{width:0}to{width:96%}}

/* ============================================================
   FEATURES STRIP
   ============================================================ */
#features{padding:70px 0}
.features-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
  margin-top:40px;
}
.feature-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--radius-md);
  padding:28px 22px;
  backdrop-filter:blur(8px);
  transition:var(--transition);
  position:relative;overflow:hidden;
}
.feature-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--green-neon),transparent);
  opacity:0;transition:var(--transition);
}
.feature-card:hover{
  transform:translateY(-5px);
  border-color:rgba(57,255,114,.35);
  box-shadow:var(--shadow-green);
}
.feature-card:hover::before{opacity:1}
.feature-icon{
  font-size:2.2rem;
  margin-bottom:14px;
  display:block;
}
.feature-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.15rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--white);
  margin-bottom:8px;
}
.feature-text{
  font-size:.88rem;
  color:var(--grey-light);
  line-height:1.6;
}

/* ============================================================
   HOW TO PLAY — STEPS
   ============================================================ */
#how-to-play{padding:70px 0}
.steps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:24px;
  margin-top:44px;
  position:relative;
}
.steps-grid::before{
  content:'';
  position:absolute;
  top:36px;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--green-mid),var(--green-neon),var(--green-mid),transparent);
  z-index:0;
}
.step-card{
  position:relative;z-index:1;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--radius-md);
  padding:28px 20px 24px;
  text-align:center;
  backdrop-filter:blur(8px);
  transition:var(--transition);
}
.step-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-green);
}
.step-num{
  width:44px;height:44px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--green-light),var(--green-main));
  color:var(--black);
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.3rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
  box-shadow:0 0 20px rgba(40,192,72,.5);
}
.step-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.05rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--white);
  margin-bottom:6px;
}
.step-text{font-size:.85rem;color:var(--grey-light);line-height:1.6}

/* ============================================================
   CONTENT SECTION
   ============================================================ */
#content{padding:80px 0}
.content-wrapper{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--radius-lg);
  padding:48px 44px;
  backdrop-filter:blur(8px);
  max-width:900px;
  margin:0 auto;
}
.content-wrapper h2{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.9rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--green-neon);
  margin-top:2rem;margin-bottom:.8rem;
}
.content-wrapper h2:first-child{margin-top:0}
.content-wrapper h3{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.35rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--white);
  margin-top:1.5rem;margin-bottom:.6rem;
}
.content-wrapper p{
  font-size:.97rem;
  color:var(--grey-light);
  line-height:1.75;
  margin-bottom:.9rem;
}
.content-wrapper ul{
  list-style:none;
  padding-left:0;
  margin-bottom:1rem;
}
.content-wrapper ul li{
  font-size:.95rem;
  color:var(--grey-light);
  padding:4px 0 4px 22px;
  position:relative;
}
.content-wrapper ul li::before{
  content:'⚽';
  position:absolute;left:0;
  font-size:.75rem;top:6px;
}
.content-wrapper table{
  width:100%;border-collapse:collapse;
  margin:1.2rem 0;
  font-size:.9rem;
}
.content-wrapper table th{
  background:rgba(30,138,53,.3);
  color:var(--green-neon);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  padding:10px 14px;text-align:left;
  border-bottom:1px solid var(--card-border);
}
.content-wrapper table td{
  padding:10px 14px;
  color:var(--grey-light);
  border-bottom:1px solid rgba(57,255,114,.06);
}
.content-wrapper table tr:hover td{background:rgba(57,255,114,.04)}

/* ============================================================
   CTA BANNER
   ============================================================ */
#cta-banner{
  padding:70px 0;
  position:relative;overflow:hidden;
}
.cta-inner{
  background:linear-gradient(135deg,var(--green-deep),var(--green-mid));
  border:1px solid var(--card-border);
  border-radius:var(--radius-lg);
  padding:60px 48px;
  text-align:center;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-green);
}
.cta-inner::before{
  content:'';position:absolute;
  top:-40%;left:-20%;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(57,255,114,.08) 0%,transparent 70%);
}
.cta-inner::after{
  content:'';position:absolute;
  bottom:-40%;right:-20%;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(245,197,24,.06) 0%,transparent 70%);
}
.cta-inner h2{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:900;text-transform:uppercase;
  color:var(--white);margin-bottom:.6rem;
  position:relative;z-index:1;
}
.cta-inner p{
  color:var(--grey-light);
  font-size:1.05rem;
  margin-bottom:2rem;
  position:relative;z-index:1;
}
.cta-btns{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
  position:relative;z-index:1;
}

/* ============================================================
   FAQ
   ============================================================ */
#faq{padding:80px 0}
.faq-list{
  max-width:800px;margin:44px auto 0;
  display:flex;flex-direction:column;gap:14px;
}
.faq-item{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--radius-md);
  overflow:hidden;
  transition:var(--transition);
}
.faq-item.open{
  border-color:rgba(57,255,114,.4);
  box-shadow:0 0 20px rgba(57,255,114,.08);
}
.faq-question{
  width:100%;background:none;border:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;
  cursor:pointer;
  color:var(--white);
  font-family:'Barlow',sans-serif;
  font-size:1rem;font-weight:600;
  text-align:left;
  gap:16px;
  transition:var(--transition);
}
.faq-question:hover{color:var(--green-neon)}
.faq-icon{
  width:30px;height:30px;flex-shrink:0;
  border-radius:50%;
  background:rgba(57,255,114,.1);
  border:1px solid var(--card-border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:700;
  color:var(--green-neon);
  transition:var(--transition);
}
.faq-item.open .faq-icon{
  background:var(--green-main);
  border-color:var(--green-neon);
  transform:rotate(45deg);
}
.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height .4s ease,padding .3s ease;
  padding:0 24px;
}
.faq-item.open .faq-answer{
  max-height:400px;
  padding:0 24px 20px;
}
.faq-answer p{
  font-size:.92rem;
  color:var(--grey-light);
  line-height:1.75;
  border-top:1px solid var(--card-border);
  padding-top:14px;
}

/* ============================================================
   AUTHOR BLOCK
   ============================================================ */
#author{padding:70px 0}
.author-card{
  max-width:740px;margin:0 auto;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--radius-lg);
  padding:36px 40px;
  display:flex;
  align-items:flex-start;
  gap:28px;
  backdrop-filter:blur(8px);
}
.author-avatar{
  width:90px;height:90px;flex-shrink:0;
  border-radius:50%;
  object-fit:cover;
  border:3px solid var(--green-main);
  box-shadow:0 0 20px rgba(40,192,72,.35);
  background:linear-gradient(135deg,var(--green-mid),var(--green-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;
}
.author-info{}
.author-name{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.3rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.05em;
  color:var(--white);
  margin-bottom:2px;
}
.author-role{
  font-size:.8rem;font-weight:600;
  color:var(--green-neon);
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:12px;
}
.author-bio{
  font-size:.9rem;
  color:var(--grey-light);
  line-height:1.72;
}

/* ============================================================
   FOOTER
   ============================================================ */
#footer{
  background:var(--black);
  border-top:1px solid var(--card-border);
  padding:52px 0 30px;
}
.footer-inner{
  text-align:center;
  max-width:680px;
  margin:0 auto;
}
.footer-logo{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-bottom:24px;
}
.footer-logo .logo-icon{width:38px;height:38px;font-size:1.3rem}
.footer-logo .logo-text{font-size:1.1rem}
.footer-disclaimer{
  font-size:.84rem;
  color:var(--grey-mid);
  line-height:1.8;
  margin-bottom:28px;
}
.footer-contacts{
  display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
  margin-bottom:24px;
}
.footer-contact-item{
  display:flex;align-items:center;gap:8px;
  font-size:.88rem;
  color:var(--grey-light);
  transition:var(--transition);
}
.footer-contact-item:hover{color:var(--green-neon)}
.footer-contact-icon{
  width:32px;height:32px;
  border-radius:50%;
  background:rgba(57,255,114,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:16px;
  font-size:.78rem;
  color:var(--grey-mid);
}
.age-badge{
  display:inline-flex;align-items:center;
  background:rgba(220,40,40,.15);
  border:1px solid rgba(220,40,40,.3);
  color:#ff6b6b;
  font-weight:800;font-size:.78rem;letter-spacing:.08em;
  padding:3px 10px;border-radius:4px;
  margin-left:10px;
}

/* ============================================================
   RESPONSIBLE GAMING RIBBON
   ============================================================ */
.rg-ribbon{
  background:rgba(245,197,24,.07);
  border-top:1px solid rgba(245,197,24,.2);
  border-bottom:1px solid rgba(245,197,24,.2);
  padding:12px 0;
  text-align:center;
}
.rg-ribbon p{
  font-size:.82rem;
  color:rgba(245,197,24,.75);
  font-weight:500;
  letter-spacing:.04em;
}
.rg-ribbon p strong{color:var(--gold)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .game-grid{grid-template-columns:1fr}
  .info-card{max-width:600px}
}
@media(max-width:768px){
  .header-inner{gap:10px}
  .header-nav .btn{padding:10px 16px;font-size:.95rem}
  .hero-inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero-desc{margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-visual{display:none}
  .hero-label{justify-content:center}
  .steps-grid::before{display:none}
  .author-card{flex-direction:column;align-items:center;text-align:center;padding:28px 24px}
  .content-wrapper{padding:28px 20px}
  .cta-inner{padding:40px 24px}
}
@media(max-width:500px){
  .header-nav .btn:not(.btn-primary){display:none}
  .demo-btns .btn{font-size:.88rem;padding:11px 14px}
  .footer-contacts{flex-direction:column;align-items:center}
}

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .65s ease, transform .65s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}