:root{
  --db-gap: 14px;
  --db-radius: 14px;

  /* card sizing (close to what you wanted: not tiny, not huge) */
  --cardW: clamp(56px, 3.4vw, 72px);
  --cardH: calc(var(--cardW) * 1.45);

  --badgeSize: 18px;

  /* Neon / glow system */
  --glow-cyan: rgba(0, 179, 255, .55);
  --glow-violet: rgba(124, 77, 255, .55);
  --glow-warm: rgba(255, 206, 66, .45);
  --glow-good: rgba(35, 209, 125, .45);
  --glow-bad: rgba(255, 59, 59, .45);

  --ring: 0 0 0 1px rgba(0,179,255,.22) inset;
  --shadow-soft: 0 12px 30px rgba(0,0,0,.35);
  --shadow-strong: 0 20px 60px rgba(0,0,0,.55);

  --trans-fast: 120ms cubic-bezier(.2,.8,.2,1);
  --trans-med: 180ms cubic-bezier(.2,.8,.2,1);
}

.app.three-cols{
  width: min(1450px, calc(100% - 24px));
  margin: 18px auto 30px;
  display: grid;
  grid-template-columns: 330px 1fr 330px;
  gap: var(--db-gap);
  align-items: start;
}

@media (max-width: 1200px){
  .app.three-cols{ grid-template-columns: 310px 1fr 310px; }
}
@media (max-width: 980px){
  .app.three-cols{ grid-template-columns: 1fr; }
}

/* =========================
   PANELS (glassy + depth)
========================= */
.panel{
  position: relative;
  background:
    radial-gradient(900px 250px at 10% 0%, rgba(0,179,255,.12), transparent 55%),
    radial-gradient(900px 250px at 90% 0%, rgba(124,77,255,.12), transparent 55%),
    rgba(8, 16, 28, 0.58);
  border: 1px solid rgba(0, 179, 255, 0.18);
  border-radius: var(--db-radius);
  box-shadow: var(--ring), var(--shadow-soft);
  padding: 12px;
  backdrop-filter: blur(10px);
  transition: transform var(--trans-med), box-shadow var(--trans-med), border-color var(--trans-med);
}

.panel:hover{
  border-color: rgba(0,179,255,.28);
  box-shadow: var(--ring), 0 14px 36px rgba(0,0,0,.42);
  transform: translateY(-1px);
}

.panel-title{
  margin: 0 0 10px;
  font-family: Orbitron, system-ui, sans-serif;
  font-size: 14px;
  letter-spacing: .5px;
  opacity: .98;
  text-shadow: 0 0 18px rgba(0,179,255,.18);
}

.panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 8px;
}

.hint{
  margin-top: 8px;
  font-size: 12px;
  opacity: .75;
}

/* =========================
   FIELDS + INPUTS
========================= */
.field{
  display:flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 10px;
}
.field > span{
  font-size: 12px;
  opacity: .84;
}

.field input,
.field select,
.select-wide{
  width: 100%;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.14);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(0,0,0,0.24));
  color: #eaf6ff;
  padding: 0 10px;
  outline: none;
  box-shadow: 0 0 0 0 rgba(0,179,255,0);
  transition: border-color var(--trans-fast), box-shadow var(--trans-fast), transform var(--trans-fast);
}

.field input:focus,
.field select:focus,
.select-wide:focus{
  border-color: rgba(0,179,255,.38);
  box-shadow:
    0 0 0 3px rgba(0,179,255,.16),
    0 0 24px rgba(0,179,255,.12);
  transform: translateY(-1px);
}

.row{
  display:flex;
  gap: 8px;
  align-items:center;
  margin-bottom: 10px;
}
.row2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}

/* =========================
   BUTTONS (real glow states)
========================= */
.btn{
  height: 34px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(0, 179, 255, 0.24);
  background:
    linear-gradient(180deg, rgba(0,179,255,0.18), rgba(124,77,255,0.10));
  color: #eaf6ff;
  cursor: pointer;
  font-weight: 700;
  letter-spacing: .2px;

  box-shadow:
    0 0 0 0 rgba(0,179,255,0),
    0 6px 16px rgba(0,0,0,.25);

  transition:
    transform var(--trans-fast),
    filter var(--trans-fast),
    border-color var(--trans-fast),
    box-shadow var(--trans-fast);
}

.btn:hover{
  filter: brightness(1.10);
  transform: translateY(-1px);
  border-color: rgba(0,179,255,.38);
  box-shadow:
    0 0 16px rgba(0,179,255,.16),
    0 10px 22px rgba(0,0,0,.28);
}

.btn:active{
  transform: translateY(0px) scale(.99);
  filter: brightness(1.06);
}

.btn:focus-visible{
  outline: none;
  border-color: rgba(0,179,255,.52);
  box-shadow:
    0 0 0 3px rgba(0,179,255,.20),
    0 0 26px rgba(0,179,255,.20),
    0 12px 26px rgba(0,0,0,.28);
}

/* “Selected / active” glow (JS adds .is-active) */
.btn.is-active,
.btn[aria-pressed="true"]{
  border-color: rgba(0,179,255,.62);
  box-shadow:
    0 0 0 3px rgba(124,77,255,.18),
    0 0 30px rgba(0,179,255,.22),
    0 0 40px rgba(124,77,255,.18),
    0 14px 30px rgba(0,0,0,.34);
  transform: translateY(-1px);
}

.btn.ghost{
  background: rgba(0,0,0,0.22);
  border-color: rgba(255,255,255,0.16);
  box-shadow: 0 6px 16px rgba(0,0,0,.22);
}
.btn.ghost:hover{
  border-color: rgba(255,255,255,0.22);
  box-shadow:
    0 0 18px rgba(255,255,255,.08),
    0 10px 22px rgba(0,0,0,.28);
}

.btn.tiny{
  height: 30px;
  border-radius: 10px;
  padding: 0 10px;
  font-size: 12px;
}
.btn.w-full{ width: 100%; }
.btn.wide{ width: 100%; }

/* =========================
   Toggle (auto check glow)
========================= */
.toggle{
  display:flex;
  align-items:center;
  gap: 8px;
  user-select:none;
  font-size: 12px;
  opacity: .95;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.14);
  transition: border-color var(--trans-fast), box-shadow var(--trans-fast);
}

.toggle input{ transform: translateY(1px); }

.toggle input:focus-visible{
  outline: none;
}

.toggle:has(input:checked){
  border-color: rgba(35,209,125,.40);
  box-shadow:
    0 0 0 3px rgba(35,209,125,.14),
    0 0 24px rgba(35,209,125,.10);
}

/* =========================
   Card Preview (more premium)
========================= */
.preview{
  display:grid;
  grid-template-columns: 118px 1fr;
  gap: 12px;
  align-items: start;
}

.preview .pic{
  width: 118px;
  height: calc(118px * 1.45);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.16);
  background:
    radial-gradient(500px 160px at 50% 0%, rgba(0,179,255,.16), transparent 55%),
    rgba(0,0,0,0.22);
  overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(124,77,255,.10) inset,
    0 12px 30px rgba(0,0,0,.38);
}
.preview .pic img{
  width:100%;
  height:100%;
  object-fit: cover;
}

.preview .meta{
  padding-top: 2px;
}

.preview .meta .nm{
  font-weight: 900;
  margin-bottom: 4px;
  letter-spacing: .2px;
  text-shadow: 0 0 20px rgba(0,179,255,.14);
}
.preview .meta .tx{
  font-size: 12px;
  opacity: .86;
  margin-bottom: 4px;
}
.preview .meta .desc{
  font-size: 12px;
  line-height: 1.32;
  max-height: 210px;
  overflow:auto;
  opacity: .94;
  padding-right: 6px;
}

/* nicer scrollbars */
.preview .meta .desc::-webkit-scrollbar,
.results-list::-webkit-scrollbar{
  width: 10px;
}
.preview .meta .desc::-webkit-scrollbar-thumb,
.results-list::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.14);
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,.18);
}
.preview .meta .desc::-webkit-scrollbar-thumb:hover,
.results-list::-webkit-scrollbar-thumb:hover{
  background: rgba(255,255,255,.20);
}

/* =========================
   TOPBAR + KEY + ISSUES
========================= */
.topbar{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 12px;
}

.topbar-left{
  display:flex;
  flex-direction: column;
  gap: 8px;
}

.topbar-title{
  font-family: Orbitron, system-ui, sans-serif;
  font-size: 14px;
  letter-spacing: .5px;
  text-shadow: 0 0 18px rgba(0,179,255,.18);
}

.key{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items:center;
}

/* Each legend row item */
.keyItem{
  display:flex;
  align-items:center;
  gap: 6px;
  font-size: 12px;
  opacity: .96;
  line-height: 1;
}

/* IMPORTANT FIX:
   Deck tiles need .badge to be absolute.
   The legend/key needs badges to be inline.
*/
.key .badge,
.keyline .badge{
  position: static !important;
  top: auto !important;
  left: auto !important;
  width: var(--badgeSize) !important;
  height: var(--badgeSize) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 7px !important;
  margin: 0 !important;
}

.topbar-actions{
  display:flex;
  gap: 8px;
  align-items:center;
  justify-content:flex-end;
  flex-wrap: wrap;
}

.issues{
  min-height: 64px;
}
.issues .ok{
  color: #8cffc2;
  font-weight: 900;
  text-shadow: 0 0 18px rgba(35,209,125,.18);
}
.issues .bad{
  color: #ff7a7a;
  font-weight: 900;
  text-shadow: 0 0 18px rgba(255,59,59,.18);
}
.issues ul{
  margin: 8px 0 0;
  padding-left: 18px;
}
.issues li{ margin: 4px 0; }

/* =========================
   CLEAN UP: duplicate Dueltainer Check bars
   - Keep topbar legend (HTML)
   - Hide issuesPanel legend injected by JS (.keyline)
   - Visually merge topbar + issues panel into one stacked bar
========================= */
#issuesPanel .keyline{
  display: none !important;
}

.panel.topbar{
  margin-bottom: 0;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}

#issuesPanel.panel.issues{
  margin-top: -8px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-top: none;
  padding-top: 10px;
}

/* =========================
   ZONES + GRIDS (more “arena”)
========================= */
.zone{
  margin-top: var(--db-gap);
}
.zone-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.zone-head h2{
  margin: 0;
  font-size: 18px;
  font-family: Orbitron, system-ui, sans-serif;
  letter-spacing: .3px;
}
.zone-head .count{
  color: #00b3ff;
  margin-left: 6px;
  text-shadow: 0 0 18px rgba(0,179,255,.22);
}
.capsule{
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.18);
  opacity: .95;
}

.deck-grid{
  display:grid;
  grid-template-columns: repeat(10, var(--cardW));
  gap: 8px;
  padding: 12px;
  border-radius: var(--db-radius);
  border: 1px dashed rgba(255,255,255,0.20);
  background:
    radial-gradient(900px 200px at 50% 0%, rgba(0,179,255,.08), transparent 62%),
    radial-gradient(900px 200px at 50% 100%, rgba(124,77,255,.08), transparent 62%),
    rgba(0,0,0,0.10);
  min-height: calc((var(--cardH) + 8px) * 2);
  box-shadow: 0 0 0 1px rgba(124,77,255,.08) inset;
}

.deck-main{
  min-height: calc((var(--cardH) + 8px) * 6);
}
.deck-extra{
  min-height: calc((var(--cardH) + 8px) * 2);
}

/* =========================
   Card tile (selected glow!)
========================= */
.card-tile{
  width: var(--cardW);
  height: var(--cardH);
  position: relative;
  border-radius: 12px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.25);
  cursor: pointer;

  transform: translateZ(0);
  transition:
    transform var(--trans-fast),
    border-color var(--trans-fast),
    box-shadow var(--trans-fast),
    filter var(--trans-fast);
}

.card-tile img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.card-tile:hover{
  border-color: rgba(0,179,255,.34);
  box-shadow:
    0 0 0 3px rgba(0,179,255,.10),
    0 0 20px rgba(0,179,255,.10);
  transform: translateY(-2px);
}

.card-tile:active{
  transform: translateY(-1px) scale(.99);
}

/* Selected (JS toggles .selected) */
.card-tile.selected{
  border-color: rgba(0,179,255,.70);
  box-shadow:
    0 0 0 3px rgba(0,179,255,.18),
    0 0 26px rgba(0,179,255,.20),
    0 0 34px rgba(124,77,255,.16);
}

/* Badge for card tiles (absolute positioning is correct HERE) */
.badge{
  position:absolute;
  top: 6px;
  left: 6px;
  width: var(--badgeSize);
  height: var(--badgeSize);
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 900;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.65);
  border: 1px solid rgba(0,0,0,0.35);
  box-shadow: 0 0 18px rgba(0,0,0,.18);
}
.badge.banned{ background: rgba(255, 59, 59, 0.95); }
.badge.aTier{ background: rgba(0, 179, 255, 0.95); }
.badge.bTier{ background: rgba(255, 206, 66, 0.95); color:#101018; text-shadow:none; }
.badge.exempt{ background: rgba(35, 209, 125, 0.95); }

/* Small remove button on deck tiles */
.card-tile .remove-btn{
  position: absolute;
  right: 6px;
  bottom: 6px;
  width: 18px;
  height: 18px;
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(0,0,0,0.48);
  color: #fff;
  font-weight: 900;
  line-height: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor: pointer;
  opacity: .90;
  transition: filter var(--trans-fast), transform var(--trans-fast), opacity var(--trans-fast), box-shadow var(--trans-fast);
}
.card-tile .remove-btn:hover{
  filter: brightness(1.18);
  opacity: 1;
  transform: translateY(-1px);
  box-shadow: 0 0 16px rgba(255,255,255,.10);
}

/* =========================
   SEARCH RESULTS (selected glow + richer rows)
========================= */
.results-wrap{
  margin-top: 10px;
}

.results-list{
  display:flex;
  flex-direction: column;
  gap: 8px;
  max-height: 520px;
  overflow:auto;
  padding-right: 4px;
}

.result{
  display:grid;
  grid-template-columns: 50px 1fr auto;
  gap: 10px;
  align-items:center;
  padding: 9px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.16);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(0,0,0,0.16));
  transition:
    transform var(--trans-fast),
    border-color var(--trans-fast),
    box-shadow var(--trans-fast),
    filter var(--trans-fast);
}

.result:hover{
  transform: translateY(-1px);
  border-color: rgba(0,179,255,.28);
  box-shadow: 0 0 0 3px rgba(0,179,255,.10), 0 12px 26px rgba(0,0,0,.28);
  filter: brightness(1.04);
}

.result.selected{
  border-color: rgba(0,179,255,.62);
  box-shadow:
    0 0 0 3px rgba(124,77,255,.16),
    0 0 26px rgba(0,179,255,.16),
    0 12px 26px rgba(0,0,0,.30);
}

.result .thumb{
  width: 50px;
  height: 72px;
  position: relative;
  border-radius: 12px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.22);
  box-shadow: 0 10px 20px rgba(0,0,0,.28);
}
.result .thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.result .info .name{
  font-weight: 900;
  font-size: 13px;
  letter-spacing: .15px;
}
.result .info .meta{
  font-size: 12px;
  opacity: .84;
}

.result .act .btn{
  height: 30px;
  border-radius: 11px;
  padding: 0 10px;
  font-size: 12px;
}

/* pager */
.pager{
  display:flex;
  align-items:center;
  justify-content: center;
  gap: 10px;
  margin-top: 10px;
}
.pageinfo{
  font-size: 12px;
  opacity: .88;
}

/* =========================
   simple modal (more premium)
========================= */
.db-modal{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.65);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index: 9999;
}

.db-modal .box{
  width: min(680px, calc(100% - 24px));
  background:
    radial-gradient(900px 250px at 20% 0%, rgba(0,179,255,.14), transparent 55%),
    radial-gradient(900px 250px at 80% 0%, rgba(124,77,255,.14), transparent 55%),
    rgba(8,16,28,0.94);
  border: 1px solid rgba(0,179,255,0.24);
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 18px 70px rgba(0,0,0,0.60);
  backdrop-filter: blur(10px);
}

.db-modal .box h3{
  margin: 0 0 10px;
  font-family: Orbitron, system-ui, sans-serif;
  font-size: 14px;
  letter-spacing: .45px;
  text-shadow: 0 0 18px rgba(0,179,255,.18);
}

.db-modal textarea,
.db-modal input{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.22);
  color: #eaf6ff;
  padding: 10px;
  outline: none;
  transition: border-color var(--trans-fast), box-shadow var(--trans-fast);
}

.db-modal textarea:focus,
.db-modal input:focus{
  border-color: rgba(0,179,255,.38);
  box-shadow: 0 0 0 3px rgba(0,179,255,.16), 0 0 24px rgba(0,179,255,.10);
}

.db-modal textarea{ min-height: 120px; resize: vertical; }

.db-modal .actions{
  display:flex;
  gap: 8px;
  justify-content:flex-end;
  margin-top: 10px;
}

/* =========================
   FIX: dropdown menus hard to see
========================= */
.field select,
.select-wide,
select{
  color-scheme: dark;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.10), rgba(0,0,0,0.42));
  border: 1px solid rgba(0,179,255,0.32);
  color: #eaf6ff;
  box-shadow:
    0 0 0 1px rgba(0,179,255,0.10) inset,
    0 8px 20px rgba(0,0,0,0.30);
}

.field select:hover,
.select-wide:hover,
select:hover{
  border-color: rgba(0,179,255,0.48);
  box-shadow:
    0 0 0 3px rgba(0,179,255,0.10),
    0 0 22px rgba(0,179,255,0.10),
    0 10px 22px rgba(0,0,0,0.34);
}

.field select:focus,
.select-wide:focus,
select:focus{
  border-color: rgba(0,179,255,0.62);
  box-shadow:
    0 0 0 3px rgba(0,179,255,0.20),
    0 0 26px rgba(0,179,255,0.18);
}

select option{
  background: #0b1322;
  color: #eaf6ff;
}

select option:checked{
  background: #0b2a44;
  color: #ffffff;
}

select option[disabled]{
  color: rgba(234,246,255,0.55);
}

select{
  background-color: rgba(8,16,28,0.85);
}

/* =========================================================
   Deckbuilder — Mobile hard fix
   Put this at the VERY BOTTOM of deckbuilder.css
   (Overrides desktop grid constraints + 10-column deck grids)
========================================================= */

@media (max-width: 1024px){

  html, body{
    overflow-x: hidden !important;
    max-width: 100% !important;
  }

  /* Force the builder to be real full-width on mobile */
  .app.three-cols{
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 12px !important;
    box-sizing: border-box !important;

    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
  }

  .left-col, .center-col, .right-col{
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  /* Make card sizing shrink on smaller screens */
  :root{
    --cardW: clamp(46px, 17vw, 64px);
    --cardH: calc(var(--cardW) * 1.45);
  }

  /* BIG FIX: stop forcing 10 columns */
  .deck-grid{
    grid-template-columns: repeat(auto-fill, minmax(var(--cardW), 1fr)) !important;
    justify-items: center !important;
    gap: 8px !important;
    padding: 10px !important;
    min-height: auto !important;
  }

  /* Search filter grid wraps cleanly */
  .row2{
    grid-template-columns: 1fr 1fr !important;
  }

  /* Search results scroll instead of stretching the page */
  .results-wrap{
    max-height: 52vh !important;
    overflow: auto !important;
  }

  /* Topbar wraps instead of squeezing */
  .topbar{
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .topbar-actions{
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
}

@media (max-width: 680px){
  :root{
    --cardW: clamp(44px, 19vw, 60px);
    --cardH: calc(var(--cardW) * 1.45);
  }

  .row2{
    grid-template-columns: 1fr !important;
  }
}