/* ===========================================================
   Cadelassi — Emerald Club theme
   Pure CSS. No frameworks. No CDN.
   =========================================================== */

:root {
  --bg:#020d07;
  --primary:#00C853;
  --accent:#B8860B;
  --cta:#CFFF00;
  --cta-text:#111;
  --text:#b8d4c0;
  --card:#051a0e;
  --border:rgba(0,200,83,.2);
  --gold-border:rgba(184,134,11,.45);
  --heading-font:'Playfair Display', Georgia, 'Times New Roman', serif;
  --body-font:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --radius:10px;
  --maxw:1180px;
}

*, *::before, *::after { box-sizing:border-box; }

html { scroll-behavior:smooth; }

body {
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--body-font);
  font-size:16px;
  line-height:1.6;
  padding-bottom:60px;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4 { font-family:var(--heading-font); color:#eafff0; line-height:1.2; margin:0 0 .6rem; font-weight:700; letter-spacing:.3px; }
h1 { font-size:clamp(2rem,5vw,3.3rem); }
h2 { font-size:clamp(1.5rem,3.5vw,2.3rem); }
h3 { font-size:1.2rem; }

p { margin:0 0 1rem; }

a { color:var(--primary); text-decoration:none; }
a:hover { color:var(--cta); }

img { max-width:100%; display:block; }

ul { line-height:1.8; }

hr.ornate {
  border:none;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-border), transparent);
  margin:2.5rem 0;
}

/* ---------- Buttons ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  font-family:var(--body-font);
  font-weight:700;
  font-size:.9rem;
  letter-spacing:.5px;
  padding:.7rem 1.4rem;
  border-radius:8px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  text-transform:uppercase;
  white-space:nowrap;
}
.btn:hover { transform:translateY(-2px); }
.btn--cta { background:var(--cta); color:var(--cta-text); box-shadow:0 4px 18px rgba(207,255,0,.18); }
.btn--cta:hover { box-shadow:0 6px 24px rgba(207,255,0,.3); color:var(--cta-text); }
.btn--outline { background:transparent; color:var(--text); border:1px solid var(--gold-border); }
.btn--outline:hover { color:var(--primary); border-color:var(--primary); }
.btn--primary { background:var(--primary); color:#041007; }
.btn--lg { padding:.9rem 2rem; font-size:1rem; }

/* ===========================================================
   HEADER
   =========================================================== */
.header { position:fixed; top:0; left:0; right:0; height:64px; z-index:100; background:var(--bg); border-bottom:1px solid var(--border); }
.header__inner { display:flex; align-items:center; gap:1rem; padding:0 1.5rem; height:100%; max-width:100%; }
.header__nav { display:flex; gap:.25rem; margin-left:auto; }
.header__actions { display:flex; gap:.5rem; align-items:center; }

.logo { display:flex; align-items:center; gap:.6rem; color:#eafff0; font-family:var(--heading-font); font-weight:700; font-size:1.35rem; letter-spacing:1px; }
.logo:hover { color:#eafff0; }
.logo svg { width:34px; height:34px; flex-shrink:0; }
.logo__name b { color:var(--primary); }

.nav-link { padding:.5rem .85rem; border-radius:6px; color:var(--text); font-weight:600; font-size:.9rem; transition:color .2s, background .2s; }
.nav-link:hover { color:var(--primary); }
.nav-link.active { color:var(--primary); background:rgba(0,200,83,.08); }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; border:none; background:none; padding:6px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:.2s; }

@media (max-width:768px) {
  .hamburger { display:flex; }
  .header__nav { display:none; }
  .header__actions { display:none; }
}

/* ===========================================================
   SIDEBAR
   =========================================================== */
.sidebar { position:fixed; top:64px; left:0; width:220px; height:calc(100vh - 64px); background:var(--card); border-right:1px solid var(--border); overflow-y:auto; z-index:90; display:flex; flex-direction:column; }
.sidebar__top { padding:1rem 1.25rem .25rem; }
.sidebar__label { font-size:.7rem; letter-spacing:2px; color:var(--accent); font-weight:700; margin:0; opacity:.9; }
.sidebar__nav { display:flex; flex-direction:column; padding:.5rem 0; }
.sidebar__link { display:flex; align-items:center; gap:.75rem; padding:.65rem 1.25rem; color:var(--text); font-weight:600; font-size:.88rem; border-left:3px solid transparent; transition:all .2s; text-decoration:none; }
.sidebar__link svg { width:18px; height:18px; flex-shrink:0; opacity:.85; }
.sidebar__link:hover, .sidebar__link.active { color:var(--primary); border-left-color:var(--primary); background:rgba(255,255,255,.04); }
.sidebar__footer { margin-top:auto; padding:1rem; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:.4rem; }
.sidebar__footer a { font-size:.75rem; color:var(--text); opacity:.6; text-decoration:none; }
.sidebar__footer a:hover { opacity:1; color:var(--primary); }
.sidebar__overlay { }

@media (min-width:1024px) {
  .main { margin-left:220px; }
  .footer { margin-left:220px; }
}
@media (max-width:1024px) {
  .sidebar { transform:translateX(-100%); transition:transform .3s; top:0; height:100vh; z-index:200; }
  .sidebar.open { transform:translateX(0); }
  .sidebar__overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:190; display:none; }
  .sidebar__overlay.show { display:block; }
  .main { margin-left:0; }
  .footer { margin-left:0; }
}

/* ===========================================================
   MOBILE BOTTOM NAV
   =========================================================== */
.mobile-nav { display:none; position:fixed; bottom:0; left:0; right:0; height:60px; background:var(--card); border-top:1px solid var(--border); z-index:150; }
.mobile-nav__item { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; flex:1; background:none; border:none; color:var(--text); font-size:.65rem; font-weight:600; cursor:pointer; padding:.3rem; text-decoration:none; letter-spacing:.5px; }
.mobile-nav__item svg { width:20px; height:20px; }
.mobile-nav__item:hover, .mobile-nav__item:active { color:var(--primary); }
@media (max-width:1024px) { .mobile-nav { display:flex; align-items:center; justify-content:space-around; } }
@media (min-width:1024px) { body { padding-bottom:0; } }

/* ===========================================================
   MAIN / LAYOUT
   =========================================================== */
.main { padding-top:64px; min-height:100vh; }
.section { padding:3.5rem 2rem; max-width:var(--maxw); margin:0 auto; }
.section--narrow { max-width:820px; }
.section__head { text-align:center; margin-bottom:2rem; }
.section__head p { opacity:.8; max-width:640px; margin:.5rem auto 0; }
.eyebrow { display:inline-block; font-size:.72rem; letter-spacing:3px; text-transform:uppercase; color:var(--accent); font-weight:700; margin-bottom:.75rem; }

/* ===========================================================
   HERO
   =========================================================== */
.hero { position:relative; overflow:hidden; padding:5rem 2rem 4rem; border-bottom:1px solid var(--border); }
.hero__inner { max-width:var(--maxw); margin:0 auto; position:relative; z-index:2; max-width:760px; }
.hero h1 { margin-bottom:1rem; }
.hero h1 .grad { background:linear-gradient(90deg,var(--primary),var(--accent)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.hero p.lead { font-size:1.15rem; max-width:560px; opacity:.92; }
.hero__actions { display:flex; gap:1rem; flex-wrap:wrap; margin:1.8rem 0 1.2rem; }
.hero__disclaimer { font-size:.78rem; opacity:.6; letter-spacing:.3px; }

/* animated geometric decor (CSS only) */
.hero__decor { position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden; }
.hero__decor svg { position:absolute; opacity:.5; }
.deco-ring { top:-80px; right:-60px; width:340px; height:340px; animation:spin 38s linear infinite; }
.deco-hex  { bottom:-90px; right:18%; width:240px; height:240px; animation:floaty 9s ease-in-out infinite; opacity:.35; }
.deco-tri  { top:40%; right:6%; width:120px; height:120px; animation:floaty 7s ease-in-out infinite reverse; }
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes floaty { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-22px); } }
.hero__decor .blob { position:absolute; border-radius:50%; filter:blur(70px); opacity:.22; }
.hero__decor .blob--1 { width:380px; height:380px; background:var(--primary); top:-120px; right:-40px; }
.hero__decor .blob--2 { width:300px; height:300px; background:var(--accent); bottom:-140px; left:30%; }

/* ===========================================================
   CAROUSEL
   =========================================================== */
.carousel-wrap { position:relative; }
.carousel-viewport { overflow:hidden; padding:.5rem .25rem; }
.carousel { display:flex; gap:1rem; transition:transform .35s ease; }
.carousel-btn { position:absolute; top:50%; transform:translateY(-50%); width:36px; height:36px; border-radius:50%; background:var(--primary); color:#041007; font-size:1.4rem; display:flex; align-items:center; justify-content:center; cursor:pointer; border:none; z-index:10; box-shadow:0 2px 10px rgba(0,0,0,.4); }
.carousel-btn:hover { background:var(--cta); }
.carousel-btn--prev { left:-8px; }
.carousel-btn--next { right:-8px; }

/* ===========================================================
   GAME CARD
   =========================================================== */
.game-card { flex:0 0 180px; width:180px; background:var(--card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; cursor:pointer; transition:transform .2s, border-color .2s, box-shadow .2s; }
.game-card:hover, .game-card:focus { transform:translateY(-4px); border-color:var(--gold-border); box-shadow:0 8px 26px rgba(0,0,0,.5); outline:none; }
.game-card__thumb { position:relative; aspect-ratio:3/4; background:#04150b; overflow:hidden; }
.game-card__thumb img { width:100%; height:100%; object-fit:cover; }
.game-card__overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(2,13,7,0) 40%, rgba(2,13,7,.85)); display:flex; flex-direction:column; align-items:center; justify-content:flex-end; gap:.5rem; padding:1rem; opacity:0; transition:opacity .2s; }
.game-card:hover .game-card__overlay, .game-card:focus .game-card__overlay { opacity:1; }
.game-card__play { background:var(--cta); color:var(--cta-text); border:none; font-weight:800; font-size:.78rem; letter-spacing:.5px; padding:.55rem 1rem; border-radius:6px; cursor:pointer; }
.game-card__demo-tag { position:absolute; top:.5rem; left:.5rem; background:var(--accent); color:#1a1208; font-size:.6rem; font-weight:800; padding:.18rem .5rem; border-radius:4px; letter-spacing:1px; }
.game-card__tags { position:absolute; top:.5rem; right:.5rem; display:flex; flex-direction:column; gap:.25rem; align-items:flex-end; }
.game-tag { background:rgba(0,0,0,.6); border:1px solid var(--border); color:var(--text); font-size:.58rem; font-weight:700; padding:.15rem .45rem; border-radius:4px; }
.game-card__info { padding:.7rem .75rem .85rem; }
.game-card__title { font-weight:700; font-size:.85rem; color:#eafff0; margin:0 0 .15rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.game-card__provider { font-size:.72rem; opacity:.6; margin:0; }

/* ===========================================================
   GAMES GRID
   =========================================================== */
.games-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(160px,1fr)); gap:1.1rem; }
.games-grid .game-card { flex:none; width:auto; }
.games-empty { text-align:center; padding:3rem 1rem; opacity:.7; }

/* category tabs */
.cat-tabs { display:flex; gap:.5rem; flex-wrap:wrap; margin:1.2rem 0 1.6rem; }
.cat-tab { background:var(--card); border:1px solid var(--border); color:var(--text); font-weight:600; font-size:.85rem; padding:.5rem 1.1rem; border-radius:50px; cursor:pointer; transition:.2s; }
.cat-tab:hover { border-color:var(--primary); color:var(--primary); }
.cat-tab.active { background:var(--primary); color:#041007; border-color:var(--primary); }

/* search */
.lobby-toolbar { display:flex; gap:1rem; flex-wrap:wrap; align-items:center; justify-content:space-between; }
.search-box { position:relative; flex:1; min-width:220px; max-width:360px; }
.search-box input { width:100%; background:var(--card); border:1px solid var(--border); border-radius:8px; padding:.7rem 1rem .7rem 2.4rem; color:var(--text); font-family:var(--body-font); font-size:.9rem; }
.search-box input:focus { outline:none; border-color:var(--primary); }
.search-box svg { position:absolute; left:.8rem; top:50%; transform:translateY(-50%); width:16px; height:16px; opacity:.5; }

/* sticky notice bar */
.notice-bar { position:sticky; top:64px; z-index:80; background:rgba(184,134,11,.1); border-bottom:1px solid var(--border); color:#e8dcb0; font-size:.78rem; font-weight:600; text-align:center; padding:.5rem 1rem; letter-spacing:.3px; }

/* ===========================================================
   HOW IT WORKS / STEP CARDS
   =========================================================== */
.steps-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:1.4rem; }
.step-card { background:var(--card); border:1px solid var(--border); border-top:2px solid var(--accent); border-radius:var(--radius); padding:1.8rem 1.5rem; position:relative; }
.step-card__num { font-family:var(--heading-font); font-size:2.6rem; color:var(--primary); opacity:.35; line-height:1; margin-bottom:.5rem; }
.step-card h3 { color:#eafff0; }
.step-card p { font-size:.92rem; opacity:.85; margin:0; }

.notice-box { background:rgba(0,200,83,.05); border:1px solid var(--border); border-left:3px solid var(--accent); border-radius:8px; padding:1.2rem 1.4rem; margin-top:2rem; font-size:.9rem; }
.notice-box strong { color:var(--accent); }

/* ===========================================================
   REVIEWS
   =========================================================== */
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(250px,1fr)); gap:1.2rem; }
.review-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem; }
.review-card__stars { color:var(--accent); letter-spacing:2px; margin-bottom:.6rem; font-size:1rem; }
.review-card__text { font-size:.92rem; opacity:.9; font-style:italic; margin-bottom:1rem; }
.review-card__author { font-weight:700; color:#eafff0; font-size:.9rem; }
.review-card__loc { font-size:.78rem; opacity:.6; }

/* ===========================================================
   ABOUT BANNER
   =========================================================== */
.banner { background:linear-gradient(120deg, rgba(0,200,83,.08), rgba(184,134,11,.06)); border:1px solid var(--gold-border); border-radius:16px; padding:3rem 2rem; text-align:center; }
.banner h2 { margin-bottom:.8rem; }
.banner p { max-width:600px; margin:0 auto 1.5rem; opacity:.9; }

/* ===========================================================
   SEO TEXT
   =========================================================== */
.seo-text { font-size:.92rem; opacity:.82; }
.seo-text details { margin-top:.5rem; }
.seo-text summary { cursor:pointer; color:var(--primary); font-weight:600; list-style:none; }
.seo-text summary::-webkit-details-marker { display:none; }
.seo-text summary::after { content:" ▾"; }
.seo-text details[open] summary::after { content:" ▴"; }

/* ===========================================================
   CONTENT PAGES
   =========================================================== */
.page-head { text-align:center; padding:3rem 2rem 1rem; }
.page-head .eyebrow { display:inline-block; }
.prose { max-width:820px; margin:0 auto; padding:1rem 2rem 3rem; }
.prose h2 { margin-top:2rem; }
.prose h3 { margin-top:1.5rem; color:#eafff0; }
.prose a { color:var(--primary); text-decoration:underline; }

/* FAQ */
.faq-item { border:1px solid var(--border); border-radius:8px; margin-bottom:.75rem; background:var(--card); overflow:hidden; }
.faq-item summary { cursor:pointer; padding:1rem 1.2rem; font-weight:700; color:#eafff0; list-style:none; position:relative; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:"+"; position:absolute; right:1.2rem; color:var(--primary); font-size:1.2rem; }
.faq-item[open] summary::after { content:"–"; }
.faq-item .faq-body { padding:0 1.2rem 1.1rem; font-size:.92rem; opacity:.88; }

/* ===========================================================
   CONTACT FORM
   =========================================================== */
.form { max-width:620px; margin:0 auto; background:var(--card); border:1px solid var(--border); border-radius:14px; padding:2rem; }
.form-row { display:flex; gap:1rem; }
.form-row .field { flex:1; }
.field { margin-bottom:1.1rem; }
.field label { display:block; font-size:.8rem; font-weight:600; margin-bottom:.4rem; letter-spacing:.3px; }
.field input, .field select, .field textarea {
  width:100%; background:var(--bg); border:1px solid var(--border); border-radius:8px;
  padding:.75rem 1rem; color:var(--text); font-family:var(--body-font); font-size:.92rem;
}
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--primary); }
.field textarea { resize:vertical; min-height:130px; }
.form-success { display:none; background:rgba(0,200,83,.1); border:1px solid var(--primary); border-radius:8px; padding:1rem 1.2rem; color:#cfffd8; margin-top:1rem; font-weight:600; }

/* contact info cards */
.contact-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1rem; margin-bottom:2rem; }
.contact-card { background:var(--card); border:1px solid var(--border); border-radius:10px; padding:1.4rem; text-align:center; }
.contact-card h3 { font-size:1rem; }
.contact-card p { font-size:.88rem; opacity:.85; margin:0; }

/* ===========================================================
   MODALS (auth + game)
   =========================================================== */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.8); z-index:9000; display:none; align-items:center; justify-content:center; padding:1rem; }
.modal-overlay.open { display:flex; }
.modal { background:var(--card); border:1px solid var(--gold-border); border-radius:14px; width:100%; max-width:420px; padding:2rem; position:relative; }
.modal h3 { font-size:1.5rem; margin-bottom:.3rem; }
.modal .modal-sub { font-size:.85rem; opacity:.7; margin-bottom:1.4rem; }
.modal__close { position:absolute; top:.8rem; right:1rem; background:none; border:none; color:var(--text); font-size:1.3rem; cursor:pointer; line-height:1; }
.modal .field { margin-bottom:1rem; }
.modal .btn { width:100%; margin-top:.5rem; }
.modal__switch { text-align:center; font-size:.83rem; margin-top:1rem; opacity:.85; }
.modal__switch button { background:none; border:none; color:var(--primary); cursor:pointer; font-weight:700; font-size:.83rem; }
.modal__err { color:#ff8a8a; font-size:.8rem; min-height:1rem; margin-top:.3rem; }
.modal__disclaimer { font-size:.72rem; opacity:.6; text-align:center; margin-top:1rem; }

/* GAME MODAL */
.game-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.9); z-index:9999; display:flex; align-items:center; justify-content:center; padding:1rem; }
.game-modal { background:var(--card); border-radius:12px; width:100%; max-width:1000px; height:85vh; display:flex; flex-direction:column; overflow:hidden; }
.game-modal__header { display:flex; align-items:center; gap:.5rem; padding:.65rem 1rem; border-bottom:1px solid var(--border); flex-shrink:0; }
.game-modal__header span { font-weight:800; color:var(--text); flex:1; font-size:.9rem; }
.game-modal__badges { display:flex; gap:.35rem; }
.badge { font-size:.6rem; font-weight:900; padding:.2rem .55rem; border-radius:50px; white-space:nowrap; }
.badge--free { background:var(--cta); color:var(--cta-text); }
.badge--social { background:var(--accent); color:#fff; }
.game-modal__close { background:none; border:none; color:var(--text); font-size:1.2rem; cursor:pointer; padding:.2rem .5rem; }
.game-modal__disclaimer { background:rgba(255,200,0,.06); padding:.4rem 1rem; font-size:.72rem; color:#ffd; text-align:center; flex-shrink:0; }
.game-modal__frame { flex:1; display:flex; min-height:0; overflow:hidden; }
.game-modal__frame iframe { width:100%; height:100%; flex:1; border:none; display:block; }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer { background:var(--card); border-top:1px solid var(--border); padding:3rem 2rem 1.5rem; }
.footer__inner { max-width:var(--maxw); margin:0 auto; }
.footer__cols { display:grid; grid-template-columns:1.5fr repeat(3,1fr); gap:2rem; margin-bottom:2rem; }
.footer__brand .logo { margin-bottom:.8rem; }
.footer__brand p { font-size:.85rem; opacity:.7; max-width:280px; }
.footer__col h4 { font-size:.8rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--accent); margin-bottom:.9rem; }
.footer__col a { display:block; color:var(--text); opacity:.7; font-size:.85rem; padding:.25rem 0; text-decoration:none; }
.footer__col a:hover { opacity:1; color:var(--primary); }
.footer__bottom { border-top:1px solid var(--border); padding-top:1.5rem; display:flex; flex-wrap:wrap; gap:1rem; align-items:center; justify-content:space-between; }
.footer__disclaimer { font-size:.74rem; opacity:.6; max-width:760px; line-height:1.7; }
.age-badge { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border:2px solid var(--accent); border-radius:50%; color:var(--accent); font-weight:900; font-size:.85rem; flex-shrink:0; }
.footer__flags { display:flex; gap:.6rem; align-items:center; flex-wrap:wrap; font-size:.72rem; opacity:.6; }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1280px) {
  .section { padding:3rem 1.5rem; }
}
@media (max-width:1024px) {
  .footer__cols { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .hero { padding:3.5rem 1.5rem 3rem; }
  .form-row { flex-direction:column; gap:0; }
  .footer__cols { grid-template-columns:1fr 1fr; gap:1.5rem; }
  .footer__bottom { flex-direction:column; align-items:flex-start; }
}
@media (max-width:600px) {
  .form-row { flex-direction:column; gap:0; }
}
@media (max-width:480px) {
  body { font-size:15px; }
  .games-grid { grid-template-columns:repeat(2,1fr); gap:.6rem; }
  .carousel .game-card { flex:0 0 80vw; width:80vw; }
  .section { padding:1.5rem 1rem; }
  .hero { padding:2.5rem 1rem; }
  .footer__cols { grid-template-columns:1fr; }
  .btn, input, select, textarea { min-height:48px; }
  .form { padding:1.4rem; }
}
@media (max-width:375px) {
  .header__inner { padding:0 .75rem; }
  .games-grid { gap:.5rem; }
}
