:root{
  --bg: linear-gradient(135deg, #1e1e24 0%, #2a2a35 25%, #1a1a22 50%, #252530 75%, #1c1c26 100%);
  --surface: rgba(255,255,255,0.08);
  --surface-2: rgba(255,255,255,0.12);
  --text: #f8f9fa;
  --muted: #adb5bd;
  --accent: #b8a3ff;
  --accent-2: #d4c7ff;
  --danger: #ff6b6b;
  --gold: #f7cc53;
  --success: #51cf66;
  --warning: #ffd43b;
  --info: #74c0fc;
  --white: #ffffff;
  --black: #000000;
  --shadow: 0 15px 40px rgba(0,0,0,0.25), 0 5px 15px rgba(0,0,0,0.15);
  --glow: 0 0 25px rgba(184,163,255,0.4);
  --transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-theme="light"] {
  --bg: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 25%, #dee2e6 50%, #ced4da 75%, #adb5bd 100%);
  --surface: rgba(0,0,0,0.08);
  --surface-2: rgba(0,0,0,0.12);
  --text: #212529;
  --muted: #6c757d;
  --accent: #6f42c1;
  --accent-2: #8e44ad;
}

*{ box-sizing:border-box }
html, body{ height:100%; scroll-behavior: smooth; }
body{
  margin:0;
  font-family: Outfit, Inter, sans-serif;
  color:var(--text);
  background: var(--bg);
  background-attachment: fixed;
  transition: background 0.5s ease, color 0.3s ease;
  position: relative;
  overflow-x: hidden;
}

body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 3px,
      rgba(184,163,255,0.02) 3px,
      rgba(184,163,255,0.02) 6px
    );
  pointer-events: none;
  z-index: -1;
}

/* Unlock cards for feature purchases - compact version */
.unlock-card{
  display:flex;
  flex-direction: column;
  gap:8px;
  padding:10px 12px;
  margin:6px 0;
  border-radius:10px;
  background: var(--surface);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  border: 1px solid var(--surface-2);
  max-width: 300px;
}
.unlock-title{ 
  font-weight:600; 
  font-size: 0.9rem;
}
.unlock-desc{ 
  color: var(--muted); 
  font-size: 0.8rem; 
  line-height: 1.3;
}
.btn.btn-accent{ 
  background: var(--accent); 
  color: #000; 
  border: none; 
  box-shadow: 0 0 15px rgba(184,163,255,0.3);
  padding: 8px 14px;
  font-size: 0.85rem;
  font-weight: 600;
}
.btn.btn-accent:hover{ filter: brightness(1.05); }

/* Auto controls layout */
.auto-wrap{ display:flex; align-items:center; gap:8px; flex-wrap: wrap; }
.auto-label{ font-weight:600; }

/* Animated background particles */
body::before {
  content: '';
  position: fixed;
  width: 200%;
  height: 200%;
  top: -50%;
  left: -50%;
  z-index: -1;
  background-image: 
    radial-gradient(2px 2px at 20% 30%, rgba(184, 163, 255, 0.3), transparent),
    radial-gradient(2px 2px at 60% 70%, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(1px 1px at 50% 50%, rgba(184, 163, 255, 0.2), transparent),
    radial-gradient(1px 1px at 80% 10%, rgba(255, 255, 255, 0.15), transparent);
  background-size: 200% 200%, 180% 180%, 150% 150%, 220% 220%;
  background-position: 0% 0%, 100% 100%, 50% 50%, 0% 100%;
  animation: drift 30s ease-in-out infinite;
  opacity: 0.4;
}

@keyframes drift {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  33% { transform: translate(2%, 2%) rotate(120deg); }
  66% { transform: translate(-2%, 2%) rotate(240deg); }
}

.app-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:24px 16px 8px;
  max-width: 1024px; margin: 0 auto;
  flex-wrap: wrap;
  gap: 12px;
}
.brand{ display:flex; align-items:center; gap:14px; }
.logo-badge{ 
  width:72px; height:72px; border-radius:50%; display:grid; place-items:center; 
  background: linear-gradient(135deg, #b8a3ff, #d4c5ff); 
  border:1px solid rgba(184,163,255,0.3); 
  box-shadow: 0 8px 22px rgba(0,0,0,0.4), var(--glow); 
  animation: pulse-glow 3s ease-in-out infinite;
  transition: var(--transition);
}
.logo-badge:hover {
  transform: scale(1.05) rotate(5deg);
  box-shadow: 0 12px 30px rgba(0,0,0,0.5), 0 0 30px rgba(184,163,255,0.6);
}
@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 20px rgba(184,163,255,0.4); }
  50% { box-shadow: 0 8px 22px rgba(0,0,0,0.4), 0 0 35px rgba(184,163,255,0.6); }
}
.logo{ 
  width: 72px; 
  height: 72px; 
  filter: drop-shadow(0 8px 16px rgba(184,163,255,0.3));
  border: 3px solid var(--accent);
  border-radius: 16px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  transition: all 0.3s ease;
  cursor: pointer;
}

.logo:hover {
  transform: translateY(-2px) scale(1.05);
  filter: drop-shadow(0 12px 24px rgba(184,163,255,0.4));
  box-shadow: 0 0 20px rgba(184,163,255,0.3);
}

.wordmark {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.wordmark .title{
  font-family: Outfit, Inter, sans-serif;
  font-size: clamp(32px, 4.5vw, 48px);
  font-weight: 700;
  letter-spacing: 1px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: 0 4px 8px rgba(184,163,255,0.2);
  margin: 0;
  animation: subtle-glow 4s ease-in-out infinite;
}

@keyframes subtle-glow {
  0%, 100% { filter: brightness(1); }
  50% { filter: brightness(1.1); }
}

.wordmark .subtitle{
  font-family: Outfit, Inter, sans-serif;
  font-size: clamp(12px, 1.8vw, 16px);
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--muted);
  font-style: italic;
  margin-top: 4px;
  opacity: 0.8;
}

/* Header controls */
.header-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}


.container{ 
  max-width: 1200px; 
  margin: 0 auto; 
  padding: 12px 20px 40px;
}

.game-card{
  margin: 20px auto 28px; 
  padding: 40px;
  background: var(--surface);
  backdrop-filter: blur(15px) saturate(1.2);
  border: 2px solid rgba(255,255,255,0.15);
  border-radius: 24px;
  box-shadow: var(--shadow);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}

.game-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(139, 90, 60, 0.15), transparent);
  transition: left 0.6s ease;
}

.game-card:hover::before {
  left: 100%;
}

.game-card:hover {
  transform: translateY(-3px);
  box-shadow: 
    0 25px 60px rgba(0,0,0,0.2), 
    0 12px 28px rgba(184,163,255,0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
  border-color: rgba(184,163,255,0.3);
}

.display-wrap{
  display:grid; grid-template-columns: 1fr auto; align-items:center; gap: 20px; margin-bottom: 24px;
}
.spin-ring{
  display:flex; align-items:center; justify-content:center; padding: 16px;
  border-radius: 16px; background: var(--surface);
}
.number-tile{
  --tile-width: clamp(120px, 28vw, 200px);
  --tile-height: clamp(90px, 22vw, 160px);
  width: var(--tile-width); height: var(--tile-height);
  border-radius: 12px;
  display:flex; align-items:center; justify-content:center;
  font-family: Outfit, Inter, system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(42px, 10vw, 74px);
  letter-spacing: 1px;
  border: 2px solid rgba(255,255,255,0.18);
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.04), var(--shadow);
  transition: transform .2s ease, box-shadow .3s ease, background-color .3s ease, color .3s ease, border-color .3s ease;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.number-tile:hover {
  transform: translateY(-2px) scale(1.02);
}
.number-tile::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(45deg, transparent 30%, rgba(255,255,255,0.1) 50%, transparent 70%);
  transform: rotate(45deg);
  transition: opacity 0.3s;
  opacity: 0;
}
.number-tile:hover::before {
  opacity: 1;
  animation: shine 1.5s ease-in-out infinite;
}
@keyframes shine {
  0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
  100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
}
.number-tile[data-color="white"]{ 
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%); 
  color: var(--white); 
  border-color: var(--accent);
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.number-tile[data-color="black"]{ 
  background: linear-gradient(135deg, #ffd43b 0%, #fff3bf 100%); 
  color: #1a1a1a; 
  border-color: #ffd43b;
  text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
.number-tile.number--spin{ animation: wobble 1.2s ease-in-out infinite, rotate-3d 2s ease-in-out infinite; }
.number-tile.number--win{ 
  box-shadow: 0 0 0 3px rgba(184,163,255,0.4), 0 0 40px rgba(184,163,255,0.4), var(--shadow); 
  animation: celebrate 0.6s ease-out;
}
.number-tile.number--lose{ 
  box-shadow: 0 0 0 3px rgba(255,107,107,0.35), 0 0 40px rgba(255,107,107,0.35), var(--shadow); 
  animation: shake 0.5s ease-out;
}

@keyframes celebrate {
  0%, 100% { transform: scale(1) rotate(0deg); }
  25% { transform: scale(1.1) rotate(5deg); }
  50% { transform: scale(1.15) rotate(-5deg); }
  75% { transform: scale(1.1) rotate(3deg); }
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-5px) rotate(-2deg); }
  75% { transform: translateX(5px) rotate(2deg); }
}

@keyframes rotate-3d {
  0%, 100% { transform: perspective(1000px) rotateY(0deg); }
  50% { transform: perspective(1000px) rotateY(10deg); }
}

@keyframes wobble{
  0%,100%{ transform: rotate(0deg) scale(1) }
  20%{ transform: rotate(2deg) scale(1.02) }
  40%{ transform: rotate(-2deg) scale(0.99) }
  60%{ transform: rotate(1deg) scale(1.02) }
  80%{ transform: rotate(-1deg) scale(0.99) }
}

.result-badge{
  min-width: 110px; padding: 12px 16px; border-radius: 10px; border:1px solid rgba(255,255,255,0.12);
  background: var(--surface);
  color: var(--muted);
  font-weight: 600; font-size: 14px; letter-spacing:.6px; text-transform: uppercase; text-align:center; align-self: center;
}
.result-badge.win{ color: var(--lavender); border-color: rgba(184,163,255,0.4); box-shadow: inset 0 0 40px rgba(184,163,255,0.1); }
.result-badge.lose{ color: var(--danger); border-color: rgba(255,107,107,0.35); box-shadow: inset 0 0 40px rgba(255,107,107,0.08); }

.controls{ padding: 16px; background: var(--surface); border-radius: 14px; border:1px solid rgba(255,255,255,0.10); }
.badge {
  background: linear-gradient(90deg, #fff 60%, #b6b6ff 100%);
  color: #222;
  font-weight: 600;
  border-radius: 12px;
  padding: 2px 10px;
  font-size: 0.95em;
  box-shadow: 0 1px 4px rgba(0,0,0,0.07);
  border: 1px solid #eaeaea;
  letter-spacing: 0.04em;
  margin-left: 8px;
}
.seed-btn {
  background: #eaeaff;
  color: #222;
  border: 1px solid #b6b6ff;
  border-radius: 8px;
  padding: 2px 10px;
  font-size: 0.95em;
  cursor: pointer;
  transition: background 0.2s;
  margin-left: 12px;
}
.seed-btn:hover {
  background: #d6d6ff;
}

.game-row{ display:grid; grid-template-columns: 90px 1fr; gap: 12px; align-items:center; margin-bottom: 14px; }
.select{ width:100%; padding:10px 12px; border-radius:10px; border:1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.06); color:var(--text); font-weight:600; }
.select option{ background: #1a1a1a; color: var(--text); }
.rules{ margin: 6px 0 14px; color: var(--muted); font-size: 13px; line-height: 1.5; }
.odds{ margin: 0 0 14px; font-size: 13px; }
.game-controls{ display:grid; gap: 12px; margin-bottom: 8px; }

.choice-row{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
input[type="radio"]{ display:none; }
.chip{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 20px; border-radius:999px; border:1px solid rgba(255,255,255,0.14); cursor:pointer;
  background: rgba(255,255,255,0.05); color: var(--text); font-weight:600;
  transition: transform .1s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.chip:hover{ transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,0.25); }
input[type="radio"]:checked + .chip{ border-color: var(--accent); box-shadow: 0 0 0 3px rgba(184,163,255,0.35); }
.chip--white{ 
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%); 
  color: var(--white);
  border-color: var(--accent);
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.chip--black{ 
  background: linear-gradient(135deg, #ffd43b 0%, #fff3bf 100%); 
  color: #1a1a1a;
  border-color: #ffd43b;
  text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

.number-inputs{ display:grid; gap:8px; }
.num-label{ color: var(--muted); font-size: 12px; letter-spacing:.6px; text-transform: uppercase; }
.num-picker{ display:grid; grid-template-columns: 140px 1fr; gap: 14px; align-items:center; width: 100%; }
.num-picker input[type="number"]{
  width:100%; padding: 10px 12px; border-radius: 10px; border:1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06); color: var(--text); font-weight:700; font-family: Outfit, Inter, sans-serif;
}

input[type="range"]{
  -webkit-appearance:none; appearance:none; height: 8px; border-radius:6px; background: rgba(255,255,255,0.14); outline:none;
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none; width:20px; height:20px; border-radius:50%; background: var(--lavender); box-shadow: 0 2px 8px rgba(184,163,255,0.5);
}
input[type="range"]::-moz-range-thumb{
  width:20px; height:20px; border-radius:50%; background: var(--lavender); box-shadow: 0 2px 8px rgba(184,163,255,0.5);
}

.actions{ 
  margin-top: 20px; 
  display:flex; 
  gap:14px; 
  flex-wrap:wrap; 
  align-items:center;
  justify-content: center;
}
.btn{
  padding: 13px 20px; 
  border-radius: 12px; 
  border:1px solid rgba(255,255,255,0.12); 
  cursor:pointer;
  background: rgba(255,255,255,0.06); 
  color: var(--text); 
  font-weight: 700;
  font-size: 0.95rem;
  transition: transform .12s ease, box-shadow .25s ease, background .2s ease, border-color .2s ease;
  position: relative;
  overflow: hidden;
}
.btn::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}
.btn:active::before {
  width: 300px;
  height: 300px;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 10px 24px rgba(0,0,0,0.35); }
.btn:active{ transform: translateY(0); }
.btn-primary{ 
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%); 
  border: 2px solid var(--accent);
  color: var(--white); 
  font-weight: 700;
  box-shadow: 0 6px 16px rgba(184,163,255,0.25), inset 0 1px 0 rgba(255,255,255,0.2);
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--accent-2) 0%, var(--accent) 100%);
  box-shadow: 0 8px 24px rgba(184,163,255,0.35), inset 0 1px 0 rgba(255,255,255,0.3);
  transform: translateY(-2px);
}
.btn-ghost{ background: rgba(255,255,255,0.08); }
.btn-danger{ 
  background: rgba(255,107,107,0.2); 
  border-color: rgba(255,107,107,0.4); 
  color: #ff6b6b;
  font-weight: 700;
}
.btn-danger:hover{ 
  background: rgba(255,107,107,0.3); 
  box-shadow: 0 6px 18px rgba(255,107,107,0.3);
}
#fullResetBtn {
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  animation: pulse-danger 3s ease-in-out infinite;
}
@keyframes pulse-danger {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,107,107,0.4); }
  50% { box-shadow: 0 0 0 4px rgba(255,107,107,0); }
}
.btn[disabled]{ opacity: .6; cursor: not-allowed; transform: none !important; }
.btn-help{ width:36px; height:36px; display:grid; place-items:center; padding:0; font-weight:800; }

.auto-wrap{ display:inline-flex; align-items:center; gap:8px; background: rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.10); padding:8px 10px; border-radius: 10px; }
.auto-label{ color: var(--muted); font-size:12px; letter-spacing:.6px; text-transform:uppercase; }
#autoCount{ width:80px; padding:8px 10px; border-radius: 8px; border:1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.06); color: var(--text); font-weight:700; font-family: Outfit, Inter, sans-serif; }

.statusbar{ 
  margin-top: 28px; 
  display:flex; 
  align-items: center; 
  justify-content: center; 
  gap: 18px; 
  flex-wrap: wrap;
  padding: 20px;
  background: var(--surface);
  border: 2px solid rgba(255,255,255,0.15);
  border-radius: 20px;
  box-shadow: var(--shadow);
}
.score{ 
  display:flex; 
  gap: 14px; 
  flex-wrap: wrap;
  justify-content: center;
}
.score-item{ 
  background: var(--surface);
  background-image: var(--marble-texture);
  padding: 18px 20px; 
  border-radius: 12px; 
  border: 2px solid rgba(139, 90, 60, 0.1); 
  min-width:130px; 
  text-align: center;
  box-shadow: 
    0 4px 8px rgba(0,0,0,0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}
.score-item .label{ 
  display:block; 
  color: var(--muted); 
  font-size: 11px; 
  letter-spacing:.8px; 
  text-transform: uppercase; 
  margin-bottom: 6px;
  font-weight: 600;
}
.score-item .value{ 
  display:block; 
  font-weight:700; 
  font-size: 26px;
  font-family: 'Georgia', serif;
  color: var(--accent);
  text-shadow: 0 2px 4px rgba(139, 90, 60, 0.2);
}
.message{ 
  color: var(--muted); 
  min-height: 24px;
  text-align: center;
  flex: 1 1 100%;
  margin-top: 8px;
}

/* Footer Styling */
.app-footer { 
  text-align: center; 
  padding: 12px 16px 24px; 
  color: var(--muted);
}

.bodhin-footer {
  max-width: 600px;
  margin: 0 auto;
}

.bodhin-logo {
  font-size: 18px;
  font-weight: bold;
  color: var(--accent);
  margin-bottom: 12px;
  letter-spacing: 0.5px;
}

.bodhin-description p {
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
  margin: 8px 0;
  opacity: 0.8;
}

.visually-hidden{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Confetti */
.confetti{ position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 9999; }
.confetti .piece{
  position: absolute; width: 8px; height: 14px; border-radius: 2px; opacity: 0; 
  transform: translateY(-40px) rotate(0deg);
  box-shadow: 0 0 10px currentColor;
}

@keyframes drop{
  0%{ opacity: 0; transform: translateY(-40px) rotate(0deg); }
  10%{ opacity: 1; }
  100%{ opacity: 0; transform: translateY(110vh) rotate(720deg); }
}

/* Floating particles background effect */
.particle {
  position: fixed;
  width: 3px;
  height: 3px;
  background: radial-gradient(circle, var(--accent) 0%, rgba(139, 90, 60, 0.6) 100%);
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  z-index: -1;
  box-shadow: 0 0 8px rgba(139, 90, 60, 0.4);
}



@keyframes float-up {
  0% {
    opacity: 0;
    transform: translateY(0) translateX(0) scale(0);
  }
  10% {
    opacity: 0.8;
  }
  90% {
    opacity: 0.8;
  }
  100% {
    opacity: 0;
    transform: translateY(-100vh) translateX(50px) scale(1.5);
  }
}

/* Glow effect on hover for interactive elements */
.btn:hover,
.chip:hover {
  box-shadow: 0 0 20px rgba(184,163,255,0.3), 0 10px 24px rgba(0,0,0,0.35);
}

/* Smooth scrollbar */
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.05);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  background: var(--accent);
  border-radius: 10px;
  transition: var(--transition);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--accent-2);
}

/* Loading spinner */
.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 3px solid rgba(255,255,255,0.3);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Enhanced stat cards with hover effect */
.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3), 0 0 20px rgba(184,163,255,0.2);
  border-color: var(--accent);
}

.score-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}

/* Clicker System Styles */
.clicker-section {
  margin-bottom: 32px;
}

.click-area {
  background: linear-gradient(135deg, rgba(184,163,255,0.15), rgba(184,163,255,0.05));
  border: 2px solid var(--accent);
  border-radius: 20px;
  padding: 48px;
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
  user-select: none;
  margin-bottom: 24px;
}

.click-area::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(184,163,255,0.3);
  transform: translate(-50%, -50%);
  transition: width 0.3s, height 0.3s;
}

.click-area:hover {
  transform: scale(1.02);
  box-shadow: 0 0 40px rgba(184,163,255,0.4), var(--shadow);
  border-color: var(--accent-2);
}

.click-area:active::before {
  width: 500px;
  height: 500px;
}

.click-area.clicked {
  animation: clickPulse 0.3s ease-out;
}

@keyframes clickPulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

.click-chip {
  font-size: 80px;
  margin-bottom: 16px;
  animation: float 3s ease-in-out infinite;
  filter: drop-shadow(0 10px 20px rgba(184,163,255,0.5));
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

.click-text {
  font-size: 24px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.click-stats {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
}

.click-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.click-stat-label {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.click-stat-value {
  font-size: 28px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.floating-number {
  position: absolute;
  font-size: 24px;
  font-weight: 800;
  color: var(--gold);
  pointer-events: none;
  animation: floatUp 1s ease-out forwards;
  text-shadow: 0 2px 4px rgba(0,0,0,0.5);
  z-index: 100;
}

@keyframes floatUp {
  0% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(-100px) scale(1.5);
  }
}

/* Upgrades Panel */
.upgrades-panel, .click-upgrades-panel {
  margin-top: 24px;
  padding: 24px;
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.10);
}

.panel-title {
  font-size: 19px;
  font-weight: 700;
  margin: 0 0 20px 0;
  color: var(--text);
}

.upgrades-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}

.upgrade-card {
  display: grid;
  grid-template-columns: 60px 1fr 50px;
  gap: 14px;
  align-items: center;
  padding: 18px;
  background: rgba(255,255,255,0.05);
  border: 2px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  cursor: pointer;
  transition: var(--transition);
}

.upgrade-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.3);
  background: rgba(255,255,255,0.08);
}

.upgrade-card.affordable {
  border-color: var(--accent);
  background: rgba(184,163,255,0.1);
}

.upgrade-card.affordable:hover {
  border-color: var(--accent-2);
  box-shadow: 0 8px 20px rgba(184,163,255,0.3);
}

.upgrade-card.locked {
  opacity: 0.5;
  cursor: not-allowed;
}

.upgrade-card.locked:hover {
  transform: none;
}

.upgrade-icon {
  font-size: 48px;
  text-align: center;
}

.upgrade-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.upgrade-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}

.upgrade-desc {
  font-size: 12px;
  color: var(--muted);
}

.upgrade-stats {
  display: flex;
  gap: 12px;
  margin-top: 4px;
}

.upgrade-production {
  font-size: 13px;
  font-weight: 700;
  color: var(--success);
}

.upgrade-cost {
  font-size: 13px;
  font-weight: 600;
  color: var(--gold);
}

.upgrade-owned {
  font-size: 24px;
  font-weight: 800;
  color: var(--accent);
  text-align: center;
}

/* Click Power Upgrades */
.click-upgrades-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.click-upgrade {
  padding: 16px;
  background: rgba(255,255,255,0.05);
  border: 2px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
  position: relative;
}

.click-upgrade:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.3);
}

.click-upgrade.affordable {
  border-color: var(--gold);
  background: rgba(247,204,83,0.1);
}

.click-upgrade.affordable:hover {
  box-shadow: 0 8px 20px rgba(247,204,83,0.3);
}

.click-upgrade.owned {
  border-color: var(--success);
  background: rgba(74,222,128,0.1);
  cursor: default;
}

.click-upgrade.owned:hover {
  transform: none;
}

.click-upgrade.locked {
  opacity: 0.5;
  cursor: not-allowed;
}

.click-upgrade.locked:hover {
  transform: none;
}

.click-upgrade-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 8px;
}

.click-upgrade-effect {
  font-size: 13px;
  color: var(--accent);
  margin-bottom: 8px;
}

.click-upgrade-cost {
  font-size: 12px;
  font-weight: 600;
  color: var(--gold);
}

.click-upgrade-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--success);
  color: #000;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}

/* Responsive tweaks */
@media (max-width: 640px){
  .display-wrap{ grid-template-columns: 1fr; gap: 16px; }
  .result-badge{ justify-self: start; }
  .num-picker{ grid-template-columns: 1fr; }
  .score{ width: 100%; }
  .score-item{ flex: 1; min-width: 90px; }
  .statusbar{ flex-direction: column; align-items: stretch; }
  .stats-grid{ grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; }
  .game-card{ padding: 20px; }
  .app-header{ padding: 16px; }
  .header-controls{ width: 100%; justify-content: flex-end; }
  .achievements-grid{ grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
  .achievement-card{ padding: 12px; }
  .achievement-icon{ font-size: 24px; }
  .toast{ right: 10px; left: 10px; max-width: none; }
  .leaderboard-item{ grid-template-columns: 30px 1fr auto; padding: 10px 12px; }
  .leaderboard-rank{ font-size: 16px; }
  .leaderboard-score{ font-size: 18px; }
  
  /* Clicker responsive */
  .click-area{ padding: 30px 20px; }
  .click-chip{ font-size: 60px; }
  .click-text{ font-size: 18px; }
  .click-stat-value{ font-size: 22px; }
  .click-stats{ gap: 20px; }
  .upgrades-grid{ grid-template-columns: 1fr; }
  .upgrade-card{ grid-template-columns: 50px 1fr 40px; padding: 12px; }
  .upgrade-icon{ font-size: 36px; }
  .click-upgrades-grid{ grid-template-columns: 1fr; }
  
  /* Tutorial responsive */
  .tutorial-step{ grid-template-columns: 50px 1fr; padding: 12px; }
  .tutorial-icon{ font-size: 32px; }
  .tutorial-step h3{ font-size: 14px; }
  .tutorial-step p{ font-size: 13px; }
}

@media (max-width: 480px) {
  .brand{ flex-wrap: wrap; }
  .logo-badge{ width: 60px; height: 60px; }
  .logo{ width: 48px; height: 48px; }
  .wordmark .title{ font-size: 18px; }
  .actions{ gap: 8px; }
  .btn{ padding: 10px 14px; font-size: 14px; }
  .auto-wrap{ padding: 6px 8px; }
}

/* Modal */
.modal{ position: fixed; inset:0; display:none; }
.modal.open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background: rgba(0,0,0,0.55); backdrop-filter: blur(2px); }
.modal-content{ position:relative; width:min(880px, 92vw); max-height: 82vh; overflow:auto; margin: 6vh auto 0; background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.06)); border:2px solid rgba(184,163,255,0.2); border-radius: 16px; padding: 24px; color: var(--text); box-shadow: 0 20px 60px rgba(0,0,0,0.3), 0 8px 25px rgba(184,163,255,0.15); backdrop-filter: blur(20px); }
.modal-close{ position:absolute; top:8px; right:10px; background: transparent; color: var(--text); border:1px solid rgba(255,255,255,0.2); width:34px; height:34px; border-radius:8px; cursor:pointer; }
.rules-list{ display:grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap:12px; margin-top: 12px; }
.rules-card{ background: var(--surface); border:1px solid rgba(255,255,255,0.10); border-radius: 10px; padding: 12px; }
.rules-card h3{ margin: 0 0 6px; font-size: 16px; }
.rules-card p{ margin: 0; color: var(--muted); font-size: 13px; }
.muted{ color: var(--muted); }

/* Tutorial Modal Styles */
.tutorial-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px;
  max-height: 65vh;
  overflow-y: auto;
  padding: 0 8px;
}

.tutorial-step {
  display: grid;
  grid-template-columns: 50px 1fr;
  gap: 14px;
  padding: 18px;
  background: var(--surface);
  border-radius: 14px;
  border: 1px solid rgba(184,163,255,0.15);
  align-items: start;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.tutorial-step:hover {
  transform: translateY(-2px);
  border-color: rgba(184,163,255,0.25);
  box-shadow: 0 6px 20px rgba(184,163,255,0.15);
}

.tutorial-icon {
  font-size: 36px;
  text-align: center;
  line-height: 1;
}

.tutorial-step h3 {
  margin: 0 0 10px 0;
  font-size: 17px;
  color: var(--text);
  font-weight: 600;
  letter-spacing: 0.3px;
}

.tutorial-step p {
  margin: 0;
  font-size: 14px;
  color: var(--muted);
  line-height: 1.6;
}

.tutorial-step strong {
  color: var(--accent);
  font-weight: 700;
}

/* Fixed Chip Counter */
.chip-counter {
  position: fixed;
  top: 20px;
  right: 20px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #0b0b0b;
  padding: 12px 20px;
  border-radius: 50px;
  font-weight: 800;
  font-size: 18px;
  box-shadow: var(--shadow), 0 0 20px rgba(184,163,255,0.5);
  z-index: 9998;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 2px solid rgba(255,255,255,0.2);
  animation: float 3s ease-in-out infinite;
  user-select: none;
  pointer-events: none;
}

.chip-counter-icon {
  font-size: 24px;
  animation: spin-slow 10s linear infinite;
}

@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.chip-counter-value {
  font-family: 'Outfit', monospace;
  letter-spacing: 0.5px;
}

/* Tutorial Popup (Corner Style) */
.tutorial-popup {
  position: fixed;
  bottom: 20px;
  left: 20px;
  max-width: 400px;
  background: linear-gradient(135deg, rgba(184,163,255,0.95), rgba(212,197,255,0.95));
  backdrop-filter: blur(10px);
  border-radius: 16px;
  padding: 24px;
  box-shadow: var(--shadow), 0 0 40px rgba(184,163,255,0.6);
  z-index: 9999;
  border: 2px solid rgba(255,255,255,0.3);
  animation: slideInLeft 0.4s ease-out;
  color: #0b0b0b;
}

@keyframes slideInLeft {
  from {
    transform: translateX(-400px);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.tutorial-popup.hiding {
  animation: slideOutLeft 0.3s ease-out forwards;
}

@keyframes slideOutLeft {
  to {
    transform: translateX(-400px);
    opacity: 0;
  }
}

.tutorial-popup-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.tutorial-popup-icon {
  font-size: 48px;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
}

.tutorial-popup-title {
  flex: 1;
}

.tutorial-popup-step {
  font-size: 12px;
  font-weight: 600;
  opacity: 0.7;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.tutorial-popup-heading {
  font-size: 20px;
  font-weight: 800;
  margin: 4px 0 0 0;
}

.tutorial-popup-content {
  margin-bottom: 16px;
  line-height: 1.6;
  font-size: 15px;
  color: rgba(0,0,0,0.8);
}

.tutorial-popup-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.tutorial-popup-btn {
  padding: 10px 20px;
  border-radius: 10px;
  border: none;
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
  font-size: 14px;
}

.tutorial-popup-btn-skip {
  background: rgba(0,0,0,0.1);
  color: rgba(0,0,0,0.7);
}

.tutorial-popup-btn-skip:hover {
  background: rgba(0,0,0,0.15);
}

.tutorial-popup-btn-next {
  background: rgba(0,0,0,0.9);
  color: #fff;
}

.tutorial-popup-btn-next:hover {
  background: #000;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.tutorial-popup-progress {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-top: 16px;
}

.tutorial-popup-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(0,0,0,0.2);
  transition: var(--transition);
}

.tutorial-popup-dot.active {
  background: rgba(0,0,0,0.8);
  transform: scale(1.3);
}

/* Chart */
.chart-section{ 
  margin-top: 32px; 
  padding: 24px; 
  background: var(--surface);
  background-image: var(--marble-texture);
  border: 2px solid rgba(139, 90, 60, 0.1);
  border-radius: 16px;
  box-shadow: 
    0 4px 12px rgba(0,0,0,0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}
.chart-title{ margin: 0 0 16px; font-size: 18px; font-weight: 700; color: var(--text); letter-spacing: -0.3px; }
#historyChart, #recentChart, #winLossChart, #streakChart, #cpsChart{ 
  display: block; 
  width: 100%; 
  height: auto; 
  background: rgba(0,0,0,0.3); 
  border-radius: 12px; 
  border: 1px solid rgba(255,255,255,0.08); 
  margin-bottom: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}
.stats-grid{ 
  display: grid; 
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); 
  gap: 16px; 
  margin-top: 20px; 
}
.stat-card{ 
  background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04)); 
  border: 1px solid rgba(255,255,255,0.12); 
  border-radius: 12px; 
  padding: 18px; 
  text-align: center;
  transition: var(--transition);
}
.stat-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(184,163,255,0.15);
  border-color: var(--accent);
}
.stat-label{ 
  color: var(--muted); 
  font-size: 11px; 
  letter-spacing: 0.8px; 
  text-transform: uppercase; 
  margin-bottom: 10px;
  font-weight: 600;
}
.stat-value{ 
  color: var(--lavender); 
  font-size: 26px; 
  font-weight: 800; 
  font-family: Outfit, Inter, sans-serif;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 10px rgba(184,163,255,0.3));
}

/* Theme Toggle & Controls */
.icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.12);
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 18px;
  transition: var(--transition);
}

.icon-btn:hover {
  background: var(--surface-2);
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.3);
}

.icon-btn.active {
  background: var(--accent);
  color: #0b0b0b;
  border-color: var(--accent-2);
}

/* Achievements Section */
.achievements-section {
  margin-top: 28px;
  padding: 24px;
  background: var(--surface);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
}

.achievements-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 16px 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.achievements-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}

.achievement-card {
  background: linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}

.achievement-card.unlocked {
  border-color: var(--accent);
  background: linear-gradient(135deg, rgba(184,163,255,0.15), rgba(184,163,255,0.05));
  box-shadow: 0 0 20px rgba(184,163,255,0.2);
}

.achievement-card.locked {
  opacity: 0.4;
  filter: grayscale(1);
}

.achievement-icon {
  font-size: 32px;
  margin-bottom: 8px;
  display: block;
}

.achievement-card.unlocked .achievement-icon {
  animation: bounce 0.6s ease-out;
}

@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

.achievement-name {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--text);
}

.achievement-desc {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.3;
}

/* Leaderboard */
.leaderboard-section {
  margin-top: 28px;
  padding: 24px;
  background: var(--surface);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
}

.leaderboard-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 16px 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.leaderboard-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.leaderboard-item {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  transition: var(--transition);
}

.leaderboard-item:hover {
  background: rgba(255,255,255,0.08);
  transform: translateX(4px);
}

.leaderboard-rank {
  font-size: 18px;
  font-weight: 800;
  color: var(--accent);
  text-align: center;
}

.leaderboard-item:nth-child(1) .leaderboard-rank {
  color: var(--gold);
  font-size: 20px;
}

.leaderboard-item:nth-child(2) .leaderboard-rank {
  color: #c0c0c0;
}

.leaderboard-item:nth-child(3) .leaderboard-rank {
  color: #cd7f32;
}

.leaderboard-info {
  display: flex;
  flex-direction: column;
}

.leaderboard-name {
  font-weight: 600;
  font-size: 14px;
}

.leaderboard-detail {
  font-size: 12px;
  color: var(--muted);
}

.leaderboard-score {
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
}

/* Notification Toast */
.toast {
  position: fixed;
  top: 20px;
  right: 20px;
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  padding: 16px 20px;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  gap: 12px;
  transform: translateX(400px);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 10000;
  max-width: 320px;
}

.toast.show {
  transform: translateX(0);
}

.toast-icon {
  font-size: 24px;
}

.toast-content {
  flex: 1;
}

.toast-title {
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 4px;
}

.toast-message {
  font-size: 12px;
  color: var(--muted);
}

.toast.success {
  border-left: 4px solid var(--success);
}

.toast.error {
  border-left: 4px solid var(--danger);
}

.toast.info {
  border-left: 4px solid var(--info);
}

/* Streak multiplier indicator */
.multiplier-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: linear-gradient(135deg, var(--gold), #f59e0b);
  border-radius: 20px;
  font-weight: 700;
  font-size: 14px;
  color: #0b0b0b;
  box-shadow: 0 4px 12px rgba(247,204,83,0.4);
  animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}

/* Progress bar */
.progress-bar {
  width: 100%;
  height: 8px;
  background: rgba(255,255,255,0.1);
  border-radius: 10px;
  overflow: hidden;
  margin-top: 8px;
}

.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: 10px;
  transition: width 0.3s ease;
  box-shadow: 0 0 10px var(--accent);
}
