/* ============================================================
 * CIF Visual Interaction Layer — UI-V1
 * Shared component CSS for cards / tasks / status / forms / tables.
 * Pure CSS, no Tailwind dependency. Safe to load on any page.
 *
 * Design tokens:
 *   --cif-gold        #d4af37
 *   --cif-gold-soft   rgba(212,175,55,.18)
 *   --cif-gold-edge   rgba(212,175,55,.32)
 *   --cif-surface     #0e0e0e
 *   --cif-surface-2   #141414
 *   --cif-line        rgba(255,255,255,.08)
 *
 * Status palette:
 *   OK / paid / approved / agreed       → emerald
 *   In progress / pending agreement     → sky blue
 *   Needs review / unpaid               → amber
 *   Blocked / danger                    → red
 *   Not started                         → slate
 * ============================================================ */

:root {
  --cif-gold:        #d4af37;
  --cif-gold-bright: #f5d060;
  --cif-gold-dim:    #8a6f1f;
  --cif-gold-soft:   rgba(212, 175, 55, 0.18);
  --cif-gold-edge:   rgba(212, 175, 55, 0.32);
  --cif-gold-glow:   rgba(212, 175, 55, 0.25);

  --cif-surface:    #0e0e0e;
  --cif-surface-2:  #141414;
  --cif-surface-3:  #1a1a1a;
  --cif-line:       rgba(255, 255, 255, 0.08);
  --cif-line-strong:rgba(255, 255, 255, 0.16);

  --cif-text:       #ffffff;
  --cif-text-mute:  #aaaaaa;
  --cif-text-dim:   #7a7a7a;

  --cif-ok:         #22c55e;
  --cif-ok-soft:    rgba(34, 197, 94, 0.14);
  --cif-info:       #60a5fa;
  --cif-info-soft:  rgba(96, 165, 250, 0.14);
  --cif-warn:       #f59e0b;
  --cif-warn-soft:  rgba(245, 158, 11, 0.14);
  --cif-danger:     #ef4444;
  --cif-danger-soft:rgba(239, 68, 68, 0.14);
  --cif-slate:      #94a3b8;
  --cif-slate-soft: rgba(148, 163, 184, 0.14);

  --cif-radius:     12px;
  --cif-radius-sm:  8px;
  --cif-shadow-lift:0 4px 20px rgba(212, 166, 63, 0.18);
  --cif-shadow-soft:0 2px 12px rgba(0, 0, 0, 0.45);

  --cif-trans: 200ms cubic-bezier(.4, 0, .2, 1);
}

/* ──────────────────────────────────────────────────────────
 * CARDS — base, hover, selected, glass
 * ────────────────────────────────────────────────────────── */
.cif-card,
.cif-task-card,
.cif-status-card,
.cif-finance-card {
  position: relative;
  display: block;
  background: var(--cif-surface);
  border: 1px solid var(--cif-line);
  border-radius: var(--cif-radius);
  padding: 16px;
  color: var(--cif-text);
  box-shadow: var(--cif-shadow-soft);
  transition:
    border-color var(--cif-trans),
    transform   var(--cif-trans),
    box-shadow  var(--cif-trans),
    background  var(--cif-trans);
}

.cif-card-hover:hover,
.cif-card.is-hoverable:hover,
.cif-task-card:hover,
.cif-status-card:hover,
.cif-finance-card:hover {
  border-color: var(--cif-gold-edge);
  transform: translateY(-2px);
  box-shadow: var(--cif-shadow-lift);
}

.cif-card.is-selected,
.cif-task-card.is-selected,
.cif-status-card.is-selected,
.cif-finance-card.is-selected {
  border-left: 3px solid var(--cif-gold);
  background: linear-gradient(90deg, var(--cif-gold-soft) 0%, var(--cif-surface) 28%);
}

.cif-glass-panel {
  background: rgba(10, 10, 10, 0.72);
  border: 1px solid var(--cif-line);
  border-radius: var(--cif-radius);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  box-shadow: var(--cif-shadow-soft);
}

/* Status accent glows — apply via .is-status-* on any cif-* card */
.is-status-ok,
.cif-status-card[data-status="ok"],
.cif-task-card[data-status="approved"],
.cif-task-card[data-status="paid"],
.cif-task-card[data-status="agreed"] {
  box-shadow: inset 0 0 0 1px rgba(34,197,94,.45), 0 0 18px rgba(34,197,94,.18);
}
.is-status-active,
.cif-task-card[data-status="in_progress"] {
  box-shadow: inset 0 0 0 1px rgba(212,175,55,.45), 0 0 18px var(--cif-gold-glow);
}
.is-status-warning,
.cif-status-card[data-status="warning"],
.cif-task-card[data-status="needs_review"],
.cif-task-card[data-status="unpaid"],
.cif-task-card[data-status="pending_agreement"] {
  box-shadow: inset 0 0 0 1px rgba(245,158,11,.45), 0 0 18px rgba(245,158,11,.18);
}
.is-status-danger,
.cif-status-card[data-status="danger"],
.cif-task-card[data-status="blocked"] {
  box-shadow: inset 0 0 0 1px rgba(239,68,68,.45), 0 0 18px rgba(239,68,68,.18);
}

/* On mobile, drop hover-translate so taps are stable */
@media (hover: none), (max-width: 768px) {
  .cif-card-hover:hover,
  .cif-card.is-hoverable:hover,
  .cif-task-card:hover,
  .cif-status-card:hover,
  .cif-finance-card:hover {
    transform: none;
  }
}

/* ──────────────────────────────────────────────────────────
 * BADGES — status pills
 * ────────────────────────────────────────────────────────── */
.cif-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
  line-height: 1.6;
  border: 1px solid transparent;
  white-space: nowrap;
}
.cif-badge::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: .9;
}

.cif-badge-not-started   { background: var(--cif-slate-soft); color: #cbd5e1; border-color: rgba(148,163,184,.3); }
.cif-badge-in-progress   { background: var(--cif-info-soft);  color: #bfdbfe; border-color: rgba(96,165,250,.35); }
.cif-badge-needs-review  { background: var(--cif-warn-soft);  color: #fde68a; border-color: rgba(245,158,11,.35); }
.cif-badge-approved      { background: var(--cif-ok-soft);    color: #bbf7d0; border-color: rgba(34,197,94,.35); }
.cif-badge-blocked       { background: var(--cif-danger-soft);color: #fecaca; border-color: rgba(239,68,68,.35); }
.cif-badge-paid          { background: var(--cif-ok-soft);    color: #bbf7d0; border-color: rgba(34,197,94,.35); }
.cif-badge-unpaid        { background: var(--cif-warn-soft);  color: #fde68a; border-color: rgba(245,158,11,.35); }
.cif-badge-agreed        { background: var(--cif-ok-soft);    color: #bbf7d0; border-color: rgba(34,197,94,.35); }
.cif-badge-pending-agree { background: var(--cif-warn-soft);  color: #fde68a; border-color: rgba(245,158,11,.35); }
.cif-badge-gold          { background: var(--cif-gold-soft);  color: var(--cif-gold-bright); border-color: var(--cif-gold-edge); }

/* ──────────────────────────────────────────────────────────
 * FORMS — unified input / select / textarea
 * Opt-in: add .cif-form to a wrapping <form> or container,
 * OR class .cif-input / .cif-select / .cif-textarea directly.
 * Existing pages with custom styles are unaffected.
 * ────────────────────────────────────────────────────────── */
.cif-input, .cif-select, .cif-textarea,
.cif-form input[type="text"],
.cif-form input[type="number"],
.cif-form input[type="email"],
.cif-form input[type="password"],
.cif-form input[type="search"],
.cif-form input[type="date"],
.cif-form input[type="datetime-local"],
.cif-form input[type="tel"],
.cif-form input[type="url"],
.cif-form select,
.cif-form textarea {
  display: block;
  width: 100%;
  background: var(--cif-surface-2);
  color: var(--cif-text);
  border: 1px solid var(--cif-line-strong);
  border-radius: var(--cif-radius-sm);
  padding: 10px 12px;
  font: inherit;
  font-size: 14px;
  line-height: 1.4;
  transition: border-color var(--cif-trans), box-shadow var(--cif-trans), background var(--cif-trans);
  outline: none;
}
.cif-input:focus, .cif-select:focus, .cif-textarea:focus,
.cif-form input:focus, .cif-form select:focus, .cif-form textarea:focus {
  border-color: var(--cif-gold);
  box-shadow: 0 0 0 3px var(--cif-gold-soft);
}
.cif-input::placeholder, .cif-textarea::placeholder,
.cif-form input::placeholder, .cif-form textarea::placeholder {
  color: var(--cif-text-dim);
}
.cif-input[readonly], .cif-textarea[readonly],
.cif-input:disabled, .cif-select:disabled, .cif-textarea:disabled,
.cif-form input[readonly], .cif-form input:disabled,
.cif-form select:disabled, .cif-form textarea:disabled {
  background: rgba(255,255,255,.03);
  color: var(--cif-text-dim);
  cursor: not-allowed;
}
.cif-input.is-error, .cif-select.is-error, .cif-textarea.is-error,
.cif-form .is-error input, .cif-form .is-error select, .cif-form .is-error textarea {
  border-color: var(--cif-danger);
  box-shadow: 0 0 0 3px rgba(239,68,68,.18);
}

/* Amount input — right-aligned tabular numerals */
.cif-input.is-amount,
input[type="number"].cif-amount-input,
.cif-amount-input {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
  letter-spacing: .01em;
}

/* Form labels and field groups */
.cif-field { display: block; margin-bottom: 14px; }
.cif-field-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--cif-text-mute);
  margin-bottom: 6px;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.cif-field-hint  { font-size: 11.5px; color: var(--cif-text-dim); margin-top: 4px; }
.cif-field-error { font-size: 11.5px; color: var(--cif-danger);   margin-top: 4px; }

/* ──────────────────────────────────────────────────────────
 * TABLES — readable money + sticky header
 * Opt-in: add .cif-table to <table>.
 * ────────────────────────────────────────────────────────── */
.cif-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
  color: var(--cif-text);
}
.cif-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #0a0a0a;
  color: var(--cif-text-mute);
  font-size: 11.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid var(--cif-line-strong);
}
.cif-table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--cif-line);
  vertical-align: middle;
}
.cif-table tbody tr:hover td {
  background: rgba(255,255,255,.025);
}
.cif-table .cif-col-amount,
.cif-table td.cif-amount,
.cif-table th.cif-amount {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
  white-space: nowrap;
}
.cif-table tr.cif-row-total td,
.cif-table tfoot tr td {
  background: var(--cif-gold-soft);
  font-weight: 700;
  color: var(--cif-text);
  border-top: 1px solid var(--cif-gold-edge);
}
.cif-table tr.cif-row-warning td {
  background: rgba(245,158,11,.08);
}
.cif-table tr.cif-row-danger td {
  background: rgba(239,68,68,.08);
}

/* Standalone amount utility — for spans / divs */
.cif-amount,
.cif-tabular {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
.cif-amount-strong {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
  font-weight: 700;
  color: var(--cif-gold-bright);
  letter-spacing: .01em;
}

/* Mobile: horizontal scroll wrapper helper */
.cif-table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--cif-radius-sm);
}

/* ──────────────────────────────────────────────────────────
 * NEXTRISE FINANCE — extra emphasis for amounts
 * Auto-applies on pages with data-visual-mode="finance".
 * ────────────────────────────────────────────────────────── */
[data-visual-mode="finance"] .cif-amount,
[data-visual-mode="finance"] .cif-table td.cif-amount,
[data-visual-mode="finance"] .cif-finance-card .amount,
[data-visual-mode="finance"] .cif-finance-card [data-amount] {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
  letter-spacing: .01em;
}

[data-visual-mode="finance"] .cif-finance-card .amount-final,
[data-visual-mode="finance"] .cif-finance-card [data-amount="final"] {
  color: var(--cif-gold-bright);
  font-weight: 700;
}

/* ──────────────────────────────────────────────────────────
 * BUTTONS — light v1 polish (does NOT override existing styles)
 * Opt-in via .cif-btn-v1.
 * ────────────────────────────────────────────────────────── */
.cif-btn-v1 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: var(--cif-radius-sm);
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--cif-line-strong);
  background: var(--cif-surface-2);
  color: var(--cif-text);
  cursor: pointer;
  transition: all var(--cif-trans);
}
.cif-btn-v1:hover {
  border-color: var(--cif-gold-edge);
  background: var(--cif-surface-3);
}
.cif-btn-v1.is-primary {
  background: linear-gradient(90deg, #c9a227 0%, #d4af37 35%, #f5d16a 55%, #d4af37 100%);
  color: #111;
  border-color: transparent;
}
.cif-btn-v1.is-primary:hover {
  filter: brightness(1.08);
}

/* ──────────────────────────────────────────────────────────
 * REDUCED MOTION — neutralize transitions / lift
 * ────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .cif-card, .cif-task-card, .cif-status-card, .cif-finance-card,
  .cif-card-hover, .cif-btn-v1,
  .cif-input, .cif-select, .cif-textarea,
  .cif-form input, .cif-form select, .cif-form textarea {
    transition: none !important;
  }
  .cif-card-hover:hover, .cif-task-card:hover,
  .cif-status-card:hover, .cif-finance-card:hover {
    transform: none !important;
  }
}
