/* ============================================================
   ZillerPortal — Admin portal, WARM re-skin
   Drop-in replacement for: wwwroot/app.css

   Same class names as the original (.portal-sidebar, .portal-nav,
   .portal-card, .btn-primary, .form-control, .login-panel, …) so
   NO .razor markup changes are needed. This only re-colors.

   Converts the old dark purple/blue theme to the warm
   "Ember on paper" design system.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Schibsted+Grotesk:wght@400;500;600;700;800;900&family=Hanken+Grotesk:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

:root {
  /* warm paper & ink (reusing the original variable names) */
  --bg-900: #F4ECE0;
  --bg-800: #FBF6EE;
  --bg-700: #FFFFFF;
  --panel: #FFFFFF;
  --panel-soft: #FFFDF9;
  --stroke: rgba(60, 44, 30, 0.10);
  --stroke-strong: rgba(60, 44, 30, 0.18);
  --text-main: #241A12;
  --text-soft: #6B5B4C;
  --text-faint: #8C7B6B;

  /* ember accent (was purple/blue) */
  --accent: #EA580C;
  --accent-2: #C2410C;
  --accent-blue: #1D6F8B;   /* info, warmed */
  --accent-cyan: #F2802F;   /* highlight */
  --ember-50: #FFF4EC;
  --ember-100: #FFE6D4;
  --ember-700: #9A3412;
  --gold: #854D0E;

  --success: #15803D;
  --warning: #B45309;
  --danger:  #C2331F;

  --shadow: 0 20px 48px rgba(60, 44, 30, 0.10);
  --shadow-sm: 0 2px 8px rgba(60, 44, 30, 0.06);
  --shadow-ember: 0 6px 18px rgba(234, 88, 12, 0.26);
  --r-sm: 10px; --r-md: 14px; --r-lg: 20px; --r-xl: 28px;

  --font-display: 'Schibsted Grotesk', system-ui, sans-serif;
  --font-sans: 'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'Space Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }

body {
  font-family: var(--font-sans);
  color: var(--text-main);
  /* flat warm cream — no more dark radial gradients */
  background:
    radial-gradient(ellipse at 30% -5%, var(--ember-50) 0%, transparent 45%),
    var(--bg-800);
}

a { color: var(--accent); }
a:hover { color: var(--accent-2); }

/* ---------- Shell & sidebar ---------- */
.portal-shell { min-height: 100vh; display: grid; grid-template-columns: 276px 1fr; }

.portal-sidebar {
  padding: 24px 20px; background: var(--panel); border-right: 1px solid var(--stroke);
  backdrop-filter: none; display: flex; flex-direction: column; gap: 20px;
}
.portal-brand-block { padding-bottom: 18px; border-bottom: 1px solid var(--stroke); margin-bottom: 4px; }
.portal-status-chip {
  display: inline-flex; align-items: center; gap: 8px; padding: 7px 12px; border-radius: 999px;
  background: rgba(21, 128, 61, 0.10); color: var(--success); font-size: 0.82rem; font-weight: 700;
}
.status-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--success); box-shadow: none; }
.portal-brand { font-family: var(--font-display); font-size: 1.55rem; font-weight: 800; letter-spacing: -0.03em; color: var(--text-main); }
.portal-subtitle { color: var(--text-faint) !important; line-height: 1.5; font-size: 0.85rem; }

.portal-sidebar-game-list { display: grid; gap: 10px; }
.portal-game-pill {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px;
  border: 1px solid var(--stroke); border-radius: 14px; background: var(--bg-800);
}
.portal-game-pill img, .portal-tcg-logo { width: 38px; height: 38px; border-radius: 12px; box-shadow: var(--shadow-sm); }
img.portal-tcg-logo { width: 38px; height: 38px; border-radius: 12px; box-shadow: var(--shadow-sm); object-fit: cover; flex-shrink: 0; display: block; }

.portal-nav {
  color: var(--text-main); text-decoration: none; padding: 11px 14px; border-radius: var(--r-sm);
  border: 1px solid transparent; background: transparent; font-weight: 600; transition: 160ms ease;
  display: flex; align-items: center;
}
.portal-nav:hover { border-color: transparent; background: var(--bg-900); transform: none; }
.portal-nav.active {
  background: var(--accent); border-color: transparent; color: #fff; box-shadow: var(--shadow-ember);
}
.portal-nav.active i, .portal-nav.active .bi { color: #fff !important; }
.portal-nav-disabled { color: var(--text-faint); border: 1px dashed var(--stroke); cursor: not-allowed; background: transparent; }

.portal-sidebar-footer { padding-top: 8px; }
.portal-user-card {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px;
  border: 1px solid var(--stroke); border-radius: var(--r-md); background: var(--bg-900);
}
.portal-user-avatar {
  width: 36px; height: 36px; border-radius: 10px; background: var(--ember-100);
  display: grid; place-items: center; font-size: 1rem; color: var(--ember-700);
}

/* ---------- Main / headers ---------- */
.portal-main { padding: 32px 36px; }
.page-header h1 {
  font-family: var(--font-display); font-size: clamp(2rem, 3vw, 2.6rem); font-weight: 800;
  letter-spacing: -0.03em; margin-bottom: 8px; color: var(--text-main);
}
.page-header p { color: var(--text-soft); max-width: 720px; font-size: 1rem; }
.section-title { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; margin-bottom: 14px; color: var(--text-main); }
.stat-label { text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.72rem; color: var(--accent-2); font-weight: 800; }
.stat-value { font-family: var(--font-display); font-size: 1.8rem; font-weight: 800; margin: 6px 0 12px; color: var(--text-main); }

/* ---------- Cards ---------- */
.portal-card {
  background: var(--panel); border: 1px solid var(--stroke); border-radius: var(--r-lg);
  padding: 22px 24px; box-shadow: var(--shadow-sm); backdrop-filter: none;
}
.portal-card-soft { background: var(--panel-soft); }
.portal-hero-card { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.portal-hero-copy h2 { font-family: var(--font-display); margin: 6px 0 10px; font-size: 1.6rem; font-weight: 800; color: var(--text-main); }
.portal-hero-copy p, .text-secondary, .text-muted { color: var(--text-soft) !important; }

.portal-inline-stat {
  background: linear-gradient(135deg, var(--ember-50), var(--panel-soft));
  border: 1px solid rgba(234, 88, 12, 0.22); border-radius: var(--r-md); padding: 14px 16px;
}
.portal-inline-stat.border-warning { border-color: rgba(180, 83, 9, 0.4) !important; background: rgba(180, 83, 9, 0.06); }
.portal-stats-grid, .settings-security-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.settings-security-card { display: flex; align-items: center; gap: 14px; padding: 18px; border-radius: var(--r-md); background: var(--bg-900); border: 1px solid var(--stroke); }
.settings-security-icon {
  width: 44px; height: 44px; display: grid; place-items: center; border-radius: 12px;
  background: var(--ember-100); color: var(--ember-700);
}

/* ---------- Pricing / simulator options ---------- */
.portal-pricing-option {
  display: block; height: 100%; padding: 18px; border-radius: var(--r-md);
  background: var(--bg-900); border: 1px solid var(--stroke); cursor: pointer; transition: 160ms ease;
}
.portal-pricing-option:hover { transform: translateY(-2px); border-color: rgba(234, 88, 12, 0.3); }
.portal-pricing-option-active { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); background: var(--ember-50); }

.portal-sim-preview {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px 14px;
  border-radius: var(--r-md); background: linear-gradient(135deg, var(--ember-50), var(--panel-soft)); color: var(--text-main);
}

/* ---------- Log (terminal) ---------- */
.portal-log {
  background: #241A12; color: #E9DFD3; padding: 18px; border-radius: var(--r-md); max-height: 560px;
  overflow: auto; font-family: var(--font-mono); font-size: 0.82rem; line-height: 1.6;
  border: 1px solid rgba(60, 44, 30, 0.3); white-space: pre-wrap; word-break: break-word;
}
.portal-log-ops { max-height: 420px; font-size: 0.78rem; }

/* ---------- Steps / progress ---------- */
.portal-progress { height: 22px; border-radius: 999px; overflow: hidden; background: var(--bg-900); }
.portal-progress-thin { height: 12px; }
.portal-step { display: flex; justify-content: space-between; gap: 16px; align-items: center; border-radius: 12px; padding: 12px 14px; font-weight: 600; }
.portal-step-pending { background: var(--bg-900); color: var(--text-soft); }
.portal-step-current { background: rgba(180, 83, 9, 0.12); color: var(--warning); }
.portal-step-done { background: rgba(21, 128, 61, 0.12); color: var(--success); }

/* ---------- Modals ---------- */
.portal-modal-backdrop { position: fixed; inset: 0; background: rgba(36, 26, 18, 0.45); backdrop-filter: blur(3px); z-index: 1040; }
.portal-modal-shell { position: fixed; inset: 0; z-index: 1050; display: flex; align-items: center; justify-content: center; padding: 22px; }
.portal-modal-card {
  width: min(1400px, 100%); min-height: min(740px, 88vh); max-height: 94vh; overflow: hidden;
  display: flex; flex-direction: column; background: var(--panel); border-radius: var(--r-xl);
  border: 1px solid var(--stroke); box-shadow: var(--shadow);
}
.portal-modal-header { flex-shrink: 0; padding: 24px 24px 0 24px; }
.portal-modal-body { flex: 1 1 0; min-height: 0; overflow-y: auto; padding: 16px 24px 24px 24px; }

/* ---------- Buttons ---------- */
.btn-primary {
  background: var(--accent); border: none; color: #fff; font-weight: 700;
  border-radius: var(--r-sm); box-shadow: var(--shadow-ember);
}
.btn-primary:hover, .btn-primary:focus { background: var(--accent-2); border: none; color: #fff; box-shadow: var(--shadow-ember); }
.btn-success { background: var(--success); border: none; color: #fff; border-radius: var(--r-sm); }
.btn-success:hover { background: #126b33; color: #fff; }
.btn-warning { background: var(--accent); border: none; color: #fff; border-radius: var(--r-sm); font-weight: 700; }
.btn-warning:hover { background: var(--accent-2); color: #fff; }

.btn-outline-primary, .btn-outline-secondary, .btn-outline-dark, .btn-outline-warning, .btn-outline-light, .btn-outline-success, .btn-outline-info {
  color: var(--text-main); border-color: var(--stroke-strong); background: var(--panel); border-radius: var(--r-sm);
}
.btn-outline-primary:hover, .btn-outline-secondary:hover, .btn-outline-dark:hover, .btn-outline-warning:hover,
.btn-outline-light:hover, .btn-outline-success:hover, .btn-outline-info:hover {
  color: var(--text-main); background: var(--bg-900); border-color: var(--stroke-strong);
}
.btn-outline-danger { color: var(--danger); border-color: rgba(194, 51, 31, 0.4); border-radius: var(--r-sm); }
.btn-outline-danger:hover { background: rgba(194, 51, 31, 0.08); color: var(--danger); }

.portal-btn-coming-soon, .portal-btn-coming-soon:hover, .portal-btn-coming-soon:focus, .portal-btn-coming-soon:active {
  background: var(--bg-900); border-color: var(--stroke); color: var(--text-faint); box-shadow: none;
}
.portal-ghost-btn { border-color: var(--stroke-strong) !important; background: var(--panel) !important; color: var(--text-main) !important; }

/* ---------- Forms ---------- */
.form-control, .form-select {
  color: var(--text-main); background: var(--panel); border: 1px solid var(--stroke-strong);
  border-radius: var(--r-sm); min-height: 46px;
}
.form-control::placeholder { color: var(--text-faint); }
.form-select option { background: var(--panel); color: var(--text-main); }
.form-control:focus, .form-select:focus {
  color: var(--text-main); background: var(--panel); border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(234, 88, 12, 0.18);
}
.form-label { font-weight: 700; color: var(--text-main); }
.form-text { color: var(--text-faint) !important; }
.form-check-input { background-color: var(--panel); border-color: var(--stroke-strong); }
.form-check-input:checked { background-color: var(--accent); border-color: var(--accent); }
.font-monospace { font-family: var(--font-mono) !important; }

/* ---------- Tables ---------- */
.table-modern { --bs-table-bg: transparent; --bs-table-color: var(--text-main); --bs-table-border-color: var(--stroke); }
.table-modern thead th, .table thead th {
  color: var(--text-soft); background: var(--bg-900); border-bottom-color: var(--stroke);
  text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.78rem; font-weight: 800;
}
.table { color: var(--text-main); }
.table tbody tr:hover td { background: var(--bg-900); }
.table td, .table th { border-color: var(--stroke); }

.badge.text-bg-light { background: var(--bg-900) !important; color: var(--text-main) !important; }

/* ---------- Alerts ---------- */
.alert { border-radius: var(--r-md); }
.alert-success { background: rgba(21,128,61,0.10); border-color: rgba(21,128,61,0.25); color: var(--success); }
.alert-danger  { background: rgba(194,51,31,0.08); border-color: rgba(194,51,31,0.25); color: var(--danger); }
.alert-light, .alert-secondary { background: var(--bg-900); border-color: var(--stroke); color: var(--text-main); }
.text-info, .text-success { color: var(--success) !important; }
.text-warning { color: var(--warning) !important; }
.text-danger { color: var(--danger) !important; }

code { color: var(--ember-700); font-family: var(--font-mono); }

/* ---------- Login ---------- */
.auth-shell { min-height: 100vh; }
.login-page {
  min-height: 100vh; display: grid; place-items: center; padding: 24px;
  background: radial-gradient(ellipse at 30% 0%, var(--ember-50) 0%, transparent 55%), var(--bg-800);
}
.login-panel {
  width: min(480px, 100%); padding: 36px 38px; border-radius: var(--r-xl);
  background: var(--panel); border: 1px solid var(--stroke); box-shadow: var(--shadow);
}
.login-kicker { color: var(--accent-2); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 800; }
.login-panel h1 { font-family: var(--font-display); margin: 8px 0 10px; font-size: 2rem; font-weight: 800; letter-spacing: -0.03em; color: var(--text-main); }
.login-panel p, .login-footnote { color: var(--text-soft); }
.login-form-grid { display: grid; gap: 16px; margin-top: 24px; }
.login-footnote { margin-top: 20px; font-size: 0.9rem; }

/* ---------- Operations / Downloads helpers ---------- */
.ops-tcg-btn {
  display: flex; align-items: center; gap: 8px; padding: 9px 14px; border-radius: 12px;
  border: 1px solid var(--stroke-strong); background: var(--panel); color: var(--text-main);
  font-weight: 600; font-size: 0.88rem; cursor: pointer; transition: 150ms ease;
}
.ops-tcg-btn:hover { border-color: rgba(234, 88, 12, 0.35); background: var(--bg-900); }
.ops-tcg-btn-active { border-color: var(--accent); background: var(--ember-50); box-shadow: none; color: var(--ember-700); }
.ops-tcg-img { width: 26px; height: 26px; border-radius: 8px; object-fit: cover; }
.ops-tcg-img-sm { width: 20px; height: 20px; border-radius: 6px; object-fit: cover; }
.ops-markup-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 12px; border: 1px solid var(--stroke); background: var(--bg-900); opacity: 0.5; transition: opacity 200ms; }
.ops-markup-active { opacity: 1; border-color: rgba(180, 83, 9, 0.3); background: rgba(180, 83, 9, 0.06); }
.ops-markup-img { width: 26px; height: 26px; border-radius: 8px; object-fit: cover; }

.dl-stat-card { text-align: center; padding: 20px; }
.dl-stat-value-sm { font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; margin: 6px 0 12px; }
.dl-search-input { padding-left: 38px; }
.dl-search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--text-faint); pointer-events: none; }
.dl-badge-shopify  { background: var(--ember-50); color: var(--ember-700); border: 1px solid rgba(234,88,12,0.25); }
.dl-badge-catalog  { background: rgba(29,111,139,0.10); color: var(--accent-blue); border: 1px solid rgba(29,111,139,0.25); }
.dl-badge-inventory{ background: rgba(21,128,61,0.10); color: var(--success); border: 1px solid rgba(21,128,61,0.25); }
.dl-badge-prices   { background: rgba(180,83,9,0.10); color: var(--warning); border: 1px solid rgba(180,83,9,0.25); }

/* ---------- Card image preview ---------- */
.card-hero-link { display: block; line-height: 0; }
.card-hero-img {
  width: 110px; height: auto; border-radius: 8px;
  border: 1px solid var(--stroke-strong); box-shadow: var(--shadow-sm);
  transition: transform 0.15s, box-shadow 0.15s; cursor: pointer;
}
.card-hero-img:hover { transform: scale(1.04); box-shadow: var(--shadow); }

.card-thumb-cell { width: 44px; padding: 4px 6px !important; }
.card-thumb-wrapper { position: relative; display: inline-block; line-height: 0; text-decoration: none; color: inherit; }
.card-thumb-wrapper img.card-thumb {
  width: 36px; height: auto; border-radius: 4px;
  border: 1px solid var(--stroke); cursor: zoom-in; display: block; transition: opacity 0.15s;
}
.card-thumb-wrapper:hover img.card-thumb { opacity: 0.8; }

/* hover modal overlay */
.card-img-modal-overlay {
  display: none; position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,0.55); align-items: center; justify-content: center;
  pointer-events: none;
}
.card-img-modal-overlay.visible { display: flex; }
.card-img-modal-overlay img {
  max-width: min(360px, 90vw); max-height: 90vh;
  border-radius: 10px; box-shadow: 0 8px 40px rgba(0,0,0,0.7);
  display: block;
}

/* ---------- Log variants ---------- */
.portal-log-modal { max-height: 52vh; }
.portal-log-full { max-height: 36vh; }

/* ---------- Operations layout ---------- */
.ops-tcg-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.ops-markup-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }

/* ---------- Downloads layout ---------- */
.dl-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.dl-filter-bar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.dl-search-wrap { position: relative; flex: 1; min-width: 200px; }

/* ---------- Simulator layout ---------- */
.portal-simulator-bar { display: flex; gap: 16px; align-items: end; flex-wrap: wrap; }
.portal-simulator-actions { display: grid; gap: 10px; min-width: 240px; }

/* ---------- Responsive ---------- */
@media (max-width: 1080px) {
  .portal-shell { grid-template-columns: 1fr; }
  .portal-main { padding: 20px; }
  .portal-stats-grid, .settings-security-grid { grid-template-columns: 1fr; }
  .dl-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .portal-sidebar { padding: 18px; }
  .portal-main { padding: 16px; }
  .portal-card, .portal-modal-card, .login-panel { padding: 18px; border-radius: var(--r-md); }
  .portal-simulator-actions { min-width: 100%; }
  .dl-stats-grid { grid-template-columns: 1fr 1fr; }
}
