/* 
 * IIFIN UI Kit (layered surfaces + components)
 * Depends on iifin-tokens.css
 */

:root {
  --iifin-surface-paper: var(--iifin-bg);
  --iifin-surface-card: var(--surface-card);
  --iifin-surface-raised: var(--surface-raised);
  --iifin-stroke-card: var(--stroke-card);
  --iifin-stroke-field: var(--stroke-field);
  --iifin-text-primary: var(--iifin-text);
  --iifin-text-muted: var(--iifin-muted);
  --iifin-brand: var(--iifin-accent);
  --iifin-brand-on: var(--iifin-on-accent);
}

body {
  background: var(--iifin-surface-paper);
  color: var(--iifin-text-primary);
}

.iifin-card {
  background: var(--iifin-surface-card);
  border: 1px solid var(--iifin-stroke-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.iifin-card--raised {
  background: var(--iifin-surface-raised);
  box-shadow: var(--shadow-md);
}

.iifin-card__head {
  padding: var(--spacing-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-4);
}

.iifin-card__body {
  padding: var(--spacing-5);
}

.iifin-muted { color: var(--iifin-text-muted); }

.iifin-field {
  width: 100%;
  background: var(--iifin-surface-raised);
  border: 1px solid var(--iifin-stroke-field);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
  color: var(--iifin-text-primary);
}

.iifin-field::placeholder { color: var(--iifin-text-muted); }

.iifin-field:focus {
  border-color: var(--iifin-brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--iifin-brand) 18%, transparent);
}

.iifin-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
}

.iifin-btn--primary {
  background: var(--iifin-brand);
  color: var(--iifin-brand-on);
  box-shadow: var(--shadow-sm);
}

.iifin-overlay {
  position: fixed;
  inset: 0;
  background: color-mix(in srgb, #000 38%, transparent);
  z-index: 9990;
}

.iifin-modal {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  z-index: 9991;
  padding: 20px;
}

.iifin-modal__panel {
  width: min(560px, 100%);
  max-height: min(84vh, 720px);
  overflow: auto;
  background: var(--iifin-surface-card);
  border: 1px solid var(--iifin-stroke-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}
