/* ═══════════════════════════════════════════════════════
   Dink Portal Design System
   Matches dink-client provisioning portal aesthetic:
   indigo-to-purple gradient buttons, 12-16px card radius,
   card borders, stronger shadows, input focus glow
   ═══════════════════════════════════════════════════════ */

/* ── Design gradient tokens ──────────────────────────── */
:root {
  --dk-grad-primary: linear-gradient(135deg, #6366f1 0%, #7c3aed 100%);
  --dk-grad-success: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  --dk-grad-error:   linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  --dk-glow-primary: rgba(99, 102, 241, .32);
  --dk-glow-success: rgba(34, 197, 94,  .32);
  --dk-glow-error:   rgba(239, 68, 68,  .32);
}

/* ── Light theme — override DaisyUI defaults ─────────── */
[data-theme="light"] {
  --color-base-100: 100% 0 0;              /* #ffffff — card */
  --color-base-200: 95.9% 0.008 264.5;    /* #f1f5f9 — page bg */
  --color-base-300: 90.2% 0.009 264.5;    /* #e2e8f0 — border */
  --color-base-content: 12.9% 0.023 264.5;/* #0f172a — text */
  --color-primary: 58.4% 0.174 277.3;     /* #6366f1 — indigo */
  --color-primary-content: 97.9% 0.003 277.3;
  --rounded-btn:   0.5rem;
  --rounded-box:   0.75rem;
  --rounded-badge: 0.375rem;
}

/* ── Base ────────────────────────────────────────────── */
body { font-size: 14px; font-family: system-ui, -apple-system, "Segoe UI", sans-serif; }

/* ── Buttons ─────────────────────────────────────────── */
.btn {
  border-radius: 8px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: .1px;
  transition: opacity .15s, transform .1s, box-shadow .15s !important;
}
.btn-xs { height: 26px !important; min-height: 26px !important; font-size: 11px !important; padding: 0 10px !important; }
.btn-sm { height: 32px !important; min-height: 32px !important; font-size: 12px !important; padding: 0 14px !important; }
.btn-lg { height: 46px !important; min-height: 46px !important; font-size: 15px !important; font-weight: 700 !important; padding: 0 24px !important; letter-spacing: .3px; }

/* join group — fix rounding on first/last only */
.join .btn { border-radius: 0 !important; }
.join .btn:first-child { border-radius: 8px 0 0 8px !important; }
.join .btn:last-child  { border-radius: 0 8px 8px 0 !important; }
.join .btn:only-child  { border-radius: 8px !important; }

/* Primary — gradient + glow */
.btn-primary {
  background: var(--dk-grad-primary) !important;
  border-color: transparent !important;
  box-shadow: var(--dk-shadow-primary, 0 4px 14px var(--dk-glow-primary)) !important;
  color: #fff !important;
}
.btn-primary:hover:not(:disabled) {
  opacity: .91;
  box-shadow: 0 6px 20px var(--dk-glow-primary) !important;
}
.btn-primary:active:not(:disabled) { transform: scale(.98); }

/* join primary active state */
.join .btn-primary { border-radius: 0 !important; }
.join .btn-primary:first-child { border-radius: 8px 0 0 8px !important; }
.join .btn-primary:last-child  { border-radius: 0 8px 8px 0 !important; }

/* Success — gradient */
.btn-success {
  background: var(--dk-grad-success) !important;
  border-color: transparent !important;
  box-shadow: 0 4px 14px var(--dk-glow-success) !important;
  color: #fff !important;
}

/* Error — gradient */
.btn-error {
  background: var(--dk-grad-error) !important;
  border-color: transparent !important;
  box-shadow: 0 4px 14px var(--dk-glow-error) !important;
  color: #fff !important;
}

/* Outline — no gradient, keep border, no shadow */
.btn-outline {
  background: transparent !important;
  box-shadow: none !important;
}
.btn-outline:hover { box-shadow: none !important; }

/* Ghost — transparent */
.btn-ghost { box-shadow: none !important; }

/* ── Cards ───────────────────────────────────────────── */
.card { border-radius: 12px !important; }

[data-theme="light"] .card {
  border: 1px solid #e2e8f0;
  box-shadow: 0 2px 12px rgba(0, 0, 0, .06) !important;
}
[data-theme="dink-dark"] .card {
  border: 1px solid #334155;
  box-shadow: 0 8px 32px rgba(0, 0, 0, .35) !important;
}

/* ── Modal ───────────────────────────────────────────── */
.modal-box { border-radius: 16px !important; }
[data-theme="light"]    .modal-box { border: 1px solid #e2e8f0; }
[data-theme="dink-dark"] .modal-box { border: 1px solid #334155; }

/* ── Inputs & Selects ────────────────────────────────── */
.input, .select, .textarea {
  border-radius: 8px !important;
  font-size: 13px !important;
}
.input-sm, .select-sm { height: 34px !important; min-height: 34px !important; }
.input-xs, .select-xs { height: 28px !important; min-height: 28px !important; }

.input:focus,
.input:focus-within,
.select:focus {
  box-shadow: 0 0 0 3px rgba(99, 102, 241, .15) !important;
  border-color: #6366f1 !important;
  outline: none !important;
}

/* ── Navbar ──────────────────────────────────────────── */
.navbar { border-bottom: 1px solid oklch(var(--color-base-300)); }

/* ── Badge ───────────────────────────────────────────── */
.badge {
  border-radius: 5px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}

/* ── Alert ───────────────────────────────────────────── */
.alert { border-radius: 10px !important; }

/* ── Dropdown content ────────────────────────────────── */
.dropdown-content { border-radius: 10px !important; }

/* ── Dink brand icon (navbar) ────────────────────────── */
.dink-icon {
  background: linear-gradient(135deg, #6366f1, #a78bfa) !important;
  box-shadow: 0 3px 10px rgba(99, 102, 241, .4) !important;
  color: #fff !important;
}
