.skip-link {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 20000;
  padding: 0.65rem 1rem;
  margin: 0;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.95rem;
  color: #0a0c10;
  background: var(--gold, #f0c04d);
  text-decoration: none;
  border-radius: 0 0 10px 0;
  box-shadow: var(--shadow, 0 8px 24px rgba(0, 0, 0, 0.35));
  clip-path: inset(0 0 100% 0);
  pointer-events: none;
}.skip-link:focus {
  clip-path: none;
  pointer-events: auto;
  outline: 2px solid var(--accent, #e43d5f);
  outline-offset: 2px;
}:root {
  color-scheme: dark;
  --font-display: "Syne", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-body: "DM Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-numeric: "DM Sans", ui-sans-serif, system-ui, monospace;
  --bg: #0a0c10;
  --bg-pattern:
    radial-gradient(circle at 82% 10%, rgba(228, 61, 95, 0.14), transparent 26rem),
    radial-gradient(circle at 8% 88%, rgba(25, 182, 162, 0.1), transparent 30rem),
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), transparent 42%);
  --surface: #12151c;
  --surface-2: #1a1f2a;
  --text: #f4f1ea;
  --muted: #9aa3b0;
  --line: #2e3544;
  --accent: #e43d5f;
  --accent-2: #19b6a2;
  --gold: #f0c04d;
  --danger: #ef5c50;
  --shadow: 0 22px 56px rgba(0, 0, 0, 0.38);
  --rim: color-mix(in srgb, var(--gold) 42%, var(--line));
  --panel-edge: linear-gradient(135deg, color-mix(in srgb, var(--gold) 22%, transparent), transparent 55%);
  --rim-light: rgba(255, 255, 255, 0.14);
}:root[data-theme="blanc"] {
  color-scheme: light;
  --bg: #f4f2ec;
  --bg-pattern:
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.95), transparent 32rem),
    radial-gradient(circle at 88% 78%, rgba(180, 190, 205, 0.18), transparent 28rem),
    linear-gradient(160deg, rgba(255, 255, 255, 0.55), rgba(235, 238, 244, 0.98));
  --surface: #ffffff;
  --surface-2: #eef1f6;
  --text: #161a22;
  --muted: #5a6270;
  --line: #d5dae3;
  --accent: #c91f4a;
  --accent-2: #1f8a7a;
  --gold: #b8860b;
  --danger: #c0392f;
  --shadow: 0 18px 46px rgba(22, 28, 38, 0.12);
  --rim: color-mix(in srgb, var(--gold) 38%, var(--line));
  --panel-edge: linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(210, 215, 225, 0.35));
}:root[data-theme="noir"] {
  color-scheme: dark;
  --bg: #0a0c10;
  --bg-pattern:
    radial-gradient(circle at 82% 10%, rgba(228, 61, 95, 0.14), transparent 26rem),
    radial-gradient(circle at 8% 88%, rgba(25, 182, 162, 0.1), transparent 30rem),
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), transparent 42%);
  --surface: #12151c;
  --surface-2: #1a1f2a;
  --text: #f4f1ea;
  --muted: #9aa3b0;
  --line: #2e3544;
  --accent: #e43d5f;
  --accent-2: #19b6a2;
  --gold: #f0c04d;
  --danger: #ef5c50;
  --shadow: 0 22px 56px rgba(0, 0, 0, 0.38);
  --rim: color-mix(in srgb, var(--gold) 42%, var(--line));
  --panel-edge: linear-gradient(135deg, color-mix(in srgb, var(--gold) 22%, transparent), transparent 55%);
}:root[data-theme="rouge-or"] {
  color-scheme: dark;
  --bg: #14080c;
  --bg-pattern:
    radial-gradient(circle at 18% 14%, rgba(255, 215, 120, 0.14), transparent 22rem),
    radial-gradient(circle at 92% 82%, rgba(220, 48, 72, 0.16), transparent 26rem),
    linear-gradient(155deg, rgba(90, 12, 22, 0.65), rgba(18, 6, 10, 0.96));
  --surface: #201018;
  --surface-2: #301622;
  --text: #fff5f3;
  --muted: #e0b8bf;
  --line: #5c2f3d;
  --accent: #f03d52;
  --accent-2: #ffb347;
  --gold: #ffd978;
  --danger: #ff6b7a;
  --shadow: 0 22px 54px rgba(8, 0, 4, 0.48);
  --rim: color-mix(in srgb, var(--gold) 55%, #5a141c);
  --panel-edge: linear-gradient(135deg, rgba(255, 215, 130, 0.35), transparent 50%);
}:root[data-theme="vert-argent"] {
  color-scheme: dark;
  --bg: #07130f;
  --bg-pattern:
    radial-gradient(circle at 16% 22%, rgba(120, 220, 170, 0.12), transparent 24rem),
    radial-gradient(circle at 90% 70%, rgba(200, 210, 220, 0.12), transparent 28rem),
    linear-gradient(165deg, rgba(12, 42, 30, 0.85), rgba(4, 14, 10, 0.98));
  --surface: #10251d;
  --surface-2: #163528;
  --text: #eefaf3;
  --muted: #a8c9ba;
  --line: #355548;
  --accent: #45d695;
  --accent-2: #c8d6dc;
  --gold: #dce6ea;
  --danger: #ff8a7a;
  --shadow: 0 22px 52px rgba(2, 12, 8, 0.42);
  --rim: color-mix(in srgb, var(--gold) 35%, var(--accent));
  --panel-edge: linear-gradient(135deg, rgba(180, 230, 205, 0.25), transparent 52%);
}:root[data-theme="bleu-bronze"] {
  color-scheme: dark;
  --bg: #060f18;
  --bg-pattern:
    radial-gradient(circle at 78% 16%, rgba(56, 170, 255, 0.18), transparent 26rem),
    radial-gradient(circle at 12% 88%, rgba(184, 132, 72, 0.14), transparent 28rem),
    linear-gradient(150deg, rgba(12, 28, 44, 0.92), rgba(6, 12, 22, 0.98));
  --surface: #0f2234;
  --surface-2: #163248;
  --text: #eef8ff;
  --muted: #9ebad0;
  --line: #315f78;
  --accent: #38aaff;
  --accent-2: #d4a574;
  --gold: #c99352;
  --danger: #ff7d7d;
  --shadow: 0 22px 54px rgba(0, 14, 26, 0.45);
  --rim: color-mix(in srgb, var(--gold) 45%, var(--accent));
  --panel-edge: linear-gradient(135deg, rgba(120, 200, 255, 0.28), rgba(212, 165, 116, 0.18));
}:root[data-theme="jaune-noir"] {
  color-scheme: dark;
  --bg: #060606;
  --bg-pattern:
    repeating-linear-gradient(-45deg, rgba(245, 214, 62, 0.06) 0 10px, transparent 10px 20px),
    radial-gradient(circle at 50% -10%, rgba(245, 214, 62, 0.12), transparent 40rem),
    linear-gradient(180deg, #0a0a0a, #030303);
  --surface: #121212;
  --surface-2: #1c1c1c;
  --text: #fffadc;
  --muted: #bdb49a;
  --line: #3a3828;
  --accent: #f5d62e;
  --accent-2: #ffe066;
  --gold: #ffe066;
  --danger: #ff7a54;
  --shadow: 0 22px 48px rgba(0, 0, 0, 0.55);
  --rim: color-mix(in srgb, var(--accent) 55%, #222);
  --panel-edge: linear-gradient(135deg, rgba(245, 214, 62, 0.4), transparent 45%);
}:root[data-theme="ygo-white-forest"] {
  color-scheme: light;
  --bg: #f4f7f4;
  --bg-pattern:
    radial-gradient(circle at 20% 30%, rgba(140, 210, 170, 0.2), transparent 26rem),
    radial-gradient(circle at 80% 70%, rgba(255, 255, 255, 0.9), transparent 32rem),
    repeating-linear-gradient(90deg, rgba(80, 120, 90, 0.04) 0 1px, transparent 1px 44px);
  --surface: #ffffff;
  --surface-2: #e8f2ea;
  --text: #152018;
  --muted: #4e6658;
  --line: #c5d8cc;
  --accent: #2f9d6a;
  --accent-2: #7ec8a3;
  --gold: #8b7355;
  --danger: #c94a3c;
  --shadow: 0 18px 44px rgba(30, 55, 40, 0.12);
  --rim: color-mix(in srgb, var(--accent-2) 45%, var(--line));
  --panel-edge: linear-gradient(135deg, rgba(180, 235, 205, 0.5), rgba(255, 255, 255, 0.8));
  --ygo-hero-art: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 420'%3E%3Cpath fill='%232f9d6a' opacity='0.28' d='M90 420 L115 210 L70 210 L175 55 L280 210 L235 210 L255 420 Z'/%3E%3Ccircle cx='390' cy='115' r='92' fill='%237ec8a3' opacity='0.34'/%3E%3Cpath fill='%234e6658' opacity='0.16' d='M430 420 L448 228 L385 228 L515 75 L645 228 L585 228 L605 420 Z'/%3E%3Cellipse cx='410' cy='420' rx='310' ry='28' fill='%232f9d6a' opacity='0.12'/%3E%3C/svg%3E");
  --ygo-hero-opacity: 0.48;
  --ygo-hero-blend: multiply;
}:root[data-theme="ygo-dracotail"] {
  color-scheme: dark;
  --bg: #160f1f;
  --bg-pattern:
    radial-gradient(circle at 70% 20%, rgba(220, 90, 180, 0.14), transparent 24rem),
    radial-gradient(circle at 10% 90%, rgba(120, 70, 200, 0.15), transparent 28rem),
    repeating-linear-gradient(115deg, rgba(255, 255, 255, 0.03) 0 2px, transparent 2px 14px);
  --surface: #221830;
  --surface-2: #2f2145;
  --text: #fceeff;
  --muted: #c9b3d8;
  --line: #4c3a63;
  --accent: #e060b0;
  --accent-2: #9b7bff;
  --gold: #f0b8e8;
  --danger: #ff8f80;
  --shadow: 0 22px 52px rgba(10, 4, 20, 0.48);
  --rim: color-mix(in srgb, var(--accent) 45%, var(--accent-2));
  --panel-edge: linear-gradient(135deg, rgba(224, 96, 176, 0.35), rgba(155, 123, 255, 0.2));
  --ygo-hero-art: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 400'%3E%3Cpath fill='none' stroke='%23e060b0' stroke-width='10' opacity='0.38' stroke-linecap='round' d='M40 300 Q180 40 400 160 T760 80'/%3E%3Cpath fill='%239b7bff' opacity='0.28' d='M460 20 L640 220 L500 220 Z'/%3E%3Cpath fill='%23e060b0' opacity='0.18' d='M280 400 Q400 120 520 400 Z'/%3E%3Ccircle cx='620' cy='110' r='45' fill='%23f0b8e8' opacity='0.22'/%3E%3C/svg%3E");
  --ygo-hero-opacity: 0.44;
  --ygo-hero-blend: soft-light;
}:root[data-theme="ygo-stardust"] {
  color-scheme: dark;
  --bg: #070b14;
  --bg-pattern:
    radial-gradient(circle at 50% 0%, rgba(180, 230, 255, 0.2), transparent 28rem),
    radial-gradient(circle at 12% 88%, rgba(80, 140, 255, 0.12), transparent 26rem),
    radial-gradient(1px 1px at 20% 30%, rgba(255, 255, 255, 0.35), transparent 1px),
    radial-gradient(1px 1px at 70% 60%, rgba(255, 255, 255, 0.25), transparent 1px),
    radial-gradient(1px 1px at 40% 80%, rgba(255, 255, 255, 0.2), transparent 1px);
  --surface: #0e1628;
  --surface-2: #152238;
  --text: #f2fbff;
  --muted: #9ec4de;
  --line: #2c4a6a;
  --accent: #7ecbff;
  --accent-2: #b8f0ff;
  --gold: #ffd77a;
  --danger: #ff8b8b;
  --shadow: 0 24px 60px rgba(0, 8, 24, 0.5);
  --rim: color-mix(in srgb, var(--accent) 40%, var(--gold));
  --panel-edge: linear-gradient(135deg, rgba(180, 230, 255, 0.35), transparent 55%);
  --ygo-hero-art: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 420'%3E%3Cdefs%3E%3CradialGradient id='g'%3E%3Cstop offset='0%25' stop-color='%237ecbff'/%3E%3Cstop offset='100%25' stop-color='%23070b14' stop-opacity='0'/%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle cx='400' cy='130' r='175' fill='url(%23g)' opacity='0.55'/%3E%3Cpath fill='%23ffd77a' opacity='0.38' d='M400 35 L422 195 L610 210 L422 225 L400 385 L378 225 L190 210 L378 195 Z'/%3E%3Cpath stroke='%23b8f0ff' stroke-width='3' opacity='0.35' fill='none' d='M120 320 L400 90 L680 320'/%3E%3C/svg%3E");
  --ygo-hero-opacity: 0.52;
  --ygo-hero-blend: screen;
}:root[data-theme="ygo-artmage"] {
  color-scheme: light;
  --bg: #f2e8d5;
  --bg-pattern:
    radial-gradient(circle at 18% 22%, rgba(92, 61, 140, 0.12), transparent 24rem),
    radial-gradient(circle at 88% 78%, rgba(212, 175, 95, 0.18), transparent 28rem),
    repeating-linear-gradient(0deg, rgba(120, 90, 50, 0.06) 0 1px, transparent 1px 24px);
  --surface: #fffaf0;
  --surface-2: #eaddc8;
  --text: #2a1f38;
  --muted: #5c4e68;
  --line: #cfc2ae;
  --accent: #5c3d8c;
  --accent-2: #d4af5f;
  --gold: #a67c00;
  --danger: #b04040;
  --shadow: 0 18px 42px rgba(60, 45, 30, 0.14);
  --rim: color-mix(in srgb, var(--accent) 35%, var(--gold));
  --panel-edge: linear-gradient(135deg, rgba(212, 175, 95, 0.45), rgba(92, 61, 140, 0.15));
  --ygo-hero-art: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 400'%3E%3Ccircle cx='400' cy='145' r='125' fill='none' stroke='%235c3d8c' stroke-width='4' opacity='0.28'/%3E%3Cpath fill='none' stroke='%235c3d8c' stroke-width='2' opacity='0.22' d='M400 40 L470 210 L620 210 L505 305 L555 470 L400 380 L245 470 L295 305 L180 210 L330 210 Z'/%3E%3Cpath fill='%23d4af5f' opacity='0.26' d='M260 360 L400 260 L540 360 L540 395 L400 310 L260 395 Z'/%3E%3Cpath fill='%235c3d8c' opacity='0.12' d='M350 380 L400 340 L450 380 Z'/%3E%3C/svg%3E");
  --ygo-hero-opacity: 0.4;
  --ygo-hero-blend: multiply;
}:root[data-theme="ygo-hecahands"] {
  color-scheme: dark;
  --bg: #0a0710;
  --bg-pattern:
    radial-gradient(circle at 50% 120%, rgba(120, 255, 220, 0.08), transparent 45rem),
    radial-gradient(circle at 12% 18%, rgba(160, 90, 220, 0.14), transparent 26rem),
    linear-gradient(185deg, rgba(24, 12, 36, 0.95), rgba(6, 4, 12, 0.98));
  --surface: #140c1c;
  --surface-2: #1e1428;
  --text: #f3ecff;
  --muted: #b9a8cc;
  --line: #3d3155;
  --accent: #9b7dff;
  --accent-2: #5ef0d8;
  --gold: #e8d0ff;
  --danger: #ff7d9c;
  --shadow: 0 24px 56px rgba(4, 0, 12, 0.55);
  --rim: color-mix(in srgb, var(--accent-2) 35%, var(--accent));
  --panel-edge: linear-gradient(135deg, rgba(158, 240, 216, 0.22), rgba(155, 125, 255, 0.22));
  --ygo-hero-art: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 420'%3E%3Cellipse cx='400' cy='410' rx='340' ry='36' fill='%239b7dff' opacity='0.1'/%3E%3Cpath fill='%239b7dff' opacity='0.22' d='M140 420 L165 190 Q185 85 245 70 Q305 55 335 125 L318 420 Z'/%3E%3Cpath fill='%235ef0d8' opacity='0.18' d='M660 420 L635 190 Q615 85 555 70 Q495 55 465 125 L482 420 Z'/%3E%3Cpath fill='none' stroke='%23e8d0ff' stroke-width='3' opacity='0.25' d='M200 160 Q400 40 600 160'/%3E%3Ccircle cx='400' cy='95' r='28' fill='%235ef0d8' opacity='0.35'/%3E%3C/svg%3E");
  --ygo-hero-opacity: 0.46;
  --ygo-hero-blend: soft-light;
}html[data-theme^="ygo-"] body::before {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  height: min(56vh, 520px);
  pointer-events: none;
  background-image: var(--ygo-hero-art);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: min(96vw, 840px) auto;
  opacity: var(--ygo-hero-opacity, 0.42);
  mix-blend-mode: var(--ygo-hero-blend, soft-light);
}@media (prefers-reduced-motion: reduce) {html[data-theme^="ygo-"] body::before {
    opacity: calc(var(--ygo-hero-opacity, 0.42) * 0.65);
  }}* {
  box-sizing: border-box;
}html {
  height: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}body {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  font-family: var(--font-body);
  background-color: var(--bg);
  background-image: var(--bg-pattern);
  background-attachment: fixed;
  background-size: 100% 100%, 100% 100%, auto, auto;
  color: var(--text);
  overflow-x: clip;
}h1,
h2,
h3,
.account-pane-title,
.panel-title > span:first-child,
.brand-lockup h1 {
  font-family: var(--font-display);
  letter-spacing: -0.02em;
}.lp-display strong {
  font-family: var(--font-numeric);
  font-variant-numeric: tabular-nums;
}img,
video {
  max-width: 100%;
  height: auto;
}button,
input,
select {
  font: inherit;
}button,
select,
input {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--text);
}button {
  min-height: 42px;
  padding: 0 14px;
  cursor: pointer;
  transition: transform 150ms ease, border-color 150ms ease, background 150ms ease;
}button:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
}input,
select {
  width: 100%;
  min-height: 42px;
  padding: 0 10px;
}.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding-top: max(24px, env(safe-area-inset-top));
  padding-right: max(clamp(16px, 4vw, 40px), env(safe-area-inset-right));
  padding-bottom: 24px;
  padding-left: max(clamp(16px, 4vw, 40px), env(safe-area-inset-left));
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  position: sticky;
  top: 0;
  /* Au-dessus du clavier LP (#lpKeypadOverlay z90) et de l’overlay hasard (z400) : sinon « Compte » semble mort si un overlay est resté ouvert. */
  z-index: 500;
  backdrop-filter: blur(14px);
}.brand-lockup {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}.brand-logo {
  width: 54px;
  height: 54px;
  flex: 0 0 auto;
  border-radius: 8px;
  object-fit: cover;
}body.deckbuilder-mode .app-header {
  padding-top: max(12px, env(safe-area-inset-top));
  padding-right: max(clamp(16px, 3vw, 28px), env(safe-area-inset-right));
  padding-bottom: 12px;
  padding-left: max(clamp(16px, 3vw, 28px), env(safe-area-inset-left));
}body.deckbuilder-mode .brand-logo {
  width: 44px;
  height: 44px;
}body.deckbuilder-mode h1 {
  font-size: clamp(1.8rem, 3vw, 2.35rem);
}.eyebrow {
  margin: 0 0 4px;
  color: var(--gold);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
}h1,
h2,
p {
  margin-top: 0;
}h1 {
  margin-bottom: 0;
  font-size: clamp(2rem, 5vw, 3.3rem);
  line-height: 0.95;
}.header-actions,
.button-row,
.dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  min-width: 0;
}.nav-actions {
  display: inline-flex;
  gap: 6px;
}.nav-actions .icon-button {
  min-height: 42px;
  border-color: color-mix(in srgb, var(--accent-2) 45%, var(--line));
  font-weight: 900;
}.nav-actions .icon-button:disabled {
  opacity: 0.35;
}.header-duel-actions {
  display: none;
  flex: 0 1 auto;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
}.theme-picker {
  min-width: 150px;
}.account-button {
  display: inline-grid;
  gap: 2px;
  min-width: 128px;
  justify-items: start;
  line-height: 1.05;
}.account-button.is-connected {
  border-color: color-mix(in srgb, var(--accent-2) 70%, var(--line));
  background: color-mix(in srgb, var(--accent-2) 18%, var(--surface-2));
}.account-badge {
  max-width: 190px;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}.account-button.is-connected .account-badge {
  color: var(--accent-2);
}#deckBuilderButton,
#headerCollectionButton {
  border-color: color-mix(in srgb, var(--accent-2) 45%, var(--line));
}.primary-action {
  border-color: transparent;
  background: linear-gradient(165deg, color-mix(in srgb, #fff 14%, var(--accent)), var(--accent));
  color: #fff;
  font-weight: 800;
  box-shadow: 0 1px 0 var(--rim-light, rgba(255, 255, 255, 0.12)) inset, 0 10px 28px color-mix(in srgb, var(--accent) 28%, transparent);
}.icon-button {
  width: 42px;
  padding: 0;
  font-size: 1.25rem;
}.app-shell {
  display: block;
  padding-top: 18px;
  padding-right: max(clamp(16px, 4vw, 40px), env(safe-area-inset-right));
  padding-bottom: max(40px, env(safe-area-inset-bottom));
  padding-left: max(clamp(16px, 4vw, 40px), env(safe-area-inset-left));
}.app-shell > section {
  min-width: 0;
  max-width: 100%;
}.is-hidden {
  display: none !important;
}.setup-view {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  min-height: 0;
}.duel-view,
.home-view,
.tools-view {
  display: grid;
  gap: 18px;
}.deckbuilder-view {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  min-width: 0;
}.home-view,
.tools-view {
  min-height: calc(100dvh - 150px);
}.home-view {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  width: 100%;
}.tools-view {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}.home-view-center,
.tools-view-center {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 0;
  gap: 18px;
}.home-social-banner {
  flex-shrink: 0;
  width: 100%;
  max-width: min(640px, 100%);
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  box-shadow: var(--shadow);
}.tools-social-banner {
  width: 100%;
  max-width: 100%;
}.home-social-banner-label {
  display: block;
  margin-bottom: 10px;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gold);
  text-align: center;
}.home-social-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 14px;
}.home-social-links a {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--accent-2);
  text-decoration: underline;
  text-underline-offset: 3px;
}.home-panel,
.tools-head,
.tool-choice-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
}.home-panel {
  display: grid;
  gap: 12px;
  width: min(92vw, 560px);
  justify-items: center;
  padding: 28px;
  text-align: center;
}.home-logo {
  width: 96px;
  height: 96px;
  border-radius: 8px;
}.home-panel h2,
.tools-head h2 {
  margin: 0;
  font-size: clamp(1.8rem, 4vw, 3rem);
}.home-panel p:not(.eyebrow) {
  max-width: 420px;
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}.home-landing {
  display: grid;
  gap: clamp(28px, 4vw, 48px);
  width: min(1180px, 100%);
  margin: 0 auto;
  padding: clamp(20px, 3vw, 40px) 0 clamp(32px, 5vw, 56px);
}.home-hero {
  position: relative;
  display: grid;
  align-items: center;
  padding: clamp(24px, 4vw, 48px);
  border: 1px solid var(--line);
  border-radius: 16px;
  background: linear-gradient(145deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface-2) 70%, transparent));
  box-shadow: var(--shadow);
  overflow: hidden;
}.home-hero-glow {
  position: absolute;
  inset: -20% 40% auto -10%;
  height: 70%;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--gold) 22%, transparent), transparent 68%);
  pointer-events: none;
  opacity: 0.85;
}.home-hero-copy {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 14px;
  max-width: 720px;
}.home-hero-logo {
  width: clamp(88px, 12vw, 112px);
  height: clamp(88px, 12vw, 112px);
  border-radius: 12px;
  box-shadow: 0 8px 28px color-mix(in srgb, var(--ink) 18%, transparent);
}.home-hero-title {
  margin: 0;
  font-size: clamp(2rem, 4.8vw, 3.2rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
}.home-hero-lead {
  margin: 0;
  max-width: 58ch;
  color: var(--muted);
  font-size: clamp(1rem, 1.35vw, 1.12rem);
  font-weight: 700;
  line-height: 1.5;
}.home-hero-actions,
.home-hero-secondary {
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 10px;
}.home-hero-discord {
  align-self: center;
  font-weight: 800;
}.home-section-title {
  margin: 0 0 14px;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gold);
}.home-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}.home-module-card {
  display: grid;
  gap: 8px;
  align-content: start;
  min-height: 168px;
  padding: 18px 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow: var(--shadow);
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}.home-module-card:hover,
.home-module-card:focus-visible {
  border-color: color-mix(in srgb, var(--gold) 55%, var(--line));
  transform: translateY(-2px);
  box-shadow: 0 10px 28px color-mix(in srgb, var(--ink) 12%, transparent);
}.home-module-icon {
  font-size: 1.75rem;
  line-height: 1;
  color: var(--gold);
}.home-module-card strong {
  font-size: 1.05rem;
}.home-module-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.45;
}.home-why-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}.home-why-grid li {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
}.home-why-grid strong {
  display: block;
  margin-bottom: 6px;
  font-size: 1rem;
}.home-why-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.45;
}.home-community {
  padding: clamp(20px, 3vw, 28px);
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in srgb, var(--surface-2) 90%, transparent);
}.home-community-lead {
  margin: 0 0 14px;
  color: var(--muted);
  font-weight: 700;
}.home-community-links {
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 10px;
}.home-community-links a {
  min-height: 40px;
  padding: 10px 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  font-weight: 800;
  text-decoration: none;
  color: var(--ink);
}.home-community-links a.primary-action {
  color: var(--on-accent, #0a0c10);
}:root[data-theme="blanc"] .home-module-card,
:root[data-theme="blanc"] .home-hero,
:root[data-theme="blanc"] .home-why-grid li,
:root[data-theme="blanc"] .home-community {
  box-shadow: 0 8px 24px color-mix(in srgb, #1a2030 8%, transparent);
}@media (max-width: 1100px) {.home-quick-grid,
  .home-why-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }}@media (max-width: 620px) {.home-landing {
    gap: 22px;
    padding-bottom: 24px;
  }.home-hero {
    padding: 18px 14px;
  }.home-hero-actions button,
  .home-hero-secondary button {
    flex: 1 1 calc(50% - 8px);
    min-width: 140px;
  }.home-quick-grid,
  .home-why-grid {
    grid-template-columns: 1fr;
  }.home-module-card {
    min-height: 0;
  }}.tools-head {
  width: 100%;
  max-width: 100%;
  padding: 18px;
}.tool-choice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  width: 100%;
  max-width: 100%;
}.tool-choice-card {
  display: grid;
  gap: 8px;
  min-height: 180px;
  justify-items: start;
  padding: 18px;
  text-align: left;
}.tool-choice-card span {
  color: var(--gold);
  font-size: 2.4rem;
}.tool-choice-card strong {
  font-size: 1.35rem;
}.tool-choice-card small {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 800;
}body.deckbuilder-mode {
  min-height: 100dvh;
  overflow-x: clip;
}body.deckbuilder-mode .app-shell {
  min-height: calc(100dvh - 94px);
  overflow: visible;
}body.deckbuilder-mode .deckbuilder-view {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  width: 100%;
  max-width: 100%;
  overflow: visible;
}.duel-view {
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  min-height: 0;
}.setup-head,
.table-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px 16px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.table-topbar > div:first-child {
  flex: 0 1 auto;
  min-width: 0;
}.table-topbar .button-row {
  flex: 0 0 auto;
  margin-left: auto;
}.setup-head h2,
.table-topbar h2 {
  margin: 0;
}.setup-wizard-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.setup-wizard-head-main {
  flex: 1 1 200px;
  min-width: 0;
}.setup-wizard-heading {
  margin: 0;
  font-size: clamp(1.1rem, 3.2vw, 1.65rem);
  line-height: 1.2;
}.setup-wizard-progress {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}.setup-step-dot {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 2px solid var(--line);
  background: var(--surface-2);
  font-weight: 900;
  font-size: 0.88rem;
  cursor: pointer;
  color: var(--text);
}.setup-step-dot.is-active {
  border-color: color-mix(in srgb, var(--gold) 70%, var(--line));
  background: color-mix(in srgb, var(--gold) 14%, var(--surface-2));
  color: var(--gold);
}.setup-wizard-actions {
  flex: 1 1 220px;
  justify-content: flex-end;
}.setup-wizard-actions #startDuelButton:not(.is-hidden) {
  min-height: 46px;
  padding-inline: 18px;
}.setup-wizard-shell {
  flex: 1 1 auto;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  min-width: 0;
}.setup-wizard-step {
  flex: 1 1 auto;
  min-height: 0;
  max-height: min(70vh, 720px);
  overflow-y: auto;
  padding: 4px 2px 14px;
  -webkit-overflow-scrolling: touch;
}.setup-step-lead {
  margin: 0 0 14px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--muted);
  line-height: 1.45;
}.setup-player-count-block {
  margin-bottom: 16px;
}.setup-subheading {
  margin: 0 0 8px;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}.setup-player-count-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}.setup-player-count-pill {
  min-width: 44px;
  min-height: 44px;
  padding: 0 10px;
  border-radius: 10px;
  border: 2px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-weight: 900;
  font-size: 1rem;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}.setup-player-count-pill.is-selected {
  border-color: color-mix(in srgb, var(--gold) 65%, var(--line));
  background: color-mix(in srgb, var(--gold) 10%, var(--surface-2));
}.setup-table-diagram-host {
  margin-bottom: 14px;
}.setup-table-diagram {
  margin: 0;
}.setup-table-diagram-cap {
  margin: 0 0 8px;
  font-size: 0.79rem;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.45;
}.setup-table-svg {
  width: 100%;
  max-width: 320px;
  height: auto;
  display: block;
  margin: 0 auto;
}.setup-table-mat {
  fill: none;
  stroke: var(--line);
  stroke-width: 1.5;
  stroke-dasharray: 4 3;
}.setup-table-mat-label {
  fill: var(--muted);
  font-size: 8px;
  font-weight: 700;
}.setup-table-seat-ring {
  fill: var(--surface-2);
  stroke: var(--gold);
  stroke-width: 2;
}.setup-table-seat-num {
  fill: var(--text);
  font-size: 11px;
  font-weight: 800;
}.setup-table-seat-name {
  fill: var(--muted);
  font-size: 7px;
  font-weight: 700;
}.setup-seat-hint {
  margin: 6px 0 0;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.4;
}.setup-duel-type-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 10px;
}.setup-duel-type-card {
  display: grid;
  gap: 6px;
  padding: 12px;
  min-height: 76px;
  border-radius: 10px;
  border: 2px solid var(--line);
  background: var(--surface-2);
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}.setup-duel-type-card strong {
  font-size: 0.95rem;
}.setup-duel-type-card span {
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--muted);
}.setup-duel-type-card.is-selected {
  border-color: color-mix(in srgb, var(--gold) 65%, var(--line));
  background: color-mix(in srgb, var(--gold) 10%, var(--surface-2));
}.setup-sync-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
}.setup-br-row {
  margin-top: 14px;
}.setup-field-block {
  display: grid;
  gap: 6px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
}.setup-rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}.setup-field-hint {
  margin: 12px 0 0;
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 700;
}.setup-recap-panel {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  background: var(--surface-2);
}.setup-recap-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}.setup-recap-card {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  font-size: 0.82rem;
}.setup-recap-k {
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}.setup-recap-v {
  font-weight: 800;
}.setup-recap-table-title {
  margin: 0 0 8px;
  font-size: 0.82rem;
  font-weight: 900;
  color: var(--gold);
}.setup-recap-list {
  margin: 0;
  padding-left: 1.25rem;
  display: grid;
  gap: 8px;
}.setup-recap-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  font-size: 0.86rem;
}.setup-recap-seat {
  font-weight: 900;
  color: var(--gold);
}.setup-recap-body {
  display: grid;
  gap: 2px;
  min-width: 0;
}.setup-recap-body strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}.setup-recap-deck {
  font-size: 0.76rem;
  color: var(--muted);
  font-weight: 700;
}.setup-recap-team {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--muted);
  text-align: right;
}.setup-launch-hint {
  margin: 14px 0 0;
  font-size: 0.78rem;
  color: var(--muted);
}.setup-players-wizard {
  grid-template-columns: 1fr;
  align-items: start;
}.setup-seat-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px dashed color-mix(in srgb, var(--accent-2) 35%, var(--line));
  background: color-mix(in srgb, var(--surface-2) 90%, transparent);
}.setup-seat-label {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--muted);
}.setup-seat-num {
  font-weight: 900;
  font-size: 1.1rem;
  color: var(--gold);
}.setup-seat-actions {
  margin-left: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}.setup-seat-btn {
  min-height: 38px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
}.setup-seat-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}.setup-players {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
}.setup-player-card {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.setup-player-head,
.duel-player-head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}.setup-player-head strong,
.duel-player-head strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}.duel-player-head span:not(.team-badge) {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}.control-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(140px, 1fr));
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
}.arena {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  align-content: start;
}.mobile-player-rail {
  display: none;
}.player-card,
.panel-block {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.player-card {
  display: grid;
  gap: 14px;
  padding: 14px;
}.team-badge {
  justify-self: start;
  padding: 6px 10px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 55%, var(--line));
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent-2) 15%, var(--surface-2));
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}.player-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}.profile-tools {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
}.profile-drawer {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2) 68%, transparent);
}.profile-drawer summary {
  min-height: 42px;
  padding: 10px 12px;
  cursor: pointer;
  color: var(--muted);
  font-weight: 800;
}.profile-drawer .profile-tools {
  padding: 0 10px 10px;
}.profile-tools select {
  min-width: 0;
}.profile-tools button {
  padding: 0 10px;
}.setup-player-card .profile-tools-setup {
  grid-template-columns: minmax(0, 1fr) auto auto auto;
}.setup-player-card .profile-tools-setup .profile-tools-span {
  grid-column: 1 / -1;
}.library-delete-btn {
  min-width: 42px;
  padding: 0 8px;
  border-color: color-mix(in srgb, var(--danger) 55%, var(--line));
  color: color-mix(in srgb, var(--danger) 92%, var(--text));
}.home-discord,
.tools-discord {
  margin: 0;
  text-align: center;
}.home-discord {
  max-width: 420px;
}.tools-discord {
  width: min(92vw, 860px);
  margin-bottom: 4px;
}.discord-link {
  color: var(--accent-2);
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 3px;
}.discord-link:hover {
  color: var(--accent);
}.lp-display {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 92px;
  padding: 16px;
  border-radius: 8px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, var(--surface-2)), var(--surface-2));
}.lp-display strong {
  font-size: clamp(2rem, 8vw, 4rem);
  line-height: 0.9;
}.lp-display span {
  color: var(--muted);
  font-weight: 800;
}.quick-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}.quick-actions button {
  padding: 0 6px;
}.custom-lp {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
}.lp-actions-drawer {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2) 62%, transparent);
}.lp-actions-drawer summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 40px;
  padding: 8px 10px;
  cursor: pointer;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 900;
  list-style: none;
}.lp-actions-drawer summary::-webkit-details-marker {
  display: none;
}.lp-actions-drawer summary::after {
  content: "+";
  color: var(--text);
}.lp-actions-drawer[open] summary::after {
  content: "-";
}.advanced-lp-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 0 10px 10px;
}.lp-actions-drawer .custom-lp,
.lp-actions-drawer .winner-row {
  margin: 0 10px 10px;
}.winner-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}.round-score {
  color: var(--gold);
  font-weight: 900;
}.tool-panel {
  display: grid;
  gap: 14px;
  align-content: start;
}.panel-block {
  display: grid;
  gap: 12px;
  padding: 14px;
}.panel-drawer {
  padding: 0;
}.panel-drawer summary {
  cursor: pointer;
  list-style: none;
  min-height: 56px;
  padding: 12px 14px;
}.panel-drawer summary::-webkit-details-marker {
  display: none;
}.panel-drawer summary::after {
  content: "+";
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--text);
  font-weight: 900;
}.panel-drawer[open] summary::after {
  content: "-";
}.panel-body {
  display: grid;
  gap: 12px;
  padding: 0 14px 14px;
}.dice-control {
  max-width: 180px;
}.panel-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}.panel-title span {
  color: var(--muted);
  font-weight: 800;
}.panel-title strong {
  color: var(--gold);
  font-size: 1.4rem;
}.timer-block.time-up {
  border-color: var(--danger);
  animation: pulse 900ms ease-in-out infinite;
}@keyframes pulse {
  50% {
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--danger) 20%, transparent);
  }
}.round-controls,
.result-list {
  display: grid;
  gap: 8px;
}details.rounds-store {
  min-width: 0;
}.round-pill,
.result-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px;
  border-radius: 8px;
  background: var(--surface-2);
}.round-pill button {
  min-height: 34px;
}.damage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}.export-dialog {
  width: min(94vw, 560px);
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
}.account-dialog {
  width: min(94vw, 520px);
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
}.account-dialog::backdrop {
  background: rgba(0, 0, 0, 0.65);
}.account-dialog form,
.account-page-form {
  display: grid;
  gap: 14px;
  padding: 16px;
}.account-view.account-page {
  padding-top: 0;
  padding-right: max(16px, env(safe-area-inset-right));
  padding-bottom: 48px;
  padding-left: max(16px, env(safe-area-inset-left));
}.account-page-shell {
  display: grid;
  gap: 20px;
  padding-bottom: 24px;
}.account-page-shell--wide {
  width: min(1200px, 100%);
  margin-inline: auto;
}.account-layout {
  display: grid;
  gap: 20px;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
}@media (min-width: 900px) {.account-layout {
    grid-template-columns: minmax(200px, 240px) minmax(0, 1fr);
    gap: 24px;
  }}.account-side-nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: sticky;
  top: 12px;
}.account-side-nav__item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 14px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  font-weight: 700;
  font-size: 0.88rem;
  cursor: pointer;
}.account-side-nav__item:hover {
  background: var(--surface-2, rgba(255, 255, 255, 0.04));
}.account-side-nav__item.is-active {
  border-color: var(--line);
  background: var(--surface);
  box-shadow: var(--shadow);
}.account-main {
  display: grid;
  gap: 16px;
  min-width: 0;
}.account-page-header--wide {
  padding-bottom: 12px;
}.account-subscription-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-2, rgba(255, 255, 255, 0.02));
}.account-subscription-soon {
  margin: 0;
  font-size: 0.8rem;
  opacity: 0.85;
}.decklist-actions-menu {
  position: relative;
  margin-left: auto;
}.decklist-actions-menu__summary {
  list-style: none;
  cursor: pointer;
  font-weight: 700;
}.decklist-actions-menu__summary::-webkit-details-marker {
  display: none;
}.decklist-actions-menu__panel {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 20;
  display: grid;
  gap: 4px;
  min-width: 200px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.decklist-actions-menu__panel button {
  width: 100%;
  text-align: left;
}.decklist-summary--compact {
  flex-wrap: wrap;
  gap: 8px 12px;
}.card-preview-compact-head--hero {
  grid-template-columns: minmax(96px, 148px) minmax(0, 1fr);
}.card-preview-compact-head .card-preview-image--hero {
  max-height: min(42vh, 260px);
}.account-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0 8px;
  border-bottom: 1px solid var(--line);
}.account-page-title {
  margin: 0.15rem 0 0;
  font-size: 1.55rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}.account-page-subtitle {
  margin: 0.35rem 0 0;
  font-size: 0.88rem;
  color: var(--muted);
  font-weight: 700;
  max-width: 42ch;
}.account-page-close {
  flex-shrink: 0;
}.account-page-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}@media (min-width: 780px) {.account-page-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }.account-pane-theme {
    grid-column: 1 / -1;
  }}@media (min-width: 1080px) {.account-page-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }.account-pane-theme {
    grid-column: auto;
  }}.account-pane {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.account-pane-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 900;
}.account-pane-desc {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--muted);
  font-weight: 700;
}.account-fields {
  display: grid;
  gap: 10px;
}.account-field {
  display: grid;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--muted);
}.account-field input {
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-size: 0.92rem;
}.account-pane-actions {
  display: grid;
  gap: 10px;
  margin-top: 4px;
}.account-button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}.account-button-row button {
  flex: 1 1 auto;
  min-height: 42px;
  font-weight: 900;
}.account-public-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--surface-2);
}.account-stats-heading {
  margin: 8px 0 0;
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}.account-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}.account-stat-card {
  display: grid;
  gap: 4px;
  padding: 12px 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  text-align: center;
}.account-stat-card strong {
  color: var(--gold);
  font-size: 1.45rem;
  font-weight: 900;
  line-height: 1.1;
}.account-stat-card span {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--muted);
  line-height: 1.25;
}.account-snapshot-text {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--muted);
  font-weight: 700;
}.account-pane.account-pane-theme {
  align-self: start;
  gap: 8px;
  padding: 14px 16px;
}.account-pane-theme .account-pane-desc {
  margin: 0 0 4px;
}.account-pane-theme .account-theme-field {
  display: grid;
  gap: 4px;
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--muted);
}.account-pane-theme select {
  min-height: 44px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 800;
}.account-theme-hint {
  margin: 0;
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.4;
}.ghost-button {
  border: 1px solid var(--line);
  background: transparent;
  color: var(--text);
}.deck-filter-spell-block,
.deck-filter-trap-block {
  grid-column: 1 / -1;
}.account-status {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--muted);
  font-weight: 800;
  white-space: pre-wrap;
}.account-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}.account-actions {
  justify-content: flex-end;
}.account-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
  gap: 10px;
}.account-summary div {
  display: grid;
  gap: 2px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  text-align: center;
}.account-summary strong {
  color: var(--gold);
  font-size: 1.6rem;
  line-height: 1;
}.account-summary span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}.account-public-block {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-2);
}.account-public-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 900;
}.account-public-hint {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--muted);
  font-weight: 700;
}.account-public-toggle {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.88rem;
  font-weight: 800;
  cursor: pointer;
}.account-public-toggle input {
  width: 20px;
  height: 20px;
  min-width: 20px;
  margin-top: 2px;
}.account-profile-url-row {
  display: grid;
  gap: 10px;
}.account-profile-url-field {
  display: grid;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--muted);
}.account-profile-url-field input {
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-size: 0.82rem;
}.account-profile-url-row button {
  min-height: 44px;
  font-weight: 900;
}.public-profile-view {
  padding: 20px;
}.public-profile-panel {
  display: grid;
  gap: 16px;
}.public-profile-head {
  display: flex;
  justify-content: flex-start;
}.public-profile-head .primary-action {
  min-height: 44px;
  padding: 12px 18px;
}.public-profile-card {
  padding: 20px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  box-shadow: var(--shadow);
}.public-profile-card-head h2 {
  margin: 0.35rem 0 0;
  font-size: 1.45rem;
}.public-profile-meta {
  margin: 0.5rem 0 0;
  font-size: 0.86rem;
  color: var(--muted);
  font-weight: 700;
}.public-profile-stats {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}.public-profile-stats li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
}.public-profile-stats strong {
  font-size: 1.35rem;
  color: var(--gold);
  min-width: 2.2rem;
}.public-profile-stats span {
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--muted);
}.public-profile-foot {
  margin: 1rem 0 0;
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--muted);
  font-weight: 700;
}body.public-profile-mode .app-header {
  position: sticky;
  top: 0;
  z-index: 5;
}.export-dialog::backdrop {
  background: rgba(0, 0, 0, 0.65);
}.export-dialog form {
  display: grid;
  gap: 14px;
  padding: 16px;
}.dialog-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}.dialog-head h2 {
  margin: 0;
}#tiktokCanvas {
  width: 100%;
  max-height: 72vh;
  border-radius: 8px;
  background: #101218;
  object-fit: contain;
}.deck-share-hint {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--muted);
  font-weight: 700;
}.deck-share-hint code {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--text);
}.deck-share-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 200px), 1fr));
  gap: 10px;
}.deck-share-tile {
  min-height: 44px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-weight: 800;
  font-size: 0.88rem;
  text-align: center;
  cursor: pointer;
}.deck-share-tile:focus-visible {
  outline: 2px solid var(--accent-2);
  outline-offset: 2px;
}.deck-import-file-wrap,
.deck-import-area {
  display: grid;
  gap: 6px;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--muted);
}.deck-import-file-wrap input[type="file"] {
  min-height: 44px;
  font-size: 0.86rem;
}.deck-import-area textarea {
  min-height: 160px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-family: ui-monospace, "Cascadia Code", "Consolas", monospace;
  font-size: 0.8rem;
  resize: vertical;
}.deck-import-actions {
  flex-wrap: wrap;
  gap: 10px;
}.deck-import-actions .primary-action {
  min-height: 44px;
  padding: 12px 16px;
}.deck-import-report {
  margin: 0;
  max-height: min(40vh, 280px);
  overflow: auto;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-family: ui-monospace, "Cascadia Code", "Consolas", monospace;
  font-size: 0.72rem;
  line-height: 1.35;
  white-space: pre-wrap;
  word-break: break-word;
}.dialog-actions {
  justify-content: flex-end;
}.deckbuilder-head,
.deckbuilder-choice-panel,
.deckbuilder-layout > *,
.deck-zones section {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
}.deckbuilder-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
}.deckbuilder-head--compact {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  padding: 10px 14px;
}.deckbuilder-head__brand {
  flex: 1 1 180px;
  min-width: 0;
}.deckbuilder-head__brand .eyebrow {
  margin: 0 0 2px;
  font-size: 0.62rem;
  line-height: 1.2;
}.deckbuilder-head--compact h2 {
  margin: 0;
  font-size: clamp(1.15rem, 2vw, 1.4rem);
  line-height: 1.15;
}.deckbuilder-head__actions {
  flex: 1 1 320px;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 6px;
}.deckbuilder-head-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 6px 12px;
  border: 1px solid color-mix(in srgb, var(--gold) 45%, var(--line));
  border-radius: 8px;
  background: color-mix(in srgb, var(--gold) 10%, var(--surface));
  color: var(--text);
  font-weight: 800;
  font-size: 0.82rem;
  white-space: nowrap;
}.deckbuilder-head-chip__icon {
  color: var(--gold);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
}.deckbuilder-head-chip:hover {
  border-color: var(--gold);
  background: color-mix(in srgb, var(--gold) 18%, var(--surface));
}.deckbuilder-head h2 {
  margin-bottom: 0;
}.deckbuilder-start {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-items: stretch;
}.deckbuilder-start--compact {
  display: block;
  grid-template-columns: none;
  gap: 0;
}.decklist-lib-shell {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 10px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
}.decklist-lib-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}.decklist-lib-bar__left,
.decklist-lib-bar__right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
}.decklist-lib-bar__right {
  margin-left: auto;
  justify-content: flex-end;
}.decklist-lib-title {
  margin: 0;
  font-size: 1rem;
  line-height: 1.2;
  color: var(--text);
}.decklist-lib-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.8rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--gold) 18%, transparent);
  color: var(--gold);
  font-size: 0.82rem;
  font-weight: 900;
}.decklist-lib-meta {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.3;
}.decklist-lib-meta--warn {
  color: color-mix(in srgb, var(--warning, #e8a020) 80%, var(--muted));
}.decklist-lib-btn-compact {
  min-height: 32px;
  padding: 5px 10px;
  font-size: 0.8rem;
  white-space: nowrap;
}.decklist-lib-bar--selection {
  padding: 6px 8px;
  border-radius: 6px;
  border: 1px solid color-mix(in srgb, var(--gold) 35%, var(--line));
  background: color-mix(in srgb, var(--gold) 8%, var(--surface-2));
}.decklist-lib-selection-label {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--text);
}.decklist-lib-menu {
  position: relative;
}.decklist-lib-menu-panel {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  z-index: 30;
  display: grid;
  gap: 4px;
  min-width: 220px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.decklist-lib-menu-panel[hidden] {
  display: none !important;
}.decklist-lib-menu-panel button {
  justify-content: flex-start;
  width: 100%;
  min-height: 34px;
  text-align: left;
}.decklist-lib-bar--filters.decklist-library-toolbar {
  align-items: flex-end;
  margin-bottom: 0;
}.deckbuilder-start:not(.deckbuilder-start--compact) > .deckbuilder-choice-panel:last-child {
  grid-column: 1 / -1;
}.deckbuilder-choice-panel {
  display: grid;
  gap: 10px;
  align-content: start;
  min-width: 0;
  padding: 16px;
  text-align: left;
}.deckbuilder-create-card {
  min-height: 180px;
}.deckbuilder-create-card span {
  color: var(--gold);
  font-size: 2.4rem;
  font-weight: 900;
}.deckbuilder-choice-panel strong,
.deckbuilder-choice-panel h3 {
  margin: 0;
  color: var(--text);
  font-size: 1.2rem;
}.deckbuilder-choice-panel small {
  color: var(--muted);
  font-weight: 800;
}.deckbuilder-library-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}.deckbuilder-library-head > strong {
  color: var(--gold);
  font-size: 1.8rem;
}.saved-decklist-library {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  overflow: visible;
}.decklist-library-stats {
  display: grid;
  gap: 6px;
  align-content: start;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  width: 100%;
  box-sizing: border-box;
}.decklist-library-stats > strong {
  font-size: 0.98rem;
  color: var(--text);
}.decklist-library-stats > span {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 800;
}.decklist-library-stats > small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}.decklist-library-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  width: 100%;
  box-sizing: border-box;
}.decklist-library-actions .decklist-library-bulk {
  flex: 1 1 220px;
  justify-content: flex-start;
}.decklist-library-actions .decklist-library-pager {
  display: flex;
  flex: 0 1 auto;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 90%, transparent);
}.decklist-library-pager--foot {
  margin-top: 4px;
}.saved-decklist-cards--grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}@media (min-width: 768px) {.saved-decklist-cards--grid {
    grid-template-columns: repeat(2, minmax(min(100%, 360px), 1fr));
  }}@media (min-width: 1100px) {.saved-decklist-cards--grid {
    grid-template-columns: repeat(3, minmax(min(100%, 360px), 1fr));
  }}@media (min-width: 1500px) {.saved-decklist-cards--grid {
    grid-template-columns: repeat(4, minmax(min(100%, 360px), 1fr));
  }}.saved-decklist-cards--list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}.saved-decklist-card--list .saved-decklist-open {
  flex: 1;
  min-width: 0;
}.decklist-library-results,
.decklist-library-pager:not(.decklist-library-pager--inline):not(.decklist-library-pager--toolbar),
.deck-eval-compare-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  width: 100%;
  box-sizing: border-box;
  flex-wrap: wrap;
}.decklist-library-results > div:first-child {
  display: grid;
  gap: 3px;
}.decklist-library-results span,
.decklist-library-results small,
.decklist-library-pager span,
.deck-eval-compare-tools span {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 800;
}.decklist-library-bulk {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}.decklist-library-pager {
  justify-content: center;
}.saved-decklist-card {
  display: grid;
  gap: 10px;
  align-items: stretch;
  min-width: 0;
  box-sizing: border-box;
}.saved-decklist-card--grid {
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
  padding: 14px 14px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow: var(--shadow);
}.saved-decklist-card--grid .saved-decklist-select {
  grid-column: 1;
  grid-row: 1;
  align-self: start;
}.saved-decklist-card--grid .saved-decklist-open {
  grid-column: 1 / -1;
  grid-row: 1;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  min-height: 0;
  padding: 0 0 0 46px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}.saved-decklist-card--grid .saved-decklist-open:hover {
  border-color: transparent;
}.saved-decklist-card--grid .saved-decklist-card-actions {
  grid-column: 1 / -1;
  grid-row: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding-top: 4px;
  border-top: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}.saved-decklist-card--list {
  grid-template-columns: auto minmax(0, 1fr) minmax(0, auto);
  gap: 10px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}.saved-decklist-select {
  display: grid;
  place-items: center;
  min-width: 38px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 82%, transparent);
}.saved-decklist-card--list .saved-decklist-open {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 72px;
  padding: 10px 12px;
  text-align: left;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: linear-gradient(var(--surface), var(--surface)) padding-box, var(--panel-edge, transparent) border-box;
  box-shadow: var(--shadow);
}.saved-decklist-card--grid .saved-decklist-open {
  cursor: pointer;
  text-align: left;
  width: 100%;
}.saved-decklist-card--list .saved-decklist-open:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
}.saved-decklist-card--grid:hover {
  border-color: color-mix(in srgb, var(--accent) 38%, var(--line));
}.saved-decklist-name-line {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
  width: 100%;
}.saved-decklist-name {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin: 0;
  min-width: 0;
  flex: 1 1 auto;
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 850;
  line-height: 1.25;
}.saved-decklist-card--grid .saved-decklist-name {
  font-size: 1.12rem;
}.saved-decklist-heading-badges {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 0 0 auto;
  align-items: center;
}.saved-decklist-open-text {
  display: grid;
  gap: 4px;
  min-width: 0;
  justify-items: start;
}.saved-decklist-archetype,
.saved-decklist-counts {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 750;
  line-height: 1.35;
}.saved-decklist-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 2px;
}.saved-decklist-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 9px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-size: 0.72rem;
  font-weight: 900;
  white-space: nowrap;
}.saved-decklist-badge--d20 {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  background: color-mix(in srgb, var(--accent-2) 14%, var(--surface-2));
}.saved-decklist-badge--ok {
  border-color: color-mix(in srgb, #5fd38d 45%, var(--line));
  color: color-mix(in srgb, #9ef0b8 88%, var(--text));
}.saved-decklist-badge--warn {
  border-color: color-mix(in srgb, #ffcf7a 55%, var(--line));
  color: #ffcf7a;
}.saved-decklist-badge--muted {
  color: var(--muted);
}.saved-decklist-badge--status {
  border-color: color-mix(in srgb, var(--gold) 40%, var(--line));
  color: color-mix(in srgb, var(--gold) 88%, var(--text));
}.saved-decklist-updated {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}.saved-decklist-card--grid .saved-decklist-thumb,
.saved-decklist-card--grid .saved-decklist-thumb.deck-box-thumb {
  width: 88px;
  height: 118px;
  flex: 0 0 88px;
}.saved-decklist-card--grid .deck-box-face {
  transform: none;
}.saved-decklist-card--list .saved-decklist-thumb,
.saved-decklist-card--list .deck-box-thumb {
  width: 56px;
  height: 74px;
  flex: 0 0 56px;
}.saved-decklist-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}.saved-decklist-tags:empty {
  display: none;
}.saved-decklist-tags span {
  padding: 2px 7px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  font-size: 0.68rem;
}.saved-decklist-card-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}.saved-decklist-card--list .saved-decklist-card-actions {
  display: grid;
  gap: 8px;
  align-content: center;
}.saved-decklist-status-select,
.decklist-lib-field--small select {
  min-height: 36px;
  max-width: 100%;
  flex: 1 1 120px;
  font-size: 0.8rem;
}.saved-decklist-card--grid .saved-decklist-status-select {
  flex: 1 1 140px;
  min-width: 120px;
}.saved-decklist-favorite {
  min-width: 40px;
  min-height: 36px;
  padding: 0 10px;
  color: var(--muted);
  flex: 0 0 auto;
}.saved-decklist-more {
  position: relative;
  flex: 0 0 auto;
}.saved-decklist-more > summary {
  list-style: none;
  min-width: 40px;
  min-height: 36px;
  display: grid;
  place-items: center;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  color: var(--muted);
  font-size: 1.1rem;
  font-weight: 900;
  cursor: pointer;
}.saved-decklist-more > summary::-webkit-details-marker {
  display: none;
}.saved-decklist-more[open] > summary {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--line));
}.saved-decklist-more-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  z-index: 6;
  display: grid;
  gap: 4px;
  min-width: 148px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  box-shadow: var(--shadow);
}.saved-decklist-more-menu button {
  width: 100%;
  min-height: 34px;
  justify-content: flex-start;
  text-align: left;
  font-size: 0.82rem;
}.saved-decklist-more-menu .danger-action {
  font-size: 0.82rem;
}.saved-decklist-favorite.is-active {
  border-color: color-mix(in srgb, var(--gold) 70%, var(--line));
  color: var(--gold);
  background: color-mix(in srgb, var(--gold) 14%, var(--surface-2));
}.saved-decklist-d20-score {
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent) 45%, var(--line));
  background: color-mix(in srgb, var(--accent-2) 14%, var(--surface-2));
  color: var(--text);
  font-size: 0.72rem;
  font-weight: 900;
}.deckbuilder-compare-card span {
  font-size: 1.35rem;
}.deck-editor-tabbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}.deck-editor-tab {
  flex: 1 1 auto;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--muted);
  font-weight: 800;
  cursor: pointer;
}.deck-editor-tab.is-active {
  border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
  color: var(--text);
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
}.deck-editor-images-wrap {
  max-height: min(72vh, 920px);
  overflow: auto;
  padding: 4px 2px 12px;
}.deck-editor-images-mount {
  display: grid;
  gap: 18px;
}.deck-images-hint {
  margin: 0;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.88rem;
}.deck-images-zone-title {
  margin: 0 0 10px;
  font-size: 1rem;
  color: var(--text);
}.deck-images-count {
  color: var(--muted);
  font-weight: 700;
}.deck-image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(86px, 1fr));
  gap: 10px;
  align-items: start;
}.deck-image-tile {
  position: relative;
  display: grid;
  gap: 4px;
  padding: 6px 6px 36px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
}.deck-image-tile-img {
  width: 100%;
  aspect-ratio: 63 / 88;
  object-fit: cover;
  border-radius: 6px;
  background: #1a1f2a;
}.deck-image-tile-ph {
  width: 100%;
  aspect-ratio: 63 / 88;
  border-radius: 6px;
  background: linear-gradient(145deg, #2a3140, #1a2030);
}.deck-image-tile-qty {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 2px 6px;
  border-radius: 6px;
  background: rgba(0, 0, 0, 0.72);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 900;
  line-height: 1.2;
}.deck-image-tile-name {
  border: 0;
  background: transparent;
  color: var(--accent-2);
  font-size: 0.68rem;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
  padding: 0;
  line-height: 1.2;
  min-height: 32px;
}.deck-image-tile-remove {
  position: absolute;
  bottom: 4px;
  right: 4px;
  width: 32px;
  min-height: 32px;
  padding: 0;
  font-size: 1.1rem;
  line-height: 1;
}.deck-eval-mount {
  max-height: min(72vh, 900px);
  overflow: auto;
  padding-top: 4px;
}.deck-eval-panel {
  display: grid;
  gap: 14px;
}.deck-eval-lead,
.deck-eval-compare-lead {
  margin: 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface-2) 85%, transparent);
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}.deck-eval-warning {
  margin: 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--gold) 55%, var(--line));
  background: color-mix(in srgb, var(--gold) 12%, var(--surface));
  color: var(--text);
  font-weight: 700;
}.deck-eval-warning--v1 {
  border-color: color-mix(in srgb, #e85d5d 55%, var(--line));
  background: color-mix(in srgb, #e85d5d 14%, var(--surface));
}.deck-eval-caps {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface-2) 70%, transparent);
}.deck-eval-caps-title {
  margin: 0 0 8px;
  font-size: 0.88rem;
  font-weight: 800;
}.deck-eval-caps-list {
  margin: 0;
  padding-left: 1.1rem;
  font-size: 0.86rem;
  line-height: 1.45;
}.deck-eval-penalties-block .deck-eval-criterion {
  border-color: color-mix(in srgb, #e85d5d 35%, var(--line));
  background: color-mix(in srgb, #e85d5d 6%, var(--surface));
}.deck-eval-criterion--penalty .deck-eval-score-label {
  color: color-mix(in srgb, #e85d5d 75%, var(--muted));
}.saved-decklist-d20-score--v1 {
  border-color: color-mix(in srgb, #e85d5d 50%, var(--line));
  background: color-mix(in srgb, #e85d5d 18%, var(--surface-2));
  color: #ffb4b4;
}.deck-eval-subsection {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}.deck-eval-calibration--ok {
  border-color: color-mix(in srgb, #3ecf8e 45%, var(--line));
  background: color-mix(in srgb, #3ecf8e 10%, var(--surface));
}.deck-eval-calibration--watch {
  border-color: color-mix(in srgb, var(--gold) 50%, var(--line));
  background: color-mix(in srgb, var(--gold) 10%, var(--surface));
}.deck-eval-calibration--alert {
  border-color: color-mix(in srgb, #e85d5d 50%, var(--line));
  background: color-mix(in srgb, #e85d5d 12%, var(--surface));
}.deck-eval-calibration-input,
.deck-eval-calibration-select {
  min-width: 72px;
  max-width: 100px;
  padding: 4px 8px;
  border-radius: 8px;
}.deck-eval-calibration-comment {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
}.deck-eval-calibration-comment textarea {
  width: 100%;
  min-height: 72px;
  padding: 8px 10px;
  border-radius: 8px;
  font-family: var(--font-body);
}.deck-eval-structure-warn {
  color: color-mix(in srgb, #e85d5d 85%, var(--text));
}.deck-eval-structure-manual {
  margin-top: 10px;
}.deck-eval-structure-manual summary {
  cursor: pointer;
  font-weight: 800;
  font-size: 0.86rem;
  color: var(--muted);
}.deck-eval-structure-manual-grid {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}.deck-eval-structure-manual-grid label {
  display: grid;
  gap: 4px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
}.deck-eval-structure-manual-grid input,
.deck-eval-structure-manual-grid select {
  min-height: 36px;
  padding: 6px 10px;
  border-radius: 8px;
}.deck-eval-hints {
  display: grid;
  gap: 10px;
}.deck-eval-hints label {
  display: grid;
  gap: 4px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
}.deck-eval-hints input,
.deck-eval-hints select,
.deck-eval-hints textarea {
  min-height: 36px;
  padding: 6px 10px;
  border-radius: 8px;
}.deck-eval-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}.deck-eval-section-title {
  margin: 0 0 8px;
  font-size: 0.95rem;
}.deck-eval-dl {
  display: grid;
  grid-template-columns: minmax(120px, 0.35fr) 1fr;
  gap: 6px 12px;
  margin: 0;
  font-size: 0.88rem;
}.deck-eval-dl dt {
  color: var(--muted);
  font-weight: 800;
}.deck-eval-dl dd {
  margin: 0;
}.deck-eval-muted {
  color: var(--muted);
  font-weight: 600;
  font-size: 0.82rem;
}.deck-eval-tags {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  margin-top: 12px;
}.deck-eval-tags ul {
  margin: 6px 0 0;
  padding-left: 1.1rem;
}.deck-eval-specific-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}.deck-eval-specific-card {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 22%, var(--line));
  background: color-mix(in srgb, var(--surface-2) 75%, transparent);
}.deck-eval-specific-card h5 {
  margin: 0 0 6px;
  font-size: 0.88rem;
}.deck-eval-specific-card p {
  margin: 0 0 8px;
  font-size: 0.82rem;
  line-height: 1.42;
}.deck-eval-specific-card ul {
  margin: 6px 0 0;
  padding-left: 1.1rem;
  font-size: 0.8rem;
  line-height: 1.35;
}.deck-eval-improvement {
  border-color: color-mix(in srgb, var(--gold) 35%, var(--line));
}.deck-eval-core,
.deck-eval-generic,
.deck-eval-notes {
  margin: 10px 0 0;
  font-size: 0.86rem;
  line-height: 1.45;
}.deck-eval-criteria-block {
  display: grid;
  gap: 12px;
}.deck-eval-criterion {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface);
}.deck-eval-criterion-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}.deck-eval-score-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--muted);
}.deck-eval-crit-select {
  min-width: 140px;
}.deck-eval-explain-input {
  width: 100%;
  resize: vertical;
  min-height: 52px;
  padding: 8px 10px;
  border-radius: 8px;
  font-family: var(--font-body);
}.deck-eval-empty {
  margin: 0;
  padding: 12px;
  border-radius: 10px;
  border: 1px dashed var(--line);
  color: var(--muted);
}.deckbuilder-eval-compare {
  display: grid;
  gap: 12px;
  padding: 12px;
}.deckbuilder-eval-compare-head {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}.deckbuilder-eval-compare-title {
  margin: 0;
  font-size: 1.25rem;
}.deck-eval-compare-table-wrap {
  overflow: auto;
  border-radius: 12px;
  border: 1px solid var(--line);
}.deck-eval-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}.deck-eval-compare-table th,
.deck-eval-compare-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}.deck-eval-compare-table th {
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  font-weight: 900;
}.deck-eval-compare-tools input {
  flex: 1 1 280px;
  min-width: 0;
  max-width: min(720px, 100%);
}.deck-eval-score-badge,
.deck-eval-category-badge,
.deck-eval-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  font-weight: 900;
  white-space: nowrap;
}.deck-eval-score-badge {
  color: var(--gold);
}.deck-eval-category-badge {
  color: var(--text);
  background: color-mix(in srgb, var(--accent-2) 16%, var(--surface-2));
}.deck-eval-status-badge--ok {
  color: #77e0a3;
  border-color: color-mix(in srgb, #77e0a3 50%, var(--line));
}.deck-eval-status-badge--warn {
  color: #ffcf7a;
  border-color: color-mix(in srgb, #ffcf7a 50%, var(--line));
}.deck-eval-compare-detail {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 8px;
  font-size: 0.86rem;
  color: var(--muted);
}.deck-box-thumb {
  width: 52px;
  height: 68px;
  flex: 0 0 auto;
  border-radius: 8px;
  perspective: 260px;
}.deck-box-face {
  width: 100%;
  height: 100%;
  border-radius: 8px;
  border: 2px solid var(--rim);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 10px 22px rgba(0, 0, 0, 0.35);
  background: linear-gradient(155deg, var(--surface-2), var(--surface));
  overflow: hidden;
  transform: rotateY(-6deg);
}.deck-box-face img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}.deck-box-placeholder {
  display: grid;
  place-items: center;
  height: 100%;
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 800;
  color: color-mix(in srgb, var(--muted) 65%, var(--text));
  background: radial-gradient(circle at 40% 25%, rgba(255, 255, 255, 0.08), transparent 55%);
}.danger-action,
#deleteDecklistButton {
  border-color: color-mix(in srgb, #e43d5f 65%, var(--line));
  color: #ff8da1;
}.deckbuilder-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(300px, 1fr) minmax(400px, 1.3fr);
  gap: 14px;
  align-items: start;
  min-height: 0;
  overflow: hidden;
}.card-search-panel,
.decklist-panel {
  display: grid;
  gap: 12px;
  padding: 14px;
  max-height: 100%;
  min-width: 0;
  overflow: hidden;
}.card-preview {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  max-height: 100%;
  min-height: 0;
  min-width: 0;
  overflow: hidden;
}.deck-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}.deck-dashboard-grid > div {
  display: grid;
  gap: 2px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface-2);
}.deck-dashboard-grid strong {
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 1.5rem;
}.deck-dashboard-grid span,
.deck-dashboard-meta dt,
.deck-dashboard-meta dd,
.deck-dashboard-recent li {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}.deck-dashboard-meta {
  display: grid;
  gap: 8px;
  margin: 0;
}.deck-dashboard-meta > div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}.deck-dashboard-meta dd {
  margin: 0;
  color: var(--text);
  text-align: right;
}.deck-dashboard-hint {
  padding: 12px;
  border: 1px dashed color-mix(in srgb, var(--accent) 45%, var(--line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
}.deck-dashboard-recent ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding-left: 18px;
}.deckbuilder-status,
.empty-state {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
}.deck-search-advanced {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 0 10px 10px;
  background: var(--surface-2);
}.deck-search-advanced summary {
  min-height: 44px;
  padding: 10px 4px;
  font-weight: 900;
  font-size: 0.88rem;
  cursor: pointer;
  list-style-position: outside;
}.deck-search-filters {
  display: grid;
  gap: 10px;
  padding-top: 4px;
}.deck-filter-monster-block {
  display: grid;
  gap: 10px;
  grid-column: 1 / -1;
}.deck-filter-field {
  display: grid;
  gap: 4px;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--muted);
}.deck-filter-field-wide {
  grid-column: 1 / -1;
}.deck-filter-field select,
.deck-filter-field input[type="search"],
.deck-filter-stats input {
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-size: 0.86rem;
}.deck-filter-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}.deck-filter-stats label {
  display: grid;
  gap: 4px;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--muted);
}.deck-search-reset {
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 8px;
  font-weight: 900;
  justify-self: start;
}.card-search-results {
  display: grid;
  gap: 8px;
  max-height: none;
  min-height: 0;
  overflow: auto;
}.card-result {
  display: grid;
  gap: 3px;
  justify-items: start;
  text-align: left;
}.card-result strong,
.deck-card-row .deck-card-name {
  overflow: hidden;
  max-width: 100%;
  text-overflow: ellipsis;
  white-space: nowrap;
}.card-result span,
.card-stats {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}.card-preview-compact-head {
  display: grid;
  grid-template-columns: minmax(72px, 124px) minmax(0, 1fr);
  gap: 10px 14px;
  align-items: start;
}.card-preview-compact-head .card-preview-image {
  width: 100%;
  max-height: min(34vh, 200px);
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
}.card-preview-compact-meta {
  min-width: 0;
}.card-preview-compact-meta h3 {
  margin: 0;
  font-size: clamp(1.05rem, 2.2vw, 1.45rem);
  word-break: break-word;
}.card-preview h3 {
  margin: 0;
  font-size: clamp(1.2rem, 2vw, 1.8rem);
}.card-preview p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
  overflow: auto;
}.card-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}.card-stats span {
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
}.decklist-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}.decklist-collection-filter {
  flex: 1 1 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
}.deck-builder-public-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
}.deck-builder-public-hint {
  margin: -6px 0 0;
  font-size: 0.75rem;
  color: var(--muted);
}.deck-builder-public-actions {
  margin: 0 0 6px;
}.deckbuilder-collection-card span {
  font-size: 1.6rem;
  line-height: 1;
}.decklist-library-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  align-items: flex-end;
  margin-bottom: 0;
  width: 100%;
}.decklist-library-toolbar .decklist-lib-field {
  flex: 1 1 min(200px, 100%);
  min-width: min(100%, 140px);
}.decklist-library-toolbar .decklist-lib-field--search {
  flex: 2 1 min(260px, 100%);
}.decklist-library-toolbar .decklist-lib-field--sort {
  flex: 1 1 min(180px, 100%);
}.decklist-library-toolbar .decklist-lib-field--small {
  flex: 0 1 96px;
  min-width: 0;
}.deck-eval-analyze-all-btn {
  align-self: flex-end;
  min-height: 38px;
  white-space: nowrap;
}.deck-eval-analyze-all-status {
  margin: 0;
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--muted);
  min-height: 1.1em;
  line-height: 1.3;
}.decklist-lib-field {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 0.7rem;
  font-weight: 800;
  color: var(--muted);
  min-width: 0;
}.decklist-lib-field__label {
  flex: 0 0 auto;
  white-space: nowrap;
}.decklist-lib-field input,
.decklist-lib-field select {
  flex: 1 1 120px;
  min-height: 32px;
  min-width: 0;
  max-width: none;
  width: 100%;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-size: 0.82rem;
}.decklist-library-pager--toolbar {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}.decklist-library-pager--toolbar .decklist-pager-btn {
  min-width: 32px;
  min-height: 32px;
  padding: 4px 8px;
  font-size: 1rem;
  line-height: 1;
}.decklist-pager-label {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
  white-space: nowrap;
}.deckbuilder-collection-full {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 4px 8px 24px;
  min-height: 0;
}.deckbuilder-collection-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-bottom: 4px;
}.collection-top-leading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  min-width: 0;
}.collection-context-back {
  min-height: 34px;
  padding: 4px 10px;
  font-size: 0.82rem;
  font-weight: 800;
  flex: 0 0 auto;
}.deckbuilder-collection-page-title {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.2;
}.collection-top-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}.deckbuilder-collection-top .collection-save-btn {
  min-height: 36px;
  padding-inline: 14px;
}.collection-actions-summary {
  min-height: 36px;
  padding: 4px 12px;
  font-size: 0.82rem;
}.collection-mode-switch,
.collection-internal-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 90%, transparent);
}.collection-mode-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 4px 10px;
  text-align: left;
  font-size: 0.82rem;
}.collection-mode-tab small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}@media (min-width: 720px) {.collection-mode-tab small {
    display: none;
  }}.collection-internal-nav button,
.collection-nav-more > summary {
  min-height: 34px;
  padding: 4px 10px;
  font-size: 0.8rem;
}.collector-page-head--compact {
  padding: 8px 12px;
  gap: 8px;
}.collector-page-head--compact .collector-page-head__crumb {
  margin: 0;
  font-size: 0.72rem;
}.collector-page-head--compact .collector-page-head__title {
  margin: 0.1rem 0 0;
  font-size: 1.05rem;
  line-height: 1.2;
}.collector-page-head--compact .collector-page-head__sub {
  margin: 0.2rem 0 0;
  font-size: 0.8rem;
  color: var(--muted);
  font-weight: 750;
  line-height: 1.35;
}.collector-page-head--compact .collector-page-head__main {
  min-width: 0;
  flex: 1 1 200px;
}.collector-tools--compact {
  gap: 4px;
  padding: 4px;
}.collector-tools--compact button {
  min-height: 30px;
  padding: 3px 8px;
  font-size: 0.74rem;
}.collector-toolbar {
  gap: 6px;
  padding: 6px 8px;
}.collector-toolbar input,
.collector-toolbar select,
.collector-toolbar button {
  min-height: 34px;
  font-size: 0.8rem;
}.collector-chip-row {
  gap: 6px;
  padding: 4px 0 0;
}.collector-chip-row button {
  min-height: 28px;
  padding: 3px 8px;
  font-size: 0.72rem;
}.collection-collector-panel {
  gap: 10px;
}.collection-mode-tab.is-active,
.collection-internal-nav button.is-active,
.collector-tools button.is-active {
  border-color: color-mix(in srgb, var(--gold) 60%, var(--line));
  background: color-mix(in srgb, var(--gold) 13%, var(--surface-2));
  color: var(--text);
}.collection-collector-panel {
  display: grid;
  gap: 14px;
  min-height: 420px;
}.collector-page-head,
.collector-card-detail,
.collector-dashboard-grid > section,
.collector-extension-card,
.collector-card,
.collector-import-export-grid {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
}.collector-page-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
}.collector-page-head h3,
.collector-extension-card h4,
.collector-card h4,
.collector-dashboard-grid h4 {
  margin: 0;
}.collector-tools,
.collector-card-badges,
.collector-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}.collector-tools {
  justify-content: flex-end;
}.collector-tools input {
  min-width: min(100%, 260px);
}.collector-toolbar {
  position: sticky;
  top: 8px;
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 8px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  box-shadow: var(--shadow);
}.collector-toolbar input[type="search"] {
  grid-column: span 2;
  min-width: min(100%, 240px);
}.collector-toolbar input,
.collector-toolbar select,
.collector-toolbar button {
  min-height: 40px;
  font-size: 0.82rem;
}.collector-chip-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
}.collector-chip-row button {
  min-height: 28px;
  padding: 4px 9px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-2) 86%, transparent);
  color: var(--muted);
  font-size: 0.72rem;
}.collector-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}.collector-stat-grid > div {
  display: grid;
  gap: 4px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface-2);
}.collector-stat-grid strong {
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 1.75rem;
}.collector-stat-grid span,
.collector-extension-card p,
.collector-card p,
.collector-activity span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}.collector-dashboard-grid,
.collector-extension-grid,
.collector-card-grid {
  display: grid;
  gap: 12px;
}.collector-dashboard-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}.collector-dashboard-grid > section,
.collector-extension-card,
.collector-card {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 14px;
}.collector-quick-grid,
.collector-progress-list,
.collector-import-export-grid,
.collector-import-box,
.collector-activity {
  display: grid;
  gap: 8px;
}.collector-import-box {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}.collector-import-box textarea {
  width: 100%;
  resize: vertical;
}.collector-progress-list button {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  text-align: left;
}.collector-activity {
  margin: 0;
  padding-left: 18px;
}.collector-activity li {
  display: grid;
  gap: 2px;
}.collector-extension-grid {
  gap: 16px;
  grid-template-columns: 1fr;
}.collector-extension-grid.collector-view-grid {
  grid-template-columns: 1fr;
}@media (min-width: 640px) {.collector-extension-grid.collector-view-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }}@media (min-width: 900px) {.collector-extension-grid.collector-view-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }}@media (min-width: 1200px) {.collector-extension-grid.collector-view-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }}@media (min-width: 1600px) {.collector-extension-grid.collector-view-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }}.collector-extension-grid.collector-view-compact {
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}@media (min-width: 640px) {.collector-extension-grid.collector-view-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }}@media (min-width: 900px) {.collector-extension-grid.collector-view-compact {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }}@media (min-width: 1200px) {.collector-extension-grid.collector-view-compact {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }}.collector-extension-grid.collector-view-list {
  grid-template-columns: 1fr;
}.collector-card-grid.collector-view-grid {
  gap: 16px;
  grid-template-columns: 1fr;
}@media (min-width: 768px) {.collector-card-grid.collector-view-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }}@media (min-width: 1024px) {.collector-card-grid.collector-view-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }}@media (min-width: 1366px) {.collector-card-grid.collector-view-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }}@media (min-width: 1600px) {.collector-card-grid.collector-view-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }}.collector-card-grid.collector-view-compact {
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}@media (min-width: 768px) {.collector-card-grid.collector-view-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }}@media (min-width: 1024px) {.collector-card-grid.collector-view-compact {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }}@media (min-width: 1366px) {.collector-card-grid.collector-view-compact {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }}@media (min-width: 1600px) {.collector-card-grid.collector-view-compact {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }}.collector-card-grid.collector-view-list {
  grid-template-columns: 1fr;
  gap: 10px;
}.collector-progress {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--surface-2);
}.collector-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--gold));
}.collector-progress--empty span {
  width: 0 !important;
  min-width: 0;
  background: transparent !important;
}.collector-card {
  position: relative;
  overflow: hidden;
  grid-template-columns: 112px minmax(0, 1fr);
  padding: 12px;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}.collector-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--line));
}.collector-card-image {
  display: block;
  width: 112px;
  min-width: 112px;
  padding: 0;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
}.collector-card-image .card-image {
  width: 112px;
  max-width: 100%;
  margin: 0 auto;
}.collector-card-image .card-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}.collector-card-grid.collector-view-grid .collector-card {
  grid-template-columns: 138px minmax(0, 1fr);
  padding: 14px;
}.collector-card-grid.collector-view-grid .collector-card-image,
.collector-card-grid.collector-view-grid .collector-card-image .card-image {
  width: 138px;
  min-width: 138px;
}.collector-card-grid.collector-view-grid .collector-card-title {
  font-size: 1.03rem;
  line-height: 1.22;
}.collector-card-grid.collector-view-grid .collector-card-info p:not(.collector-card-kicker) {
  font-size: 0.8rem;
}.collector-card-grid.collector-view-compact .collector-card {
  grid-template-columns: 100px minmax(0, 1fr);
  padding: 10px;
}.collector-card-grid.collector-view-compact .collector-card-image,
.collector-card-grid.collector-view-compact .collector-card-image .card-image {
  width: 100px;
  min-width: 100px;
}.collector-card-body,
.collector-card-info {
  display: grid;
  min-width: 0;
}.collector-card-body {
  gap: 8px;
  align-content: space-between;
}.collector-card-info {
  gap: 3px;
}.collector-card-kicker {
  margin: 0;
  color: var(--gold) !important;
  font-size: 0.68rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}.collector-card-title {
  display: -webkit-box;
  min-height: 2.2em;
  overflow: hidden;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-family: var(--font-display);
  font-size: 0.98rem;
  font-weight: 850;
  text-align: left;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.1;
}.collector-card-title:hover {
  color: var(--gold);
}.collector-card-info p:not(.collector-card-kicker) {
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}.collector-card-badges,
.collector-card-actions {
  margin-top: 4px;
}.collector-card-badges {
  gap: 5px;
}.collector-card-context {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 800;
}.collector-card-context span {
  padding: 2px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-2) 78%, transparent);
}.collector-badge {
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
}.collector-badge--owned {
  border-color: color-mix(in srgb, #4ad48c 45%, var(--line));
  color: #248f5b;
}.collector-badge--wish {
  border-color: color-mix(in srgb, var(--gold) 60%, var(--line));
  color: #9b6a00;
}.collector-badge--missing {
  color: color-mix(in srgb, var(--muted) 78%, var(--text));
}.collector-badge--double {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  color: var(--accent);
}.collector-badge--complete {
  border-color: color-mix(in srgb, #4ad48c 55%, var(--line));
  background: color-mix(in srgb, #4ad48c 12%, var(--surface-2));
  color: #237a52;
}.collector-card-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(32px, 1fr));
  gap: 5px;
}.collector-card-actions button {
  min-width: 0;
  min-height: 34px;
  padding: 0 6px;
  border-radius: 9px;
  font-size: 0.88rem;
  font-weight: 900;
}.collector-card-action--secondary {
  opacity: 0.72;
}@media (hover: hover) {.collector-card .collector-card-action--secondary {
    opacity: 0;
    transition: opacity 160ms ease;
  }.collector-card:hover .collector-card-action--secondary,
  .collector-card:focus-within .collector-card-action--secondary {
    opacity: 0.9;
  }}.collector-card-actions button.is-active {
  border-color: color-mix(in srgb, var(--gold) 70%, var(--line));
  background: color-mix(in srgb, var(--gold) 16%, var(--surface-2));
  color: #9b6a00;
}.collector-print-list {
  display: grid;
  gap: 7px;
  margin-top: 10px;
}.collector-print-list h4 {
  margin: 0;
  color: var(--muted);
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}.collector-print-list button {
  display: grid;
  gap: 2px;
  justify-items: start;
  min-height: 0;
  padding: 8px 10px;
  border-radius: 10px;
  text-align: left;
}.collector-print-list small {
  color: var(--muted);
  font-weight: 800;
}.collector-card--compact {
  grid-template-columns: 1fr;
  padding: 9px;
}.collector-card--compact .collector-card-image {
  width: 100%;
  min-width: 0;
}.collector-card--compact .collector-card-image .card-image {
  width: min(100%, 96px);
}.collector-card--compact .collector-card-actions {
  grid-template-columns: repeat(3, 1fr);
}.collector-card--list {
  grid-template-columns: 64px minmax(0, 1fr);
  align-items: center;
  padding: 8px 10px;
}.collector-card--list .collector-card-image {
  width: 56px;
  min-width: 56px;
}.collector-card--list .collector-card-image .card-image {
  width: 56px;
}.collector-card--list .collector-card-body {
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
}.collector-card--list .collector-card-title {
  min-height: 0;
  -webkit-line-clamp: 1;
}.collector-card--list .collector-card-actions {
  min-width: 150px;
}.collector-card-detail.collector-card-detail--split {
  display: grid;
  grid-template-columns: minmax(200px, 440px) minmax(0, 1fr);
  gap: 20px;
  padding: 16px 18px;
  align-items: start;
}.collector-card-detail__media {
  display: grid;
  gap: 8px;
  justify-items: center;
}.collector-card-detail__media .card-image--detail,
.collector-card-detail__media .card-image {
  width: min(100%, 440px);
  max-width: 100%;
}.collector-card-detail:not(.collector-card-detail--split) {
  display: grid;
  grid-template-columns: minmax(92px, 140px) minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
}.collector-card-detail__body {
  min-width: 0;
}.collector-card-detail__title {
  margin: 0.15rem 0 0.45rem;
  font-size: 1.28rem;
  line-height: 1.2;
}.collector-card-detail__text {
  line-height: 1.45;
  max-height: 15rem;
  overflow: auto;
}.collector-card-badges--under {
  justify-content: center;
}.collector-prints-section {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 72%, transparent);
}.collector-prints-section__head {
  display: grid;
  gap: 4px;
  margin-bottom: 10px;
}.collector-prints-section__head h4 {
  margin: 0;
  font-size: 1.02rem;
}.collector-prints-section__sub {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.35;
}.collector-prints-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}.collector-prints-filters select {
  min-height: 36px;
  min-width: min(100%, 180px);
  font-size: 0.82rem;
}.collector-print-table-scroll {
  max-height: min(52vh, 420px);
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--line) 85%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 94%, transparent);
}.collector-print-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
  table-layout: fixed;
}.collector-print-table th,
.collector-print-table td {
  padding: 10px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 65%, transparent);
  vertical-align: middle;
  line-height: 1.35;
}.collector-print-table tbody tr:hover {
  background: color-mix(in srgb, var(--accent) 6%, transparent);
}.collector-print-table th {
  text-align: left;
  position: sticky;
  top: 0;
  background: color-mix(in srgb, var(--surface) 98%, transparent);
  z-index: 1;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--muted);
}.collector-print-col-ext {
  width: 34%;
  word-break: break-word;
}.collector-print-col-code {
  width: 14%;
  white-space: nowrap;
}.collector-print-col-rarity {
  width: 22%;
  word-break: break-word;
}.collector-print-col-qty {
  width: 6%;
  text-align: center !important;
}.collector-print-col-actions {
  width: 18%;
}.collector-print-row-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}.collector-print-edit {
  min-height: 34px;
  padding: 4px 10px;
  font-size: 0.8rem;
}.collector-print-more {
  position: relative;
}.collector-print-more > summary {
  list-style: none;
  min-width: 34px;
  min-height: 34px;
  display: grid;
  place-items: center;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 90%, transparent);
  color: var(--muted);
  font-size: 1rem;
  font-weight: 900;
  cursor: pointer;
}.collector-print-more > summary::-webkit-details-marker {
  display: none;
}.collector-print-more-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  z-index: 8;
  display: grid;
  gap: 4px;
  min-width: 168px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  box-shadow: var(--shadow);
}.collector-print-more-menu button {
  width: 100%;
  min-height: 34px;
  justify-content: flex-start;
  text-align: left;
  font-size: 0.8rem;
}.collector-print-cards-mobile {
  display: none;
}.collector-print-mobile-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
}.collector-print-mobile-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}.collector-print-mobile-card__head strong {
  font-size: 0.95rem;
  line-height: 1.25;
}.collector-print-mobile-card__rarity,
.collector-print-mobile-card__qty {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 750;
}.collector-prints-expand {
  margin-top: 10px;
  width: 100%;
}.collector-code-disp {
  font-size: 0.8rem;
  font-weight: 800;
}.collector-card-actions--primary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}.collector-reset-btn.is-disabled,
.collector-reset-btn:disabled {
  opacity: 0.45;
  pointer-events: none;
}.collector-card-title--clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  white-space: normal;
  line-height: 1.28;
  text-align: left;
}.collector-tools--view {
  align-items: center;
}.collector-tools-sep {
  opacity: 0.35;
  padding: 0 4px;
}.collection-actions-dropdown {
  position: relative;
}.collection-actions-menu {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 0 0;
}.collection-actions-summary::-webkit-details-marker {
  display: none;
}.collection-nav-more summary {
  list-style: none;
  cursor: pointer;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  font-weight: 800;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}.collection-nav-more summary::-webkit-details-marker {
  display: none;
}.collection-nav-more-menu {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 0 0 4px;
}.collector-extension-meta {
  font-size: 0.88rem;
  color: var(--muted);
  margin: 0;
}.card-image {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: radial-gradient(circle at 50% 18%, color-mix(in srgb, var(--gold) 10%, transparent), var(--surface-2));
  min-height: 0;
}.card-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
}.card-image.is-loading img {
  opacity: 0;
}.card-image.is-error img {
  display: none;
}.card-image-placeholder {
  display: none;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 80px;
  color: var(--muted);
  font-size: 1.4rem;
  font-weight: 900;
}.card-image.is-error .card-image-placeholder {
  display: flex;
}.card-image--grid {
  width: min(100%, 132px);
}.card-image--compact {
  width: min(100%, 88px);
}.card-image--list {
  width: 56px;
}.collector-db-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.5rem 0 1rem;
}.collector-loading-state {
  max-width: 42rem;
}.collector-load-progress {
  margin: 0.5rem 0 0;
  color: var(--muted, #6b7280);
  font-size: 0.92rem;
}.card-db-notice {
  margin: 0 0 0.75rem;
  padding: 0.55rem 0.85rem;
  border-radius: 8px;
  font-size: 0.9rem;
  line-height: 1.35;
}.card-db-notice--degraded {
  background: rgba(230, 167, 0, 0.12);
  border: 1px solid rgba(230, 167, 0, 0.35);
  color: var(--text, #e8eaed);
}.card-db-notice--updating {
  background: rgba(96, 165, 250, 0.1);
  border: 1px solid rgba(96, 165, 250, 0.3);
  color: var(--text, #e8eaed);
}.collector-debug-panel {
  margin: 0.75rem 0 1rem;
  padding: 0.75rem 1rem;
  border: 1px dashed var(--line);
  border-radius: 10px;
  font-size: 0.9rem;
}.collector-debug-panel ul {
  margin: 0.35rem 0 0;
  padding-left: 1.1rem;
}.collector-debug-warn {
  color: var(--warn, #e6a700);
  margin-top: 0.5rem;
}.card-image--detail {
  width: min(100%, 300px);
}.collection-add-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}.collection-add-grid label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-weight: 800;
}.collection-add-wide {
  grid-column: 1 / -1;
}.collection-back-btn {
  align-self: flex-start;
}.deckbuilder-collection-page-title {
  margin: 0.15rem 0 0;
  font-size: 1.35rem;
}.collection-workspace {
  display: grid;
  grid-template-columns: minmax(240px, 0.95fr) minmax(300px, 1.1fr) minmax(280px, 1.1fr);
  gap: 14px;
  align-items: start;
  min-height: 0;
}.collection-workspace .collection-card-preview {
  max-height: min(92vh, 900px);
}.collection-sidebar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.collection-sidebar-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 900;
}.collection-sidebar-desc {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.4;
  color: var(--muted);
  font-weight: 700;
}.collection-field {
  display: grid;
  gap: 6px;
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--muted);
}.collection-field input,
.collection-field select {
  min-height: 42px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-size: 0.88rem;
}.collection-db-status {
  margin: 0;
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--muted);
}.collection-search-results {
  display: grid;
  gap: 6px;
  max-height: min(52vh, 560px);
  overflow: auto;
  min-height: 120px;
}.collection-search-result {
  display: grid;
  gap: 2px;
  padding: 10px 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}.collection-search-result strong {
  font-size: 0.88rem;
  font-weight: 900;
}.collection-search-result span {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 800;
}.collection-search-result:hover,
.collection-search-result.is-selected {
  border-color: color-mix(in srgb, var(--gold) 55%, var(--line));
  background: color-mix(in srgb, var(--gold) 8%, var(--surface-2));
}.collection-card-preview.card-preview {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  box-shadow: var(--shadow);
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}.collection-preview-hint {
  margin: 0;
  font-size: 0.86rem;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.45;
}.collection-lists-intro {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
  line-height: 1.4;
}.collection-lists-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}.collection-tab {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 48px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 2px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 900;
  cursor: pointer;
  text-align: left;
  transition: border-color 0.15s ease, background 0.15s ease;
}.collection-tab:hover {
  border-color: color-mix(in srgb, var(--gold) 35%, var(--line));
}.collection-tab.is-active {
  border-color: color-mix(in srgb, var(--gold) 65%, var(--line));
  background: color-mix(in srgb, var(--gold) 12%, var(--surface-2));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--gold) 25%, transparent);
}.collection-tab-label {
  flex: 1;
  min-width: 0;
}.collection-tab-badge {
  flex-shrink: 0;
  min-width: 1.75rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--bg);
  border: 1px solid var(--line);
  font-size: 0.78rem;
  font-weight: 900;
  color: var(--gold);
  text-align: center;
}.collection-tab.is-active .collection-tab-badge {
  border-color: color-mix(in srgb, var(--gold) 45%, var(--line));
}.collection-tab-panel {
  margin-top: 10px;
}.collection-tab-panel.is-hidden {
  display: none !important;
}.collection-lists-hint {
  margin: 10px 0 0;
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.35;
}.collection-list {
  max-height: min(42vh, 480px);
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 6px;
  background: var(--surface-2);
}.collection-list--scroll {
  max-height: min(42vh, 480px);
}.collection-list--tabbed {
  max-height: min(52vh, 560px);
}.collection-row {
  padding: 6px 4px;
  border-bottom: 1px solid var(--line);
  font-size: 0.82rem;
}.collection-row:last-child {
  border-bottom: none;
}.collection-row-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}.collection-row--rich {
  border-radius: 8px;
  border-bottom: none;
  margin-bottom: 4px;
  padding: 6px;
  border: 1px solid transparent;
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
}.collection-row--rich.is-selected {
  border-color: color-mix(in srgb, var(--gold) 50%, var(--line));
  background: color-mix(in srgb, var(--gold) 10%, var(--surface-2));
}.collection-row-main {
  display: grid;
  gap: 2px;
  padding: 0;
  border: none;
  background: none;
  color: inherit;
  text-align: left;
  cursor: pointer;
  font: inherit;
}.collection-row-name {
  font-weight: 800;
  min-width: 0;
}.collection-row-type {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 800;
}.collection-row-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}.collection-row-actions--inline {
  flex-wrap: nowrap;
  gap: 4px;
  justify-content: flex-end;
}.collection-qty-btn,
.collection-wish-btn,
.collection-remove-btn {
  min-height: 30px;
  min-width: 30px;
  padding: 0 6px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
}.collection-qty {
  min-width: 1.5rem;
  text-align: center;
  font-weight: 900;
  color: var(--gold);
}.collection-remove-btn {
  margin-left: auto;
  font-size: 0.85rem;
}.collection-row-actions--inline .collection-remove-btn {
  margin-left: 0;
}.danger-text {
  border-color: color-mix(in srgb, #e43d5f 55%, var(--line));
  color: #ff9aad;
}@media (max-width: 1080px) {.collection-workspace {
    grid-template-columns: 1fr;
  }.collection-card-preview.card-preview {
    max-height: none;
  }}@media (max-width: 520px) {.collection-row-inner {
    grid-template-columns: 1fr;
    gap: 6px;
  }.collection-row-actions--inline {
    justify-content: flex-start;
    flex-wrap: wrap;
  }}.deck-share-public-url-row {
  display: grid;
  gap: 8px;
  margin-bottom: 6px;
}.deck-share-public-url-row label {
  display: grid;
  gap: 4px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--muted);
}.deck-share-public-url-row input[type="text"] {
  width: 100%;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-size: 0.8rem;
}.card-preview-collection {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
}.card-preview-compact-head + .card-preview-collection {
  margin-top: 4px;
  padding-top: 8px;
}.card-preview-collection-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
}.card-preview-collection-row--compact {
  flex-wrap: nowrap;
  gap: 6px;
  margin-top: 0;
}.card-preview-wish-inline {
  margin-left: auto;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  font-weight: 900;
  font-size: 0.82rem;
  cursor: pointer;
}.card-preview-missing-note {
  margin: 8px 0 0;
  font-size: 0.8rem;
  color: #e8a035;
}.decklist-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}.decklist-actions button {
  min-height: 44px;
  padding: 10px 12px;
}.decklist-summary strong {
  color: var(--gold);
  font-size: 1.25rem;
}.deck-zones {
  display: grid;
  grid-template-rows: repeat(3, auto);
  gap: 10px;
  min-height: 0;
  overflow: auto;
}.deck-zones section {
  display: grid;
  grid-template-rows: auto auto;
  gap: 8px;
  padding: 10px;
  min-height: 0;
  box-shadow: none;
}.deck-zones h3 {
  display: flex;
  justify-content: space-between;
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  text-transform: uppercase;
}.deck-zone-head {
  display: grid;
  gap: 8px;
}.deck-zone-head h3 {
  margin: 0;
}.deck-zone-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: flex-end;
}.deck-zone-own-batch {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  width: 100%;
  flex-basis: 100%;
}.deck-zone-own-batch button {
  min-height: 36px;
  padding: 0 10px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  font-size: 0.76rem;
  font-weight: 800;
  cursor: pointer;
  color: var(--text);
}.deck-zone-field {
  display: grid;
  gap: 4px;
  min-width: 0;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--muted);
}.deck-zone-field select {
  min-width: 0;
  max-width: 160px;
  min-height: 36px;
  font-size: 0.8rem;
}.card-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}.card-preview-actions-block {
  flex-shrink: 0;
}.card-preview-cover-block {
  padding-top: 8px;
  border-top: 1px solid var(--line);
}.card-preview-cover-btn {
  width: 100%;
  border-color: color-mix(in srgb, var(--gold) 42%, var(--line));
  font-weight: 750;
}.card-preview-description {
  flex: 0 1 auto;
  align-self: stretch;
  margin-top: 0;
  min-height: 0;
  max-height: min(46vh, 400px);
  overflow: auto;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}.card-preview-description p {
  margin: 0;
  color: var(--text);
  font-weight: 650;
  line-height: 1.45;
}.preview-zone-col {
  display: grid;
  gap: 6px;
  min-width: 0;
}.preview-zone-label {
  font-size: 0.72rem;
  font-weight: 900;
  color: var(--muted);
  text-transform: uppercase;
}.preview-zone-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}.preview-zone-buttons button {
  min-height: 40px;
  min-width: 52px;
  padding: 0 10px;
  font-weight: 900;
}.deck-card-list {
  display: grid;
  gap: 6px;
  align-content: start;
  max-height: min(360px, 46vh);
  overflow: auto;
}.deck-card-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto 34px;
  gap: 6px;
  align-items: center;
}.deck-row-own-check {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  cursor: pointer;
}.deck-row-own-check input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--gold);
}.deck-card-row button {
  min-height: 32px;
  padding: 0 8px;
}.deck-card-row span {
  color: var(--gold);
  font-weight: 900;
}.table-card-results {
  display: grid;
  gap: 6px;
  max-height: 120px;
  overflow: auto;
  overscroll-behavior: contain;
}.table-card-preview {
  display: grid;
  gap: 4px;
  max-height: 160px;
  overflow: auto;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}.table-card-preview strong {
  color: var(--text);
  font-size: 0.9rem;
}.table-card-preview span {
  color: var(--gold);
}.table-card-meta,
.card-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}.table-card-meta span,
.card-stats span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
}.table-card-keyboard {
  display: grid;
  grid-template-columns: repeat(9, minmax(0, 1fr));
  gap: 4px;
}.table-card-keyboard button {
  min-height: 30px;
  padding: 0;
  border-radius: 7px;
  font-size: 0.7rem;
}.table-card-keyboard [data-card-key="space"] {
  grid-column: span 3;
}.table-card-keyboard [data-card-key="back"],
.table-card-keyboard [data-card-key="clear"] {
  grid-column: span 2;
}.table-card-preview p {
  margin: 0;
  line-height: 1.35;
}.is-winner .player-lp-display {
  background: linear-gradient(135deg, color-mix(in srgb, var(--gold) 35%, var(--surface-2)), var(--surface-2));
}@media (min-width: 621px) and (max-width: 1024px) {.app-shell {
    padding-bottom: max(36px, env(safe-area-inset-bottom));
  }.deckbuilder-layout {
    gap: 12px;
  }.tool-choice-grid {
    gap: 12px;
  }.setup-view.layout-standard {
    max-width: 100%;
  }}@media (max-width: 980px) {.duel-view {
    grid-template-columns: 1fr;
  }.deckbuilder-layout {
    grid-template-columns: 1fr;
  }.saved-decklist-card--list,
  .decklist-library-results,
  .decklist-library-actions,
  .deck-eval-compare-tools {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }.decklist-library-actions .decklist-library-bulk {
    justify-content: flex-start;
  }.saved-decklist-cards--grid {
    grid-template-columns: 1fr !important;
  }.saved-decklist-card--grid {
    grid-template-columns: auto 1fr;
  }.saved-decklist-card--grid .saved-decklist-open {
    padding-left: 42px;
  }.saved-decklist-card--list .saved-decklist-card-actions {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }.collector-page-head,
  .collector-card-detail--split,
  .collector-card-detail:not(.collector-card-detail--split) {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }.collector-print-table--desktop {
    display: none;
  }.collector-print-cards-mobile {
    display: grid;
    gap: 10px;
    padding: 8px;
  }.collector-print-table-scroll {
    max-height: none;
  }.collector-card,
  .collector-card-grid,
  .collector-extension-grid {
    grid-template-columns: 1fr;
  }.collector-toolbar {
    position: static;
    grid-template-columns: 1fr;
  }.collection-add-grid {
    grid-template-columns: 1fr;
  }.control-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }}@media (max-width: 620px) {.app-header {
    align-items: flex-start;
    flex-direction: column;
    position: sticky;
    top: 0;
    padding-top: max(10px, env(safe-area-inset-top));
    padding-bottom: 12px;
    gap: 12px;
  }.brand-logo {
    width: 44px;
    height: 44px;
  }.header-actions button,
  .header-actions .account-button {
    min-height: 44px;
    padding-top: 0;
    padding-bottom: 0;
  }.setup-wizard-shell {
    min-width: 0;
    overflow-x: clip;
  }.setup-wizard-step {
    min-width: 0;
  }h1 {
    font-size: 2.15rem;
  }.header-actions {
    width: 100%;
  }.theme-picker,
  .header-actions .primary-action {
    flex: 1 1 160px;
  }.app-shell {
    padding-top: max(12px, env(safe-area-inset-top));
    padding-right: max(10px, env(safe-area-inset-right));
    padding-bottom: max(28px, env(safe-area-inset-bottom));
    padding-left: max(10px, env(safe-area-inset-left));
  }.setup-view,
  .duel-view {
    gap: 12px;
  }.setup-head,
  .setup-wizard-head,
  .table-topbar {
    align-items: stretch;
    flex-direction: column;
    padding: 12px;
  }.setup-wizard-actions {
    width: 100%;
    justify-content: stretch;
  }.setup-head .primary-action,
  .table-topbar .button-row {
    width: 100%;
  }.table-topbar .button-row button {
    flex: 1 1 130px;
  }.control-strip,
  .player-top,
  .profile-tools,
  .account-grid,
  .damage-grid {
    grid-template-columns: 1fr;
  }.quick-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }.quick-actions button {
    min-height: 42px;
    font-size: max(16px, 0.88rem);
  }.advanced-lp-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }.custom-lp {
    grid-template-columns: 1fr 1fr;
  }.custom-lp input {
    grid-column: 1 / -1;
  }.mobile-player-rail {
    position: sticky;
    top: 0;
    z-index: 9;
    display: flex;
    gap: 8px;
    margin: 0 -10px;
    padding: 10px;
    overflow-x: auto;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 92%, transparent);
    backdrop-filter: blur(14px);
    scroll-snap-type: x mandatory;
  }.mobile-player-chip {
    display: grid;
    gap: 2px;
    flex: 0 0 132px;
    min-height: 74px;
    padding: 8px 10px;
    text-align: left;
    scroll-snap-align: start;
  }.mobile-player-chip span,
  .mobile-player-chip small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }.mobile-player-chip strong {
    color: var(--gold);
    font-size: 1.35rem;
    line-height: 1;
  }.mobile-player-chip small {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 800;
  }.tool-panel {
    order: 3;
  }.duel-play-surface {
    order: 2;
  }.player-card {
    scroll-margin-top: 100px;
  }body:not(.duel-mode) .lp-display {
    min-height: 68px;
    padding: 10px;
  }body:not(.duel-mode) .lp-display strong {
    font-size: 2.85rem;
  }.panel-block {
    padding: 12px;
  }.panel-drawer {
    padding: 0;
  }.panel-drawer summary {
    min-height: 48px;
    padding: 10px 12px;
  }.panel-body {
    padding: 0 12px 12px;
  }.button-row button {
    flex: 1 1 120px;
  }.dice-control {
    max-width: none;
  }}@media (max-width: 900px) and (orientation: portrait) {body.setup-mode {
    height: 100dvh;
    overflow: hidden;
  }body.setup-mode .app-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    padding: max(8px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  }body.setup-mode .brand-logo {
    width: 38px;
    height: 38px;
  }body.setup-mode .app-header .eyebrow {
    display: none;
  }body.setup-mode h1 {
    overflow: hidden;
    font-size: 1.35rem;
    line-height: 1.05;
    text-overflow: ellipsis;
    white-space: nowrap;
  }body.setup-mode .header-actions {
    display: flex;
    width: auto;
    gap: 6px;
  }body.setup-mode .theme-picker {
    width: 118px;
    min-width: 0;
    flex: 0 0 118px;
  }body.setup-mode #newMatchButton {
    display: none;
  }body.setup-mode #deckBuilderButton,
  body.setup-mode #headerCollectionButton {
    display: none;
  }body.setup-mode .app-shell {
    height: calc(100dvh - 54px);
    padding-top: max(8px, env(safe-area-inset-top));
    padding-right: max(8px, env(safe-area-inset-right));
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    padding-left: max(8px, env(safe-area-inset-left));
    overflow: hidden;
  }body.setup-mode .setup-view {
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    gap: 8px;
    overflow: hidden;
  }body.setup-mode .setup-wizard-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
    flex-shrink: 0;
  }body.setup-mode .setup-wizard-progress {
    order: 2;
    justify-content: center;
    flex-wrap: wrap;
  }body.setup-mode .setup-wizard-actions {
    order: 3;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    width: 100%;
  }body.setup-mode .setup-wizard-actions .setup-nav-btn {
    grid-column: 1 / -1;
  }body.setup-mode .setup-wizard-heading {
    overflow: hidden;
    font-size: 1rem;
    text-overflow: ellipsis;
    white-space: nowrap;
  }body.setup-mode .setup-wizard-head .eyebrow {
    display: none;
  }body.setup-mode .setup-wizard-head button {
    width: auto;
    min-height: 38px;
    padding: 0 10px;
    font-size: 0.84rem;
  }body.setup-mode .setup-wizard-shell {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }body.setup-mode .setup-wizard-step {
    max-height: none;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
  }body.setup-mode .setup-duel-type-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }body.setup-mode .setup-rules-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }body.setup-mode .setup-table-svg {
    max-width: min(92vw, 440px);
  }body.setup-mode .setup-step-dot {
    width: 40px;
    height: 40px;
    min-width: 40px;
  }body.setup-mode .setup-recap-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }body.setup-mode .setup-wizard-actions .setup-nav-next,
  body.setup-mode .setup-wizard-actions #startDuelButton {
    min-height: 44px;
  }body.setup-mode .setup-duel-type-card {
    min-height: 72px;
    padding: 10px;
  }}@media (max-width: 620px) and (orientation: portrait) {body.setup-mode input,
  body.setup-mode select,
  body.setup-mode button {
    min-height: 32px;
    border-radius: 7px;
    padding: 0 5px;
    font-size: 0.76rem;
  }body.setup-mode .setup-recap-cards {
    grid-template-columns: 1fr;
  }body.setup-mode .setup-players {
    grid-template-columns: 1fr;
    gap: 8px;
    min-height: 0;
    overflow: visible;
    align-items: start;
  }body.setup-mode .setup-player-card {
    align-content: start;
    gap: 5px;
    min-height: 0;
    padding: 7px;
    overflow: hidden;
  }body.setup-mode .setup-player-head {
    gap: 5px;
  }body.setup-mode .setup-player-head .team-badge {
    max-width: 52px;
    padding: 3px 5px;
    overflow: hidden;
    font-size: 0.56rem;
    text-overflow: ellipsis;
    white-space: nowrap;
  }body.setup-mode .setup-player-head strong {
    font-size: 0.76rem;
  }body.setup-mode .player-top {
    grid-template-columns: 1fr;
    gap: 4px;
  }body.setup-mode .player-top label {
    gap: 2px;
    font-size: 0.62rem;
  }body.setup-mode .setup-shortcuts {
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: color-mix(in srgb, var(--surface-2) 62%, transparent);
  }body.setup-mode .setup-shortcuts summary {
    min-height: 28px;
    padding: 5px 7px;
    cursor: pointer;
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 900;
    list-style: none;
  }body.setup-mode .setup-shortcuts summary::-webkit-details-marker {
    display: none;
  }body.setup-mode .setup-shortcuts summary::after {
    content: "+";
    float: right;
    color: var(--text);
  }body.setup-mode .setup-shortcuts[open] summary::after {
    content: "-";
  }body.setup-mode .profile-tools {
    grid-template-columns: minmax(0, 1fr) 34px 34px 34px;
    gap: 4px;
    padding: 0 5px 5px;
  }body.setup-mode .profile-tools select {
    grid-column: 1 / -1;
  }}@media (max-width: 620px) and (orientation: portrait) {body.setup-mode .app-header {
    grid-template-columns: 1fr;
    gap: 7px;
    padding: 8px 10px 9px;
  }body.setup-mode .brand-lockup {
    width: 100%;
    gap: 9px;
  }body.setup-mode .brand-logo {
    width: 42px;
    height: 42px;
  }body.setup-mode h1 {
    max-width: 100%;
    font-size: 1.32rem;
  }body.setup-mode .header-actions {
    display: grid;
    grid-template-columns: minmax(118px, 0.8fr) minmax(0, 1.2fr);
    width: 100%;
    gap: 7px;
  }body.setup-mode .theme-picker,
  body.setup-mode .account-button {
    width: 100%;
    min-width: 0;
  }body.setup-mode .theme-picker {
    flex: none;
  }body.setup-mode .theme-picker select {
    min-height: 38px;
  }body.setup-mode .account-button {
    min-height: 52px;
    padding: 7px 9px;
  }body.setup-mode .account-badge {
    max-width: 100%;
    font-size: 0.72rem;
  }body.setup-mode .app-shell {
    height: calc(100dvh - 112px);
    padding-top: max(8px, env(safe-area-inset-top));
    padding-right: max(8px, env(safe-area-inset-right));
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    padding-left: max(8px, env(safe-area-inset-left));
  }}@media (max-width: 620px) {.home-view,
  .tools-view {
    min-height: calc(100dvh - 92px);
  }.home-panel {
    padding: 18px;
  }.home-logo {
    width: 74px;
    height: 74px;
  }.tool-choice-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }.tool-choice-card {
    min-height: 132px;
  }body.deckbuilder-mode .app-header {
    position: static;
    padding-top: max(8px, env(safe-area-inset-top));
    padding-right: max(10px, env(safe-area-inset-right));
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    padding-left: max(10px, env(safe-area-inset-left));
  }body.deckbuilder-mode .brand-logo {
    width: 40px;
    height: 40px;
  }body.deckbuilder-mode h1 {
    font-size: 1.25rem;
  }body.deckbuilder-mode .theme-picker,
  body.deckbuilder-mode #newMatchButton,
  body.deckbuilder-mode #deckBuilderButton,
  body.deckbuilder-mode #headerCollectionButton {
    display: none;
  }body.deckbuilder-mode .app-shell {
    padding-top: max(8px, env(safe-area-inset-top));
    padding-right: max(8px, env(safe-area-inset-right));
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    padding-left: max(8px, env(safe-area-inset-left));
  }.deckbuilder-head,
  .deckbuilder-head--compact {
    align-items: stretch;
    flex-direction: column;
    padding: 10px;
  }.deckbuilder-head .button-row,
  .deckbuilder-head__actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
  }.deckbuilder-head-chip {
    justify-content: center;
  }.decklist-lib-bar__right {
    width: 100%;
    margin-left: 0;
  }.decklist-library-pager--toolbar {
    width: 100%;
    margin-left: 0;
    justify-content: center;
    order: 10;
  }.deckbuilder-layout {
    gap: 8px;
  }.card-search-panel,
  .card-preview,
  .decklist-panel {
    padding: 10px;
  }.card-search-results,
  .deck-card-list {
    max-height: 32vh;
  }}.round-dots {
  display: flex;
  gap: 4px;
  margin-left: auto;
  flex: 0 0 auto;
}.round-dots span {
  width: 11px;
  height: 11px;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--surface-2);
}.round-dots .is-won {
  border-color: var(--gold);
  background: var(--gold);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--gold) 18%, transparent);
}.lp-adjust-drawer {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2) 62%, transparent);
}.lp-adjust-button {
  min-height: 40px;
  color: var(--text);
  font-weight: 900;
}.lp-adjust-drawer summary {
  min-height: 40px;
  padding: 8px 10px;
  cursor: pointer;
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 900;
  text-align: center;
  list-style: none;
}.lp-adjust-drawer summary::-webkit-details-marker {
  display: none;
}.lp-adjust-drawer .custom-lp {
  padding: 0 10px 10px;
}.lp-keypad {
  display: grid;
  gap: 6px;
  padding: 0 10px 10px;
}.lp-keypad output {
  display: grid;
  min-height: 34px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  font-size: 1.2rem;
  font-weight: 900;
}.keypad-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
}.keypad-grid button,
.keypad-actions button {
  min-height: 34px;
  padding: 0 4px;
  font-weight: 900;
}.keypad-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 5px;
}.keypad-actions .primary-action {
  grid-column: 1 / -1;
}.lp-keypad-overlay {
  position: fixed;
  inset: 0;
  z-index: 98;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(0, 0, 0, 0.58);
  transform: none;
  touch-action: manipulation;
}.lp-keypad-sheet {
  display: grid;
  gap: 10px;
  width: min(92vw, 340px);
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}.lp-keypad-sheet output {
  display: grid;
  min-height: 44px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--text);
  font-size: 1.6rem;
  font-weight: 900;
}.pictogram-button {
  display: grid;
  place-items: center;
  min-height: 48px;
  font-size: 1.5rem;
  font-weight: 900;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--line));
  background: linear-gradient(165deg, color-mix(in srgb, var(--accent-2) 16%, var(--surface-2)), var(--surface));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 8px 22px color-mix(in srgb, var(--accent) 12%, transparent);
}.pictogram-button .pictogram-svg {
  width: 1.65rem;
  height: 1.65rem;
  stroke: currentColor;
  fill: none;
}.pictogram-button .pictogram-svg circle[fill],
.pictogram-button .pictogram-svg rect[fill] {
  fill: currentColor;
}.tools-view {
  min-height: calc(100dvh - 112px);
}.tool-choice-grid {
  align-items: stretch;
}.tool-choice-card {
  min-height: 150px;
}@media (max-width: 620px) {body.home-mode,
  body.tools-mode {
    min-height: 100dvh;
    overflow: hidden;
  }body.tools-mode .app-header {
    display: grid;
    grid-template-columns: 1fr;
    gap: 7px;
    padding: calc(8px + env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  }body.tools-mode .brand-lockup {
    width: 100%;
  }body.tools-mode .header-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    width: min(100%, 420px);
    gap: 7px;
  }body.tools-mode .account-button {
    width: 100%;
    min-height: 44px;
  }body.tools-mode .theme-picker,
  body.tools-mode #deckBuilderButton,
  body.tools-mode #headerCollectionButton,
  body.tools-mode #newMatchButton {
    display: none;
  }body.tools-mode .app-shell {
    height: calc(100dvh - 118px);
    padding-top: max(8px, env(safe-area-inset-top));
    padding-right: max(8px, env(safe-area-inset-right));
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    padding-left: max(8px, env(safe-area-inset-left));
    overflow: hidden;
  }.home-view {
    min-height: 0;
    height: auto;
  }.tools-view {
    min-height: 0;
    height: 100%;
  }.home-panel {
    gap: 8px;
    padding: 14px;
  }.tool-choice-grid {
    gap: 8px;
    width: 100%;
  }.tool-choice-card {
    min-height: 118px;
    padding: 14px;
  }.tool-choice-card span {
    font-size: 1.8rem;
  }.tool-choice-card strong {
    font-size: 1.15rem;
  }.tool-choice-card small {
    font-size: 0.78rem;
  }}@media (max-width: 620px) {body.deckbuilder-mode {
    min-height: 100dvh;
    overflow: auto;
  }body.deckbuilder-mode .app-header {
    display: grid;
    grid-template-columns: 1fr;
    gap: 7px;
    padding: calc(8px + env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  }body.deckbuilder-mode .brand-lockup {
    width: 100%;
  }body.deckbuilder-mode .header-actions {
    display: grid;
    grid-template-columns: minmax(118px, 0.8fr) minmax(0, 1.2fr);
    width: 100%;
    gap: 7px;
  }body.deckbuilder-mode .account-button {
    min-height: 44px;
    width: 100%;
  }body.deckbuilder-mode .theme-picker {
    display: grid;
  }body.deckbuilder-mode #newMatchButton,
  body.deckbuilder-mode #deckBuilderButton,
  body.deckbuilder-mode #headerCollectionButton {
    display: none;
  }}@media (max-width: 768px) {.lp-keypad-sheet .keypad-grid button,
  .lp-keypad-sheet .keypad-actions button {
    min-height: 48px;
    font-size: 1.08rem;
  }.lp-keypad-sheet output {
    min-height: 54px;
    font-size: 1.75rem;
  }}@keyframes chance-coin-flip {
  0% {
    transform: rotateY(0deg);
  }
  100% {
    transform: rotateY(720deg);
  }
}@keyframes chance-dice-tumble {
  0%,
  100% {
    transform: rotate(0deg) scale(1);
  }
  30% {
    transform: rotate(-22deg) scale(1.06);
  }
  65% {
    transform: rotate(24deg) scale(1.04);
  }
}@keyframes lp-flash-up {
  0% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent-2) 0%, transparent);
  }
  40% {
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--accent-2) 35%, transparent);
  }
  100% {
    box-shadow: 0 0 0 0 transparent;
  }
}@keyframes lp-flash-down {
  0% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--danger) 0%, transparent);
  }
  40% {
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--danger) 32%, transparent);
  }
  100% {
    box-shadow: 0 0 0 0 transparent;
  }
}.random-block.chance-anim-coin #randomResult {
  display: inline-block;
  transform-style: preserve-3d;
  perspective: 120px;
  animation: chance-coin-flip 0.58s ease-in-out;
}#diceButton.chance-anim-dice {
  animation: chance-dice-tumble 0.45s ease-in-out;
}.player-card.lp-flash-up .player-lp-display {
  animation: lp-flash-up 0.58s ease-out;
}.player-card.lp-flash-down .player-lp-display {
  animation: lp-flash-down 0.58s ease-out;
}@media (prefers-reduced-motion: reduce) {.random-block.chance-anim-coin #randomResult,
  #diceButton.chance-anim-dice,
  .player-card.lp-flash-up .player-lp-display,
  .player-card.lp-flash-down .player-lp-display {
    animation: none !important;
  }}:root {
  --ui-touch-target: 44px;
  --ui-btn-radius: 10px;
}.home-panel .button-row button,
.tool-choice-grid .tool-choice-card,
.header-actions > button:not(.icon-button):not(.account-button),
.account-view .account-button-row button,
.account-view .account-profile-url-row button,
.dialog-actions button:not(.icon-button),
.decklist-actions button,
.table-topbar .button-row button,
.setup-wizard-actions .setup-nav-btn,
.setup-wizard-actions #setupDeckBuilderButton {
  min-height: var(--ui-touch-target);
  border-radius: var(--ui-btn-radius);
}@media (max-width: 520px) {.header-actions {
    flex-wrap: wrap;
    gap: 8px;
  }}.chance-overlay {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: grid;
  place-items: center;
  padding: max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom))
    max(16px, env(safe-area-inset-left));
  pointer-events: none;
}.chance-overlay:not(.is-hidden) {
  pointer-events: auto;
}.chance-overlay.is-hidden {
  visibility: hidden;
  opacity: 0;
}.chance-overlay-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 5, 10, 0.72);
  backdrop-filter: blur(8px);
}.chance-overlay-card {
  position: relative;
  z-index: 1;
  min-width: min(92vw, 320px);
  padding: 28px 22px 22px;
  border-radius: 18px;
  border: 1px solid var(--rim);
  background: linear-gradient(165deg, var(--surface-2), var(--surface));
  box-shadow: var(--shadow);
  text-align: center;
}.chance-anim {
  display: grid;
  place-items: center;
  min-height: 168px;
}.chance-anim.is-hidden {
  display: none;
}.coin-3d-wrap {
  perspective: 520px;
  width: 140px;
  height: 140px;
  margin: 0 auto;
}.coin-inner {
  position: relative;
  width: 120px;
  height: 120px;
  margin: 10px auto;
  transform-style: preserve-3d;
  transition: transform 1.05s cubic-bezier(0.18, 0.82, 0.22, 1);
}.coin-face {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  border-radius: 50%;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  backface-visibility: hidden;
  border: 3px solid var(--gold);
  box-shadow:
    inset 0 3px 14px rgba(255, 255, 255, 0.18),
    0 14px 34px rgba(0, 0, 0, 0.45);
}.coin-face-pile {
  background: radial-gradient(circle at 32% 28%, #f2f4fb, #7a8496);
  color: #1a1f28;
  transform: rotateY(0deg) translateZ(5px);
}.coin-face-face {
  background: radial-gradient(circle at 32% 28%, #ffeaa6, #c9972e);
  color: #2b1f08;
  transform: rotateY(180deg) translateZ(5px);
}.coin-inner.is-pile {
  transform: rotateY(720deg);
}.coin-inner.is-face {
  transform: rotateY(900deg);
}.dice-visual-mount {
  display: grid;
  place-items: center;
  min-height: 140px;
}.dice-faces-hint {
  margin: 4px 0 0;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
}.dice-cube-scene {
  perspective: 560px;
  width: 112px;
  height: 112px;
}.dice-cube {
  width: 96px;
  height: 96px;
  margin: 8px auto;
  position: relative;
  transform-style: preserve-3d;
  animation: dice-cube-spin 1.05s cubic-bezier(0.25, 0.82, 0.25, 1) forwards;
}.dface {
  position: absolute;
  width: 96px;
  height: 96px;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.65rem;
  border: 2px solid var(--rim);
  border-radius: 12px;
  background: linear-gradient(165deg, var(--surface-2), var(--surface));
  color: var(--text);
  backface-visibility: hidden;
}.dface:nth-child(1) {
  transform: rotateY(0deg) translateZ(48px);
}.dface:nth-child(2) {
  transform: rotateY(180deg) translateZ(48px);
}.dface:nth-child(3) {
  transform: rotateY(90deg) translateZ(48px);
}.dface:nth-child(4) {
  transform: rotateY(-90deg) translateZ(48px);
}.dface:nth-child(5) {
  transform: rotateX(90deg) translateZ(48px);
}.dface:nth-child(6) {
  transform: rotateX(-90deg) translateZ(48px);
}@keyframes dice-cube-spin {
  0% {
    transform: rotateX(-18deg) rotateY(12deg);
  }
  100% {
    transform: rotateX(432deg) rotateY(540deg);
  }
}.dice-poly {
  position: relative;
  width: 108px;
  height: 108px;
  margin: 6px auto;
  border-radius: 22px;
  border: 2px solid var(--rim);
  background: linear-gradient(145deg, color-mix(in srgb, var(--accent) 22%, var(--surface)), var(--surface-2));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 16px 36px rgba(0, 0, 0, 0.38);
  animation: dice-poly-tumble 1.05s cubic-bezier(0.25, 0.85, 0.3, 1) forwards;
}.dice-faces-hint.is-hidden {
  display: none;
}.dice-face-card {
  width: 112px;
  height: 112px;
  margin: 0 auto;
  border-radius: 18px;
  border: 2px solid var(--rim);
  background: linear-gradient(165deg, var(--surface-2), var(--surface));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 16px 36px rgba(0, 0, 0, 0.38);
  animation: dice-face-pop 1.05s cubic-bezier(0.25, 0.82, 0.25, 1) forwards;
}.dice-face-card__inner {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  padding: 10px;
  box-sizing: border-box;
}.dice-face-num {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 9vw, 3rem);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--accent-2);
  text-shadow: 0 0 24px color-mix(in srgb, var(--accent) 35%, transparent);
  line-height: 1;
}.dice-poly-inner {
  position: absolute;
  inset: 8px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  border: 1px dashed color-mix(in srgb, var(--accent-2) 45%, var(--line));
  opacity: 0.65;
}@keyframes dice-face-pop {
  0% {
    transform: rotate(-12deg) scale(0.9);
  }
  55% {
    transform: rotate(8deg) scale(1.06);
  }
  100% {
    transform: rotate(0deg) scale(1);
  }
}@keyframes dice-poly-tumble {
  0% {
    transform: rotate(-14deg) scale(0.94);
  }
  40% {
    transform: rotate(10deg) scale(1.05) rotate(180deg);
  }
  100% {
    transform: rotate(0deg) scale(1);
  }
}.dice-big-num {
  display: none;
  margin-top: 10px;
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 10vw, 3.2rem);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--accent-2);
  text-shadow: 0 0 28px color-mix(in srgb, var(--accent) 35%, transparent);
}.chance-overlay-caption {
  margin: 14px 0 0;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.25rem;
}@media (prefers-reduced-motion: reduce) {.coin-inner {
    transition: none;
  }.dice-cube,
  .dice-poly {
    animation: none !important;
  }}.storage-warning-banner {
  position: fixed;
  top: max(10px, env(safe-area-inset-top));
  left: 50%;
  z-index: 350;
  width: min(540px, calc(100vw - 24px));
  transform: translateX(-50%);
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--rim);
  background: linear-gradient(165deg, var(--surface-2), var(--surface));
  box-shadow: var(--shadow);
}.storage-warning-inner {
  display: grid;
  gap: 8px;
}.storage-warning-detail {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.38;
}.storage-warning-dismiss {
  justify-self: start;
  min-height: 38px;
}.app-update-banner {
  position: fixed;
  top: max(10px, env(safe-area-inset-top));
  left: 50%;
  z-index: 720;
  width: min(540px, calc(100vw - 24px));
  max-height: min(82dvh, calc(100vh - 20px));
  transform: translateX(-50%);
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 55%, var(--line));
  background: linear-gradient(165deg, color-mix(in srgb, var(--surface-2) 88%, var(--accent-2)), var(--surface));
  box-shadow: var(--shadow);
  overflow: auto;
  overscroll-behavior: contain;
}.app-update-inner {
  display: grid;
  gap: 10px;
}.app-update-detail {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.42;
}.app-update-actions {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}@media (max-height: 360px), (max-width: 420px) {.app-update-banner {
    top: max(4px, env(safe-area-inset-top));
    width: min(96vw, 420px);
    padding: 8px;
  }.app-update-inner {
    gap: 6px;
  }.app-update-detail {
    font-size: 0.76rem;
    line-height: 1.25;
  }.app-update-actions button {
    flex: 1 1 120px;
    min-height: 34px;
    padding-inline: 8px;
    font-size: 0.76rem;
  }}.app-build-stamp {
  margin: 2px 0 0;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--muted);
  opacity: 0.92;
}.duel-tool-backdrop {
  position: fixed;
  inset: 0;
  z-index: 4;
  margin: 0;
  padding: 0;
  border: none;
  background: rgba(2, 6, 16, 0.38);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}#duelToolModalRoot.duel-tool-modal-root {
  position: fixed;
  inset: 0;
  z-index: 95;
  display: block;
  margin: 0;
  padding: 0;
  pointer-events: none;
}#duelToolModalRoot.duel-tool-modal-root:not(.is-hidden) {
  pointer-events: auto;
}#duelToolModalRoot .duel-tool-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
}.duel-tool-modal-frame {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: max(10px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right))
    max(68px, calc(env(safe-area-inset-bottom) + 52px)) max(12px, env(safe-area-inset-left));
  box-sizing: border-box;
  pointer-events: none;
}.duel-tool-modal-sheets {
  pointer-events: auto;
  width: 100%;
  max-width: min(calc(100vw - 24px), 560px);
  display: flex;
  justify-content: center;
  align-items: stretch;
}.duel-panel-body-head {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin: 0 0 2px;
}.duel-panel-close {
  position: relative;
  z-index: 2;
  touch-action: manipulation;
  min-width: 40px;
  min-height: 36px;
  padding: 0 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 800;
  cursor: pointer;
  background: var(--surface-2);
  color: var(--text);
}.account-backup-row {
  margin-top: 8px;
}.account-backup-hint {
  margin: 10px 0 0;
  font-size: 0.86rem;
  color: var(--muted);
  max-width: 52ch;
  line-height: 1.45;
}.account-theme-status {
  margin: 8px 0 0;
  min-height: 1.2em;
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--accent-2);
}.account-danger-zone {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid color-mix(in srgb, var(--danger, #c44) 35%, var(--line));
}.account-danger-title {
  margin: 0 0 8px;
  font-size: 1rem;
  color: color-mix(in srgb, var(--danger, #e85) 85%, var(--ink));
}.danger-button {
  border-color: color-mix(in srgb, var(--danger, #c44) 70%, var(--line));
  background: color-mix(in srgb, var(--danger, #a33) 18%, var(--surface));
  color: color-mix(in srgb, var(--danger, #f66) 80%, var(--ink));
  font-weight: 900;
}.danger-button:hover:not(:disabled),
.danger-button:focus-visible:not(:disabled) {
  background: color-mix(in srgb, var(--danger, #c44) 28%, var(--surface));
}.danger-button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}.reset-user-data-dialog .reset-user-data-copy {
  margin: 0 0 14px;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.5;
}.reset-user-data-confirm-label {
  display: grid;
  gap: 8px;
  font-weight: 800;
}.reset-user-data-confirm-label input {
  font-family: var(--font-mono, ui-monospace, monospace);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}.duel-tool-drawers {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 0;
}.duel-tool-tabstrip {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 4px;
  padding: 2px 0 4px;
  margin: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}.duel-tool-tab {
  flex: 0 0 auto;
  min-height: 40px;
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
}.duel-tool-tab.is-active {
  border-color: color-mix(in srgb, var(--accent-2) 65%, var(--line));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-2) 35%, transparent);
  color: var(--accent-2);
}.duel-elimination-summary {
  margin: 0 0 16px;
  font-size: 1rem;
  line-height: 1.45;
  color: var(--text);
}.duel-end-hint {
  margin: 0 0 14px;
  font-size: 0.82rem;
  line-height: 1.4;
  color: var(--muted);
}.duel-elimination-actions,
.duel-end-actions {
  flex-wrap: wrap;
}.duel-end-actions .primary-action {
  flex: 1 1 220px;
}.player-actions-overlay {
  position: fixed;
  inset: 0;
  z-index: 94;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  box-sizing: border-box;
  pointer-events: none;
}.player-actions-overlay:not(.is-hidden) {
  pointer-events: auto;
}.player-lp-tools-overlay {
  position: fixed;
  inset: 0;
  z-index: 96;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  box-sizing: border-box;
  pointer-events: none;
}.player-lp-tools-overlay:not(.is-hidden) {
  pointer-events: auto;
}.player-lp-tools-subtitle {
  margin: 0 0 12px;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  color: var(--text);
  font-family: var(--font-numeric, ui-monospace, system-ui, sans-serif);
}.player-lp-tools-actions button#playerLpToolsOpenKeypad {
  border-color: color-mix(in srgb, var(--accent-2) 55%, var(--line));
  background: linear-gradient(165deg, color-mix(in srgb, var(--accent-2) 18%, var(--surface-2)), var(--surface-2));
  color: var(--accent-2);
}.player-actions-backdrop {
  position: absolute;
  inset: 0;
  margin: 0;
  padding: 0;
  border: none;
  background: rgba(2, 6, 16, 0.55);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}.player-actions-sheet {
  position: relative;
  z-index: 1;
  width: min(100%, 440px);
  padding: 12px 14px 14px;
  border-radius: 14px 14px 0 0;
  border: 1px solid var(--line);
  border-bottom: none;
  background: var(--surface);
  box-shadow: 0 -12px 40px rgba(0, 0, 0, 0.45);
  box-sizing: border-box;
  pointer-events: auto;
}.player-actions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 4px;
}.player-actions-grid button {
  min-height: 44px;
  padding: 0 8px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
  touch-action: manipulation;
}.player-actions-grid button:active:not(:disabled) {
  transform: translateY(1px);
}:root {
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --tap-size: 44px;
  /** Largeurs par type de page (desktop) — utiliser les classes .layout-* sur les sections */
  --layout-page-max: 1180px;
  --layout-standard-max: 1360px;
  --layout-data-max: 1680px;
  --layout-table-max: 1800px;
  --page-pad: max(clamp(14px, 3vw, 34px), env(safe-area-inset-left));
  --page-max: var(--layout-page-max);
}.layout-page,
.layout-standard,
.layout-data,
.layout-table {
  width: 100%;
  max-width: min(var(--_layout-capped, 100%), 100%);
  margin-inline: auto;
  box-sizing: border-box;
}.layout-page {
  --_layout-capped: var(--layout-page-max);
}.layout-standard {
  --_layout-capped: var(--layout-standard-max);
}.layout-data {
  --_layout-capped: var(--layout-data-max);
}.layout-table {
  --_layout-capped: var(--layout-table-max);
}:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--gold) 82%, #fff);
  outline-offset: 3px;
}button,
input,
select,
textarea {
  border-radius: var(--radius-sm);
}textarea {
  width: 100%;
  min-height: 96px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font: inherit;
  resize: vertical;
}body:not(.duel-mode) button,
body:not(.duel-mode) input,
body:not(.duel-mode) select {
  min-height: var(--tap-size);
}button:disabled,
button[aria-disabled="true"],
input:disabled,
select:disabled,
textarea:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}.app-header {
  gap: clamp(10px, 2vw, 20px);
}.header-actions {
  align-items: center;
  justify-content: flex-end;
}.app-nav-button {
  border-color: color-mix(in srgb, var(--accent-2) 28%, var(--line));
}.app-nav-button.is-active,
.app-nav-button[aria-current="page"] {
  border-color: color-mix(in srgb, var(--gold) 72%, var(--line));
  background: linear-gradient(160deg, color-mix(in srgb, var(--gold) 16%, var(--surface-2)), var(--surface-2));
  color: var(--gold);
  box-shadow: inset 0 1px 0 var(--rim-light), 0 8px 22px color-mix(in srgb, var(--gold) 12%, transparent);
}body:not(.duel-mode) .app-shell {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}.home-panel,
.tools-head,
.tool-choice-card,
.setup-wizard-head,
.setup-recap-panel,
.deckbuilder-head,
.deckbuilder-choice-panel,
.account-pane,
.public-profile-panel,
.export-dialog form {
  border-radius: var(--radius-lg);
}.tool-choice-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}.tool-choice-card {
  min-height: 150px;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}.tool-choice-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--gold) 62%, var(--line));
}.empty-state {
  margin: 0;
  padding: 14px 16px;
  border: 1px dashed color-mix(in srgb, var(--accent-2) 34%, var(--line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-2) 72%, transparent);
  color: var(--muted);
  font-weight: 800;
  line-height: 1.42;
}.network-status-banner {
  position: fixed;
  right: max(16px, env(safe-area-inset-right));
  bottom: max(16px, env(safe-area-inset-bottom));
  z-index: 35;
  width: min(420px, calc(100vw - 32px));
  padding: 14px 16px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 42%, var(--line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  box-shadow: var(--shadow);
}.network-status-banner strong {
  display: block;
  margin-bottom: 4px;
  color: var(--gold);
}.network-status-banner p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1.35;
}body:not(.duel-mode) dialog.export-dialog {
  max-width: min(960px, calc(100vw - 24px));
  max-height: min(760px, calc(100dvh - 24px));
  padding: 0;
  overflow: hidden;
}body:not(.duel-mode) dialog.export-dialog form {
  max-height: inherit;
  overflow: auto;
  overscroll-behavior: contain;
}.dialog-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  backdrop-filter: blur(12px);
}.card-search-results,
.collection-card-results,
.decklist-library-list,
.deck-card-list,
.collection-list {
  scrollbar-gutter: stable both-edges;
  overscroll-behavior: contain;
}@media (max-width: 860px) {.app-header {
    position: static;
    flex-direction: column;
    align-items: stretch;
    padding: max(10px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) 10px max(12px, env(safe-area-inset-left));
  }.brand-lockup {
    justify-content: space-between;
  }.brand-lockup h1 {
    font-size: clamp(1.45rem, 8vw, 2rem);
    line-height: 1;
  }.app-build-stamp {
    font-size: 0.72rem;
  }.brand-logo {
    width: 42px;
    height: 42px;
  }.header-actions {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 6px;
    max-width: 100%;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
  }.header-actions > button,
  .header-actions .account-button {
    flex: 0 0 auto;
    min-width: max-content;
    padding-inline: 8px;
    font-size: 0.82rem;
  }.nav-actions {
    flex: 0 0 auto;
    display: flex;
  }.nav-actions .icon-button {
    width: 44px;
  }.home-view,
  .tools-view {
    min-height: auto;
  }.home-panel {
    width: 100%;
    padding: 20px;
  }.setup-wizard-head,
  .deckbuilder-head,
  .account-page-header {
    align-items: stretch;
  }.setup-wizard-progress {
    width: 100%;
    justify-content: space-between;
  }.setup-wizard-actions,
  .decklist-actions,
  .account-button-row,
  .deck-builder-public-actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    width: 100%;
  }}@media (max-width: 620px) {body:not(.duel-mode) .app-shell {
    padding: 12px max(10px, env(safe-area-inset-right)) max(28px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
  }.account-button {
    justify-items: center;
    text-align: center;
  }.account-badge {
    max-width: 100%;
    font-size: 0.64rem;
  }.tool-choice-card {
    min-height: 118px;
  }.deckbuilder-head .button-row,
  .decklist-actions,
  .card-preview-actions,
  .preview-zone-buttons,
  .deck-share-grid,
  .collection-share-actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
    width: 100%;
  }.deck-card-row {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }}.dice-pips {
  --pip-size: 12px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
  width: 64px;
  height: 64px;
  padding: 10px;
}.dice-pips i {
  align-self: center;
  justify-self: center;
  width: var(--pip-size);
  height: var(--pip-size);
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 10px currentColor;
}.dice-pips .pip-pos-1 { grid-area: 1 / 1; }.dice-pips .pip-pos-2 { grid-area: 1 / 2; }.dice-pips .pip-pos-3 { grid-area: 1 / 3; }.dice-pips .pip-pos-4 { grid-area: 2 / 1; }.dice-pips .pip-pos-5 { grid-area: 2 / 2; }.dice-pips .pip-pos-6 { grid-area: 2 / 3; }.dice-pips .pip-pos-7 { grid-area: 3 / 1; }.dice-pips .pip-pos-8 { grid-area: 3 / 2; }.dice-pips .pip-pos-9 { grid-area: 3 / 3; }.table-card-preview-inner {
  display: grid;
  grid-template-columns: minmax(54px, 78px) minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}.table-card-preview-inner img {
  width: 100%;
  border-radius: 8px;
}