/* ============================================================
   FDV Holding ERP - Ambiental UI Theme Layer
   Visual-only overrides. No functional selectors are renamed.
   Source: shared/fdv-ui-themes/.../themes/ambiental
   ============================================================ */

:root {
  --theme-name: "Ambiental UI Theme";

  --ambient-bg-0: #031519;
  --ambient-bg-1: #04222b;
  --ambient-bg-2: #062d35;
  --ambient-panel: rgba(8, 43, 50, 0.86);
  --ambient-panel-strong: rgba(10, 53, 61, 0.94);
  --ambient-panel-soft: rgba(255, 255, 255, 0.04);
  --ambient-border: rgba(141, 174, 187, 0.18);
  --ambient-border-strong: rgba(23, 212, 207, 0.32);
  --ambient-cyan: #17d4cf;
  --ambient-green: #20c772;
  --ambient-warning: #ffb84d;
  --ambient-danger: #f06464;
  --ambient-info: #57a6ff;
  --ambient-text: #f4fbfb;
  --ambient-text-2: #c6dce2;
  --ambient-muted: #8daebb;
  --ambient-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.18);
  --ambient-shadow-md: 0 12px 30px rgba(0, 0, 0, 0.22);
  --ambient-shadow-float: 0 20px 60px rgba(0, 0, 0, 0.26);
  --ambient-focus: 0 0 0 3px rgba(23, 212, 207, 0.22);

  --navy: var(--ambient-bg-1);
  --navy-deep: var(--ambient-bg-0);
  --navy-light: var(--ambient-bg-2);
  --navy-card: var(--ambient-panel);
  --navy-hover: rgba(23, 212, 207, 0.10);
  --mint: var(--ambient-cyan);
  --mint-dim: rgba(23, 212, 207, 0.13);
  --mint-glow: rgba(23, 212, 207, 0.08);
  --teal: var(--ambient-green);
  --teal-dim: rgba(32, 199, 114, 0.18);
  --gray: var(--ambient-text-2);
  --muted: var(--ambient-muted);
  --border: var(--ambient-border);
  --border-sub: rgba(141, 174, 187, 0.12);
  --border-color: var(--ambient-border);
  --text: var(--ambient-text-2);
  --text-secondary: var(--ambient-muted);
  --surface-1: rgba(8, 43, 50, 0.90);
  --surface-2: rgba(5, 31, 38, 0.88);
  --surface-3: rgba(255, 255, 255, 0.045);
  --focus-ring: rgba(23, 212, 207, 0.40);

  --color-ingreso: var(--ambient-green);
  --color-egreso: var(--ambient-danger);
  --color-neutral: var(--ambient-text-2);
  --color-warning: var(--ambient-warning);
  --color-info: var(--ambient-info);

  --font-title: "Space Grotesk", Inter, system-ui, sans-serif;
  --font-body: Inter, "Space Grotesk", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --radius-xs: 6px;
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 12px;

  --shadow-card: var(--ambient-shadow-md);
  --shadow-glow: 0 0 0 1px rgba(23, 212, 207, 0.04);
  --shadow-modal: var(--ambient-shadow-float);
}

html,
body {
  background:
    linear-gradient(180deg, #031519 0%, #04222b 48%, #031519 100%);
  color: var(--ambient-text);
}

body {
  font-family: var(--font-body);
}

button,
input,
select,
textarea {
  letter-spacing: 0;
}

button:focus-visible,
.nav-item:focus-visible,
.module-toggle:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.btn-icon-close:focus-visible,
.notifications-btn:focus-visible {
  outline: none;
  box-shadow: var(--ambient-focus);
}

/* Login */
.login-screen {
  background:
    linear-gradient(135deg, rgba(23, 212, 207, 0.10), transparent 34%),
    linear-gradient(225deg, rgba(32, 199, 114, 0.10), transparent 38%),
    #031519;
}

.login-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.065), rgba(255,255,255,0.025)),
    var(--ambient-panel-strong);
  border-color: var(--ambient-border-strong);
  box-shadow: var(--ambient-shadow-float), inset 0 1px 0 rgba(255,255,255,0.08);
}

.brand-dot-grid span {
  background: var(--ambient-cyan);
}

.brand-fdv,
.login-title,
.page-title,
.section-title,
.table-card-title,
.chart-title,
.modal-title {
  color: var(--ambient-text);
}

.brand-bi,
.brand-tagline,
.brand-sub,
.text-mint {
  color: var(--ambient-cyan);
}

.login-sub,
.muted,
.text-muted,
.kpi-sub,
.empresa-label,
.user-badge {
  color: var(--ambient-muted);
}

/* Shell */
.app-shell {
  background:
    linear-gradient(rgba(141, 174, 187, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(141, 174, 187, 0.018) 1px, transparent 1px),
    linear-gradient(180deg, #031519 0%, #04222b 52%, #031519 100%);
  background-size: 36px 36px, 36px 36px, auto;
}

.app-shell::before,
.dashboard-modern::before,
.dashboard-hero::before {
  display: none;
}

.main-content {
  background: transparent;
}

.sidebar {
  background:
    linear-gradient(180deg, rgba(23, 212, 207, 0.08), transparent 220px),
    rgba(3, 21, 25, 0.96);
  border-right-color: var(--ambient-border-strong);
  box-shadow: 10px 0 34px rgba(0, 0, 0, 0.24);
}

.sidebar-brand {
  background: rgba(3, 21, 25, 0.96);
  border-bottom-color: rgba(23, 212, 207, 0.22);
  backdrop-filter: blur(14px);
}

.module-toggle {
  color: rgba(23, 212, 207, 0.82);
}

.module-toggle:hover,
.module-group.open > .module-toggle {
  color: var(--ambient-text);
  background: linear-gradient(90deg, rgba(23, 212, 207, 0.12), transparent 76%);
}

.module-chevron {
  color: var(--ambient-muted);
}

.nav-item {
  color: var(--ambient-muted);
  border: 1px solid transparent;
}

.nav-item:hover {
  color: var(--ambient-text);
  background: rgba(23, 212, 207, 0.075);
  border-color: rgba(23, 212, 207, 0.10);
}

.nav-item.active {
  color: var(--ambient-text);
  background:
    linear-gradient(90deg, rgba(23, 212, 207, 0.24), rgba(32, 199, 114, 0.08)),
    rgba(23, 212, 207, 0.08);
  border-color: rgba(23, 212, 207, 0.25);
  box-shadow:
    inset 3px 0 0 var(--ambient-cyan),
    0 8px 22px rgba(0, 0, 0, 0.18);
}

.nav-item.active::after {
  display: none;
}

.top-bar {
  background: rgba(3, 21, 25, 0.82);
  border-bottom-color: rgba(23, 212, 207, 0.22);
  box-shadow: inset 0 -1px 0 rgba(255,255,255,0.035);
  backdrop-filter: blur(16px);
}

.page-title::before {
  background: var(--ambient-cyan);
  box-shadow: 0 0 18px rgba(23, 212, 207, 0.46);
}

.view {
  color: var(--ambient-text-2);
}

/* Surfaces */
.login-card,
.top-bar,
.kpi-card,
.table-card,
.chart-card,
.diag-lane,
.diag-card,
.diag-report-head,
.crm-leads-card,
.crm-campaign-card,
.dashboard-hero,
.dashboard-hero-metrics,
.pago-item,
dialog,
.notifications-panel,
.wa-sidebar,
.wa-main,
.wa-header,
.wa-side-panel,
.md-shell,
.md-panel,
.md-table-card,
.md-records-wrap,
.nb-layout,
.nb-months,
.nb-pages,
.nb-content {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
    var(--ambient-panel);
  border-color: var(--ambient-border);
  box-shadow: var(--ambient-shadow-sm), inset 0 1px 0 rgba(255,255,255,0.055);
}

.kpi-card,
.table-card,
.chart-card,
.dashboard-modern .kpi-card,
.dashboard-modern .chart-card,
.dashboard-modern .table-card,
.crm-leads-card,
.crm-campaign-card {
  border-radius: var(--radius-lg);
}

.kpi-card:hover,
.chart-card:hover,
.diag-card:hover,
.pago-item:hover {
  border-color: var(--ambient-border-strong);
  box-shadow: var(--ambient-shadow-md), inset 0 1px 0 rgba(255,255,255,0.075);
}

.dashboard-hero {
  background:
    linear-gradient(135deg, rgba(23, 212, 207, 0.16), rgba(32, 199, 114, 0.08) 42%, rgba(3, 21, 25, 0.88)),
    var(--ambient-panel);
  border-color: rgba(23, 212, 207, 0.24);
}

.dashboard-hero::after {
  background: linear-gradient(90deg, transparent, rgba(23, 212, 207, 0.62), transparent);
}

.dashboard-eyebrow {
  color: var(--ambient-cyan);
  background: rgba(23, 212, 207, 0.09);
  border-color: rgba(23, 212, 207, 0.25);
}

.dashboard-hero p,
.dashboard-hero-metrics span,
.dashboard-hero-metrics small,
.crm-leads-header p,
.crm-campaign-header p,
.crm-campaign-detail-head span {
  color: var(--ambient-muted);
}

.dashboard-hero-metrics strong,
.kpi-pos,
.saldo-label span:last-child {
  color: var(--ambient-cyan);
}

.kpi-card::before {
  box-shadow: none;
}

.kpi-label {
  color: var(--ambient-muted);
  letter-spacing: 0.08em;
}

.kpi-value {
  color: var(--ambient-text);
}

/* Tables */
.table-card-header,
.modal-header,
.notifications-head,
.wa-header {
  background: rgba(255,255,255,0.026);
  border-color: rgba(141, 174, 187, 0.13);
}

table {
  color: var(--ambient-text-2);
}

th,
.dashboard-modern th,
.crm-campaign-matrix thead th {
  background: rgba(3, 21, 25, 0.96);
  color: var(--ambient-muted);
  border-bottom-color: rgba(23, 212, 207, 0.16);
}

td,
.crm-campaign-matrix tbody td {
  color: var(--ambient-text-2);
  border-bottom-color: rgba(141, 174, 187, 0.10);
}

tbody tr:hover td,
.dashboard-modern tbody tr:hover td,
.crm-campaign-matrix tbody tr:hover th,
.crm-campaign-matrix tbody tr:hover td {
  background: rgba(23, 212, 207, 0.045);
}

.table-empty,
.loading-placeholder,
.notif-empty {
  color: var(--ambient-muted);
}

/* Forms */
label {
  color: var(--ambient-muted);
  letter-spacing: 0.08em;
}

input,
select,
textarea,
.form-control,
.filter-input,
.empresa-selector {
  min-height: 40px;
  background: rgba(3, 21, 25, 0.68);
  border-color: rgba(141, 174, 187, 0.18);
  color: var(--ambient-text);
  border-radius: var(--radius-sm);
}

input::placeholder,
textarea::placeholder {
  color: rgba(141, 174, 187, 0.68);
}

input:hover,
select:hover,
textarea:hover,
.form-control:hover,
.filter-input:hover {
  border-color: rgba(23, 212, 207, 0.32);
  background: rgba(3, 21, 25, 0.82);
}

input:focus,
select:focus,
textarea:focus,
.form-control:focus,
.filter-input:focus {
  border-color: var(--ambient-cyan);
  background: rgba(3, 21, 25, 0.94);
  box-shadow: var(--ambient-focus);
}

select option,
select optgroup {
  background: #04222b;
  color: var(--ambient-text);
}

.check-option input {
  accent-color: var(--ambient-cyan);
}

/* Buttons */
.btn-primary {
  color: #031519;
  background: linear-gradient(135deg, var(--ambient-cyan), var(--ambient-green));
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.32), 0 8px 18px rgba(0, 0, 0, 0.18);
}

.btn-primary:hover {
  filter: brightness(1.05);
  box-shadow: var(--ambient-focus), 0 12px 24px rgba(0, 0, 0, 0.24);
}

.btn-secondary,
.btn-ghost-sm,
.btn-icon-close {
  background: rgba(255,255,255,0.035);
  border-color: rgba(141, 174, 187, 0.20);
  color: var(--ambient-text-2);
}

.btn-secondary:hover,
.btn-ghost-sm:hover,
.btn-icon-close:hover {
  background: rgba(23, 212, 207, 0.08);
  border-color: rgba(23, 212, 207, 0.34);
  color: var(--ambient-text);
}

.btn-danger {
  background: rgba(240, 100, 100, 0.11);
  border-color: rgba(240, 100, 100, 0.36);
  color: #ff9a9a;
}

.btn-danger:hover {
  background: rgba(240, 100, 100, 0.18);
}

.btn-sm {
  border-radius: var(--radius-xs);
}

/* Badges and semantic states */
.badge {
  border: 1px solid rgba(255,255,255,0.055);
  box-shadow: none;
}

.badge-ingreso,
.badge-activo,
.badge-pagado,
.badge-ganada,
.badge-cobrada,
.badge-enviada,
.badge-aceptada,
.badge-baja,
.badge-listo,
.badge-lead_to_cash,
.badge-holding {
  background: rgba(32, 199, 114, 0.13);
  color: #74e7ad;
}

.badge-egreso,
.badge-vencido,
.badge-perdida,
.badge-anulada,
.badge-rechazada,
.badge-alta {
  background: rgba(240, 100, 100, 0.13);
  color: #ff9a9a;
}

.badge-pendiente,
.badge-pausado,
.badge-parcial,
.badge-simple,
.badge-recurrente,
.badge-contrato,
.badge-producto_fisico,
.badge-variable {
  background: rgba(255, 184, 77, 0.13);
  color: #ffd28b;
}

.badge-abierta,
.badge-borrador,
.badge-facturada,
.badge-servicio,
.badge-producto_digital,
.badge-admin,
.badge-manager,
.badge-usuario,
.badge-media,
.badge-en-progreso,
.badge-venta_facturada,
.badge-oportunidad_vendida,
.badge-lead_oportunidad,
.badge-terminado {
  background: rgba(23, 212, 207, 0.12);
  color: #8be9e7;
}

.badge-inactivo,
.badge-cancelado,
.badge-stand-by {
  background: rgba(141, 174, 187, 0.10);
  color: var(--ambient-muted);
}

/* Notifications and modal */
.notifications-btn {
  background: rgba(23, 212, 207, 0.11);
  border-color: rgba(23, 212, 207, 0.30);
  color: var(--ambient-cyan);
}

.notifications-btn:hover {
  background: rgba(23, 212, 207, 0.17);
}

.notifications-count {
  background: var(--ambient-warning);
  color: #031519;
}

.notif-item:hover {
  background: rgba(23, 212, 207, 0.06);
}

dialog {
  border-color: rgba(23, 212, 207, 0.24);
}

dialog::backdrop {
  background: rgba(3, 12, 15, 0.74);
  backdrop-filter: blur(5px);
}

.modal-body {
  color: var(--ambient-text-2);
}

.error-msg {
  background: rgba(240, 100, 100, 0.12);
  border-color: rgba(240, 100, 100, 0.28);
  color: #ffb1b1;
}

.spinner {
  border-color: rgba(141, 174, 187, 0.20);
  border-top-color: var(--ambient-cyan);
  filter: drop-shadow(0 0 12px rgba(23, 212, 207, 0.22));
}

.loading-placeholder:has(.spinner)::after {
  background: linear-gradient(90deg, rgba(255,255,255,0.035), rgba(23, 212, 207,0.16), rgba(255,255,255,0.035));
}

/* Module-specific surfaces */
.diag-chip,
.crm-leads-stat,
.crm-campaign-insights > span,
.crm-campaign-matrix-wrap,
.crm-campaign-table-wrap,
.progress-wrap,
.saldo-track {
  background: rgba(3, 21, 25, 0.48);
  border-color: rgba(141, 174, 187, 0.14);
}

.progress-bar,
.saldo-fill,
.dashboard-modern .saldo-fill,
.dashboard-modern .progress-bar {
  background: linear-gradient(90deg, var(--ambient-cyan), var(--ambient-green));
  box-shadow: 0 0 16px rgba(23, 212, 207, 0.18);
}

.mini-bar.ingreso,
.crm-leads-day.best .crm-leads-bar {
  background: linear-gradient(to top, #159762, var(--ambient-green));
}

.mini-bar.egreso {
  background: linear-gradient(to top, #9a3434, var(--ambient-danger));
}

.crm-leads-bar {
  background: linear-gradient(180deg, #65deda 0%, #17d4cf 58%, #0c8c91 100%);
}

.crm-leads-day.today .crm-leads-label {
  color: #8be9e7;
}

.crm-campaign-matrix thead th.current {
  background: rgba(23, 212, 207, 0.13);
  color: #b3f4f2;
}

.crm-campaign-attribution {
  color: #ffd28b !important;
  background: rgba(255, 184, 77, 0.12);
}

.crm-invoice-status.paid strong { color: #74e7ad; }
.crm-invoice-status.pending strong,
.crm-invoice-status.due-today strong { color: #ffd28b; }
.crm-invoice-status.overdue strong { color: #ff9a9a; }

::-webkit-scrollbar-thumb {
  background: rgba(23, 212, 207, 0.24);
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(23, 212, 207, 0.42);
}

@media (max-width: 640px) {
  .view {
    padding: 20px 16px;
  }

  .top-bar {
    padding: 0 16px;
  }

  .login-card {
    padding: 34px 24px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}


/* CRM paid media spend block */
.crm-spend-card { border-color: rgba(255, 184, 77, 0.28); }
.crm-leads-legend-dot.spend,
.crm-spend-day.spend .crm-leads-bar {
  background: linear-gradient(180deg, #ffd28b 0%, var(--ambient-warning) 58%, #b66e15 100%);
}
.crm-spend-day.best .crm-leads-bar {
  background: linear-gradient(180deg, #ffe2a8 0%, #ffbd59 58%, #c77d1a 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.30), 0 0 14px rgba(255, 184, 77, 0.20);
}
.crm-spend-day.best .crm-leads-value { color: #ffd28b; }
