@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --void:#150A24;
  --panel:#2A1648;
  --panel-edge:#42276E;
  --magenta:#FF2E92;
  --cyan:#43F4EC;
  --yellow:#FCE94E;
  --bone:#F1E9F7;
  --bone-dim:#C9BBDC;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  background:var(--void);
  color:var(--bone);
  font-family:'Space Grotesk', sans-serif;
  line-height:1.5;
  position:relative;
  overflow-x:hidden;
}

/* CRT scanline overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,0.025) 0px,
    rgba(255,255,255,0.025) 1px,
    transparent 1px,
    transparent 3px
  );
  z-index:50;
  mix-blend-mode:overlay;
}

@keyframes flicker{
  0%, 100% { opacity:1; }
  50% { opacity:0.96; }
}
body{ animation: flicker 4s infinite; }

@media (prefers-reduced-motion: reduce){
  body{ animation:none; }
  body::before{ display:none; }
}

.pixel{
  font-family:'Press Start 2P', monospace;
  letter-spacing:1px;
}

a{ color:var(--cyan); }

/* ---------------- Nav ---------------- */
.site-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 24px;
  border-bottom:2px solid var(--panel-edge);
  background:var(--void);
  position:sticky;
  top:0;
  z-index:60;
  flex-wrap:wrap;
  gap:12px;
}
.site-nav .brand{
  font-family:'Press Start 2P', monospace;
  font-size:16px;
  color:var(--magenta);
  text-decoration:none;
  text-shadow:0 0 6px var(--magenta), 0 0 18px rgba(255,46,146,0.5);
  white-space:nowrap;
}
.site-nav .brand span{ color:var(--cyan); text-shadow:0 0 6px var(--cyan); }
.site-nav nav{ display:flex; gap:22px; flex-wrap:wrap; }
.site-nav nav a{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--bone-dim);
  text-decoration:none;
  border-bottom:2px solid transparent;
  padding-bottom:2px;
  transition:color .15s ease, border-color .15s ease;
}
.site-nav nav a:hover,
.site-nav nav a.active{
  color:var(--cyan);
  border-color:var(--cyan);
}

/* ---------------- Auth / membership ---------------- */
#authSlot{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--bone-dim);
  white-space:nowrap;
}
#authSlot a{
  color:var(--magenta);
  text-decoration:none;
  font-weight:700;
}
#authSlot a:hover{ color:var(--yellow); }
.auth-pill{
  display:inline-block;
  background:var(--panel);
  border:1px solid var(--panel-edge);
  border-radius:20px;
  padding:4px 12px;
  color:var(--cyan);
  margin-right:8px;
}
.auth-popover{
  position:absolute;
  right:16px;
  top:60px;
  background:var(--panel);
  border:1px solid var(--panel-edge);
  border-radius:8px;
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:8px;
  z-index:70;
  min-width:220px;
}
.auth-popover input{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  padding:8px 10px;
  border-radius:4px;
  border:1px solid var(--panel-edge);
  background:var(--void);
  color:var(--bone);
}
.auth-popover-status{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--bone-dim);
  margin:0;
}
.member-gate{
  max-width:520px;
  margin:64px auto;
  text-align:center;
  background:var(--panel);
  border:1px solid var(--panel-edge);
  border-radius:10px;
  padding:40px 28px;
}
.member-gate .pixel{
  color:var(--magenta);
  font-size:18px;
  margin:0 0 14px;
}
.member-gate p{ color:var(--bone-dim); margin:0 0 24px; }

.hidden{ display:none !important; }

/* ---------------- Hero ---------------- */
header.hero{
  text-align:center;
  padding:64px 24px 48px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,46,146,0.18), transparent 60%),
    radial-gradient(ellipse at 50% 100%, rgba(67,244,236,0.12), transparent 60%);
  border-bottom:2px solid var(--panel-edge);
}
header.hero p.eyebrow{
  font-family:'JetBrains Mono', monospace;
  color:var(--cyan);
  text-transform:uppercase;
  letter-spacing:4px;
  font-size:12px;
  margin:0 0 18px;
}
header.hero h1{
  font-size:clamp(28px, 7vw, 56px);
  margin:0 0 14px;
  color:var(--magenta);
  text-shadow:
    0 0 6px var(--magenta),
    0 0 22px rgba(255,46,146,0.55),
    3px 3px 0 var(--cyan);
}
header.hero p.tag{
  font-size:clamp(14px, 2.4vw, 18px);
  color:var(--bone-dim);
  max-width:620px;
  margin:0 auto 32px;
}

/* ---------------- Buttons ---------------- */
.button-row{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; }
.btn{
  font-family:'JetBrains Mono', monospace;
  font-weight:700;
  font-size:14px;
  letter-spacing:1px;
  text-transform:uppercase;
  padding:14px 22px;
  border-radius:6px;
  border:2px solid transparent;
  cursor:pointer;
  text-decoration:none;
  display:inline-block;
  transition:transform .1s ease;
}
.btn:active{ transform:translateY(2px); }
.btn-primary{
  background:var(--magenta);
  color:var(--void);
  border-color:var(--yellow);
  box-shadow:0 4px 0 rgba(0,0,0,0.35);
}
.btn-secondary{
  background:transparent;
  color:var(--cyan);
  border-color:var(--cyan);
  box-shadow:0 0 12px rgba(67,244,236,0.35) inset;
}
.btn-buy{
  background:var(--yellow);
  color:#241038;
  border-color:#241038;
}

/* ---------------- Layout helpers ---------------- */
main{ max-width:1100px; margin:0 auto; padding:48px 24px; }
section + section{ margin-top:56px; }
.section-head{ margin-bottom:24px; }
.section-head .eyebrow{
  font-family:'JetBrains Mono', monospace;
  color:var(--cyan);
  text-transform:uppercase;
  letter-spacing:3px;
  font-size:12px;
  margin:0 0 8px;
}
.section-head h2{
  font-family:'Press Start 2P', monospace;
  font-size:clamp(18px,4vw,28px);
  margin:0 0 8px;
  color:var(--bone);
}
.section-head p{ color:var(--bone-dim); max-width:640px; margin:0; }

/* ---------------- Filter bar ---------------- */
.filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:28px;
}
.filter-chip{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--bone-dim);
  background:var(--panel);
  border:1px solid var(--panel-edge);
  border-radius:20px;
  padding:8px 16px;
  cursor:pointer;
  transition:all .15s ease;
}
.filter-chip:hover{ border-color:var(--cyan); color:var(--cyan); }
.filter-chip.active{
  background:var(--cyan);
  color:var(--void);
  border-color:var(--cyan);
}

/* ---------------- Cards ---------------- */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
  gap:24px;
}
.card{
  background:var(--panel);
  border:1px solid var(--panel-edge);
  border-radius:10px;
  overflow:hidden;
  transition:transform .15s ease, box-shadow .15s ease;
  display:flex;
  flex-direction:column;
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:0 0 0 2px var(--cyan), 0 8px 24px rgba(67,244,236,0.18);
}
.card .thumb{
  height:140px;
  display:flex; align-items:center; justify-content:center;
  font-size:40px;
  position:relative;
}
.card .thumb::after{
  content:"";
  position:absolute; inset:0;
  background:repeating-linear-gradient(to bottom, rgba(255,255,255,0.05) 0 2px, transparent 2px 4px);
}
.thumb-cursed{ background:linear-gradient(135deg,#3a0e1f,#1a0b2e); }
.thumb-astral{ background:linear-gradient(135deg,#1b0e3a,#0d1f3a); }
.thumb-grumbley{ background:linear-gradient(135deg,#2b240e,#1a0b2e); }
.thumb-mathmarathon{ background:linear-gradient(135deg,#0e2b2b,#0b1a2e); }
.thumb-nightshift{ background:linear-gradient(135deg,#2b0e24,#0d0d1f); }

.card .body{ padding:16px; display:flex; flex-direction:column; flex:1; }
.badge{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--cyan);
  border:1px solid var(--cyan);
  border-radius:4px;
  padding:3px 8px;
  margin-bottom:8px;
  align-self:flex-start;
}
.badge.lesson{ color:var(--yellow); border-color:var(--yellow); }
.card h3{
  font-family:'Press Start 2P', monospace;
  font-size:14px;
  color:var(--bone);
  margin:0 0 8px;
  line-height:1.4;
}
.card p{
  font-size:13px;
  color:var(--bone-dim);
  margin:0 0 14px;
  flex:1;
}
.card .meta{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:auto;
}
.card .price{
  font-family:'JetBrains Mono', monospace;
  color:var(--yellow);
  font-weight:700;
  font-size:13px;
}
.card .play{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  color:var(--magenta);
  text-decoration:none;
  font-weight:700;
}
.card .play:hover{ color:var(--yellow); }

/* ---------------- Ticker ---------------- */
.ticker{
  border-top:2px solid var(--panel-edge);
  border-bottom:2px solid var(--panel-edge);
  background:var(--panel);
  overflow:hidden;
  white-space:nowrap;
  padding:12px 0;
}
.ticker span{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  letter-spacing:2px;
  color:var(--yellow);
  animation:scroll 22s linear infinite;
  padding-right:60px;
}
@keyframes scroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-100%); }
}
@media (prefers-reduced-motion: reduce){
  .ticker span{ animation:none; }
}

/* ---------------- Footer ---------------- */
footer{
  border-top:2px solid var(--panel-edge);
  padding:32px 24px;
  text-align:center;
  color:var(--bone-dim);
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:1px;
}
footer a{ color:var(--cyan); text-decoration:none; }
footer a:hover{ color:var(--yellow); }

/* ---------------- Responsive ---------------- */
@media (max-width:640px){
  .site-nav{ flex-direction:column; align-items:flex-start; }
  main{ padding:32px 16px; }
}

/* ========================================
   AUTH & PROFILE UI
   ======================================== */

.auth-profile {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
}

.profile-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  background: var(--panel);
  border: 2px solid var(--panel-edge);
  border-radius: 8px;
  text-decoration: none;
  color: var(--bone);
  cursor: pointer;
  transition: all 0.2s;
}

.profile-link:hover {
  border-color: var(--cyan);
  box-shadow: 0 0 12px rgba(67, 244, 236, 0.3);
}

.profile-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--cyan);
  object-fit: cover;
}

.profile-avatar-default {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--cyan);
  background: linear-gradient(135deg, var(--magenta), var(--cyan));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Press Start 2P', monospace;
  font-size: 18px;
  color: var(--void);
}

.profile-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.profile-name {
  font-weight: 600;
  font-size: 14px;
  color: var(--bone);
}

.role-badge {
  font-family: 'Press Start 2P', monospace;
  font-size: 8px;
  padding: 2px 6px;
  border-radius: 4px;
  text-transform: uppercase;
  display: inline-block;
}

.role-badge.admin {
  background: var(--magenta);
  color: var(--void);
}

.role-badge.mod {
  background: var(--yellow);
  color: var(--void);
}

.role-badge.member {
  background: var(--cyan);
  color: var(--void);
}

.role-badge.free {
  background: var(--panel-edge);
  color: var(--bone);
}

.profile-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 8px;
  background: var(--panel);
  border: 2px solid var(--panel-edge);
  border-radius: 8px;
  padding: 8px;
  min-width: 180px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.2s;
  z-index: 100;
}

.profile-dropdown.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.profile-dropdown a {
  display: block;
  padding: 8px 12px;
  color: var(--bone);
  text-decoration: none;
  border-radius: 4px;
  transition: background 0.2s;
  font-size: 14px;
}

.profile-dropdown a:hover {
  background: var(--panel-edge);
  color: var(--cyan);
}

/* Auth Modal */
.auth-modal {
  position: fixed;
  inset: 0;
  background: rgba(21, 10, 36, 0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.auth-modal.hidden {
  display: none;
}

.auth-modal-content {
  background: var(--panel);
  border: 2px solid var(--cyan);
  border-radius: 12px;
  padding: 32px;
  max-width: 400px;
  width: 90%;
  position: relative;
  box-shadow: 0 0 40px rgba(67, 244, 236, 0.3);
}

.auth-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  background: none;
  border: none;
  color: var(--bone);
  font-size: 32px;
  cursor: pointer;
  line-height: 1;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-modal-close:hover {
  color: var(--magenta);
}

.auth-modal h3 {
  font-family: 'Press Start 2P', monospace;
  color: var(--cyan);
  margin: 0 0 16px 0;
  font-size: 18px;
}

.auth-modal p {
  margin: 0 0 16px 0;
  color: var(--bone-dim);
}

.auth-modal form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.auth-modal input[type="email"] {
  padding: 12px;
  background: var(--void);
  border: 2px solid var(--panel-edge);
  border-radius: 6px;
  color: var(--bone);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 16px;
}

.auth-modal input[type="email"]:focus {
  outline: none;
  border-color: var(--cyan);
  box-shadow: 0 0 12px rgba(67, 244, 236, 0.2);
}

.auth-status {
  margin: 8px 0 0 0;
  font-size: 14px;
  text-align: center;
}

/* Sign in button */
#authLoginBtn {
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
}

/* Responsive */
@media (max-width: 768px) {
  .profile-link {
    padding: 6px 8px;
  }
  
  .profile-avatar,
  .profile-avatar-default {
    width: 32px;
    height: 32px;
    font-size: 14px;
  }
  
  .profile-name {
    font-size: 12px;
  }
  
  .role-badge {
    font-size: 7px;
  }
}
