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

:root {
  --bg: #f4f8ff;
  --surface: #ffffff;
  --surface2: #ebf3ff;
  --border: #d8e4ff;
  --text: #10233f;
  --muted: #5b7194;
  --accent: #2f6fff;
  --accent2: #00b8d9;
  --accent3: #7e4dff;
  --radius: 16px;
  --font-display: 'Sora', sans-serif;
  --font-body: 'Space Grotesk', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  font-family:var(--font-body);
  background:radial-gradient(circle at 15% 0%,#dff0ff 0,#f4f8ff 50%),var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:16px;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,45,120,0.015) 2px,rgba(255,45,120,0.015) 4px),
    repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,229,255,0.01) 2px,rgba(0,229,255,0.01) 4px);
}
body::after{
  content:'';position:fixed;inset:0;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0.08) 0px,rgba(0,0,0,0.08) 1px,transparent 1px,transparent 3px);
  pointer-events:none;z-index:9999;
}

/* COIN BANNER */
.coin-banner{background:linear-gradient(90deg,var(--accent),var(--accent3));padding:0.4rem;text-align:center;overflow:hidden}
.coin-banner-inner{
  font-family:var(--font-display);font-size:0.65rem;color:var(--bg);
  letter-spacing:0.25em;white-space:nowrap;
  animation:marquee 22s linear infinite;display:inline-block;
}
@keyframes marquee{0%{transform:translateX(50vw)}100%{transform:translateX(-100%)}}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:100;
  padding:0 1.5rem;height:64px;
  display:flex;align-items:center;gap:2rem;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
  box-shadow:0 8px 20px rgba(47,111,255,0.08);
}
.logo{
  font-family:var(--font-display);font-size:0.85rem;
  color:var(--accent);text-decoration:none;
  text-shadow:none;
  letter-spacing:0.05em;line-height:1.5;
}
.logo:hover{color:var(--accent3);text-shadow:none}
.tagline{font-family:var(--font-body);color:var(--muted);font-size:0.85rem;letter-spacing:0.1em;text-transform:uppercase;border-left:2px solid var(--border);padding-left:1.5rem}
.breadcrumbs{font-family:var(--font-body);font-size:0.85rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.05em}
.breadcrumbs a{color:var(--accent2);text-decoration:none}
.breadcrumbs a:hover{text-shadow:0 0 8px var(--accent2)}
.breadcrumbs .sep{color:var(--border)}

/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem}

/* HERO */
.hero{padding:2.5rem 0 2rem}
.hero-label{font-family:var(--font-display);font-size:0.7rem;letter-spacing:.2em;color:var(--accent3);text-shadow:0 0 8px var(--accent3);margin-bottom:1rem}
.hero h1{
  font-family:var(--font-display);font-size:clamp(0.9rem,3vw,1.6rem);
  line-height:1.6;letter-spacing:.05em;color:var(--text);
  text-shadow:3px 3px 0 var(--accent),6px 6px 0 rgba(255,45,120,0.3);
  margin-bottom:1.25rem;
}
.hero h1 span{color:var(--accent2);text-shadow:0 0 15px var(--accent2),3px 3px 0 #004455}
.hero-sub{font-family:var(--font-body);color:var(--muted);font-size:1.05rem;letter-spacing:.05em;text-transform:uppercase;max-width:50ch}

/* FILTERS */
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.filter-btn{
  padding:.55rem 1.1rem;border:1px solid var(--border);background:transparent;
  color:var(--muted);font-family:var(--font-display);font-size:0.78rem;
  cursor:pointer;letter-spacing:.1em;transition:all .15s;
}
.filter-btn:hover{border-color:var(--accent2);color:var(--accent2);text-shadow:0 0 8px var(--accent2);box-shadow:0 0 10px rgba(0,229,255,0.2),inset 0 0 10px rgba(0,229,255,0.05)}
.filter-btn.active{border-color:var(--accent);color:var(--accent);text-shadow:0 0 8px var(--accent);box-shadow:0 0 12px rgba(255,45,120,0.3),inset 0 0 12px rgba(255,45,120,0.05)}

/* SECTION */
.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.section-title{font-family:var(--font-display);font-size:1rem;color:var(--accent3);text-shadow:0 0 8px var(--accent3);letter-spacing:.1em}
.section-count{font-family:var(--font-display);font-size:0.72rem;color:var(--muted)}

/* GRIDS */
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:3rem}
.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}

/* CARDS */
.game-card{
  background:var(--surface);border:1px solid var(--border);
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
  position:relative;transition:transform .15s;overflow:hidden;
}
.game-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  opacity:0;transition:opacity .2s;z-index:1;
}
.game-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 15px 35px rgba(47,111,255,0.14)}
.game-card:hover::before{opacity:1}
.game-card.featured{border-color:rgba(255,45,120,0.4)}
.card-img-wrap{position:relative;overflow:hidden}
.game-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;transition:transform .4s;filter:saturate(1.2)}
.game-card:hover img{transform:scale(1.06);filter:saturate(1.4) brightness(1.1)}
.card-badge{position:absolute;top:.5rem;left:.5rem;padding:.25rem .6rem;font-family:var(--font-display);font-size:0.65rem;letter-spacing:.12em}
.card-badge.featured-badge{background:var(--accent);color:white;box-shadow:none;border-radius:999px}
.card-badge.cat-badge{background:rgba(13,9,21,0.85);color:var(--accent2);border:1px solid rgba(0,229,255,0.3);box-shadow:0 0 8px rgba(0,229,255,0.15)}
.card-play-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;background:rgba(5,3,8,0.6);transition:opacity .2s}
.game-card:hover .card-play-icon{opacity:1}
.card-play-icon svg{width:52px;height:52px;filter:drop-shadow(0 0 12px var(--accent))}
.game-card-body{padding:.85rem 1rem;flex:1;display:flex;flex-direction:column;gap:.4rem;border-top:1px solid var(--border)}
.game-card h2{font-family:var(--font-display);font-size:0.95rem;letter-spacing:.04em;line-height:1.35;color:var(--text)}
.game-card p{font-family:var(--font-body);font-size:.85rem;color:var(--muted);line-height:1.5}
.empty-state{grid-column:1/-1;text-align:center;padding:3rem;color:var(--muted);font-family:var(--font-display);font-size:.95rem;line-height:1.7;letter-spacing:.06em}

/* FOOTER */
.site-footer{padding:1.5rem;border-top:1px solid var(--border);box-shadow:none;display:flex;gap:2rem;flex-wrap:wrap;align-items:center}
.site-footer small{font-family:var(--font-display);font-size:0.78rem;color:var(--muted);letter-spacing:.12em}
.site-footer a{color:var(--accent2);text-decoration:none}
.site-footer a:hover{text-shadow:0 0 8px var(--accent2)}

/* GAME PAGE */
.game-page-header{padding:1.5rem 0 0}
.game-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.game-category-tag{font-family:var(--font-display);font-size:0.72rem;padding:.3rem .8rem;border:1px solid var(--accent2);color:var(--accent2);text-shadow:0 0 8px var(--accent2);letter-spacing:.12em}
.game-page h1{font-family:var(--font-display);font-size:clamp(.7rem,2.5vw,1.1rem);line-height:1.7;color:var(--text);text-shadow:2px 2px 0 var(--accent);letter-spacing:.05em;margin-bottom:.25rem}
.player-wrap{margin:1.25rem 0}
.player-ratio{position:relative;width:100%;aspect-ratio:16/9;background:#000;border:2px solid var(--accent);box-shadow:0 0 30px rgba(255,45,120,0.2),inset 0 0 30px rgba(0,0,0,0.5);overflow:hidden}
.player-ratio[data-ratio="4/3"]{aspect-ratio:4/3}
.game-iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}

.player-loader{position:absolute;inset:0;z-index:9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.9rem;background:rgba(5,3,8,0.88);font-family:var(--font-display);font-size:.85rem;letter-spacing:.08em;color:var(--accent2);text-align:center;padding:1rem}
.loader-spinner{width:36px;height:36px;border:3px solid rgba(0,229,255,0.25);border-top-color:var(--accent2);border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.player-toolbar{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.5rem;z-index:10}
.toolbar-btn{width:36px;height:36px;border:1px solid var(--accent);background:rgba(5,3,8,0.85);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);transition:all .15s;text-decoration:none;box-shadow:0 0 8px rgba(255,45,120,0.2)}
.toolbar-btn:hover{background:rgba(255,45,120,0.15);box-shadow:0 0 16px rgba(255,45,120,0.4)}
#fullscreen-icon[data-state="enter"] .fs-exit{display:none}
#fullscreen-icon[data-state="exit"] .fs-enter{display:none}

/* Fullscreen mode: kill aspect-ratio so the iframe fills the screen,
   and keep toolbar visible above the iframe. */
.player-ratio:fullscreen,
.player-ratio:-webkit-full-screen{
  aspect-ratio:auto;width:100vw;height:100vh;
  border:0;box-shadow:none;background:#000;
}
.player-ratio:fullscreen .player-toolbar,
.player-ratio:-webkit-full-screen .player-toolbar{
  top:1rem;right:1rem;z-index:2147483647;
}
.player-ratio:fullscreen .toolbar-btn,
.player-ratio:-webkit-full-screen .toolbar-btn{
  width:44px;height:44px;
}
.fallback{color:var(--muted);margin:.75rem 0 0;padding:1rem 1.25rem;border:1px solid var(--border);background:var(--surface);font-family:var(--font-display);font-size:.85rem;line-height:1.7;letter-spacing:.06em}
.fallback a{color:var(--accent2)}
.hidden{display:none !important}
.game-desc{color:var(--muted);max-width:65ch;font-size:1rem;margin-top:.75rem;letter-spacing:.03em}
.game-actions{display:flex;gap:.75rem;margin-top:1.5rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-family:var(--font-display);font-size:.8rem;letter-spacing:.08em;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:all .15s}
.btn-primary{background:var(--accent);color:white;border-color:var(--accent);box-shadow:0 0 16px rgba(255,45,120,0.4)}
.btn-primary:hover{box-shadow:0 0 24px rgba(255,45,120,0.6);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}
.btn-ghost:hover{color:var(--accent2);border-color:var(--accent2);text-shadow:0 0 8px var(--accent2)}

@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border:1px solid var(--border)}

/* GAME INSTRUCTIONS */
.game-instructions{
  margin-top:1.25rem;padding:1rem 1.25rem;
  background:var(--surface);border:1px solid var(--border);
  border-left:3px solid var(--accent2);
  display:flex;flex-direction:column;gap:.4rem;
  max-width:65ch;
}
.game-instructions-label{font-family:var(--font-display);font-size:.72rem;letter-spacing:.18em;color:var(--accent2);text-shadow:0 0 8px var(--accent2)}
.game-instructions-body{font-family:var(--font-body);color:var(--text);font-size:.95rem;line-height:1.55}

/* LEGAL & CONTACT PAGES */
.legal-page{max-width:880px}
.legal-header{padding:2rem 0 1rem;border-bottom:1px dashed var(--border);margin-bottom:2rem}
.legal-header h1{
  font-family:var(--font-display);font-size:clamp(.9rem,3vw,1.55rem);
  line-height:1.6;letter-spacing:.05em;color:var(--text);
  text-shadow:3px 3px 0 var(--accent),6px 6px 0 rgba(126,77,255,0.3);
  margin-bottom:1rem;
}
.legal-header h1 span{color:var(--accent2);text-shadow:0 0 15px var(--accent2),3px 3px 0 #004455}
.legal-meta{font-family:var(--font-display);font-size:.78rem;letter-spacing:.16em;color:var(--muted)}

.legal-body{display:flex;flex-direction:column;gap:1.5rem}
.legal-lead{
  background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent3);
  padding:1.2rem 1.4rem;font-size:1.02rem;color:var(--text);
}
.legal-lead strong{color:var(--accent3)}
.legal-body section{
  background:var(--surface);border:1px solid var(--border);
  padding:1.2rem 1.4rem;
  position:relative;
}
.legal-body section::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:24px;
  background:var(--accent);box-shadow:0 0 10px var(--accent);
}
.legal-body h2{
  font-family:var(--font-display);font-size:1rem;letter-spacing:.1em;
  color:var(--accent);margin-bottom:.85rem;
  text-shadow:0 0 6px rgba(47,111,255,0.5);
}
.legal-body p{color:var(--text);font-size:.97rem;margin-bottom:.7rem}
.legal-body p:last-child{margin-bottom:0}
.legal-body ul{margin:.5rem 0 .8rem 1.2rem;display:flex;flex-direction:column;gap:.4rem}
.legal-body li{font-size:.97rem;color:var(--text);line-height:1.55}
.legal-body strong{color:var(--accent3)}
.legal-body a{color:var(--accent2);text-decoration:underline;text-decoration-color:rgba(0,184,217,0.4);text-underline-offset:3px;transition:all .15s}
.legal-body a:hover{text-shadow:0 0 8px var(--accent2);text-decoration-color:var(--accent2)}

/* CONTACT CARDS */
.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.contact-card{
  display:flex;flex-direction:column;gap:.45rem;
  padding:1.4rem 1.5rem;
  background:var(--surface);border:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:transform .15s,box-shadow .15s,border-color .15s;
}
.contact-card::after{
  content:'';position:absolute;top:0;right:0;width:40px;height:40px;
  background:linear-gradient(135deg,transparent 50%,rgba(47,111,255,0.15) 50%);
  transition:background .2s;
  pointer-events:none;
}
.contact-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 15px 35px rgba(47,111,255,0.14)}
.contact-card:hover::after{background:linear-gradient(135deg,transparent 50%,rgba(47,111,255,0.4) 50%)}
.contact-card-tag{font-family:var(--font-display);font-size:.7rem;letter-spacing:.18em;color:var(--accent3);text-shadow:0 0 6px rgba(126,77,255,0.5)}
.contact-card-title{font-family:var(--font-display);font-size:.95rem;letter-spacing:.04em;color:var(--text);line-height:1.45;word-break:break-word;text-decoration:none;transition:color .15s,text-shadow .15s}
.contact-card-title:hover{color:var(--accent2);text-shadow:0 0 10px rgba(0,184,217,0.6)}
.contact-card-sub{font-family:var(--font-body);font-size:.88rem;color:var(--muted);line-height:1.5}
.contact-card-sub a{color:var(--accent2)}

/* COOKIE CONSENT */
.cookie-consent{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:200;
  pointer-events:none;
  opacity:0;transform:translateY(20px);
  transition:opacity .25s ease, transform .25s ease;
}
.cookie-consent.cookie-consent-visible{opacity:1;transform:translateY(0);pointer-events:auto}
.cookie-consent-inner{
  margin:0 auto;max-width:780px;
  background:var(--surface);
  border:1px solid var(--border);
  border-left:3px solid var(--accent);
  box-shadow:0 20px 60px rgba(47,111,255,0.18),0 0 24px rgba(126,77,255,0.12);
  padding:1.1rem 1.3rem;
  display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.cookie-consent-inner::before{
  content:'';position:absolute;top:0;right:0;width:120px;height:100%;
  background:linear-gradient(90deg,transparent,rgba(0,184,217,0.06));
  pointer-events:none;
}
.cookie-msg{
  flex:1;min-width:240px;
  font-family:var(--font-body);font-size:.92rem;color:var(--text);line-height:1.55;
  display:flex;flex-direction:column;gap:.25rem;
}
.cookie-tag{font-family:var(--font-display);font-size:.65rem;letter-spacing:.2em;color:var(--accent3);text-shadow:0 0 6px rgba(126,77,255,0.5)}
.cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-actions .btn{padding:.6rem 1.2rem;font-size:.7rem}

/* Mid screens — tighter cards, smaller hero. */
@media(max-width:900px){
  .featured-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
  .game-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .hero{padding:1.5rem 0 1.25rem}
  .game-page h1{font-size:clamp(.95rem,4vw,1.3rem)}
}

/* Mobile — single-feature column, larger touch targets, banner full-width */
@media(max-width:600px){
  .site-header{padding:0 1rem;height:56px;gap:1rem}
  .container{padding:1.25rem 1rem 6rem}
  .hero{padding:1.25rem 0 1rem}
  .hero h1{font-size:1.15rem;text-shadow:2px 2px 0 var(--accent),4px 4px 0 rgba(255,45,120,0.3)}
  .hero-sub{font-size:.92rem}
  .featured-grid{grid-template-columns:1fr;gap:.85rem;margin-bottom:2rem}
  .game-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.6rem}
  .game-card h2{font-size:.85rem}
  .game-card p{font-size:.78rem}
  .filters{gap:.4rem;margin-bottom:1.25rem}
  .filter-btn{padding:.5rem .85rem;font-size:.7rem;letter-spacing:.08em}
  .section-title{font-size:.85rem}
  .section-count{font-size:.65rem}
  .tagline{font-size:.7rem;padding-left:1rem}
  .breadcrumbs{font-size:.7rem;gap:.4rem}
  .coin-banner-inner{font-size:.55rem}
  .game-category-tag{font-size:.62rem}
  .game-instructions{padding:.8rem 1rem}
  .game-instructions-label{font-size:.62rem}
  .game-instructions-body{font-size:.88rem}
  .player-toolbar{top:.5rem;right:.5rem;gap:.4rem}
  .toolbar-btn{width:34px;height:34px}
  .player-loader{font-size:.78rem}
  .btn{padding:.7rem 1.2rem;font-size:.72rem}
  .game-actions{gap:.5rem}
  .site-footer{padding:1.2rem 1rem;gap:1rem}
  .site-footer small{font-size:.7rem}
  .cookie-consent{left:.5rem;right:.5rem;bottom:.5rem}
  .cookie-consent-inner{padding:.9rem 1rem;flex-direction:column;align-items:stretch;gap:.8rem}
  .cookie-msg{font-size:.85rem;min-width:0}
  .cookie-actions{justify-content:stretch;gap:.5rem}
  .cookie-actions .btn{flex:1;justify-content:center}
  .legal-body section,.legal-lead{padding:1rem 1.1rem}
  .legal-body h2{font-size:.9rem}
  .legal-meta{font-size:.7rem}
  .legal-header h1{font-size:1.2rem;text-shadow:2px 2px 0 var(--accent),4px 4px 0 rgba(126,77,255,0.3)}
  .contact-cards{grid-template-columns:1fr}
  .contact-card-title{font-size:.88rem}
}

/* Very narrow — Galaxy Fold etc. */
@media(max-width:380px){
  .game-grid{grid-template-columns:1fr 1fr;gap:.5rem}
  .game-card h2{font-size:.8rem}
  .game-card p{display:none}
  .filter-btn{padding:.45rem .7rem;font-size:.65rem}
}
