/* ============================================================
   CRACKDRAFT — arcane grimoire theme
   ============================================================ */
:root {
  --bg:        #07070c;
  --bg-2:      #0e0e18;
  --bg-3:      #161426;
  --panel:     rgba(22, 20, 38, 0.72);
  --line:      rgba(214, 178, 110, 0.18);
  --gold:      #d6b26e;
  --gold-lit:  #f3e0aa;
  --gold-deep: #8a6a30;
  --ember:     #e8662a;
  --ember-lit: #ff9248;
  --blood:     #8c1f2b;
  --mist:      #5d7bb0;
  --arcane:    #8a6cff;
  --parch:     #e9ddc2;
  --ink:       #b6a784;
  --ink-dim:   #6f6650;

  --serif: "EB Garamond", Georgia, serif;
  --display: "Cinzel", serif;
  --decor: "Cinzel Decorative", "Cinzel", serif;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

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

html, body { height: 100%; }

body {
  font-family: var(--serif);
  color: var(--parch);
  background:
    radial-gradient(120% 80% at 50% -10%, #1b1530 0%, transparent 55%),
    radial-gradient(90% 60% at 90% 110%, #1a0e16 0%, transparent 50%),
    radial-gradient(70% 50% at 8% 100%, #0c1626 0%, transparent 55%),
    var(--bg);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Subtle film grain + vignette ----------------------------- */
.vignette {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  background: radial-gradient(120% 100% at 50% 40%, transparent 55%, rgba(0,0,0,0.65) 100%);
  mix-blend-mode: multiply;
}
body::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 2;
  opacity: 0.05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Floating embers ------------------------------------------ */
.embers { position: fixed; inset: 0; pointer-events: none; z-index: 1; overflow: hidden; }
.ember {
  position: absolute; bottom: -10px; width: 3px; height: 3px; border-radius: 50%;
  background: radial-gradient(circle, var(--ember-lit), var(--ember) 60%, transparent 70%);
  box-shadow: 0 0 6px 1px rgba(232,102,42,0.6);
  animation: rise linear infinite;
  opacity: 0;
}
@keyframes rise {
  0%   { transform: translateY(0) translateX(0) scale(0.6); opacity: 0; }
  10%  { opacity: 0.9; }
  90%  { opacity: 0.5; }
  100% { transform: translateY(-104vh) translateX(var(--drift, 30px)) scale(1.1); opacity: 0; }
}

/* ============================================================
   SCREENS
   ============================================================ */
.screen { display: none; position: relative; z-index: 3; }
.screen.is-active { display: block; animation: screen-in 0.7s var(--ease) both; }
@keyframes screen-in { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero { text-align: center; padding: clamp(3rem, 9vh, 7rem) 1.5rem 1.5rem; }
.hero--compact { padding: 3rem 1.5rem 0.5rem; }
.hero__kicker {
  font-family: var(--display); letter-spacing: 0.42em; text-transform: uppercase;
  font-size: 0.72rem; color: var(--gold); opacity: 0.8; margin-bottom: 1.4rem;
}
.hero__title {
  font-family: var(--decor); font-weight: 900;
  font-size: clamp(3.4rem, 12vw, 8.5rem); line-height: 0.92; letter-spacing: 0.02em;
  color: var(--parch);
  text-shadow: 0 0 40px rgba(138,108,255,0.25), 0 2px 0 #000;
}
.hero__title span {
  color: transparent;
  background: linear-gradient(180deg, var(--gold-lit), var(--gold) 45%, var(--gold-deep));
  -webkit-background-clip: text; background-clip: text;
  filter: drop-shadow(0 0 22px rgba(214,178,110,0.45));
}
.hero__sub {
  max-width: 40ch; margin: 1.6rem auto 0; font-size: clamp(1rem, 2.2vw, 1.28rem);
  font-style: italic; color: var(--ink); line-height: 1.5;
}

/* divider flourish under titles */
.hero__title::after {
  content: "✶"; display: block; font-family: var(--serif); font-style: normal;
  font-size: 1.1rem; color: var(--gold); opacity: 0.6; margin-top: 1.2rem;
  text-shadow: 0 0 16px var(--gold);
}

/* ============================================================
   SECTION TITLES
   ============================================================ */
.section-title {
  font-family: var(--display); font-weight: 600; letter-spacing: 0.18em;
  text-transform: uppercase; font-size: 1rem; color: var(--gold-lit);
}
.section-title--center { text-align: center; margin: 2.5rem 0 1.5rem; }

/* ============================================================
   SET PICKER
   ============================================================ */
.set-section { max-width: 1180px; margin: 0 auto; padding: 1rem 1.5rem 5rem; }
.set-toolbar {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  flex-wrap: wrap; margin-bottom: 2rem;
  border-bottom: 1px solid var(--line); padding-bottom: 1rem;
}
.set-search {
  background: var(--bg-2); border: 1px solid var(--line); color: var(--parch);
  font-family: var(--serif); font-size: 1rem; padding: 0.6rem 1rem; border-radius: 2px;
  min-width: 240px; outline: none; transition: border-color 0.3s, box-shadow 0.3s;
}
.set-search:focus { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold-deep), 0 0 18px rgba(214,178,110,0.2); }
.set-search::placeholder { color: var(--ink-dim); font-style: italic; }

.sets-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 1rem;
}

.set-card {
  position: relative; text-align: left; cursor: pointer;
  background: linear-gradient(160deg, rgba(30,26,52,0.85), rgba(12,11,22,0.9));
  border: 1px solid var(--line); border-radius: 4px;
  padding: 1.1rem 1.1rem 1rem; overflow: hidden;
  transition: transform 0.4s var(--ease), border-color 0.4s, box-shadow 0.4s;
}
.set-card::before {
  content: ""; position: absolute; inset: 0; opacity: 0; transition: opacity 0.4s;
  background: radial-gradient(80% 120% at 50% -20%, rgba(214,178,110,0.18), transparent 60%);
}
.set-card:hover {
  transform: translateY(-5px); border-color: var(--gold);
  box-shadow: 0 14px 40px -14px rgba(0,0,0,0.8), 0 0 0 1px rgba(214,178,110,0.25);
}
.set-card:hover::before { opacity: 1; }
.set-card__top { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 0.9rem; }
.set-card__icon {
  width: 38px; height: 38px; flex: none; object-fit: contain;
  filter: invert(1) sepia(1) saturate(2.5) hue-rotate(2deg) brightness(1.05) drop-shadow(0 0 6px rgba(214,178,110,0.4));
}
.set-card__code {
  font-family: var(--display); font-weight: 700; font-size: 0.7rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--gold); border: 1px solid var(--line);
  padding: 0.2rem 0.45rem; border-radius: 2px; margin-left: auto;
}
.set-card__name {
  font-family: var(--display); font-size: 1.08rem; font-weight: 600; color: var(--parch);
  line-height: 1.18; margin-bottom: 0.35rem;
}
.set-card__meta { font-size: 0.85rem; color: var(--ink-dim); font-style: italic; }

/* ============================================================
   DRAFT SCREEN
   ============================================================ */
#screen-draft.is-active { display: grid; }
#screen-draft {
  grid-template-columns: 1fr 280px;
  min-height: 100vh; align-items: start;
}
.draft-stage { padding: 1.2rem clamp(1rem, 3vw, 2.5rem) 3rem; }

.draft-header {
  display: flex; align-items: center; gap: 1.2rem; margin-bottom: 1.2rem;
  padding-bottom: 1rem; border-bottom: 1px solid var(--line);
}
.draft-set { display: flex; align-items: center; gap: 0.7rem; }
.draft-set img {
  width: 30px; height: 30px; object-fit: contain;
  filter: invert(1) sepia(1) saturate(2.5) hue-rotate(2deg) brightness(1.05);
}
.draft-set__name { font-family: var(--display); font-weight: 600; display: block; }
.draft-set__meta { font-size: 0.82rem; color: var(--ink-dim); }
.pick-counter {
  margin-left: auto; text-align: center; font-family: var(--display);
  line-height: 1; color: var(--gold-lit);
}
.pick-counter span { font-size: 1.7rem; display: block; }
.pick-counter small { font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim); }

.pack-status {
  text-align: center; font-family: var(--display); letter-spacing: 0.28em;
  text-transform: uppercase; font-size: 0.78rem; color: var(--gold);
  margin-bottom: 1.6rem; min-height: 1.2em;
}
.pack-status b { color: var(--gold-lit); }

/* The pack grid */
.pack {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: clamp(0.7rem, 1.6vw, 1.3rem); max-width: 1100px; margin: 0 auto;
}

.draft-card {
  position: relative; cursor: pointer; border-radius: 12px;
  aspect-ratio: 488 / 680; background: var(--bg-3);
  transform: translateY(20px); opacity: 0;
  animation: deal 0.55s var(--ease) forwards;
  transition: transform 0.3s var(--ease), filter 0.3s, box-shadow 0.3s;
  box-shadow: 0 6px 18px -8px rgba(0,0,0,0.9);
}
@keyframes deal { to { transform: none; opacity: 1; } }
.draft-card img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; display: block; }
.draft-card::after {
  content: ""; position: absolute; inset: -2px; border-radius: 13px; opacity: 0;
  background: linear-gradient(135deg, transparent 30%, rgba(243,224,170,0.5) 50%, transparent 70%);
  transition: opacity 0.35s; pointer-events: none;
}
.draft-card:hover {
  transform: translateY(-10px) scale(1.04); z-index: 5;
  box-shadow: 0 22px 50px -16px rgba(0,0,0,0.95), 0 0 0 2px var(--gold), 0 0 32px rgba(214,178,110,0.4);
}
.draft-card:hover::after { opacity: 1; }
.draft-card.picking {
  animation: picked 0.6s var(--ease) forwards;
  z-index: 20;
}
@keyframes picked {
  0%   { transform: translateY(-10px) scale(1.04); box-shadow: 0 0 0 2px var(--gold), 0 0 40px rgba(214,178,110,0.6); }
  40%  { transform: scale(1.12); box-shadow: 0 0 0 3px var(--gold-lit), 0 0 70px rgba(243,224,170,0.9); }
  100% { transform: scale(0.2) translateY(60vh) translateX(40vw); opacity: 0; }
}
.draft-card.fade-out { animation: fade 0.45s var(--ease) forwards; }
@keyframes fade { to { opacity: 0; transform: scale(0.85); } }

/* badge: pick a card hint on hover */
.draft-card .pick-tag {
  position: absolute; left: 50%; bottom: 8%; transform: translate(-50%, 12px);
  font-family: var(--display); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: #0a0a0a; background: linear-gradient(180deg, var(--gold-lit), var(--gold));
  padding: 0.32rem 0.8rem; border-radius: 2px; opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s; white-space: nowrap;
  box-shadow: 0 4px 14px rgba(0,0,0,0.6);
}
.draft-card:hover .pick-tag { opacity: 1; transform: translate(-50%, 0); }

/* ============================================================
   POOL RAIL
   ============================================================ */
.pool-rail {
  position: sticky; top: 0; height: 100vh; padding: 1.2rem 1rem;
  background: linear-gradient(180deg, rgba(14,14,24,0.6), rgba(7,7,12,0.85));
  border-left: 1px solid var(--line); overflow-y: auto;
}
.pool-rail__title {
  font-family: var(--display); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  font-size: 0.82rem; color: var(--gold); margin-bottom: 1rem; position: sticky; top: 0;
}
.pool-list { display: flex; flex-direction: column; gap: 0.35rem; }
.pool-item {
  display: flex; align-items: center; gap: 0.5rem; font-size: 0.82rem;
  padding: 0.3rem 0.4rem; border-radius: 3px; color: var(--ink);
  border-left: 2px solid var(--c, var(--ink-dim));
  background: rgba(255,255,255,0.015);
  animation: pool-in 0.5s var(--ease) both;
}
@keyframes pool-in { from { opacity: 0; transform: translateX(14px); } to { opacity: 1; transform: none; } }
.pool-item .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c, var(--ink-dim)); flex: none; box-shadow: 0 0 6px var(--c); }
.pool-item span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* color tokens */
.c-W { --c: #f4e9c8; } .c-U { --c: #4a90d9; } .c-B { --c: #9b6bd6; }
.c-R { --c: #e8662a; } .c-G { --c: #3fae6a; } .c-M { --c: #d6b26e; } .c-C { --c: #9aa0a8; }

/* ============================================================
   BUTTONS
   ============================================================ */
.epic-btn {
  font-family: var(--display); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  font-size: 0.85rem; color: #0a0a0a; cursor: pointer; border: none; border-radius: 3px;
  padding: 0.95rem 2rem; background: linear-gradient(180deg, var(--gold-lit), var(--gold) 60%, var(--gold-deep));
  box-shadow: 0 0 0 1px rgba(243,224,170,0.4), 0 10px 30px -10px rgba(214,178,110,0.6);
  transition: transform 0.3s var(--ease), box-shadow 0.3s, filter 0.3s;
}
.epic-btn:hover { transform: translateY(-2px); filter: brightness(1.08); box-shadow: 0 0 0 1px var(--gold-lit), 0 16px 40px -12px rgba(214,178,110,0.8); }
.ghost-btn {
  font-family: var(--display); letter-spacing: 0.12em; text-transform: uppercase; font-size: 0.78rem;
  color: var(--ink); background: transparent; border: 1px solid var(--line); border-radius: 3px;
  padding: 0.7rem 1.2rem; cursor: pointer; transition: color 0.3s, border-color 0.3s, background 0.3s;
}
.ghost-btn:hover { color: var(--gold-lit); border-color: var(--gold); background: rgba(214,178,110,0.06); }

/* ============================================================
   SUMMARY
   ============================================================ */
.summary-stats {
  max-width: 1000px; margin: 1.5rem auto; display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.2rem; padding: 0 1.5rem;
}
.stat-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 4px; padding: 1.2rem;
}
.stat-card h4 {
  font-family: var(--display); font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 0.9rem; font-weight: 600;
}
.bar { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.45rem; font-size: 0.85rem; }
.bar__label { width: 2.4rem; color: var(--ink); flex: none; }
.bar__track { flex: 1; height: 9px; background: rgba(255,255,255,0.06); border-radius: 99px; overflow: hidden; }
.bar__fill { height: 100%; border-radius: 99px; background: var(--c, var(--gold)); box-shadow: 0 0 8px var(--c, var(--gold)); transition: width 0.8s var(--ease); }
.bar__val { width: 1.8rem; text-align: right; color: var(--ink-dim); flex: none; font-variant-numeric: tabular-nums; }

.summary-grid {
  max-width: 1180px; margin: 0 auto; padding: 0 1.5rem;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(118px, 1fr)); gap: 0.6rem;
}
.summary-grid img {
  width: 100%; border-radius: 8px; aspect-ratio: 488/680; object-fit: cover; cursor: pointer;
  box-shadow: 0 4px 14px -6px rgba(0,0,0,0.8); transition: transform 0.3s var(--ease), box-shadow 0.3s;
}
.summary-grid img:hover { transform: translateY(-6px) scale(1.05); box-shadow: 0 16px 36px -12px rgba(0,0,0,0.9), 0 0 0 1px var(--gold); }

.summary-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; padding: 3rem 1.5rem 5rem; }

/* ============================================================
   LOADER
   ============================================================ */
.loader { grid-column: 1 / -1; text-align: center; padding: 4rem 1rem; color: var(--ink); font-style: italic; }
.loader .rune {
  display: block; width: 44px; height: 44px; margin: 0 auto 1.2rem; border-radius: 50%;
  border: 2px solid rgba(214,178,110,0.2); border-top-color: var(--gold-lit);
  animation: spin 0.9s linear infinite; box-shadow: 0 0 22px rgba(214,178,110,0.3);
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   ZOOM OVERLAY
   ============================================================ */
.zoom {
  position: fixed; inset: 0; z-index: 50; display: flex; align-items: center; justify-content: center;
  background: rgba(4,4,8,0.85); backdrop-filter: blur(6px); opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.zoom.is-open { opacity: 1; pointer-events: auto; }
.zoom img {
  max-height: 86vh; max-width: 90vw; border-radius: 18px;
  box-shadow: 0 30px 80px -20px #000, 0 0 60px rgba(214,178,110,0.3);
  transform: scale(0.92); transition: transform 0.35s var(--ease);
}
.zoom.is-open img { transform: scale(1); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 820px) {
  #screen-draft.is-active { grid-template-columns: 1fr; }
  .pool-rail { position: static; height: auto; border-left: none; border-top: 1px solid var(--line); }
  .pool-list { flex-direction: row; flex-wrap: wrap; }
  .pool-item { width: calc(50% - 0.2rem); }
}

.error-box {
  grid-column: 1 / -1; text-align: center; padding: 3rem 1rem; color: var(--blood);
  font-family: var(--display);
}
.error-box button { margin-top: 1rem; }
