
/*
Theme Name: PPC2 Blueprint
Author: PPC2
Description: Minimal theme CSS. Layout + game structure live in core-layout.css.
Version: 0.2
*/

@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap");
@import url("/assetscore-layout.css");

/* =========================
   TOKENS (NEON JUSTICE BROADCAST)
========================= */
:root{
  --bg-0:#f6f7ff;
  --bg-1:#ffffff;
  --bg-2:#eef1ff;
  --bg-3:#0b1020;
  --ink-0:#10162f;
  --ink-1:#28304f;
  --ink-2:#4e5a7a;
  --ink-3:#ffffff;
  --line:#b7c2ff;
  --line-soft:#d7ddff;
  --line-strong:#1e2a62;
  --accent:#ff2d55;
  --accent-2:#00d4ff;
  --accent-3:#ffd43b;
  --accent-4:#6bf7b3;
  --shadow:0 16px 0 rgba(16,22,47,.25);
  --shadow-soft:0 12px 30px rgba(16,22,47,.15);
  --radius:6px;
  --radius-lg:14px;
  --space-1:.5rem;
  --space-2:.9rem;
  --space-3:1.4rem;
  --space-4:2.2rem;
  --space-5:3.2rem;
  --space-6:4.6rem;
  --font-ui:"Barlow", "Segoe UI", Arial, sans-serif;
  --font-display:"Bebas Neue", Impact, "Arial Black", sans-serif;
  --font-mono:"JetBrains Mono", Menlo, Consolas, monospace;
  --outline:2px solid var(--line-strong);
  --frame:3px solid var(--line-strong);
}

/* =========================
   BASE
========================= */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  color:var(--ink-0);
  font-family:var(--font-ui);
  font-size:17px;
  line-height:1.65;
  background:
    radial-gradient(1000px 600px at 80% -10%, rgba(0,212,255,.18), transparent 60%),
    radial-gradient(800px 480px at 0% 10%, rgba(255,45,85,.16), transparent 55%),
    var(--bg-0);
}
img{ max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
p{ color:var(--ink-1); margin:.7rem 0; }

h1,h2,h3,h4{ margin:0 0 .7rem; line-height:1.12; letter-spacing:.015em; }
h1,h2{ font-family:var(--font-display); text-transform:uppercase; }

:focus{ outline:none; }
:focus-visible{ box-shadow:0 0 0 3px rgba(0,212,255,.4); }

@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; scroll-behavior:auto !important; }
}

/* =========================
   ACCESSIBILITY
========================= */
.skip-link{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:1rem; top:1rem; width:auto; height:auto; padding:.6rem .9rem;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-soft); z-index:9999;
}

/* =========================
   GLOBAL TEXTURE + BROADCAST EFFECTS
========================= */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .2;
  z-index: -1;
  background:
    radial-gradient(circle at 12px 12px, rgba(16,22,47,.18) 1px, transparent 1px) 0 0/18px 18px,
    radial-gradient(circle at 6px 6px, rgba(16,22,47,.08) 1px, transparent 1px) 0 0/12px 12px;
  mix-blend-mode: multiply;
}
body::after{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background:
    linear-gradient(115deg, rgba(255,212,59,.12) 0 12%, transparent 12% 100%),
    linear-gradient(295deg, rgba(0,212,255,.1) 0 10%, transparent 10% 100%);
}

/* =========================
   COMMON LAYOUT
========================= */
.container{
  width:min(1120px, 92vw);
  margin:0 auto;
}

header{
  position:sticky;
  top:0;
  z-index:50;
  background:linear-gradient(90deg, rgba(255,45,85,.16), rgba(0,212,255,.16));
  border-bottom:var(--frame);
  box-shadow:0 6px 0 rgba(16,22,47,.1);
  backdrop-filter: blur(6px);
}
.header-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  flex-wrap:wrap;
  padding:1rem 0;
}
.logo{
  font-family:var(--font-display);
  font-size:2rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-0);
  padding:.4rem .7rem;
  border:var(--frame);
  background:var(--bg-1);
  box-shadow:var(--shadow);
  line-height:1;
}

.user-menu{
  display:flex;
  align-items:center;
  gap:1rem;
}
.user-info{
  display:flex;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
  font-weight:600;
  text-transform:uppercase;
  color:var(--ink-1);
  line-height:1.4;
}
.user-info .mark{
  color:var(--accent);
  letter-spacing:.08em;
  margin:0 .35rem;
}
.points{
  padding:.35rem .75rem;
  border:var(--outline);
  background:linear-gradient(180deg, #fff 0, var(--bg-2) 100%);
  box-shadow:0 6px 0 rgba(16,22,47,.2);
  font-family:var(--font-mono);
  letter-spacing:.06em;
}
.nav-link{ text-decoration:underline; text-underline-offset:3px; }

.auth-buttons{
  display:flex;
  gap:.7rem;
  align-items:center;
}
.auth-buttons a{
  padding:.45rem .85rem;
  border:var(--outline);
  background:var(--bg-1);
  font-weight:700;
  text-transform:uppercase;
  box-shadow:0 6px 0 rgba(16,22,47,.18);
}
.auth-buttons a:last-child{
  background:var(--accent);
  color:var(--ink-3);
  border-color:var(--accent);
}

main{ padding:var(--space-5) 0 var(--space-6); }

/* =========================
   BUTTONS + TAGS
========================= */
.btn,
.play-btn,
.submit-btn,
.age-popup__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  padding:.8rem 1.5rem;
  border:var(--frame);
  background:var(--accent-2);
  color:var(--ink-0);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:1rem;
  line-height:1;
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.play-btn.alt{
  background:var(--bg-1);
  color:var(--ink-0);
}
.btn--primary{ background:var(--accent); color:var(--ink-3); border-color:var(--accent); }
.btn:hover,
.play-btn:hover,
.submit-btn:hover,
.age-popup__btn:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 0 rgba(16,22,47,.2);
}

.badge{
  display:inline-block;
  padding:.2rem .6rem;
  border:2px solid var(--line-strong);
  background:var(--accent-3);
  color:var(--ink-0);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
}

/* =========================
   HERO + BROADCAST FRAME
========================= */
.broadcast{
  display:flex;
  flex-direction:column;
  gap:var(--space-5);
}
.hero{
  position:relative;
  padding:var(--space-5);
  background:linear-gradient(130deg, #ffffff 0%, #eef1ff 100%);
  border:var(--frame);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero > *{
  position:relative;
  z-index:2;
}
.hero::before{
  content:"";
  position:absolute;
  top:-40px;
  right:-40px;
  width:160px;
  height:160px;
  background:var(--accent-3);
  border:var(--frame);
  transform:rotate(18deg);
  z-index:0;
}
.hero::after{
  content:"";
  position:absolute;
  bottom:-30px;
  left:-30px;
  width:150px;
  height:120px;
  background:var(--accent-2);
  border:var(--frame);
  transform:rotate(-12deg);
  opacity:.6;
  z-index:0;
}
.kicker{
  display:inline-block;
  padding:.35rem .7rem;
  border:var(--outline);
  background:var(--bg-1);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.85rem;
}
.hero-title{
  font-size:clamp(2.8rem, 7vw, 5.2rem);
  margin:.6rem 0 .4rem;
  line-height:.98;
}
.hero-title__name{
  display:inline-block;
  padding:.25rem .7rem;
  border:var(--frame);
  background:var(--accent);
  color:var(--ink-3);
  box-shadow:var(--shadow);
}
.hero-disclaimer{
  font-size:.9rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent);
  margin:.6rem 0 0;
}
.hero-lead{
  font-size:1.2rem;
  max-width:52ch;
}
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; margin-top:1.2rem; position:relative; z-index:3; }

/* =========================
   NOTICE + DISCLAIMER
========================= */
.disclaimer-banner{
  border:var(--frame);
  background:linear-gradient(90deg, rgba(255,212,59,.2), rgba(0,212,255,.2));
  padding:var(--space-3);
  box-shadow:var(--shadow);
}
.disclaimer-banner h2{
  font-family:var(--font-display);
  letter-spacing:.08em;
  margin-bottom:.4rem;
}

.section-lead{
  max-width:60ch;
  font-size:1.1rem;
}

/* =========================
   PANELS + SECTIONS
========================= */
.content-section{
  display:flex;
  flex-direction:column;
  gap:1.2rem;
}
.panel{
  border:var(--frame);
  background:var(--bg-1);
  padding:var(--space-3);
  box-shadow:var(--shadow);
}
.panel--marble{
  background:
    linear-gradient(135deg, rgba(255,255,255,.9), rgba(239,244,255,.9)),
    repeating-linear-gradient(45deg, rgba(16,22,47,.05) 0 6px, transparent 6px 12px);
}

/* =========================
   GAMES GRID
========================= */
.games-section{ position:relative; }
.games-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1.4rem;
}
.game-card{
  position:relative;
  border:var(--frame);
  background:var(--bg-1);
  padding:1.4rem 1.2rem 1.6rem;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.game-card::after{
  content:"";
  position:absolute;
  inset:auto -40px -40px auto;
  width:120px;
  height:120px;
  background:var(--accent-2);
  border:var(--frame);
  transform:rotate(12deg);
  opacity:.25;
}
.game-card h3{
  display:flex;
  align-items:center;
  gap:.6rem;
  font-family:var(--font-display);
  letter-spacing:.08em;
}
.game-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border:var(--frame);
  background:var(--accent-3);
  font-weight:700;
}
.game-title{ text-transform:uppercase; }
.game-desc{ margin:.8rem 0 1.1rem; }

/* =========================
   FAQ (ONE LINE, DISTINCT)
========================= */
.faq-wrap{ gap:1.2rem; }
.faq-item{
  border:var(--outline);
  padding:1rem;
  background:var(--bg-1);
  box-shadow:0 8px 0 rgba(16,22,47,.2);
}
.faq-item h3{
  font-size:1.1rem;
  text-transform:uppercase;
  letter-spacing:.06em;
}

/* =========================
   CONTACT FORM
========================= */
.contact-form{
  display:grid;
  gap:1.1rem;
  border:var(--frame);
  padding:2rem;
  background:var(--bg-1);
  box-shadow:0 18px 0 rgba(16,22,47,.28), 0 28px 60px rgba(16,22,47,.18);
  max-width:980px;
  margin:0 auto;
  width:100%;
}
.form-group{ display:flex; flex-direction:column; gap:.45rem; }
label{
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-0);
  font-size:.9rem;
}
input, textarea, select{
  border:var(--outline);
  padding:.85rem 1rem;
  font-family:var(--font-ui);
  font-size:1rem;
  background:#fff;
  color:var(--ink-0);
  min-height:52px;
  box-shadow:inset 0 0 0 1px rgba(16,22,47,.08);
}
textarea{ min-height:160px; }
input::placeholder, textarea::placeholder{ color:var(--ink-2); }

/* =========================
   FOOTER
========================= */
footer{
  border-top:var(--frame);
  background:linear-gradient(180deg, rgba(255,45,85,.08), rgba(0,212,255,.08));
  padding:var(--space-5) 0 var(--space-4);
}
.footer-content{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:2rem;
}
.footer-section h4{
  font-family:var(--font-display);
  letter-spacing:.08em;
  text-transform:uppercase;
}
.footer-links{ display:flex; flex-direction:column; gap:.4rem; }
.footer-links a{ text-decoration:underline; text-underline-offset:3px; }
.footer-bottom{
  margin-top:var(--space-3);
  border-top:var(--outline);
  padding-top:1.4rem;
  font-size:.95rem;
}

/* =========================
   AGE POPUP (HOME)
========================= */
.age-popup{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(16,22,47,.75);
  opacity:0;
  visibility:hidden;
  transition:opacity .25s ease;
  z-index:100;
}
.age-popup--open{
  opacity:1;
  visibility:visible;
}
.age-popup__panel{
  border:var(--frame);
  background:var(--bg-1);
  padding:1.6rem 1.8rem;
  max-width:420px;
  text-align:center;
  box-shadow:var(--shadow);
}
.age-popup__text{
  margin:0 0 1rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--accent);
}

/* =========================
   BULLET LISTS (EMOJI)
========================= */
:root{ --bullet-emoji: "⚡"; }
.notice-list,
.list,
.quick-rules__list,
.game-coming__list{
  list-style:none;
  padding-left:0;
}
.notice-list li,
.list li,
.quick-rules__list li,
.game-coming__list li{
  position:relative;
  padding-left:1.6rem;
  margin:.35rem 0;
}
.notice-list li::before,
.list li::before,
.quick-rules__list li::before,
.game-coming__list li::before{
  content:var(--bullet-emoji);
  position:absolute;
  left:0;
  top:0;
}

/* =========================
   GAME UI SAFETY
========================= */
.game-page button,
.game-page .bet-btn,
.game-page .bet-btn-mobile,
.game-page .bet-set-btn,
.game-page #predict-low,
.game-page #predict-high,
.game-page #predict-red,
.game-page #predict-blue,
.game-page #spin-btn,
.game-page #deal-btn,
.game-page #deal-btn-mobile,
.game-page #hit-btn,
.game-page #stand-btn,
.game-page #hit-btn-mobile,
.game-page #stand-btn-mobile{
  background:var(--accent-2);
  color:var(--ink-0);
  border:2px solid var(--line-strong);
}
.game-page input,
.game-page textarea,
.game-page .bet-input{
  background:var(--bg-1);
  color:var(--ink-0);
  border:2px solid var(--line-strong);
}
.game-page input::placeholder,
.game-page textarea::placeholder{
  color:var(--ink-2);
}

/* =========================
   GAME PAGES (GENERAL)
========================= */
.game-page main .container,
.game-container{
  border:var(--frame);
  background:linear-gradient(135deg, #ffffff 0%, #eef1ff 100%);
  box-shadow:var(--shadow);
}
.game-page h1,
.game-container h1{
  font-family:var(--font-display);
  letter-spacing:.08em;
  text-transform:uppercase;
}
.guest-notice{
  border:var(--outline);
  background:rgba(255,212,59,.2);
  color:var(--ink-0);
}

/* =========================
   TABLES + BADGES
========================= */
table{
  width:100%;
  border-collapse:collapse;
  font-size:.95rem;
}
th,td{
  border:1px solid var(--line);
  padding:.6rem .8rem;
}
th{
  background:var(--bg-2);
  text-transform:uppercase;
  letter-spacing:.05em;
}

/* =========================
   MICRO-DETAILS
========================= */
hr{
  border:none;
  height:3px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
  margin:1.5rem 0;
}

blockquote{
  border-left:4px solid var(--accent);
  padding:1rem 1.2rem;
  background:var(--bg-1);
  box-shadow:var(--shadow-soft);
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 900px){
  .header-content{ flex-direction:column; align-items:flex-start; }
  .logo{ font-size:1.7rem; }
  .hero{ padding:var(--space-4); }
}

@media (max-width: 700px){
  .hero-actions{ flex-direction:column; align-items:stretch; }
  .play-btn, .btn, .submit-btn{ width:100%; justify-content:center; }
  .disclaimer-banner{ padding:var(--space-2); }
  .panel{ padding:var(--space-2); }
}

@media (max-width: 520px){
  .hero{ padding:var(--space-3); }
  .hero-title{ font-size:2.2rem; }
  .header-content{ padding:.8rem 0; }
  .points{ width:100%; text-align:center; }
}
