/* ============================================================================
   KrakenTheMeta — Dashboard rebuild  ·  app.css
   "Abyssal Arsenal" extended into an app surface. Cinzel display + Sora body,
   abyssal depth, cyan + mana accents, glassy panels. Mobile-first.
   Namespace: .kd-   (never collides with the live dashboard's .dashboard-*)
   ============================================================================ */

:root {
  --kd-display: 'Cinzel', Georgia, serif;
  --kd-body: 'Sora', -apple-system, BlinkMacSystemFont, sans-serif;

  --kd-abyss: #04101e;   /* deepest background           */
  --kd-ink:   #081f33;   /* panel surface                */
  --kd-ink-2: #0b2640;   /* raised surface / hover       */
  --kd-line:  rgba(162, 231, 238, 0.12);
  --kd-line-2:rgba(162, 231, 238, 0.22);

  --kd-cyan:  #a2e7ee;
  --kd-cyan-2:#7bc0e8;
  --kd-blue:  #4196e0;

  --kd-text:    #eaf4fb;
  --kd-text-dim:#9fb6c9;
  --kd-text-mut:#6f879b;

  /* mana accents */
  --kd-w:#e0c45a; --kd-u:#4196e0; --kd-b:#9b7be6; --kd-r:#e0584f; --kd-g:#3fbf86; --kd-c:#a2e7ee;

  --kd-ok:#3fbf86; --kd-warn:#e0c45a; --kd-bad:#e0584f;

  --kd-grad: linear-gradient(135deg, #a2e7ee, #4196e0);
  --kd-radius: 16px;
  --kd-radius-sm: 11px;
  --kd-shadow: 0 18px 50px -22px rgba(0,0,0,.7);
  --kd-side-w: 248px;
  --kd-header-h: 85px;           /* site header (header.php) height — measured live + overridden by app.js */
  --kd-ease: cubic-bezier(.2,.8,.2,1);
}

/* ----------------------------------------------------------------- reset */
.kd-app, .kd-app *, .kd-veil, .kd-veil *, .kd-toasts, .kd-toasts *,
.kd-modal-host, .kd-modal-host * { box-sizing: border-box; }

.kd-app {
  font-family: var(--kd-body);
  color: var(--kd-text);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  background: var(--kd-abyss);
  position: relative;
}
.kd-app h1,.kd-app h2,.kd-app h3,.kd-app h4 { font-family: var(--kd-display); font-weight: 600; margin: 0; }
.kd-app button { font-family: inherit; cursor: pointer; }
.kd-app img { display: block; }
.kd-view[hidden] { display: none; }
/* The `hidden` attribute must always win — otherwise elements with an explicit
   display (e.g. .kd-deckgrid{display:grid}) ignore it and stay visible, which
   left the deck grid showing under the builder (50 decks pushing it off-screen). */
.kd-app [hidden] { display: none !important; }

/* ambient background glows */
.kd-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(700px 460px at 8% -4%, rgba(65,150,224,.12), transparent 60%),
    radial-gradient(620px 520px at 100% 8%, rgba(162,231,238,.08), transparent 62%),
    radial-gradient(900px 700px at 50% 120%, rgba(65,150,224,.08), transparent 60%),
    var(--kd-abyss);
}

/* ============================================================ APP LAYOUT */
/* The site's global CSS sets body{display:flex; align-items:center}, which would
   shrink this grid to its content width and center it (huge empty margins). Force
   it to span the full viewport width, flush-left, like an app / the old dashboard. */
.kd-app { display: grid; grid-template-columns: var(--kd-side-w) 1fr; width: 100%; align-self: stretch; }

/* -------- sidebar (desktop) --------
   FIXED (not sticky): the site sets html/body{overflow-x:hidden}, and an ancestor with
   any overflow breaks position:sticky (the sidebar scrolled away). Fixed pins it to the
   viewport regardless. The grid still reserves the --kd-side-w track (see .kd-main below). */
.kd-side {
  position: fixed; top: var(--kd-header-h); left: 0; z-index: 3;
  width: var(--kd-side-w); height: calc(100vh - var(--kd-header-h));
  display: flex; flex-direction: column; overflow-y: auto;
  padding: 18px 16px 22px;
  background: linear-gradient(180deg, rgba(8,31,51,.92), rgba(4,16,30,.92));
  border-right: 1px solid var(--kd-line);
  backdrop-filter: blur(8px);
}
.kd-brand { display: flex; align-items: center; gap: 11px; text-decoration: none; padding: 4px 8px 18px; }
.kd-brand-mark { width: 34px; height: 34px; border-radius: 9px; }
.kd-brand-name { font-family: var(--kd-display); font-size: 17px; color: var(--kd-text); letter-spacing: .3px; }
.kd-brand-name b { color: var(--kd-cyan); font-weight: 700; }

.kd-nav { display: flex; flex-direction: column; gap: 4px; margin-top: 6px; }
.kd-nav-item {
  display: flex; align-items: center; gap: 13px;
  padding: 12px 14px; border-radius: var(--kd-radius-sm);
  background: transparent; border: 1px solid transparent;
  color: var(--kd-text-dim); font-size: 14.5px; font-weight: 500;
  text-align: left; width: 100%;
  transition: background .2s, color .2s, border-color .2s, transform .15s;
}
.kd-nav-item i { width: 20px; text-align: center; font-size: 15px; }
.kd-nav-item:hover { background: var(--kd-ink-2); color: var(--kd-text); }
.kd-nav-item.is-active {
  color: var(--kd-text);
  background: linear-gradient(120deg, rgba(162,231,238,.16), rgba(65,150,224,.06));
  border-color: var(--kd-line-2);
  box-shadow: inset 2px 0 0 var(--kd-cyan);
}

.kd-side-foot { margin-top: auto; display: flex; flex-direction: column; gap: 12px; padding-top: 16px; }
.kd-gens {
  display: flex; align-items: center; gap: 9px;
  padding: 12px 14px; border-radius: var(--kd-radius-sm);
  background: linear-gradient(135deg, rgba(162,231,238,.12), rgba(65,150,224,.05));
  border: 1px solid var(--kd-line-2); color: var(--kd-cyan); font-weight: 600; font-size: 15px;
}
.kd-gens i { font-size: 14px; }
.kd-gens small { color: var(--kd-text-dim); font-weight: 500; font-size: 12px; margin-left: auto; }
.kd-signout {
  display: flex; align-items: center; gap: 11px; justify-content: flex-start;
  padding: 11px 14px; border-radius: var(--kd-radius-sm);
  background: transparent; border: 1px solid var(--kd-line);
  color: var(--kd-text-mut); font-size: 13.5px; font-weight: 500;
  transition: color .2s, border-color .2s, background .2s;
}
.kd-signout:hover { color: var(--kd-bad); border-color: rgba(224,88,79,.4); background: rgba(224,88,79,.06); }

/* -------- main -------- */
/* grid-column:2 keeps content in the second track since the sidebar is now fixed (out of flow). */
.kd-main { position: relative; z-index: 1; min-width: 0; grid-column: 2; padding: var(--kd-header-h) clamp(16px, 3vw, 40px) 120px; }

.kd-topbar {
  position: sticky; top: var(--kd-header-h); z-index: 2;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 22px 0 18px;
  margin-bottom: 6px;
}
.kd-topbar-title h1 { font-size: clamp(22px, 3vw, 30px); color: #fff; letter-spacing: .4px; }
.kd-topbar-title p { margin: 3px 0 0; color: var(--kd-text-dim); font-size: 13.5px; }
.kd-topbar-right { display: flex; align-items: center; gap: 12px; }
.kd-gens--top { padding: 8px 13px; font-size: 14px; }
.kd-gens--top small { display: none; }
.kd-user { display: flex; align-items: center; gap: 9px; padding: 6px 12px 6px 6px; border-radius: 999px; border: 1px solid var(--kd-line); background: var(--kd-ink); }
.kd-user-avatar { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; border: 1px solid var(--kd-line-2); }
.kd-user-name { font-size: 13.5px; color: var(--kd-text); font-weight: 500; max-width: 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* view enter animation */
.kd-view { animation: kdFade .4s var(--kd-ease); }
@keyframes kdFade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ============================================================ PRIMITIVES */
.kd-panel {
  background: linear-gradient(165deg, rgba(255,255,255,.05), rgba(255,255,255,.012) 60%), var(--kd-ink);
  border: 1px solid var(--kd-line); border-radius: var(--kd-radius);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.kd-section-title { font-size: 13px; letter-spacing: 2px; text-transform: uppercase; color: var(--kd-text-dim); font-family: var(--kd-body); font-weight: 600; margin: 0 0 14px; }

/* buttons */
.kd-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 12px 20px; border-radius: var(--kd-radius-sm);
  font-size: 14px; font-weight: 600; border: 1px solid transparent;
  transition: transform .15s, box-shadow .25s, background .2s, border-color .2s, color .2s;
  white-space: nowrap;
}
.kd-btn i { font-size: 13px; }
.kd-btn--primary { background: var(--kd-grad); color: #05101c; }
.kd-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 12px 30px -10px rgba(162,231,238,.6); }
.kd-btn--ghost { background: var(--kd-ink); color: var(--kd-text); border-color: var(--kd-line); }
.kd-btn--ghost:hover { background: var(--kd-ink-2); border-color: var(--kd-line-2); }
.kd-btn--soft { background: rgba(162,231,238,.08); color: var(--kd-cyan); border-color: var(--kd-line-2); }
.kd-btn--soft:hover { background: rgba(162,231,238,.16); }
.kd-btn--danger { background: rgba(224,88,79,.1); color: #ff9a8d; border-color: rgba(224,88,79,.35); }
.kd-btn--danger:hover { background: rgba(224,88,79,.2); }
.kd-btn--block { width: 100%; }
.kd-btn[disabled] { opacity: .55; cursor: not-allowed; transform: none !important; box-shadow: none !important; }
.kd-btn--lg { padding: 15px 26px; font-size: 15px; }
.kd-btn--sm { padding: 8px 13px; font-size: 13px; }

/* form controls */
.kd-input, .kd-select, .kd-textarea {
  width: 100%; padding: 12px 14px; border-radius: var(--kd-radius-sm);
  background: rgba(3,12,22,.6); border: 1px solid var(--kd-line);
  color: var(--kd-text); font-family: var(--kd-body); font-size: 14px;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.kd-input::placeholder, .kd-textarea::placeholder { color: var(--kd-text-mut); }
.kd-input:focus, .kd-select:focus, .kd-textarea:focus {
  outline: none; border-color: var(--kd-cyan-2);
  box-shadow: 0 0 0 3px rgba(162,231,238,.12); background: rgba(3,12,22,.85);
}
.kd-textarea { resize: vertical; min-height: 96px; line-height: 1.5; }
.kd-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239fb6c9' viewBox='0 0 16 16'%3E%3Cpath d='M3 6l5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; }
.kd-label { display: block; font-size: 13px; font-weight: 600; color: var(--kd-text-dim); margin-bottom: 7px; }
.kd-field { margin-bottom: 16px; }

/* ============================================================ OVERVIEW */
.kd-hero {
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
  padding: 24px; margin-bottom: 18px; position: relative; overflow: hidden;
}
.kd-hero::before { content:''; position:absolute; inset:0; background: radial-gradient(420px 260px at 90% -20%, rgba(162,231,238,.14), transparent 62%); pointer-events:none; }
.kd-hero-avatar { width: 64px; height: 64px; border-radius: 16px; object-fit: cover; border: 1px solid var(--kd-line-2); box-shadow: 0 8px 22px -10px rgba(0,0,0,.6); }
.kd-hero-info { flex: 1; min-width: 180px; }
.kd-hero-info h2 { font-size: 24px; color: #fff; }
.kd-hero-info a { color: var(--kd-cyan); font-size: 13px; text-decoration: none; font-family: var(--kd-body); display: inline-flex; align-items: center; gap: 6px; margin-top: 5px; }
.kd-hero-info a:hover { text-decoration: underline; }

.kd-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.kd-stat { padding: 16px 18px; text-align: center; }
.kd-stat-num { font-family: var(--kd-display); font-size: 30px; font-weight: 700; color: #fff; line-height: 1; }
.kd-stat--gens .kd-stat-num { background: var(--kd-grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.kd-stat-label { display: block; margin-top: 6px; font-size: 11.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--kd-text-dim); }

.kd-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 18px 0; }
.kd-action {
  display: flex; flex-direction: column; gap: 12px; align-items: flex-start;
  padding: 22px; text-align: left; --acc: var(--kd-cyan);
  background: linear-gradient(165deg, rgba(255,255,255,.05), rgba(255,255,255,.012) 60%), var(--kd-ink);
  border: 1px solid var(--kd-line); border-radius: var(--kd-radius); position: relative; overflow: hidden;
  transition: transform .3s var(--kd-ease), border-color .3s, box-shadow .3s;
}
.kd-action::before { content:''; position:absolute; top:-40%; left:-15%; width:200px; height:200px; background: radial-gradient(circle, var(--acc), transparent 68%); opacity:.12; transition: opacity .3s; }
.kd-action:hover { transform: translateY(-5px); border-color: color-mix(in srgb, var(--acc) 50%, transparent); box-shadow: 0 18px 44px -18px color-mix(in srgb, var(--acc) 65%, transparent); }
.kd-action:hover::before { opacity: .24; }
.kd-action-ico { width: 48px; height: 48px; border-radius: 13px; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--acc); background: color-mix(in srgb, var(--acc) 16%, transparent); border: 1px solid color-mix(in srgb, var(--acc) 34%, transparent); }
.kd-action h3 { font-size: 17px; color: #fff; }
.kd-action p { margin: 0; font-size: 13px; color: var(--kd-text-dim); line-height: 1.5; }
.kd-action--ai { --acc: var(--kd-b); }
.kd-action--import { --acc: var(--kd-g); }

.kd-grid-2 { display: grid; grid-template-columns: 1.6fr 1fr; gap: 16px; align-items: start; }

/* recent decks list / pro panel reuse .kd-panel */
.kd-recent { padding: 20px; }

/* Kraken Pro card — the overview's conversion surface */
.kd-pro { position: relative; overflow: hidden; padding: 22px;
  border-color: var(--kd-line-2);
  background: linear-gradient(165deg, rgba(162,231,238,.1), rgba(65,150,224,.03) 60%), var(--kd-ink); }
.kd-pro::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--kd-grad); }
.kd-pro--active { background: linear-gradient(165deg, rgba(63,191,134,.09), rgba(65,150,224,.03) 60%), var(--kd-ink); }
.kd-pro--active::before { background: linear-gradient(180deg, #3fbf86, #4196e0); }
.kd-pro-flag { position: absolute; top: 0; right: 0; font-size: 9px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  background: var(--kd-grad); color: #05101c; padding: 4px 12px; border-radius: 0 0 0 10px; }
.kd-pro-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.kd-pro-title { font-family: var(--kd-display); font-size: 1.05rem; color: #fff; margin: 0; }
.kd-pro-price { font-family: var(--kd-display); font-size: 1.55rem; font-weight: 700; color: var(--kd-cyan); white-space: nowrap; }
.kd-pro-price span { font-family: var(--kd-body); font-size: 12px; font-weight: 500; color: var(--kd-text-dim); }
.kd-pro-feats { list-style: none; margin: 0 0 16px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.kd-pro-feats li { font-size: 13px; color: var(--kd-text-dim); padding-left: 20px; position: relative; line-height: 1.45; }
.kd-pro-feats li::before { content: '✓'; position: absolute; left: 0; color: var(--kd-cyan); font-weight: 700; }
.kd-pro-feats b { color: var(--kd-text); }
.kd-pro-now { color: var(--kd-text-mut); font-size: 11.5px; }
.kd-pro-sub { font-size: 13px; color: var(--kd-text-dim); line-height: 1.55; margin: 0 0 12px; }
.kd-pro-sub b { color: var(--kd-text); }
.kd-pro-note { font-size: 11px; color: var(--kd-text-mut); text-align: center; margin: 10px 0 0; }
.kd-row { display: flex; align-items: center; justify-content: space-between; padding: 9px 0; border-top: 1px solid rgba(255,255,255,.06); font-size: 13.5px; }
.kd-row:first-of-type { border-top: none; }
.kd-row .k { color: var(--kd-text-dim); }
.kd-row .v { color: var(--kd-text); font-weight: 600; }
.kd-badge { display:inline-flex; align-items:center; gap:6px; padding: 4px 11px; border-radius: 999px; font-size: 11.5px; font-weight: 600; letter-spacing: .5px; }
.kd-badge--off { background: rgba(224,88,79,.12); color:#ff9a8d; }
.kd-badge--on  { background: rgba(63,191,134,.14); color:#87e6b8; }

.kd-empty { text-align: center; padding: 40px 20px; color: var(--kd-text-mut); }
.kd-empty i { font-size: 30px; color: var(--kd-text-mut); opacity: .6; margin-bottom: 12px; }
.kd-empty p { margin: 0 0 4px; font-size: 14.5px; color: var(--kd-text-dim); }

/* deck list rows (recent + decks view) */
.kd-decklist { display: flex; flex-direction: column; gap: 8px; }
.kd-deckrow {
  display: flex; align-items: center; gap: 13px; padding: 12px 14px; width: 100%; text-align: left;
  border-radius: var(--kd-radius-sm); border: 1px solid var(--kd-line); background: var(--kd-ink);
  transition: border-color .2s, background .2s, transform .15s;
}
.kd-deckrow:hover { border-color: var(--kd-line-2); background: var(--kd-ink-2); transform: translateX(3px); }
.kd-deckrow-ico { width: 38px; height: 38px; border-radius: 10px; display:flex; align-items:center; justify-content:center; background: rgba(162,231,238,.1); color: var(--kd-cyan); flex-shrink: 0; }
.kd-deckrow-main { flex: 1; min-width: 0; }
.kd-deckrow-name { font-size: 14.5px; color: var(--kd-text); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-deckrow-meta { font-size: 12px; color: var(--kd-text-mut); margin-top: 2px; }
.kd-deckrow .fa-chevron-right { color: var(--kd-text-mut); font-size: 12px; }

/* ============================================================ DECKS GRID */
.kd-toolbar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.kd-toolbar .kd-search { flex: 1; min-width: 200px; }
.kd-deckgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 14px; }
.kd-deckcard {
  border-radius: var(--kd-radius); overflow: hidden; border: 1px solid var(--kd-line);
  background: var(--kd-ink); transition: transform .25s var(--kd-ease), border-color .25s, box-shadow .25s; cursor: pointer;
}
.kd-deckcard:hover { transform: translateY(-4px); border-color: var(--kd-line-2); box-shadow: var(--kd-shadow); }
.kd-deckcard-art { height: 128px; background: linear-gradient(135deg, #0b2640, #04101e); position: relative; display:flex; align-items:flex-end; padding: 12px; background-size: cover; background-position: center 34%; }
.kd-deckcard-art::after { content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent, rgba(4,16,30,.85)); }
.kd-deckcard-fmt { position: relative; z-index:1; font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: var(--kd-cyan); background: rgba(4,16,30,.7); padding: 3px 9px; border-radius: 999px; border: 1px solid var(--kd-line-2); }
.kd-deckcard-body { padding: 13px 15px 15px; }
.kd-deckcard-name { font-family: var(--kd-display); font-size: 16px; color: #fff; margin: 0 0 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-deckcard-sub { font-size: 12.5px; color: var(--kd-text-mut); }
.kd-deckcard-foot { display:flex; gap: 8px; margin-top: 12px; }

/* ============================================================ BUILDER */
.kd-builder { display: grid; grid-template-columns: 380px 1fr; gap: 18px; align-items: start; min-width: 0; }
/* grid items default to min-width:auto, which lets a long card name balloon the column past the
   viewport (horizontal overflow). min-width:0 lets the column shrink so names ellipsis instead. */
.kd-builder > * { min-width: 0; }
.kd-builder-tools { position: sticky; top: 88px; }
.kd-tabs { display: flex; gap: 4px; padding: 5px; background: rgba(3,12,22,.5); border: 1px solid var(--kd-line); border-radius: var(--kd-radius-sm); margin-bottom: 14px; }
.kd-tab-btn { flex: 1; padding: 10px; border-radius: 8px; background: transparent; border: none; color: var(--kd-text-dim); font-size: 13px; font-weight: 600; display: flex; align-items: center; justify-content: center; gap: 7px; transition: background .2s, color .2s; }
.kd-tab-btn i { font-size: 12px; }
.kd-tab-btn.is-active { background: var(--kd-grad); color: #05101c; }
.kd-tool-panel { padding: 18px; }
.kd-tool-panel[hidden] { display: none; }

.kd-search-bar { display: flex; gap: 8px; margin-bottom: 12px; }
.kd-search-bar .kd-input { flex: 1; }
.kd-colors { display: flex; gap: 7px; margin-bottom: 14px; flex-wrap: wrap; }
.kd-color { width: 34px; height: 34px; border-radius: 9px; border: 1px solid var(--kd-line); background: var(--kd-ink-2); color: var(--kd-text-dim); font-weight: 700; font-size: 13px; transition: transform .15s, border-color .2s; }
.kd-color[data-color="W"].on { background: var(--kd-w); color:#05101c; } .kd-color[data-color="U"].on { background: var(--kd-u); color:#fff; }
.kd-color[data-color="B"].on { background: var(--kd-b); color:#fff; } .kd-color[data-color="R"].on { background: var(--kd-r); color:#fff; }
.kd-color[data-color="G"].on { background: var(--kd-g); color:#05101c; } .kd-color[data-color="C"].on { background: var(--kd-c); color:#05101c; }
.kd-color:hover { transform: translateY(-2px); border-color: var(--kd-line-2); }

.kd-results { display: flex; flex-direction: column; gap: 8px; max-height: 60vh; overflow-y: auto; padding-right: 4px; }
.kd-result {
  display: flex; align-items: center; gap: 11px; padding: 8px; border-radius: 10px;
  border: 1px solid var(--kd-line); background: var(--kd-ink); transition: border-color .2s, background .2s;
}
.kd-result:hover { border-color: var(--kd-line-2); background: var(--kd-ink-2); }
.kd-result-thumb { width: 40px; height: 56px; border-radius: 5px; object-fit: cover; background: var(--kd-abyss); flex-shrink: 0; }
.kd-result-main { flex: 1; min-width: 0; }
.kd-result-name { font-size: 13.5px; color: var(--kd-text); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-result-meta { font-size: 11.5px; color: var(--kd-text-mut); margin-top: 2px; }
.kd-result-add { width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0; background: rgba(162,231,238,.1); color: var(--kd-cyan); border: 1px solid var(--kd-line-2); display:flex; align-items:center; justify-content:center; transition: background .2s; }
.kd-result-add:hover { background: var(--kd-grad); color: #05101c; }

/* AI panel */
.kd-ai-head { display:flex; align-items:center; gap: 11px; margin-bottom: 14px; }
.kd-ai-head .ico { width: 40px; height: 40px; border-radius: 11px; display:flex; align-items:center; justify-content:center; background: color-mix(in srgb, var(--kd-b) 18%, transparent); color: var(--kd-b); border:1px solid color-mix(in srgb, var(--kd-b) 34%, transparent); }
.kd-ai-head h3 { font-size: 16px; color: #fff; } .kd-ai-head p { margin: 2px 0 0; font-size: 12.5px; color: var(--kd-text-dim); }
.kd-check { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--kd-text-dim); margin: 12px 0; cursor: pointer; }
.kd-check input { width: 17px; height: 17px; accent-color: var(--kd-cyan); }
.kd-advanced { border: 1px solid var(--kd-line); border-radius: var(--kd-radius-sm); padding: 10px 14px; margin: 12px 0; }
.kd-advanced summary { cursor: pointer; font-size: 13px; font-weight: 600; color: var(--kd-text-dim); }
.kd-advanced[open] summary { margin-bottom: 12px; }
.kd-hint { font-size: 11.5px; color: var(--kd-text-mut); margin: 4px 0 0; }

/* current deck display */
.kd-deckhead { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; padding: 18px 20px; margin-bottom: 14px; position: relative; overflow: hidden; }
/* Deck header shows the commander/prominent card as background art (set in JS), with a
   left-weighted overlay so the title + actions stay readable — like the published deck view. */
.kd-deckhead.has-art { background-size: cover; background-position: center 32%; }
.kd-deckhead.has-art::before { content: ''; position: absolute; inset: 0; z-index: 0; background: linear-gradient(90deg, rgba(6,20,34,.95) 0%, rgba(6,20,34,.8) 55%, rgba(6,20,34,.55) 100%); }
.kd-deckhead > * { position: relative; z-index: 1; }
.kd-deckhead-main { flex: 1; min-width: 160px; }
.kd-deckhead h2 { font-size: 21px; color: #fff; display: flex; align-items: center; gap: 10px; }
.kd-deckhead-edit { background: none; border: none; color: var(--kd-text-mut); font-size: 14px; padding: 4px; } .kd-deckhead-edit:hover { color: var(--kd-cyan); }
.kd-deckhead-meta { display: flex; gap: 14px; margin-top: 6px; font-size: 12.5px; color: var(--kd-text-dim); flex-wrap: wrap; }
.kd-deckhead-meta b { color: var(--kd-cyan); }
.kd-deckhead-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.kd-cats { display: flex; flex-direction: column; gap: 16px; }
.kd-cat-title { font-size: 13px; letter-spacing: 1px; text-transform: uppercase; color: var(--kd-cyan); margin: 0 0 10px; display: flex; align-items: center; gap: 8px; font-family: var(--kd-body); font-weight: 600; }
.kd-cat-title .count { color: var(--kd-text-mut); font-weight: 500; }
.kd-cardrows { display: flex; flex-direction: column; gap: 5px; }
.kd-cardrow { display: flex; align-items: center; gap: 10px; padding: 7px 10px 7px 9px; border-radius: 9px; background: var(--kd-ink); border: 1px solid var(--kd-line); border-left: 3px solid var(--cardc, var(--kd-line)); min-width: 0; }
.kd-cardrow:hover { border-color: var(--kd-line-2); border-left-color: var(--cardc, var(--kd-line-2)); }
.kd-cardrow.is-cmd { background: rgba(224,196,90,.06); }
.kd-cardrow-qty { font-size: 13px; color: var(--kd-cyan); font-weight: 700; min-width: 24px; flex-shrink: 0; }
.kd-cardrow-name {
  flex: 1; min-width: 0; font-family: var(--kd-body); font-size: 13.5px; color: var(--kd-text); font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; text-align: left;
  background: none; border: none; padding: 0; cursor: pointer; transition: color .15s;
}
.kd-cardrow-name:hover { color: var(--kd-cyan); }
.kd-cardrow-name .cmd-tag { font-size: 9.5px; color: var(--kd-w); border:1px solid rgba(224,196,90,.4); padding: 1px 5px; border-radius: 999px; margin-left: 6px; vertical-align: middle; }
.kd-cardrow-meta { display: inline-flex; align-items: center; gap: 10px; flex-shrink: 0; }
.kd-cardrow-mana { display: inline-flex; align-items: center; gap: 1px; flex-shrink: 0; }
.kd-mana { width: 14px; height: 14px; vertical-align: middle; }
.kd-cardrow-price { font-size: 12px; color: var(--kd-text-mut); flex-shrink: 0; min-width: 38px; text-align: right; }

/* ---- Card (image) view ---- */
.kd-cats--card .kd-cardimgs { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 9px; }
.kd-cardimg { position: relative; border-radius: 9px; overflow: hidden; border: 1px solid var(--kd-line); box-shadow: inset 0 0 0 1.5px color-mix(in srgb, var(--cardc) 55%, transparent); cursor: pointer; aspect-ratio: 63/88; background: var(--kd-abyss); transition: transform .2s, box-shadow .2s; }
.kd-cardimg:hover { transform: translateY(-3px); box-shadow: 0 12px 26px -12px rgba(0,0,0,.7), inset 0 0 0 1.5px var(--cardc); }
.kd-cardimg.is-cmd { box-shadow: inset 0 0 0 2px #d4af37; }
.kd-cardimg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kd-cardimg-qty { position: absolute; top: 6px; left: 6px; background: rgba(4,16,30,.85); border: 1px solid var(--kd-line-2); color: var(--kd-cyan); font-size: 11px; font-weight: 700; padding: 1px 7px; border-radius: 999px; }
.kd-cardimg-step { position: absolute; bottom: 0; left: 0; right: 0; display: flex; opacity: 0; transition: opacity .2s; background: linear-gradient(0deg, rgba(4,16,30,.92), transparent); padding: 14px 6px 6px; gap: 6px; justify-content: center; }
.kd-cardimg:hover .kd-cardimg-step { opacity: 1; }
.kd-cardimg-step button { width: 30px; height: 26px; border-radius: 7px; background: rgba(8,31,51,.9); border: 1px solid var(--kd-line-2); color: var(--kd-text); font-size: 11px; }
.kd-cardimg-step button:hover { color: var(--kd-cyan); border-color: var(--kd-cyan); }

/* ---- Card preview popover (hover/tap) ---- */
/* Visibility is controlled by `display` (set in JS) so it never depends on a
   transition — opacity/transform are pure enhancement (transitions get throttled
   in background tabs, which would otherwise leave the panel invisible). */
.kd-pop { position: fixed; z-index: 140; width: 240px; display: none; opacity: 1; transform: translateY(6px) scale(.98); transition: transform .18s var(--kd-ease); background: var(--kd-ink-2); border: 1px solid var(--kd-line-2); border-radius: 14px; padding: 10px; box-shadow: 0 24px 60px -20px rgba(0,0,0,.85); }
.kd-pop.show { transform: none; }
.kd-pop-img { width: 100%; border-radius: 10px; display: block; }
.kd-pop-foot { display: flex; align-items: center; gap: 8px; margin-top: 9px; }
.kd-pop-price { font-family: var(--kd-display); font-size: 16px; font-weight: 700; color: #fff; }
.kd-pop-price.empty { font-family: var(--kd-body); font-size: 12px; font-weight: 500; color: var(--kd-text-mut); }
.kd-pop-buy { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; padding: 8px 13px; border-radius: 9px; font-size: 12.5px; font-weight: 600; text-decoration: none; color: #05101c; background: var(--kd-grad); transition: transform .15s, box-shadow .2s; }
.kd-pop-buy:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(162,231,238,.6); }
.kd-pop-buy i { font-size: 12px; }
.kd-stepper { display: flex; align-items: center; gap: 4px; }
.kd-stepper button { width: 26px; height: 26px; border-radius: 7px; background: var(--kd-ink-2); border: 1px solid var(--kd-line); color: var(--kd-text-dim); display:flex; align-items:center; justify-content:center; font-size: 11px; }
.kd-stepper button:hover { color: var(--kd-cyan); border-color: var(--kd-line-2); }

/* ============================================================ COLLECTION */
.kd-cardgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 12px; }
.kd-collcard { border-radius: 10px; overflow: hidden; border: 1px solid var(--kd-line); background: var(--kd-ink); position: relative; }
.kd-collcard img { width: 100%; aspect-ratio: 63/88; object-fit: cover; background: var(--kd-abyss); }
.kd-collcard-info { padding: 8px 10px; }
.kd-collcard-name { font-size: 12px; color: var(--kd-text); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-collcard-sub { font-size: 11px; color: var(--kd-text-mut); display: flex; justify-content: space-between; margin-top: 3px; }
.kd-collcard-qty { position: absolute; top: 7px; right: 7px; background: rgba(4,16,30,.85); border: 1px solid var(--kd-line-2); color: var(--kd-cyan); font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; }

/* ============================================================ PROFILE */
/* Profile fills the width like every other tab (no per-tab width shift). Avatar/bio card
   and the save row span full width; social + API sit side by side on desktop. */
.kd-prof { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
.kd-prof > .kd-prof-card:first-child,
.kd-prof > div:last-child { grid-column: 1 / -1; }
.kd-prof-card { padding: 22px; }
.kd-avatars { display: flex; gap: 12px; flex-wrap: wrap; }
.kd-avatars input { display: none; }
.kd-avatars label { cursor: pointer; border-radius: 13px; padding: 3px; border: 2px solid transparent; transition: border-color .2s, transform .15s; }
.kd-avatars label img { width: 58px; height: 58px; border-radius: 10px; object-fit: cover; }
.kd-avatars label:hover { transform: translateY(-2px); }
.kd-avatars input:checked + label { border-color: var(--kd-cyan); }
.kd-prof-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.kd-input-icon { position: relative; }
.kd-input-icon i { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--kd-text-mut); font-size: 13px; }
.kd-input-icon .kd-input { padding-left: 36px; }

/* ============================================================ MODAL/TOAST/VEIL */
.kd-modal-host { position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center; padding: 18px; background: rgba(2,8,16,.75); backdrop-filter: blur(8px); animation: kdFade .25s; }
.kd-modal-host[hidden] { display: none; }
.kd-modal { width: 100%; max-width: 480px; padding: 26px; max-height: 86vh; overflow-y: auto; animation: kdPop .3s var(--kd-ease); }
@keyframes kdPop { from { opacity: 0; transform: translateY(20px) scale(.98); } to { opacity: 1; transform: none; } }
.kd-modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.kd-modal-head h3 { font-size: 20px; color: #fff; }
.kd-modal-close { background: none; border: none; color: var(--kd-text-mut); font-size: 20px; } .kd-modal-close:hover { color: var(--kd-text); }

.kd-veil { position: fixed; inset: 0; z-index: 120; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; background: rgba(2,8,16,.82); backdrop-filter: blur(6px); }
.kd-veil[hidden] { display: none; }
.kd-veil-orb { width: 54px; height: 54px; border-radius: 50%; border: 3px solid rgba(162,231,238,.18); border-top-color: var(--kd-cyan); animation: kdSpin .8s linear infinite; }
@keyframes kdSpin { to { transform: rotate(360deg); } }
.kd-veil p { color: var(--kd-text-dim); font-size: 14px; }

.kd-toasts { position: fixed; bottom: 22px; right: 22px; z-index: 130; display: flex; flex-direction: column; gap: 10px; max-width: min(360px, 90vw); }
.kd-toast { display: flex; align-items: flex-start; gap: 11px; padding: 13px 16px; border-radius: var(--kd-radius-sm); background: var(--kd-ink-2); border: 1px solid var(--kd-line-2); box-shadow: var(--kd-shadow); animation: kdSlideIn .3s var(--kd-ease); }
@keyframes kdSlideIn { from { opacity: 0; transform: translateX(30px); } to { opacity: 1; transform: none; } }
.kd-toast.out { animation: kdSlideOut .3s var(--kd-ease) forwards; }
@keyframes kdSlideOut { to { opacity: 0; transform: translateX(30px); } }
.kd-toast i { font-size: 15px; margin-top: 1px; }
.kd-toast--ok i { color: var(--kd-ok); } .kd-toast--err i { color: var(--kd-bad); } .kd-toast--info i { color: var(--kd-cyan); }
.kd-toast p { margin: 0; font-size: 13.5px; color: var(--kd-text); line-height: 1.4; }

/* ============================================================ MOBILE TABBAR */
.kd-tabbar { display: none; }

/* ============================================================ RESPONSIVE */
@media (max-width: 1100px) {
  .kd-builder { grid-template-columns: 320px 1fr; }
  .kd-grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .kd-app { grid-template-columns: 1fr; }
  .kd-side { display: none; }
  .kd-main { grid-column: 1; padding: var(--kd-header-h) 16px 110px; }
  .kd-builder { grid-template-columns: 1fr; }
  .kd-builder-tools { position: static; }
  .kd-tabbar {
    display: grid; grid-template-columns: repeat(4, 1fr);
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 40;
    background: linear-gradient(180deg, rgba(8,31,51,.96), rgba(4,16,30,.98));
    border-top: 1px solid var(--kd-line-2); backdrop-filter: blur(10px);
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom));
  }
  .kd-tab { display: flex; flex-direction: column; align-items: center; gap: 4px; background: none; border: none; color: var(--kd-text-mut); font-size: 10.5px; font-weight: 600; padding: 6px 4px; border-radius: 10px; }
  .kd-tab i { font-size: 18px; }
  .kd-tab.is-active { color: var(--kd-cyan); }
  .kd-topbar-title h1 { font-size: 22px; }

  /* Mobile: surface the Kraken Pro card above the fold — order becomes
     hero → PRO CARD → Create-Deck actions → Recent Decks. Desktop untouched.
     :not([hidden]) guard: a bare display:flex would defeat the tab-switch hidden attr. */
  #view-overview:not([hidden]) { display: flex; flex-direction: column; gap: 16px; }
  #view-overview .kd-grid-2 { display: contents; } /* frees kd-pro/kd-recent to be reordered */
  #view-overview .kd-actions { margin: 0; }
  #view-overview .kd-hero { order: 0; }
  #view-overview .kd-pro { order: 1; }
  #view-overview .kd-actions { order: 2; }
  #view-overview .kd-recent { order: 3; }
}
@media (max-width: 560px) {
  .kd-stats { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .kd-stat { padding: 12px 6px; } .kd-stat-num { font-size: 22px; }
  .kd-stat-label { font-size: 9.5px; letter-spacing: 1px; }
  .kd-actions { grid-template-columns: 1fr; gap: 10px; }
  .kd-action { flex-direction: row; align-items: center; padding: 16px; }
  .kd-action-ico { flex-shrink: 0; }
  .kd-action p { display: none; }
  .kd-hero { padding: 18px; }
  .kd-user-name { display: none; }
  .kd-deckgrid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .kd-cardgrid { grid-template-columns: repeat(auto-fill, minmax(104px, 1fr)); gap: 9px; }
  .kd-prof-grid { grid-template-columns: 1fr; }
  .kd-prof { grid-template-columns: 1fr; }
  .kd-toasts { left: 12px; right: 12px; bottom: 84px; }
  /* Card rows on phones: qty + full card name on line 1 (name may wrap, never truncates/overflows),
     mana + price + stepper drop to line 2. */
  .kd-cardrow { flex-wrap: wrap; row-gap: 7px; }
  .kd-cardrow-name { white-space: normal; overflow: visible; text-overflow: clip; }
  .kd-cardrow-meta { flex-basis: 100%; }
  .kd-cardrow-meta .kd-stepper { margin-left: auto; }
  .kd-modal { padding: 20px; }
}

/* ---- Arena view (match history + coached recaps) ---- */
.kd-arena-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 20px; }
.kd-arena-sub { font-size: 12.5px; color: var(--kd-text-mut); margin: 4px 0 0; }
.kd-arena-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.kd-arena-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 14px;
  background: rgba(0,0,0,.18); border: 1px solid var(--kd-line); border-radius: 12px; padding: 12px 16px; margin-bottom: 8px; }
.kd-arena-row.clickable { cursor: pointer; transition: border-color .15s; }
.kd-arena-row.clickable:hover { border-color: var(--kd-line-2); }
.kd-arena-row.clickable:hover .kd-arena-hint { color: var(--kd-cyan); }
.kd-arena-badge { font-family: var(--kd-display); font-weight: 700; font-size: 12px; padding: 5px 12px; border-radius: 100px; min-width: 56px; text-align: center;
  background: rgba(255,255,255,.06); color: var(--kd-text-dim); border: 1px solid var(--kd-line); }
.kd-arena-badge.win { background: rgba(63,191,134,.14); color: #87e6b8; border-color: rgba(63,191,134,.3); }
.kd-arena-badge.loss { background: rgba(224,88,79,.12); color: #ff9a8d; border-color: rgba(224,88,79,.28); }
.kd-arena-main { min-width: 0; font-size: 13px; color: var(--kd-text); }
.kd-arena-opp { font-size: 11.5px; color: var(--kd-text-mut); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-arena-hint { color: var(--kd-text-mut); }
.kd-arena-when { font-size: 11.5px; color: var(--kd-text-mut); white-space: nowrap; }
/* multi-Arena-account support: per-match account tag + filter chips */
.kd-arena-acct { color: var(--kd-cyan); font-size: 12px; }
.kd-arena-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.kd-arena-chip { font-family: var(--kd-body); font-size: 12px; font-weight: 600; padding: 6px 14px; border-radius: 100px;
  background: rgba(255,255,255,.05); color: var(--kd-text-dim); border: 1px solid var(--kd-line); cursor: pointer; transition: all .18s; }
.kd-arena-chip:hover { border-color: rgba(162,231,238,.35); color: var(--kd-text); }
.kd-arena-chip.on { background: rgba(162,231,238,.12); color: var(--kd-cyan); border-color: rgba(162,231,238,.4); }
.kd-arena-recap { margin: -4px 0 10px; border: 1px solid var(--kd-line); border-top: none; border-radius: 0 0 12px 12px;
  background: rgba(0,0,0,.25); padding: 14px 16px; max-height: 380px; overflow-y: auto; }
.kd-recap-turn { font-family: var(--kd-display); font-size: 10.5px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--kd-cyan); margin: 12px 0 8px; padding-top: 10px; border-top: 1px dashed rgba(162,231,238,.14); }
.kd-arena-recap .kd-recap-turn:first-child { border-top: none; margin-top: 0; padding-top: 0; }
.kd-recap-msg { font-size: 12.5px; line-height: 1.55; padding: 9px 12px; border-radius: 10px; margin: 6px 0; max-width: 92%; color: var(--kd-text); }
.kd-recap-msg b { display: block; font-size: 9.5px; letter-spacing: 1px; text-transform: uppercase; color: var(--kd-text-mut); margin-bottom: 3px; }
.kd-recap-msg.coach { background: rgba(162,231,238,.08); border: 1px solid var(--kd-line); }
.kd-recap-msg.coach b { color: var(--kd-cyan); }
.kd-recap-msg.user { background: rgba(65,150,224,.14); border: 1px solid rgba(65,150,224,.3); margin-left: auto; }
.kd-recap-event { font-size: 11.5px; color: var(--kd-text-mut); padding: 3px 2px; }

/* avatar chip doubles as the Profile button (mobile has no Profile tab) */
.kd-user { cursor: pointer; transition: border-color .2s; }
.kd-user:hover { border-color: var(--kd-line-2); }

/* ---- profile: membership & billing ---- */
.kd-mem-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.kd-mem-rows { margin-bottom: 16px; }
.kd-mem-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.kd-purchases { display: flex; flex-direction: column; gap: 7px; }
.kd-purchase { display: flex; align-items: center; justify-content: space-between; gap: 12px; font-size: 13px; color: var(--kd-text);
  background: rgba(0,0,0,.18); border: 1px solid var(--kd-line); border-radius: 10px; padding: 10px 14px; }
.kd-purchase-meta { color: var(--kd-text-mut); font-size: 12px; white-space: nowrap; }

/* ---- arena stats: four tiles that actually fit ---- */
.kd-arstats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 16px 0; }
.kd-arstats .kd-stat { padding: 18px 10px; }
@media (max-width: 640px) { .kd-arstats { grid-template-columns: repeat(2, 1fr); gap: 10px; } }
