/* Arial ашиглана -- системийн font тул @import шаардлагагүй */

html {
  touch-action: manipulation;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
button, a, label, .tool-btn, .tool-card, .back-btn, .add-plus,
.spin-btn, .item-tag, .item-tag .rm, .upgrade-pill,
.winner-btn, .results-clear-btn, .pcard, .tcard, canvas {
  touch-action: manipulation;
}
@media (max-width: 768px) {
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="tel"],
  input[type="number"],
  input[type="search"],
  input[type="url"],
  textarea,
  select {
    font-size: 16px !important;
  }
  #lang-btn img {
    height: 15px !important;
    width: auto !important;
  }
  #lang-btn {
    padding: 6px !important;
  }
}

:root {
  color-scheme: light;
  --bg-base:    #f7f6f3;
  --orb-purple: transparent;
  --orb-pink:   transparent;
  --orb-blue:   transparent;
  --orb-white:  transparent;

  --glass-bg:        #ffffff;
  --glass-bg-hover:  #faf9f7;
  --glass-bg-strong: #ffffff;
  --glass-bg-nav:    #ffffff;
  --glass-border:    rgba(0,0,0,0.09);
  --glass-border-lo: rgba(0,0,0,0.06);
  --glass-blur:      none;
  --glass-blur-sm:   none;
  --glass-shadow:    0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --glass-shadow-lg: 0 4px 16px rgba(0,0,0,0.08);

  --accent:      #f97316;
  --accent-hover:#ea6a0e;
  --accent-lt:   rgba(249,115,22,0.08);
  --accent-pill: rgba(249,115,22,0.12);
  --accent-glow: 0 4px 14px rgba(249,115,22,0.20);

  --text:   #1c1917;
  --text2:  #78716c;
  --text3:  #a8a29e;
  --border:    rgba(0,0,0,0.09);
  --border-lo: rgba(0,0,0,0.06);

  --danger:     #e11d48;
  --danger-bg:  rgba(225,29,72,0.08);
  --success:    #059669;
  --success-bg: rgba(5,150,105,0.08);

  --radius:    10px;
  --radius-lg: 16px;
  --radius-xl: 22px;
  --font: 'Roboto', system-ui, sans-serif;
}

:root[data-theme="dark"] {
  color-scheme: dark;
  --bg-base:    #0f1115;
  --orb-purple: transparent;
  --orb-pink:   transparent;
  --orb-blue:   transparent;
  --orb-white:  transparent;

  --glass-bg:        #181b20;
  --glass-bg-hover:  #1e2228;
  --glass-bg-strong: #1e2228;
  --glass-bg-nav:    #15181d;
  --glass-border:    rgba(255,255,255,0.10);
  --glass-border-lo: rgba(255,255,255,0.06);
  --glass-blur:      none;
  --glass-blur-sm:   none;
  --glass-shadow:    0 1px 3px rgba(0,0,0,0.40);
  --glass-shadow-lg: 0 6px 22px rgba(0,0,0,0.55);

  --accent:      #f97316;
  --accent-hover:#ea6a0e;
  --accent-lt:   rgba(249,115,22,0.12);
  --accent-pill: rgba(249,115,22,0.18);
  --accent-glow: 0 4px 14px rgba(249,115,22,0.22);

  --text:   #f0eeea;
  --text2:  #a1a1aa;
  --text3:  #71717a;
  --border:    rgba(255,255,255,0.10);
  --border-lo: rgba(255,255,255,0.06);

  --danger:     #fb7185;
  --danger-bg:  rgba(251,113,133,0.14);
  --success:    #34d399;
  --success-bg: rgba(52,211,153,0.14);
}

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

html { min-height: 100%; }

body {
  min-height: 100vh;
  font-family: var(--font);
  font-size: 14px;
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  background-color: var(--bg-base);
  background-image: none;
}

.nav {
  position: sticky; top: 0; z-index: 200;
  height: 56px;
  background: var(--glass-bg-nav);
  backdrop-filter: none;
  backdrop-filter: none;
  border-bottom: 1px solid var(--glass-border);
  display: flex; align-items: center;
  padding: 0 28px; gap: 20px;
  box-shadow: var(--glass-shadow);
}

/* Баруун талын товчнуудын бүлэг (хэл + нэвтрэх) */
.nav-right { margin-left: auto; display: flex; align-items: center; gap: 4px; }
#lang-btn {
  display: flex; align-items: center; padding: 6px;
  border: none; background: transparent; cursor: pointer;
  border-radius: 4px; transition: transform .15s;
}
#lang-btn:hover { transform: scale(1.08); }

/* Хэл солих флаг — height-аар тогтооно (товчтой ижил өндөр болгохын тулд) */
#lang-btn img { height: 15px; width: auto; display: block; border-radius: 3px; }

/* Нэвтрэх товч — флагтай ижил өндөр (36px), ижил булангийн радиус (3px) */
.nav-login-btn {
  display: inline-flex; align-items: center; justify-content: center;
  box-sizing: border-box; height: 26px; padding: 0 14px;
  border: none; background: var(--accent, #f97316); color: #fff;
  font-weight: 700; font-size: 13px; border-radius: 3px;
  cursor: pointer; transition: transform .15s, box-shadow .15s;
}
.nav-login-btn:hover { transform: translateY(-1px); }

.nav-brand {
  display: flex; align-items: center; gap: 0;
  font-weight: 700; font-size: clamp(15px, 1.4vw + 10px, 22px);
  color: var(--accent); cursor: pointer;
  letter-spacing: -.2px;
  line-height: 1;
}
.nav-brand .brand-logo {
  height: 1.35em;
  width: 1.35em;
  object-fit: contain;
  border-radius: 5px;
  margin-right: -5px;
  flex-shrink: 0;
}
.nav-brand-icon {
  width: 30px; height: 30px;
  background: var(--accent-pill);
  border: 1px solid rgba(249,115,22,0.18);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center; font-size: 15px;
}

.lang-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 6px 12px; border-radius: 8px;
  border: 1px solid var(--glass-border-lo);
  background: var(--glass-bg);
  backdrop-filter: none;
  color: var(--text2); font-size: 13px; font-weight: 600;
  cursor: pointer; font-family: var(--font);
  transition: background .15s, color .15s, border-color .15s;
}
.lang-btn:hover { background: var(--glass-bg-hover); color: var(--text); border-color: rgba(249,115,22,0.25); }

.sign-in-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 18px;
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  font-weight: 600; font-size: 13px; cursor: pointer; font-family: var(--font);
  box-shadow: var(--accent-glow);
  transition: background .15s, box-shadow .15s;
}
.sign-in-btn:hover { background: var(--accent);filter:brightness(0.9); box-shadow: 0 6px 24px rgba(249,115,22,0.40); }

.sign-out-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 14px;
  background: var(--glass-bg);
  backdrop-filter: none;
  color: var(--text); border: 1px solid var(--glass-border-lo);
  border-radius: 8px; font-weight: 600; font-size: 13px;
  cursor: pointer; font-family: var(--font);
  transition: background .15s;
}
.sign-out-btn:hover { background: var(--glass-bg-hover); }

.user-badge {
  display: flex; align-items: center; gap: 7px;
  padding: 5px 13px;
  background: var(--accent-pill);
  border: 1px solid rgba(249,115,22,0.18);
  border-radius: 8px; font-size: 13px; font-weight: 600; color: var(--accent);
}

.page { display: none; }
.page.active { display: block; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

.hero { text-align: center; padding: 60px 0 44px; }
.hero h1 {
  font-size: 42px; font-weight: 800;
  color: var(--text);
  letter-spacing: -.8px; line-height: 1.1;
}

.hero h1 {
  background: var(--accent); opacity:0.95;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero p     { font-size: 16px; color: var(--text2); margin-top: 12px; }
.hero p.sub { font-size: 14px; color: var(--text3); margin-top: 6px; }

.tool-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-bottom: 24px;
}
.tool-grid.two-col { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 1100px) {
  .tool-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .tool-grid { grid-template-columns: 1fr; }
  .tool-grid.two-col { grid-template-columns: 1fr; }
}

/* Home дээр шууд дэлгэгдсэн tool section (wheel, password) */
.home-tool-section {
  margin-bottom: 28px;
}

/* ===== Wheel — wheelofnames маягийн ===== */
.wheel-section { margin-bottom: 36px; }
.wheel-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 28px;
  align-items: stretch;
}
.wheel-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--glass-shadow);
  padding: 20px 16px;
}
.wheel-section .wheel-canvas-wrap {
  position: relative;
  width: 100%;
  max-width: 480px;
  aspect-ratio: 1 / 1;
  margin: 0 auto;
}
.wheel-section #wheel-canvas {
  width: 100%;
  height: auto;
  max-width: 100%;
  display: block;
  margin: 0 auto;
}
.wheel-spins-line {
  margin-top: 16px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text2);
  text-align: center;
}
.wheel-spins-line #spin-counter-num {
  color: var(--accent);
  font-weight: 800;
}

.wheel-controls {
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--glass-shadow);
  padding: 16px;
  display: flex;
  flex-direction: column;
}
.wheel-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}
.wheel-tab {
  flex: 1;
  padding: 9px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--glass-border-lo);
  background: transparent;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
  cursor: pointer;
  transition: all .15s;
}
.wheel-tab.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.wheel-tab-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.wheel-toolbar {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.wheel-tool-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--glass-border-lo);
  background: var(--glass-bg);
  font-family: var(--font);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  transition: all .15s;
}
.wheel-tool-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.wheel-textarea {
  flex: 1;
  width: 100%;
  min-height: 320px;
  resize: none;
  padding: 12px 14px;
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius);
  font-family: var(--font);
  font-size: 14px;
  line-height: 1.9;
  color: var(--text);
  background: var(--glass-bg);
  outline: none;
  overflow-y: auto;
  transition: border-color .15s;
}
.wheel-textarea:focus {
  border-color: var(--accent);
}
.wheel-count-line {
  margin-top: 10px;
  font-size: 12.5px;
  color: var(--text2);
  font-weight: 600;
}
.wheel-count-line #wheel-count {
  color: var(--accent);
  font-weight: 800;
}
.wheel-results-empty {
  text-align: center;
  color: var(--text3);
  font-size: 13px;
  padding: 24px 0;
}
.wheel-tab-panel .results-list {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
}
@media (max-width: 900px) {
  .wheel-layout { grid-template-columns: 1fr; justify-items: center; }
  .wheel-main { order: 1; width: 100%; text-align: center; }
  .wheel-controls { order: 2; width: 100%; }
  .wheel-section .wheel-canvas-wrap { max-width: 480px; margin-left: auto; margin-right: auto; }
  .wheel-textarea { min-height: 220px; }
}
@media (max-width: 480px) {
  .wheel-section .wheel-canvas-wrap { max-width: 100%; margin-left: auto; margin-right: auto; }
}
.home-tool-hdr {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}
.home-tool-hdr h2 {
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.3px;
  line-height: 1.2;
}
.home-tool-sub {
  font-size: 13px;
  color: var(--text2);
  margin-top: 2px;
}
@media (max-width: 600px) {
  .home-tool-hdr .spin-counter { display: none !important; }
  .home-tool-hdr h2 { font-size: 17px; }
}
.tool-card {
  background: var(--glass-bg);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 26px;
  box-shadow: var(--glass-shadow);
  display: flex; flex-direction: column; gap: 14px;
  transition: background .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.tool-card:hover {
  background: var(--glass-bg-hover);
  border-color: rgba(249,115,22,0.20);
  transform: translateY(-3px);
  box-shadow: var(--glass-shadow-lg);
}
.tool-card-hdr { display: flex; align-items: flex-start; gap: 12px; min-height: 44px; }
.tool-card-hdr h3 { display: flex; align-items: center; min-height: 44px; }
.tool-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--accent-pill);
  border: 1px solid rgba(249,115,22,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; flex-shrink: 0;
  padding: 6px; overflow: hidden;
}
.tool-icon img { display: block; }
.tool-icon.gray {
  background: rgba(249,115,22,0.06);
  border-color: var(--glass-border-lo);
}
.tool-card h3 { font-size: 16px; font-weight: 700; color: var(--text); }
.tool-card p  { font-size: 13px; color: var(--text2); line-height: 1.65; flex: 1; }

.tool-btn {
  width: 100%; padding: 11px; border-radius: var(--radius);
  font-weight: 700; font-size: 14px; cursor: pointer; font-family: var(--font);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: all .15s;
}
.tool-btn.dark {
  background: var(--accent); color: #fff; border: none;
  box-shadow: var(--accent-glow);
}
.tool-btn.dark:hover { background: var(--accent);filter:brightness(0.9); box-shadow: 0 6px 22px rgba(249,115,22,0.40); }
.tool-btn.outline {
  background: var(--glass-bg); color: var(--text);
  border: 1px solid var(--glass-border-lo);
  backdrop-filter: none;
}
.tool-btn.outline:hover { background: var(--glass-bg-hover); border-color: rgba(249,115,22,0.25); }
.tool-btn.premium {
  background: var(--accent);
  color: #fff; border: none;
  box-shadow: var(--accent-glow);
  transition: filter .15s, box-shadow .15s;
}
.tool-btn.premium:hover { filter: brightness(1.08); box-shadow: var(--accent-glow); }

.premium-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--accent-pill); border: 1px solid rgba(249,115,22,0.18);
  color: var(--accent); font-size: 11px; font-weight: 700;
  padding: 3px 8px; border-radius: 999px; margin-left: 6px;
}

.feat-card {
  background: var(--glass-bg);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 20px 26px;
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 16px; margin-bottom: 48px;
  box-shadow: var(--glass-shadow);
}
.feat { display: flex; flex-direction: column; gap: 4px; }
.feat-title { display: flex; align-items: center; gap: 7px; font-weight: 600; font-size: 13px; color: var(--text); }
.feat-icon  { color: var(--accent); }
.feat p     { font-size: 12px; color: var(--text2); }

.tool-page { max-width: 620px; margin: 36px auto; padding: 0 20px; }
.tcard {
  background: var(--glass-bg-strong);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 32px;
  box-shadow: var(--glass-shadow-lg);
}
.tcard h2   { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 5px; }
.tcard .desc{ font-size: 13px; color: var(--text2); margin-bottom: 24px; }

.pw-out {
  display: flex; align-items: center; gap: 8px;
  background: rgba(249,115,22,0.05);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); padding: 11px 13px; margin-bottom: 18px;
}
.pw-out input {
  flex: 1; background: none; border: none; outline: none;
  font-family: 'Courier New', monospace; font-size: 15px;
  color: var(--text); font-weight: 500; letter-spacing: .5px;
}
.pw-out input::placeholder { color: var(--text3); font-family: var(--font); font-size: 13px; letter-spacing: 0; }
.copy-btn {
  width: 34px; height: 34px; border-radius: 8px;
  border: 1px solid var(--glass-border-lo);
  background: var(--glass-bg);
  color: var(--text2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
  transition: background .15s, color .15s, border-color .15s;
}
.copy-btn:hover { background: var(--glass-bg-hover); color: var(--accent); border-color: rgba(249,115,22,0.30); }

.slider-row {
  display: flex; justify-content: space-between;
  font-size: 13px; font-weight: 500; color: var(--text2); margin-bottom: 8px;
}
.slider-row span { color: var(--accent); font-weight: 700; }
input[type=range] {
  width: 100%; appearance: none; height: 4px;
  background: rgba(249,115,22,0.15); border-radius: 999px;
  outline: none; border: none; padding: 0; box-shadow: none;
}
input[type=range]::-webkit-slider-thumb {
  appearance: none; width: 18px; height: 18px;
  background: var(--accent); border-radius: 50%; cursor: pointer;
  box-shadow: 0 0 0 3px rgba(249,115,22,0.15);
}

.char-section { margin: 18px 0; }
.char-section p { font-size: 13px; font-weight: 600; color: var(--text2); margin-bottom: 10px; }
.chk-row {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 0; border-bottom: 1px solid rgba(249,115,22,0.08);
}
.chk-row:last-child { border-bottom: none; }
.chk-row input[type=checkbox] {
  width: 17px; height: 17px; accent-color: var(--accent);
  cursor: pointer; border: none; padding: 0; background: none; flex-shrink: 0;
}
.chk-row label { font-size: 14px; cursor: pointer; flex: 1; color: var(--text); }

.gen-btn {
  width: 100%; padding: 12px;
  background: var(--accent); color: #fff; border: none; border-radius: var(--radius);
  font-weight: 700; font-size: 14px; cursor: pointer; font-family: var(--font);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 20px;
  box-shadow: var(--accent-glow);
  transition: background .15s, box-shadow .15s;
}
.gen-btn:hover { background: var(--accent);filter:brightness(0.9); box-shadow: 0 6px 26px rgba(249,115,22,0.40); }

.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  background: var(--glass-bg-strong);
  backdrop-filter: none;
  border: 1px solid rgba(249,115,22,0.25);
  color: var(--accent);
  padding: 9px 22px; border-radius: 999px;
  font-size: 13px; font-weight: 600;
  opacity: 0; transition: opacity .2s;
  pointer-events: none; z-index: 9999;
  box-shadow: var(--glass-shadow);
}
.toast.show { opacity: 1; }

.picker-layout {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; max-width: 1000px; margin: 36px auto; padding: 0 20px;
  align-items: start;
}
.picker-layout > .pcard:first-child {
  position: sticky;
  top: 20px;
  align-self: start;
}
.pcard {
  background: var(--glass-bg-strong);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 26px;
  box-shadow: var(--glass-shadow-lg);
}
.pcard h2   { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 5px; }
.pcard .desc{ font-size: 13px; color: var(--text2); margin-bottom: 18px; }

.add-row { display: flex; gap: 8px; margin-bottom: 12px; }
.add-row input {
  flex: 1; padding: 9px 12px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); font-size: 14px;
  font-family: var(--font); color: var(--text); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.add-row input::placeholder { color: var(--text3); }
.add-row input:focus {
  border-color: rgba(249,115,22,0.35);
  box-shadow: 0 0 0 3px rgba(249,115,22,0.10);
}
.add-plus {
  width: 38px; height: 38px; background: var(--accent); color: #fff;
  border: none; border-radius: var(--radius); font-size: 18px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: background .15s;
  box-shadow: 0 3px 10px rgba(249,115,22,0.28);
}
.add-plus:hover { background: #ea580c; }

.items-lbl { font-size: 13px; font-weight: 600; margin-bottom: 8px; color: var(--text2); }
.items-box {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); padding: 12px;
  min-height: 76px; display: flex; flex-wrap: wrap; gap: 7px;
}
.item-tag {
  display: flex; align-items: center; gap: 6px;
  background: var(--accent-pill);
  border: 1px solid rgba(249,115,22,0.18);
  border-radius: 999px; padding: 5px 12px;
  font-size: 13px; font-weight: 500; color: var(--accent);
}
.item-tag .rm {
  background: none; border: none; color: rgba(249,115,22,0.4);
  cursor: pointer; font-size: 14px; padding: 0;
  display: flex; align-items: center; line-height: 1; transition: color .1s;
}
.item-tag .rm:hover { color: var(--danger); }

.spin-btn {
  width: 100%; padding: 12px;
  background: var(--glass-bg-hover); color: var(--text);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius);
  font-weight: 700; font-size: 14px; cursor: pointer; font-family: var(--font);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 16px; transition: background .15s, border-color .15s;
}
.spin-btn:hover { border-color: rgba(249,115,22,0.30); background: var(--glass-bg); }

.wheel-wrap {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; height: 100%;
}
.wheel-canvas-wrap { position: relative; }
.wheel-pointer-overlay {
  position: absolute;
  top: -14px; left: 50%; transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 14px solid transparent;
  border-right: 14px solid transparent;
  border-top: 28px solid #e11d48;
  z-index: 10;
  filter: drop-shadow(0 2px 6px rgba(225,29,72,0.35));
}
#wheel-canvas {
  display: block; border-radius: 50%;
  box-shadow: 0 8px 32px rgba(249,115,22,0.18), 0 0 0 2px var(--glass-border);
}
.wheel-result {
  margin-top: 16px; font-size: 16px; font-weight: 700;
  color: var(--accent); min-height: 22px; text-align: center;
}

.overlay {
  position: fixed; inset: 0;
  background: rgba(180,170,220,0.30);
  backdrop-filter: none;
  z-index: 1000; display: none;
  align-items: center; justify-content: center;
}
.overlay.open { display: flex; }

.mbox {
  background: var(--glass-bg);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 36px 32px;
  width: 390px; max-width: 94vw;
  box-shadow: var(--glass-shadow-lg);
  position: relative;
}
.mbox-close {
  position: absolute; top: 14px; right: 16px;
  background: rgba(249,115,22,0.06);
  border: 1px solid var(--glass-border-lo);
  border-radius: 50%; width: 28px; height: 28px;
  font-size: 16px; color: var(--text2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.mbox-close:hover { background: rgba(249,115,22,0.12); color: var(--text); }

.mbox-logo { display: flex; align-items: center; gap: 9px; margin-bottom: 22px; }
.mbox-logo-icon {
  width: 36px; height: 36px;
  background: var(--accent-pill);
  border: 1px solid rgba(249,115,22,0.20);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center; font-size: 17px;
}
.mbox-logo-text { font-weight: 700; font-size: 15px; color: var(--accent); }
.mbox h2   { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 4px; }
.mbox .sub { font-size: 13px; color: var(--text2); margin-bottom: 22px; }

.fg { margin-bottom: 14px; }
.fg label {
  display: block; font-size: 11px; font-weight: 600;
  color: var(--text2); margin-bottom: 6px;
  text-transform: uppercase; letter-spacing: .5px;
}
.fg input {
  width: 100%; padding: 10px 13px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); font-size: 14px;
  font-family: var(--font); color: var(--text); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.fg input::placeholder { color: var(--text3); }
.fg input:focus {
  border-color: rgba(249,115,22,0.40);
  box-shadow: 0 0 0 3px rgba(249,115,22,0.10);
}

.login-sub {
  width: 100%; padding: 12px;
  background: var(--accent); color: #fff; border: none; border-radius: var(--radius);
  font-weight: 700; font-size: 14px; cursor: pointer; font-family: var(--font);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 4px;
  box-shadow: var(--accent-glow);
  transition: background .15s, box-shadow .15s;
}
.login-sub:hover { background: #ea580c; box-shadow: 0 6px 26px rgba(249,115,22,0.40); }
#login-message { font-size: 13px; margin-top: 10px; min-height: 18px; }

.google-btn {
  width: 100%; padding: 11px 16px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius);
  font-size: 14px; font-weight: 600; color: var(--text);
  cursor: pointer; font-family: var(--font);
  box-shadow: var(--glass-shadow);
  transition: background .15s, box-shadow .15s;
  margin-bottom: 2px;
}
.google-btn:hover {
  background: var(--glass-bg);
  box-shadow: var(--glass-shadow-lg);
}

.divider {
  display: flex; align-items: center; gap: 12px;
  margin: 16px 0;
}
.divider::before, .divider::after {
  content: '';
  flex: 1; height: 1px;
  background: var(--glass-border-lo);
}
.divider span {
  font-size: 12px; color: var(--text3); white-space: nowrap;
}

#screen-cases, #screen-case-detail { display: none; }

.cases-wrap { max-width: 680px; margin: 36px auto; padding: 0 20px; }
.cases-wrap > h2 { font-size: 20px; font-weight: 800; margin-bottom: 20px; color: var(--text); }

#screen-lottery .cases-wrap {
  max-width: none !important;
  margin: 0 !important;
  padding: 18px 22px 48px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.premium-picker-bar { display: none !important; }

#case-list { list-style: none; padding: 0; margin-bottom: 18px; }
.case-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px;
  background: var(--glass-bg);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg); margin-bottom: 8px;
  box-shadow: var(--glass-shadow);
  transition: background .15s, border-color .15s, transform .15s, box-shadow .15s;
}
.case-item:hover {
  background: var(--glass-bg-hover);
  border-color: rgba(249,115,22,0.22);
  transform: translateX(3px);
  box-shadow: var(--glass-shadow-lg);
}
.case-item-l { display: flex; align-items: center; gap: 11px; }
.case-icon {
  width: 34px; height: 34px;
  background: var(--accent-pill);
  border: 1px solid rgba(249,115,22,0.15);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center; font-size: 15px;
}
.case-name { font-weight: 600; cursor: pointer; color: var(--text); transition: color .15s; }
.case-name:hover { color: var(--accent); }
.del-btn {
  background: var(--danger-bg); color: var(--danger);
  border: 1px solid rgba(225,29,72,0.15);
  border-radius: 999px; padding: 5px 12px;
  font-size: 12px; font-weight: 600; cursor: pointer; font-family: var(--font);
  transition: background .15s;
}
.del-btn:hover { background: rgba(225,29,72,0.14); }

.new-case-card {
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg); padding: 20px 22px;
  box-shadow: var(--glass-shadow);
  margin-bottom: 18px;
}
.new-case-card h3 { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 12px; }
.new-case-row { display: flex; gap: 8px; }
.new-case-row input {
  flex: 1; padding: 9px 12px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); font-size: 14px;
  font-family: var(--font); outline: none; color: var(--text);
  transition: border-color .15s;
}
.new-case-row input::placeholder { color: var(--text3); }
.new-case-row input:focus { border-color: rgba(249,115,22,0.35); }
.acc-btn {
  padding: 9px 18px; background: var(--accent); color: #fff; border: none;
  border-radius: var(--radius); font-weight: 700; font-size: 13px;
  cursor: pointer; font-family: var(--font); white-space: nowrap;
  box-shadow: 0 3px 12px rgba(249,115,22,0.28); transition: background .15s;
}
.acc-btn:hover { background: #ea580c; }

.lot-hdr {
  height: 54px;
  background: rgba(236,234,246,0.65);
  backdrop-filter: none;
  border-bottom: 1px solid var(--glass-border);
  display: flex; align-items: center; padding: 0 18px; gap: 13px;
  position: sticky; top: 56px; z-index: 100;
  box-shadow: 0 1px 0 rgba(230,210,190,0.35);
}
.lot-hdr h1 {
  font-size: 15px; font-weight: 700; flex: 1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text);
}
.detail-layout { display: flex; height: calc(100vh - 110px); overflow: hidden; }

.sidebar {
  width: 62px;
  background: rgba(236,234,246,0.55);
  backdrop-filter: none;
  border-right: 1px solid var(--glass-border);
  display: flex; flex-direction: column;
  align-items: center; padding: 10px 0; gap: 4px; flex-shrink: 0;
}
.sb-btn {
  width: 44px; height: 44px; border-radius: var(--radius);
  background: none; border: none; color: var(--text2);
  font-size: 16px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; font-family: var(--font);
}
.sb-btn:hover { background: rgba(249,115,22,0.07); color: var(--accent); }
.sb-btn.active {
  background: var(--accent-pill); color: var(--accent);
  border: 1px solid rgba(249,115,22,0.18);
}

.detail-body { flex: 1; overflow-y: auto; padding: 24px; background: transparent; }
.pane { display: none; }
.pane.active { display: block; }
.pane > h2 { font-size: 18px; font-weight: 800; margin-bottom: 16px; color: var(--text); }

.detail-body::-webkit-scrollbar { width: 5px; }
.detail-body::-webkit-scrollbar-track { background: transparent; }
.detail-body::-webkit-scrollbar-thumb { background: rgba(249,115,22,0.18); border-radius: 999px; }

.toolbar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px; flex-wrap: wrap; gap: 8px;
}
.btn-grp { display: flex; gap: 6px; }

.btn {
  padding: 8px 14px; border-radius: var(--radius);
  font-size: 13px; font-weight: 600; cursor: pointer; font-family: var(--font);
  border: 1px solid var(--glass-border-lo);
  background: var(--glass-bg);
  backdrop-filter: none;
  color: var(--text);
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: var(--glass-shadow);
  transition: background .15s, border-color .15s, box-shadow .15s;
}
.btn:hover { background: var(--glass-bg-hover); border-color: rgba(249,115,22,0.22); }
.btn.p {
  background: var(--accent); color: #fff; border-color: transparent;
  box-shadow: 0 3px 12px rgba(249,115,22,0.28);
}
.btn.p:hover { background: #ea580c; box-shadow: 0 5px 16px rgba(249,115,22,0.38); }
.btn.p:disabled { background: rgba(249,115,22,0.25); border-color: transparent; cursor: not-allowed; box-shadow: none; }
.btn.d { background: var(--danger-bg); color: var(--danger); border-color: rgba(225,29,72,0.15); }
.btn.d:hover { background: rgba(225,29,72,0.12); }

.dtable {
  width: 100%; border-collapse: collapse;
  background: var(--glass-bg);
  backdrop-filter: none;
  border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
}
.dtable th, .dtable td {
  padding: 9px 12px; text-align: left;
  font-size: 13px; border-bottom: 1px solid rgba(249,115,22,0.07);
  color: var(--text);
}
.dtable th {
  background: rgba(249,115,22,0.05);
  font-weight: 600; color: var(--text2);
  font-size: 11px; text-transform: uppercase; letter-spacing: .4px;
}
.dtable tbody tr:last-child td { border-bottom: none; }
.dtable tbody tr:hover { background: rgba(249,115,22,0.04); }

.prize-list { display: flex; flex-direction: column; gap: 10px; }
.prize-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--glass-shadow);
  transition: background .15s, border-color .15s, box-shadow .15s;
}
.prize-card:hover { background: var(--glass-bg-hover); border-color: rgba(249,115,22,0.20); box-shadow: var(--glass-shadow-lg); }
.pz-thumb {
  width: 62px; height: 62px; border-radius: var(--radius);
  object-fit: cover; background: rgba(249,115,22,0.06);
  border: 1px solid var(--glass-border-lo); flex-shrink: 0;
}
.pz-name { font-weight: 600; font-size: 14px; color: var(--text); }
.pz-meta { font-size: 12px; color: var(--text2); margin-top: 2px; }

.sum-bar { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.sum-chip {
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  padding: 6px 14px; border-radius: 999px;
  font-size: 13px; color: var(--text2);
  box-shadow: var(--glass-shadow);
}
.sum-chip b { color: var(--accent); }

.w-grid { display: grid; grid-template-columns: 220px 1fr; gap: 16px; }
.w-sidebar {
  display: flex; flex-direction: column; gap: 7px;
  max-height: calc(100vh - 260px); overflow-y: auto;
}
.wp-card {
  display: flex; gap: 10px; padding: 10px 12px;
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg); cursor: pointer;
  box-shadow: var(--glass-shadow);
  transition: all .15s; position: relative;
}
.wp-card:hover { background: var(--glass-bg-hover); border-color: rgba(249,115,22,0.22); box-shadow: var(--glass-shadow-lg); }
.wp-card.active {
  border-color: rgba(249,115,22,0.35);
  background: rgba(249,115,22,0.06);
  box-shadow: 0 0 0 2px rgba(249,115,22,0.12);
}
.wp-card.done { border-color: rgba(5,150,105,0.30); background: var(--success-bg); }
.wp-card.done::after {
  content: "✓ DONE"; position: absolute;
  bottom: 5px; right: 8px; padding: 2px 8px;
  border-radius: 999px;
  background: var(--success-bg); color: var(--success);
  font-size: 10px; font-weight: 700;
  border: 1px solid rgba(5,150,105,0.20);
}
.wp-thumb {
  width: 52px; height: 52px; border-radius: 8px;
  object-fit: cover; background: rgba(249,115,22,0.06);
  border: 1px solid var(--glass-border-lo); flex-shrink: 0;
}
.wp-ttl { font-size: 13px; font-weight: 600; color: var(--text); }
.wp-sub { font-size: 11px; color: var(--text2); margin-top: 2px; }

.w-main { display: flex; flex-direction: column; gap: 10px; }
#winner-selected-prize-name h2 { font-size: 18px; font-weight: 800; color: var(--text); }
.w-meta { font-size: 13px; color: var(--text2); }

.wc-container { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 4px; }
.wcard {
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg); padding: 14px 16px;
  min-width: 220px; max-width: 340px;
  box-shadow: var(--glass-shadow);
}
.wcard-hdr { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.wnum {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--accent); color: #fff;
  box-shadow: 0 3px 10px rgba(249,115,22,0.30);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px; flex-shrink: 0;
}
.wcard-ttl { font-size: 14px; font-weight: 600; color: var(--text); }
.wi-row { display: flex; gap: 8px; font-size: 13px; margin-bottom: 5px; }
.wi-lbl { width: 96px; color: var(--text2); flex-shrink: 0; font-size: 12px; }
.wi-val { flex: 1; font-weight: 500; word-break: break-word; color: var(--text); }
.act-row { display: flex; gap: 8px; margin-top: 8px; }

.w-overlay {
  position: fixed; inset: 0;
  background: rgba(180,170,220,0.40);
  backdrop-filter: none;
  display: none; justify-content: center; align-items: center; z-index: 999;
}
.w-oi { display: flex; flex-direction: column; align-items: center; width: 90%; max-width: 540px; }
.w-cd {
  font-size: 120px; font-weight: 900;
  background: linear-gradient(135deg, #c2410c, #f97316, #fb923c);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; line-height: 1;
}
.w-rc {
  width: 100%;
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl); padding: 30px 32px;
  box-shadow: var(--glass-shadow-lg);
}
.w-rh { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.w-rn {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--accent); color: #fff;
  box-shadow: var(--accent-glow);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 18px;
}
.w-rt { font-size: 20px; font-weight: 800; color: var(--text); }
.rv-row { display: flex; gap: 10px; font-size: 16px; margin-bottom: 9px; }
.rv-lbl { width: 130px; color: var(--text2); flex-shrink: 0; }
.rv-val { flex: 1; font-weight: 700; word-break: break-word; color: var(--text); }
.rv-close {
  margin-top: 18px; padding: 10px 28px; border-radius: 999px;
  background: var(--accent); color: #fff; border: none;
  font-weight: 700; font-size: 13px; cursor: pointer; font-family: var(--font);
  box-shadow: var(--accent-glow);
  transition: background .15s, box-shadow .15s;
}
.rv-close:hover { background: #ea580c; box-shadow: 0 6px 26px rgba(249,115,22,0.40); }

.m-ov { position: fixed; inset: 0; z-index: 1000; display: none; align-items: center; justify-content: center; }
.m-ov.open { display: flex; }
.m-bk { position: absolute; inset: 0; background: rgba(180,170,220,0.30); backdrop-filter: none; }
.m-bx {
  position: relative;
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl); padding: 28px;
  width: 410px; max-width: 94vw;
  box-shadow: var(--glass-shadow-lg);
}
.m-bx h3 { font-size: 16px; font-weight: 800; color: var(--text); margin-bottom: 18px; }
.m-cl {
  position: absolute; top: 13px; right: 15px;
  background: rgba(249,115,22,0.07);
  border: 1px solid var(--glass-border-lo);
  border-radius: 50%; width: 26px; height: 26px;
  font-size: 16px; color: var(--text2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; font-family: var(--font);
}
.m-cl:hover { background: rgba(249,115,22,0.14); color: var(--text); }

.mfg { margin-bottom: 12px; }
.mfg label {
  display: block; font-size: 11px; font-weight: 600;
  color: var(--text2); margin-bottom: 5px;
  text-transform: uppercase; letter-spacing: .5px;
}
.mfg input {
  width: 100%; padding: 9px 12px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); font-size: 14px;
  font-family: var(--font); color: var(--text); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.mfg input::placeholder { color: var(--text3); }
.mfg input:focus { border-color: rgba(249,115,22,0.38); box-shadow: 0 0 0 3px rgba(249,115,22,0.09); }

.m-acts { display: flex; gap: 8px; margin-top: 16px; }
.m-ok {
  padding: 9px 22px; background: var(--accent); color: #fff; border: none;
  border-radius: var(--radius); font-weight: 700; font-size: 13px;
  cursor: pointer; font-family: var(--font);
  box-shadow: 0 3px 12px rgba(249,115,22,0.28); transition: background .15s;
}
.m-ok:hover { background: #ea580c; }
.m-cn {
  padding: 9px 18px;
  background: var(--glass-bg); color: var(--text);
  border: 1px solid var(--glass-border-lo);
  border-radius: var(--radius); font-weight: 600; font-size: 13px;
  cursor: pointer; font-family: var(--font);
  transition: background .15s;
}
.m-cn:hover { background: var(--glass-bg-hover); }

.pz-prev {
  max-width: 110px; max-height: 110px; object-fit: cover;
  border-radius: var(--radius); border: 1px solid var(--glass-border-lo);
  display: none; margin-top: 6px;
}

@media (max-width: 700px) {
  .tool-grid     { grid-template-columns: 1fr; }
  .feat-card     { grid-template-columns: 1fr; }
  .picker-layout { grid-template-columns: 1fr; }
  .picker-layout > .pcard:first-child { position: static; top: auto; }
  .w-grid        { grid-template-columns: 1fr; }
}

:root {
  --gold:    #b45309;
  --gold-lt: rgba(180,83,9,.09);
}
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 48px;
}
.price-card {
  background: var(--glass-bg);
  backdrop-filter: none;
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--glass-shadow);
  transition: transform .2s, box-shadow .2s;
  position: relative;
}
.price-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--glass-shadow-lg);
}
.price-card-popular {
  border: 2px solid rgba(37,99,235,.35);
}
.price-card-gold {
  border: 1.5px solid rgba(180,83,9,.3);
  background: var(--glass-bg);
}
.price-popular-badge {
  position: absolute;
  top: -12px; left: 50%;
  transform: translateX(-50%);
  background: var(--info-lt);
  color: var(--info);
  border: 1px solid rgba(37,99,235,.22);
  font-size: 11px; font-weight: 700;
  padding: 3px 12px; border-radius: 999px;
  white-space: nowrap;
}
.price-plan-name {
  font-size: 18px; font-weight: 800;
}
.price-amount {
  font-size: 24px; font-weight: 800; color: var(--text);
  line-height: 1;
}
.price-amount span {
  font-size: 13px; font-weight: 400; color: var(--text2);
}
.price-desc {
  font-size: 12px; color: var(--text2); line-height: 1.55; flex: 1;
}
.price-feats {
  list-style: none; display: flex; flex-direction: column; gap: 7px;
}
.price-feats li {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text);
}
.price-feats li i {
  color: var(--ok); font-size: 11px; flex-shrink: 0;
}
.price-btn {
  width: 100%; padding: 11px;
  border: none; border-radius: var(--radius);
  font-weight: 700; font-size: 14px;
  cursor: pointer; font-family: var(--font);
  margin-top: auto;
  transition: all .15s;
}
.price-btn-basic {
  background: var(--ok-lt); color: var(--ok);
  border: 1.5px solid rgba(5,150,105,.25);
}
.price-btn-basic:hover { background: rgba(5,150,105,.15); }
.price-btn-std {
  background: var(--info); color: #fff;
  box-shadow: 0 4px 14px rgba(37,99,235,.3);
}
.price-btn-std:hover { background: #1d4ed8; }
.price-btn-pro {
  background: var(--accent); color: #fff;
  box-shadow: var(--accent-glow);
}
.price-btn-pro:hover { background: #ea580c; }
.price-btn-gold {
  background: linear-gradient(135deg,#b45309,#d97706);
  color: #fff;
  box-shadow: 0 4px 14px rgba(180,83,9,.3);
}
.price-btn-gold:hover { filter: brightness(1.08); }

@media (max-width: 900px) {
  .pricing-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .pricing-grid { grid-template-columns: 1fr; }
}

.plan-banner {
  border-radius: var(--radius-lg);
  margin-bottom: 20px;
  overflow: hidden;
}
.plan-banner.no-plan {
  background: rgba(220,38,38,.06);
  border: 1px solid rgba(220,38,38,.18);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.pb-left { display: flex; align-items: center; gap: 12px; }
.pb-icon  { font-size: 22px; flex-shrink: 0; }
.pb-title { font-weight: 700; font-size: 14px; color: var(--danger); }
.pb-sub   { font-size: 12px; color: var(--text2); margin-top: 2px; }
.pb-btn {
  padding: 8px 18px; border-radius: 999px;
  font-size: 13px; font-weight: 700;
  cursor: pointer; text-decoration: none;
  white-space: nowrap; flex-shrink: 0;
  transition: all .15s;
}
.pb-btn-buy {
  background: var(--accent); color: #fff;
  border: none;
  box-shadow: var(--accent-glow);
}
.pb-btn-buy:hover { background: #ea580c; }

.plan-banner.has-plan {
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
}
.pb-top {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border-lo);
  gap: 10px; flex-wrap: wrap;
}
.pb-subs { display: flex; gap: 6px; flex-wrap: wrap; }
.pb-sub-tag {
  font-size: 12px; font-weight: 600;
  padding: 4px 10px; border-radius: 999px;
  border: 1px solid;
  background: var(--glass-bg);
}
.pb-sub-tag small { opacity: .7; font-weight: 400; margin-left: 4px; }
.pb-btn-more {
  background: var(--accent-lt); color: var(--accent);
  border: 1px solid rgba(249,115,22,.2);
  font-size: 12px; padding: 6px 14px; border-radius: 999px;
  cursor: pointer; font-weight: 600; text-decoration: none;
}
.pb-btn-more:hover { background: rgba(249,115,22,.14); }
.pb-limits {
  display: flex; align-items: center;
  padding: 10px 16px; gap: 0;
}
.pb-lim-item {
  display: flex; flex-direction: column;
  align-items: center; flex: 1; padding: 4px 8px;
}
.pb-lim-lbl { font-size: 11px; color: var(--text2); margin-bottom: 2px; }
.pb-lim-val { font-size: 18px; font-weight: 800; color: var(--text); }
.pb-lim-sep {
  width: 1px; height: 32px;
  background: var(--glass-border-lo);
}

.premium-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 20px;
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 5px;
}
.premium-tab {
  flex: 1;
  padding: 9px 16px;
  border-radius: var(--radius);
  border: none;
  background: transparent;
  color: var(--text2);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  transition: all .15s;
}
.premium-tab:hover {
  background: var(--glass-bg);
  color: var(--text);
}
.premium-tab.active {
  background: var(--glass-bg-strong);
  color: var(--accent);
  box-shadow: var(--glass-shadow);
  border: 1px solid var(--glass-border);
}

.fmt-card {
  border: 1.5px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 16px;
  cursor: pointer;
  transition: all .15s;
  background: var(--glass-bg);
  text-align: center;
}
.fmt-card:hover {
  border-color: rgba(249,115,22,.3);
  background: var(--glass-bg);
}
.fmt-card.sel {
  border-color: var(--accent);
  background: var(--accent-lt);
  box-shadow: 0 0 0 2px rgba(249,115,22,.12);
}
.btn.active-sel {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

body {
  transition: background-color 0.6s ease;
}

.price-card:nth-child(1) .price-plan-name { color: #059669 !important; }
.price-card:nth-child(1) .price-btn-basic {
  background: rgba(5,150,105,0.08) !important;
  color: #059669 !important;
  border: 1.5px solid rgba(5,150,105,0.25) !important;
}
.price-card:nth-child(1) .price-btn-basic:hover {
  background: rgba(5,150,105,0.15) !important;
}

.price-card:nth-child(2) .price-plan-name { color: #f97316 !important; }
.price-card:nth-child(2) .price-btn-std {
  background: #f97316 !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(37,99,235,0.3) !important;
}
.price-card:nth-child(2) .price-btn-std:hover { background: #1d4ed8 !important; }

.price-card:nth-child(3) .price-plan-name { color: #f97316 !important; }
.price-card:nth-child(3) .price-btn-pro {
  background: #f97316 !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(79,70,229,0.3) !important;
}
.price-card:nth-child(3) .price-btn-pro:hover { background: #4338ca !important; }

.price-card:nth-child(4) .price-plan-name { color: #b45309 !important; }
.price-card:nth-child(4) .price-amount    { color: #b45309 !important; }
.price-card:nth-child(4) .price-btn-gold {
  background: linear-gradient(135deg,#b45309,#d97706) !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(180,83,9,0.3) !important;
}
.price-card:nth-child(4) .price-btn-gold:hover { filter: brightness(1.08) !important; }

#pricing-section h2 { color: var(--text) !important; }
#pricing-section .price-feats li i { color: #059669 !important; }
.price-card:nth-child(4) .price-feats li i { color: #b45309 !important; }

.plan-banner.has-plan {
  background: var(--glass-bg);
  backdrop-filter: none;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  box-shadow: var(--glass-shadow);
  margin-bottom: 16px;
}
.plan-banner.has-plan .pb-limits {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  gap: 0;
}
.plan-banner.has-plan .pb-lim-item {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  padding: 4px 8px;
}
.plan-banner.has-plan .pb-lim-lbl {
  font-size: 12px;
  color: var(--text2);
}
.plan-banner.has-plan .pb-lim-val {
  font-size: 16px;
  font-weight: 800;
  color: var(--accent);
}
.plan-banner.has-plan .pb-lim-sep {
  width: 1px; height: 28px;
  background: var(--glass-border-lo);
  flex-shrink: 0;
}

@media (max-width: 680px) {
  
  .nav {
    padding: 0 12px;
    flex-wrap: wrap;
    height: auto;
    min-height: 52px;
    gap: 0;
    position: relative;
  }
  .nav-brand { flex: 1; min-width: 0; }
  
  #lang-btn { padding: 6px 10px !important; }
  #lang-btn img { height: 15px !important; }
  .nav-login-btn { height: 26px !important; font-size: 13px !important; }

  
  .hero { padding: 28px 14px 20px; }
  .hero h1 { font-size: 26px; }
  .section { padding: 20px 14px; }
  .tool-grid { grid-template-columns: 1fr; gap: 10px; }
  .pricing-grid { grid-template-columns: 1fr; }
  .feat-card { grid-template-columns: 1fr; }
  .w-grid { grid-template-columns: 1fr; }
  .picker-layout { grid-template-columns: 1fr; }
  .cases-wrap { padding: 0 14px; margin: 14px auto; }
}

@media (max-width: 680px) {
  
  #tournament-view [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  #tournament-view [style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

.hero-brand {
  display: inline-flex;
  align-items: center;
  gap: 0;
  justify-content: center;
  flex-wrap: wrap;
}
.hero-brand > span:first-child { margin-right: 14px; }
.hero-brand-name {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}
.hero-brand .hero-logo { margin-right: -8px; }
.hero-logo {
  height: 1.35em;
  width: 1.35em;
  object-fit: contain;
  border-radius: 8px;
  flex-shrink: 0;
  -webkit-text-fill-color: initial;
}
@media (max-width: 600px) {
  .hero-brand { gap: 0; }
  .hero-brand > span:first-child { margin-right: 10px; }
  .hero-brand .hero-logo { margin-right: -6px; }
}

.back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  margin-bottom: 14px;
  border-radius: 8px;
  border: 1px solid rgba(230,210,190,0.5);
  background: transparent;
  color: var(--text2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
  align-self: flex-start;
  width: auto;
  max-width: max-content;
}
.back-btn:hover {
  background: rgba(249,115,22,0.06);
  color: var(--accent);
  border-color: var(--accent);
}

.spin-counter {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin-bottom: 14px;
  font-size: 12px;
  color: var(--text2);
}
.spin-counter-num {
  font-weight: 800;
  color: var(--accent);
  font-size: 22px;
  font-variant-numeric: tabular-nums;
  transition: transform .25s cubic-bezier(.34, 1.56, .64, 1);
  line-height: 1.1;
}
.spin-counter-num.bump {
  transform: scale(1.18);
}
.spin-counter-lbl {
  font-weight: 600;
  text-align: center;
}

.picker-hint {
  font-size: 11px;
  color: var(--text3);
  margin-top: 6px;
  margin-bottom: 4px;
  font-style: italic;
}

.results-section {
  margin-top: 14px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  max-height: 240px;
  overflow-y: auto;
}
.results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.results-header h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.results-clear-btn {
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 500;
  background: transparent;
  border: 1px solid rgba(230, 210, 190, 0.5);
  border-radius: 6px;
  color: var(--text2);
  cursor: pointer;
  transition: all .15s;
}
.results-clear-btn:hover {
  border-color: var(--danger, #ef4444);
  color: var(--danger, #ef4444);
}
.results-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.result-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.7);
  border-radius: 8px;
  font-size: 13px;
}
.result-item-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent-lt);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 11px;
  flex-shrink: 0;
}
.result-item-text {
  flex: 1;
  color: var(--text);
  word-break: break-word;
}
.result-item-time {
  font-size: 10px;
  color: var(--text3);
  flex-shrink: 0;
}

.winner-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: none;
  z-index: 10000;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
canvas.confetti-canvas,
body > canvas[style*="position: fixed"][style*="pointer-events: none"] {
  z-index: 100001 !important;
}
.winner-modal.open {
  display: flex;
  animation: winner-fade-in .2s ease-out;
}
@keyframes winner-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
.winner-modal-content {
  background: var(--glass-bg);
  border-radius: 20px;
  padding: 36px 28px 28px;
  max-width: 420px;
  width: 100%;
  text-align: center;
  box-shadow: 0 20px 60px rgba(249, 115, 22, 0.3);
  animation: winner-pop .35s cubic-bezier(.34, 1.56, .64, 1);
}
@keyframes winner-pop {
  0% { transform: scale(.7); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}
.winner-modal-emoji {
  font-size: 56px;
  margin-bottom: 8px;
  animation: winner-bounce 1s ease-in-out infinite;
}
@keyframes winner-bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
.winner-modal-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.winner-modal-name {
  font-size: 28px;
  font-weight: 800;
  color: var(--accent);
  margin-bottom: 24px;
  word-break: break-word;
  line-height: 1.2;
}
.winner-modal-buttons {
  display: flex;
  gap: 10px;
  justify-content: center;
}
.winner-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: 10px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  border: none;
}
.winner-btn-remove {
  background: rgba(239, 68, 68, 0.1);
  color: #dc2626;
  border: 1px solid rgba(239, 68, 68, 0.3);
}
.winner-btn-remove:hover {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.5);
}
.winner-btn-close {
  background: var(--accent);
  color: #fff;
}
.winner-btn-close:hover {
  background: var(--accent-strong, #ea580c);
}

@media (max-width: 600px) {
  .winner-modal-content { padding: 28px 20px 22px; }
  .winner-modal-emoji { font-size: 48px; }
  .winner-modal-name { font-size: 22px; }
  .winner-btn { padding: 9px 14px; font-size: 13px; }
}

.card-premium-steps {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.card-premium-steps > span {
  display: block;
}
.legal-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: none;
  backdrop-filter: none;
  z-index: 12000;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.legal-modal.open { display: flex; animation: legal-fade-in .2s ease-out; }
@keyframes legal-fade-in { from { opacity: 0; } to { opacity: 1; } }
.legal-modal-content {
  background: var(--glass-bg);
  border-radius: 16px;
  max-width: 720px;
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(249, 115, 22, 0.25);
  animation: legal-pop .3s cubic-bezier(.34, 1.56, .64, 1);
  overflow: hidden;
}
@keyframes legal-pop { 0% { transform: scale(.85); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
.legal-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
  gap: 12px;
}
.legal-modal-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  flex: 1;
  min-width: 0;
}
.legal-modal-header-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.legal-lang-btn {
  background: transparent;
  border: none;
  width: auto;
  height: auto;
  border-radius: 6px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: transform .15s;
  padding: 4px;
}
.legal-lang-btn:hover { background: rgba(249, 115, 22, 0.08); transform: scale(1.05); }
.legal-lang-btn img { width: 32px; height: auto; border-radius: 4px; display: block; }
.legal-modal-close {
  background: rgba(249, 115, 22, 0.08);
  border: none;
  width: 32px; height: 32px;
  border-radius: 8px;
  cursor: pointer;
  color: var(--text2);
  font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.legal-modal-close:hover { background: rgba(249, 115, 22, 0.15); color: #f97316; }
.legal-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--text);
  -webkit-overflow-scrolling: touch;
}
.legal-modal-body h1, .legal-modal-body h2, .legal-modal-body h3 { margin: 18px 0 10px; font-weight: 700; }
.legal-modal-body h1 { font-size: 20px; }
.legal-modal-body h2 { font-size: 16px; }
.legal-modal-body h3 { font-size: 14px; }
.legal-modal-body p { margin: 8px 0; }
.legal-modal-body ul, .legal-modal-body ol { margin: 8px 0; padding-left: 20px; }
.legal-modal-body li { margin: 4px 0; }
.legal-modal-body a { color: #f97316; }
.legal-modal-body .doc-header h1 { font-size: 22px; margin: 0 0 6px; }
.legal-modal-body .doc-header .subtitle { color: var(--text2); font-size: 14px; margin: 0 0 18px; }
.legal-modal-body .doc-header .updated-date { font-size: 12px; color: var(--text3); margin: 8px 0 18px; font-family: var(--font); }
.legal-modal-body .meta-block { background: var(--glass-bg-hover); border: 1px solid rgba(230, 210, 190, 0.5); border-radius: 8px; padding: 12px 14px; margin: 14px 0 18px; font-size: 13px; }
.legal-modal-body .meta-row { margin: 3px 0; }
.legal-modal-body .meta-label { font-weight: 600; min-width: 180px; display: inline-block; color: var(--text2); }
.legal-modal-body .toc { background: var(--glass-bg-hover); border: 1px solid var(--glass-border); border-radius: 8px; padding: 14px 18px; margin: 14px 0 22px; }
.legal-modal-body .toc-title { font-weight: 700; margin-bottom: 8px; font-size: 14px; }
.legal-modal-body .toc ol { margin: 0; padding-left: 20px; }
.legal-modal-body .toc li { margin: 3px 0; }
.legal-modal-body .toc a { text-decoration: none; }
.legal-modal-body .toc a:hover { text-decoration: underline; }
.legal-modal-body .section { font-size: 16px; margin-top: 22px; }
.legal-modal-body .section:first-of-type { margin-top: 8px; }
.legal-modal-body table { width: 100%; border-collapse: collapse; margin: 14px 0; font-size: 13px; border: 1px solid var(--glass-border); }
.legal-modal-body table th, .legal-modal-body table td { padding: 9px 12px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--glass-border); border-right: 1px solid var(--glass-border); }
.legal-modal-body table th { background: var(--glass-border); font-weight: 700; }
.legal-modal-body table th:last-child, .legal-modal-body table td:last-child { border-right: none; }
.legal-modal-body table tr:last-child td { border-bottom: none; }
.legal-modal-body .closing { margin-top: 32px; padding-top: 18px; border-top: 1px solid var(--glass-border); font-size: 12px; color: var(--text3); }
.legal-modal-body [data-lang-hide] { display: none !important; }
.legal-modal-loading { text-align: center; padding: 48px 0; color: var(--text3); font-size: 24px; }
.legal-modal-footer {
  padding: 14px 24px;
  border-top: 1px solid var(--glass-border);
  flex-shrink: 0;
  display: flex;
  justify-content: flex-end;
}
.legal-modal-btn-close {
  padding: 10px 22px;
  border-radius: 10px;
  border: none;
  background: #f97316;
  color: #fff;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: filter .15s;
}
.legal-modal-btn-close:hover { filter: brightness(1.08); }
body.modal-open { overflow: hidden; }
@media (max-width: 600px) {
  .legal-modal { padding: 0; align-items: stretch; }
  .legal-modal-content { max-width: 100%; max-height: 100%; border-radius: 0; height: 100dvh; }
  .legal-modal-header { padding: 14px 18px; }
  .legal-modal-body { padding: 16px 18px; font-size: 13px; }
  .legal-modal-footer { padding: 12px 18px; }
}

#theme-btn {
  display: flex; align-items: center; justify-content: center;
  height: 26px; padding: 0 9px;
  border: 1px solid var(--glass-border); background: var(--glass-bg);
  color: var(--text2); cursor: pointer; border-radius: 8px;
  transition: background .15s, color .15s, border-color .15s, transform .15s;
}
#theme-btn:hover { color: var(--accent); border-color: var(--accent); transform: scale(1.05); }
#theme-btn i { font-size: 15px; }

@media (max-width: 768px) {
  .wheel-section, .home-tool-section, .tool-grid, .feat-card { margin-bottom: 22px; }
  .wheel-layout { gap: 22px; }
  .tool-grid { gap: 22px; }
}

.home-public-list { display: flex; flex-direction: column; gap: 8px; margin: 2px 0 14px; }
.hp-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--glass-border); border-radius: 10px; background: var(--glass-bg-hover); cursor: pointer; transition: border-color .15s, background .15s; }
.hp-item:hover { border-color: var(--accent); background: var(--glass-bg); }
.hp-item > i { color: var(--accent); font-size: 14px; flex-shrink: 0; width: 18px; text-align: center; }
.hp-main { flex: 1; min-width: 0; }
.hp-name { font-size: 13px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hp-meta { font-size: 11px; color: var(--text2); margin-top: 1px; }
.home-public-empty { font-size: 12px; color: var(--text3); padding: 6px 2px; }