/*
 * Cart widget styles. Themeable: every visual is driven by the CSS custom
 * properties below, so a new band only overrides these (or relies on the
 * site's existing --teal/--gold/etc. tokens, which are picked up as defaults).
 */
:root {
  --ck-bg: var(--panel, #201816f0);
  --ck-fg: var(--cream, #f0e0b8);
  --ck-accent: var(--gold, #e8b068);
  --ck-accent-ink: var(--ink, #201816);
  --ck-muted: #b9ad93;
  --ck-line: rgba(240, 224, 184, 0.2);
  --ck-radius: 14px;
  --ck-font: "Newsreader", Georgia, serif;
  --ck-ui-font: "DM Mono", ui-monospace, monospace;
}

.ck-fab {
  position: fixed; right: 18px; bottom: 18px; z-index: 9998;
  display: flex; align-items: center; gap: 6px;
  font-family: var(--ck-ui-font); font-size: 15px;
  padding: 12px 16px; border: 1px solid var(--ck-line); border-radius: 999px;
  background: var(--ck-bg); color: var(--ck-fg); cursor: pointer;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
}
.ck-fab .ck-count {
  min-width: 20px; height: 20px; padding: 0 5px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--ck-accent); color: var(--ck-accent-ink); font-size: 12px;
}
.ck-fab:not(.ck-has-items) { opacity: 0.85; }

.ck-overlay {
  position: fixed; inset: 0; z-index: 9999; display: none;
  background: rgba(0, 0, 0, 0.5); backdrop-filter: blur(2px);
}
.ck-overlay.ck-open { display: block; }

.ck-drawer {
  position: absolute; top: 0; right: 0; height: 100%;
  width: min(420px, 100%); overflow-y: auto;
  background: var(--ck-bg); color: var(--ck-fg);
  font-family: var(--ck-font); padding: 20px;
  border-left: 1px solid var(--ck-line);
  box-shadow: -8px 0 30px rgba(0, 0, 0, 0.4);
}

.ck-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.ck-head h2 { margin: 0; font-size: 22px; }
.ck-close { background: none; border: none; color: var(--ck-fg); font-size: 28px; line-height: 1; cursor: pointer; }
.ck-empty, .ck-note { color: var(--ck-muted); font-size: 14px; }

.ck-lines { list-style: none; margin: 0; padding: 0; }
.ck-line { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--ck-line); }
.ck-line img { width: 52px; height: 52px; object-fit: cover; border-radius: 8px; }
.ck-line-info { flex: 1; display: flex; flex-direction: column; }
.ck-line-title { font-size: 16px; }
.ck-line-fmt { font-family: var(--ck-ui-font); font-size: 12px; color: var(--ck-muted); }
.ck-qty { display: flex; align-items: center; gap: 8px; }
.ck-qty button {
  width: 26px; height: 26px; border: 1px solid var(--ck-line); border-radius: 6px;
  background: transparent; color: var(--ck-fg); cursor: pointer; font-size: 15px;
}

.ck-subtotal { display: flex; justify-content: space-between; margin: 16px 0 4px; font-size: 18px; }
.ck-subtotal span:first-child { font-family: var(--ck-ui-font); }

.ck-primary, .ck-secondary {
  width: 100%; margin-top: 14px; padding: 13px; border-radius: 10px; cursor: pointer;
  font-family: var(--ck-ui-font); font-size: 15px; border: 1px solid var(--ck-line);
}
.ck-primary { background: var(--ck-accent); color: var(--ck-accent-ink); border-color: transparent; font-weight: 600; }
.ck-primary:disabled { opacity: 0.6; cursor: default; }
.ck-secondary { background: transparent; color: var(--ck-fg); }

.ck-form { display: flex; flex-direction: column; gap: 10px; }
.ck-field { display: flex; flex-direction: column; gap: 4px; font-family: var(--ck-ui-font); font-size: 12px; color: var(--ck-muted); }
.ck-field input {
  padding: 10px; border: 1px solid var(--ck-line); border-radius: 8px;
  background: rgba(255, 255, 255, 0.04); color: var(--ck-fg);
  font-family: var(--ck-font); font-size: 16px;
}
.ck-row { display: flex; gap: 10px; }
.ck-row .ck-field { flex: 1; }

.ck-ship { list-style: none; margin: 6px 0 0; padding: 0; }
.ck-ship li { border: 1px solid var(--ck-line); border-radius: 10px; margin-bottom: 8px; }
.ck-ship label { display: flex; align-items: center; gap: 10px; padding: 12px; cursor: pointer; font-size: 14px; }
.ck-ship label span:nth-of-type(1) { flex: 1; }
.ck-ship strong { font-family: var(--ck-ui-font); }

.ck-err { color: var(--rust, #c86848); font-size: 14px; margin-top: 10px; }

/* Buy buttons embedded in the page (album cards). */
.album-buy { display: flex; flex-wrap: wrap; gap: 8px; }
.buy-media-btn {
  display: inline-block; font-family: var(--ck-ui-font); font-size: 13px;
  padding: 8px 14px; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--ck-line); background: var(--ck-accent); color: var(--ck-accent-ink);
}
.buy-media-btn:disabled { background: transparent; color: var(--ck-muted); cursor: default; }
