/* ═══════════════════════════════════════════════════════════════════
   SOKO — Component Library
   Requires soko-theme.css to be loaded first (uses its --tokens).
   ═══════════════════════════════════════════════════════════════════ */


/* ╔══════════════════════════════════════════╗
   ║  BUTTONS                                 ║
   ╚══════════════════════════════════════════╝ */
.soko-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 10px 16px;
  font-family: inherit;
  font-size: var(--f-base);
  font-weight: var(--fw-semibold);
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--t-fast) var(--easing),
              box-shadow var(--t-fast) var(--easing),
              background var(--t-fast) var(--easing),
              border-color var(--t-fast) var(--easing),
              filter var(--t-fast) var(--easing);
  user-select: none;
  white-space: nowrap;
}
.soko-btn:hover  { background: var(--surface-3); border-color: var(--border-strong); }
.soko-btn:active { transform: translateY(1px) scale(0.99); }
.soko-btn:disabled, .soko-btn[aria-disabled="true"] {
  opacity: 0.45; cursor: not-allowed; transform: none;
}
.soko-btn .soko-btn-icon { font-size: 1.05em; line-height: 1; }

/* variants */
.soko-btn--primary {
  background: var(--accent-grad);
  border-color: transparent;
  color: var(--text-onaccent);
  box-shadow: var(--sh-glow-sky);
}
.soko-btn--primary:hover  { background: var(--accent-grad-hover); filter: brightness(1.05); }

.soko-btn--success {
  background: var(--success-grad);
  border-color: transparent;
  color: #052e1e;
  box-shadow: var(--sh-glow-emerald);
}
.soko-btn--warning {
  background: var(--warning-grad);
  border-color: transparent;
  color: #3b2608;
  box-shadow: var(--sh-glow-amber);
}
.soko-btn--danger {
  background: var(--danger-grad);
  border-color: transparent;
  color: #ffffff;
  box-shadow: var(--sh-glow-rose);
}
.soko-btn--ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--text-soft);
}
.soko-btn--ghost:hover { background: var(--surface-1); color: var(--text); }

.soko-btn--link {
  background: transparent;
  border: none;
  color: var(--accent-hi);
  padding: 6px 8px;
  box-shadow: none;
}
.soko-btn--link:hover { color: var(--accent); background: transparent; }

/* sizes */
.soko-btn--sm { padding: 7px 12px; font-size: var(--f-sm); border-radius: var(--r-sm); }
.soko-btn--lg { padding: 14px 22px; font-size: var(--f-md); border-radius: var(--r-lg); }
.soko-btn--xl { padding: 18px 28px; font-size: var(--f-lg); border-radius: var(--r-lg); }
.soko-btn--icon { padding: 10px; width: 40px; height: 40px; }
.soko-btn--block { display: flex; width: 100%; }


/* ╔══════════════════════════════════════════╗
   ║  CARDS                                   ║
   ╚══════════════════════════════════════════╝ */
.soko-card {
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  box-shadow: var(--sh-md);
  transition: border-color var(--t-med) var(--easing),
              transform var(--t-med) var(--easing),
              box-shadow var(--t-med) var(--easing);
}
.soko-card--elevated { background: var(--surface-2); box-shadow: var(--sh-lg); }

/* Glass card — for "hero" surfaces that should glow through the ambient bg */
.soko-card--glass {
  background: var(--surface-glass);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--border);
  box-shadow: var(--sh-lg);
}

.soko-card--interactive { cursor: pointer; }
.soko-card--interactive:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
  box-shadow: var(--sh-lg);
}

.soko-card-header {
  display: flex; align-items: center; gap: var(--s-3);
  padding-bottom: var(--s-3);
  margin-bottom: var(--s-4);
  border-bottom: 1px solid var(--border-subtle);
}
.soko-card-title {
  font-size: var(--f-md);
  font-weight: var(--fw-semibold);
  color: var(--text);
  margin: 0;
}
.soko-card-subtitle {
  font-size: var(--f-sm);
  color: var(--text-muted);
  margin-top: 2px;
}


/* ╔══════════════════════════════════════════╗
   ║  INPUTS                                  ║
   ╚══════════════════════════════════════════╝ */
.soko-input, .soko-select, .soko-textarea {
  width: 100%;
  padding: 11px 14px;
  font-family: inherit;
  font-size: var(--f-base);
  color: var(--text);
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  outline: none;
  transition: border-color var(--t-fast) var(--easing),
              background var(--t-fast) var(--easing),
              box-shadow var(--t-fast) var(--easing);
}
.soko-input::placeholder, .soko-textarea::placeholder { color: var(--text-dim); }
.soko-input:hover, .soko-select:hover, .soko-textarea:hover {
  background: var(--input-bg-hov);
  border-color: var(--border-strong);
}
.soko-input:focus, .soko-select:focus, .soko-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.18);
  background: var(--input-bg-hov);
}
.soko-input:disabled { opacity: 0.5; cursor: not-allowed; }
.soko-select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
}
.soko-textarea { min-height: 96px; resize: vertical; line-height: var(--lh-normal); }

.soko-field { display: flex; flex-direction: column; gap: 6px; }
.soko-label {
  font-size: var(--f-xs);
  font-weight: var(--fw-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.soko-hint  { font-size: var(--f-sm); color: var(--text-dim); }
.soko-error { font-size: var(--f-sm); color: var(--danger); }

/* input with leading icon */
.soko-input-wrap { position: relative; }
.soko-input-wrap .soko-input-icon {
  position: absolute; top: 50%; left: 14px;
  transform: translateY(-50%);
  color: var(--text-dim); pointer-events: none;
}
.soko-input-wrap .soko-input { padding-left: 40px; }


/* ╔══════════════════════════════════════════╗
   ║  TOPBAR                                  ║
   ╚══════════════════════════════════════════╝ */
.soko-topbar {
  display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  background: var(--surface-glass);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  margin-bottom: var(--s-5);
  box-shadow: var(--sh-md);
}
.soko-topbar-brand {
  display: flex; align-items: center; gap: var(--s-3);
}
.soko-topbar-brand img { height: 38px; width: auto; }
.soko-topbar-title {
  font-size: var(--f-lg);
  font-weight: var(--fw-bold);
  color: var(--text);
  line-height: 1.15;
}
.soko-topbar-sub {
  font-size: var(--f-sm);
  color: var(--text-muted);
  margin-top: 2px;
}
.soko-topbar-right { margin-left: auto; display: flex; gap: var(--s-2); align-items: center; }


/* ╔══════════════════════════════════════════╗
   ║  BADGES / CHIPS                          ║
   ╚══════════════════════════════════════════╝ */
.soko-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  font-size: var(--f-xs);
  font-weight: var(--fw-semibold);
  border-radius: var(--r-pill);
  background: var(--surface-2);
  color: var(--text-soft);
  border: 1px solid var(--border-subtle);
  line-height: 1.4;
}
.soko-badge--success { background: var(--success-lo); color: var(--success); border-color: transparent; }
.soko-badge--warning { background: var(--warning-lo); color: var(--warning); border-color: transparent; }
.soko-badge--danger  { background: var(--danger-lo);  color: var(--danger);  border-color: transparent; }
.soko-badge--info    { background: var(--info-lo);    color: var(--info);    border-color: transparent; }
.soko-badge--accent  { background: rgba(56, 189, 248, 0.14); color: var(--accent-hi); border-color: transparent; }
.soko-badge--dot::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}


/* ╔══════════════════════════════════════════╗
   ║  TABLE                                   ║
   ╚══════════════════════════════════════════╝ */
.soko-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--f-sm);
}
.soko-table thead th {
  text-align: left;
  padding: 12px 14px;
  font-size: var(--f-xs);
  font-weight: var(--fw-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  background: rgba(129, 140, 248, 0.04);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0;
}
.soko-table tbody td {
  padding: 12px 14px;
  color: var(--text-soft);
  border-bottom: 1px solid var(--border-subtle);
}
.soko-table tbody tr {
  transition: background var(--t-fast) var(--easing);
}
.soko-table tbody tr:hover { background: rgba(129, 140, 248, 0.04); }
.soko-table tbody tr:last-child td { border-bottom: none; }

.soko-table-wrap {
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  overflow: auto;
  box-shadow: var(--sh-md);
}


/* ╔══════════════════════════════════════════╗
   ║  MODAL                                   ║
   ╚══════════════════════════════════════════╝ */
.soko-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(5, 8, 18, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: var(--z-modal-bg);
  display: flex; align-items: center; justify-content: center;
  padding: var(--s-4);
  animation: soko-fade-in var(--t-med) var(--easing) both;
}
.soko-modal {
  position: relative;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  max-width: 560px; width: 100%;
  max-height: 90vh; overflow: auto;
  box-shadow: var(--sh-xl);
  z-index: var(--z-modal);
  animation: soko-slide-up var(--t-slow) var(--easing) both;
}
.soko-modal-header {
  display: flex; align-items: center; gap: var(--s-3);
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--border-subtle);
}
.soko-modal-title { font-size: var(--f-lg); font-weight: var(--fw-bold); }
.soko-modal-close {
  margin-left: auto;
  background: transparent; border: none;
  color: var(--text-muted); cursor: pointer;
  font-size: 18px; padding: 4px 8px; border-radius: var(--r-sm);
  transition: all var(--t-fast) var(--easing);
}
.soko-modal-close:hover { color: var(--danger); background: var(--danger-lo); }


/* ╔══════════════════════════════════════════╗
   ║  TOAST                                   ║
   ╚══════════════════════════════════════════╝ */
.soko-toast {
  position: fixed; top: 24px; right: 24px;
  padding: 14px 20px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-md);
  color: var(--text);
  font-size: var(--f-base);
  box-shadow: var(--sh-lg);
  z-index: var(--z-toast);
  min-width: 240px; max-width: 420px;
  animation: soko-slide-in-right var(--t-slow) var(--easing) both;
}
.soko-toast--success { border-left-color: var(--success); }
.soko-toast--warning { border-left-color: var(--warning); }
.soko-toast--danger  { border-left-color: var(--danger); }


/* ╔══════════════════════════════════════════╗
   ║  KPI / STAT CARD                         ║
   ╚══════════════════════════════════════════╝ */
.soko-kpi {
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  position: relative;
  overflow: hidden;
  transition: all var(--t-med) var(--easing);
}
.soko-kpi::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent-grad);
  opacity: 0.7;
}
.soko-kpi:hover { transform: translateY(-2px); box-shadow: var(--sh-lg); border-color: var(--border); }
.soko-kpi--success::before { background: var(--success-grad); }
.soko-kpi--warning::before { background: var(--warning-grad); }
.soko-kpi--danger::before  { background: var(--danger-grad); }

.soko-kpi-label {
  font-size: var(--f-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: var(--fw-semibold);
  margin-bottom: var(--s-2);
}
.soko-kpi-value {
  font-size: var(--f-3xl);
  font-weight: var(--fw-xbold);
  color: var(--text);
  line-height: 1;
  letter-spacing: -0.02em;
}
.soko-kpi-delta {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--f-sm);
  font-weight: var(--fw-semibold);
  margin-top: var(--s-2);
}
.soko-kpi-delta--up   { color: var(--success); }
.soko-kpi-delta--down { color: var(--danger); }


/* ╔══════════════════════════════════════════╗
   ║  GRID HELPERS                            ║
   ╚══════════════════════════════════════════╝ */
.soko-grid { display: grid; gap: var(--s-4); }
.soko-grid-2 { grid-template-columns: repeat(2, 1fr); }
.soko-grid-3 { grid-template-columns: repeat(3, 1fr); }
.soko-grid-4 { grid-template-columns: repeat(4, 1fr); }
.soko-grid-auto { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
@media (max-width: 900px) {
  .soko-grid-2, .soko-grid-3, .soko-grid-4 { grid-template-columns: 1fr; }
}


/* ╔══════════════════════════════════════════╗
   ║  UTILITY                                 ║
   ╚══════════════════════════════════════════╝ */
.soko-divider { height: 1px; background: var(--border-subtle); margin: var(--s-4) 0; }
.soko-muted  { color: var(--text-muted); }
.soko-dim    { color: var(--text-dim); }
.soko-mono   { font-family: var(--font-mono); font-size: 0.9em; }
.soko-row    { display: flex; align-items: center; gap: var(--s-3); }
.soko-col    { display: flex; flex-direction: column; gap: var(--s-3); }
.soko-spacer { flex: 1; }
.soko-center { display: flex; align-items: center; justify-content: center; }

.soko-spinner {
  display: inline-block;
  width: 16px; height: 16px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: soko-spin 700ms linear infinite;
}
