/* ============================================
   GLOBAL COLOR SYSTEM - Unica fonte di verità
   ============================================ */

:root {
  /* DARK GLASS THEME COLORS */
  --g-bg: oklch(0.18 0.02 250);
  --g-bg-soft: oklch(0.24 0.025 250);
  --g-surface: oklch(0.24 0.028 250 / 0.88);
  --g-surface-strong: oklch(0.2 0.03 250 / 0.95);
  
  /* TEXT COLORS */
  --g-text: oklch(0.97 0.01 240);
  --g-muted: oklch(0.8 0.02 240);
  
  /* SEMANTIC COLORS */
  --g-accent: oklch(0.68 0.11 180);
  --g-accent-strong: oklch(0.58 0.11 190);
  --g-danger: oklch(0.73 0.13 25);
  --g-success: oklch(0.78 0.12 150);
  
  /* BORDERS & LINES */
  --g-line: rgba(255, 255, 255, 0.12);
  --g-line-subtle: rgba(255, 255, 255, 0.06);
  
  /* COMPONENT COLORS (specific use cases) */
  --g-blue-primary: #3b82f6;
  --g-blue-primary-light: #38bdf8;
  --g-green-primary: #22c55e;
  --g-amber-primary: #f59e0b;
  --g-amber-dark: #d97706;
  --g-slate-muted: #64748b;
  --g-slate-surface: #1e293b;
  --g-slate-surface-light: #94a3b8;
  
  /* LIGHT MODE COLORS */
  --l-bg: oklch(0.96 0.014 85);
  --l-bg-strong: oklch(0.9 0.025 85);
  --l-surface: oklch(0.985 0.008 75);
  --l-surface-soft: oklch(0.972 0.012 80);
  --l-line: oklch(0.84 0.018 80);
  --l-text: oklch(0.23 0.018 60);
  --l-muted: oklch(0.48 0.015 60);
  --l-accent: oklch(0.43 0.09 145);
  --l-accent-strong: oklch(0.36 0.095 145);
  --l-accent-soft: oklch(0.9 0.05 145);
  --l-danger-soft: oklch(0.93 0.035 25);
  --l-danger-text: oklch(0.46 0.12 25);
  --l-success-soft: oklch(0.94 0.045 145);
  --l-success-text: oklch(0.41 0.09 145);
  
  /* EFFECTS */
  --g-radius-lg: 20px;
  --g-radius-xl: 30px;
  --g-radius-md: 14px;
  --g-radius-sm: 10px;
  --g-shadow: 0 30px 60px rgba(2, 6, 23, 0.35);
  --l-shadow: 0 24px 60px rgba(66, 44, 10, 0.12);
}

* {
  box-sizing: border-box;
}

/* ============================================
   DARK GLASS THEME OVERRIDES
   ============================================ */

body.force-glass {
  margin: 0;
  color: var(--g-text) !important;
  font-family: 'Manrope', sans-serif !important;
  background:
    radial-gradient(circle at top, rgba(37, 99, 235, 0.18), transparent 35%),
    radial-gradient(circle at bottom right, rgba(20, 184, 166, 0.16), transparent 30%),
    linear-gradient(180deg, var(--g-bg) 0%, var(--g-bg-soft) 100%) !important;
}

body.force-glass h1,
body.force-glass h2,
body.force-glass h3,
body.force-glass h4,
body.force-glass h5,
body.force-glass h6 {
  color: var(--g-text);
  font-family: 'Space Grotesk', sans-serif;
}

body.force-glass p,
body.force-glass small,
body.force-glass label,
body.force-glass .text-muted,
body.force-glass .muted,
body.force-glass .hint {
  color: var(--g-muted) !important;
}

body.force-glass input,
body.force-glass select,
body.force-glass textarea {
  background: rgba(15, 23, 42, 0.62) !important;
  color: var(--g-text) !important;
  border: 1px solid var(--g-line) !important;
  border-radius: var(--g-radius-md);
}

body.force-glass input:focus,
body.force-glass select:focus,
body.force-glass textarea:focus {
  outline: none;
  border-color: rgba(45, 212, 191, 0.55) !important;
  box-shadow: 0 0 0 4px rgba(45, 212, 191, 0.12) !important;
}

body.force-glass button,
body.force-glass .btn,
body.force-glass .submit,
body.force-glass .btn-primary,
body.force-glass .action-btn {
  border: 1px solid transparent;
  border-radius: var(--g-radius-md);
  background: linear-gradient(180deg, var(--g-accent), var(--g-accent-strong)) !important;
  color: oklch(0.17 0.01 250) !important;
  font-weight: 800;
}

body.force-glass .card,
body.force-glass .frame,
body.force-glass .panel,
body.force-glass .sidebar,
body.force-glass .modal-content,
body.force-glass .wallet-card,
body.force-glass .qr-section,
body.force-glass .status,
body.force-glass .navbar,
body.force-glass .info-scadenza,
body.force-glass .risultato-ricerca,
body.force-glass .movimento-item,
body.force-glass .negozio-item,
body.force-glass .pane,
body.force-glass .scene,
body.force-glass .hero,
body.force-glass .history-section {
  background: var(--g-surface) !important;
  border: 1px solid var(--g-line) !important;
  box-shadow: var(--g-shadow);
  backdrop-filter: blur(20px);
  color: var(--g-text) !important;
}

body.force-glass .overlay {
  background: linear-gradient(rgba(2, 6, 23, 0.65), rgba(2, 6, 23, 0.92)) !important;
}

body.force-glass .eyebrow,
body.force-glass .badge,
body.force-glass .chip,
body.force-glass .switcher button,
body.force-glass .ghost-link {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--g-muted) !important;
  border-color: var(--g-line) !important;
}

body.force-glass .switcher button.active,
body.force-glass .chip.active {
  background: rgba(255, 255, 255, 0.16) !important;
  color: var(--g-text) !important;
}

body.force-glass .msg.error,
body.force-glass .feedback.error,
body.force-glass .inline-msg.error,
body.force-glass .form-msg.error {
  background: rgba(239, 68, 68, 0.14) !important;
  color: var(--g-danger) !important;
  border-color: rgba(239, 68, 68, 0.2) !important;
}

body.force-glass .msg.success,
body.force-glass .msg.ok,
body.force-glass .feedback.success,
body.force-glass .inline-msg.success,
body.force-glass .form-msg.success {
  background: rgba(16, 185, 129, 0.14) !important;
  color: var(--g-success) !important;
  border-color: rgba(16, 185, 129, 0.2) !important;
}

body.force-glass table,
body.force-glass th,
body.force-glass td,
body.force-glass .modal-table,
body.force-glass .modal-table th,
body.force-glass .modal-table td {
  border-color: var(--g-line) !important;
  color: var(--g-text) !important;
  background: transparent;
}

body.force-glass .modal {
  background: rgba(2, 6, 23, 0.8) !important;
}

/* ============================================
   REUSABLE COMPONENT STYLES
   ============================================ */

/* CARD COMPONENTS */
.card-title {
  margin: 0 0 14px 0;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--g-text);
}

.card-subtitle {
  margin: 0 0 12px 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--g-muted);
}

.card-body {
  color: var(--g-muted);
  line-height: 1.6;
  font-size: 0.93rem;
}

/* FORM COMPONENTS */
.form-group {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.form-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--g-text);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.form-hint {
  font-size: 0.82rem;
  color: var(--g-muted);
  font-weight: 500;
}

/* BUTTON VARIANTS */
.btn-secondary {
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--g-muted) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  color: var(--g-text) !important;
}

.btn-danger {
  background: rgba(239, 68, 68, 0.14) !important;
  color: var(--g-danger) !important;
  border: 1px solid rgba(239, 68, 68, 0.2) !important;
}

.btn-success {
  background: rgba(34, 197, 94, 0.14) !important;
  color: var(--g-success) !important;
  border: 1px solid rgba(34, 197, 94, 0.2) !important;
}

/* STATUS BADGES */
.badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.badge-pending {
  background: rgba(71, 85, 105, 0.14);
  color: rgba(255, 255, 255, 0.6);
}

.badge-demo {
  background: rgba(245, 158, 11, 0.18);
  color: var(--g-amber-primary);
}

.badge-active {
  background: rgba(34, 197, 94, 0.14);
  color: var(--g-success);
}

/* SECTION DIVIDERS */
.section-divider {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  margin: 18px 0;
  padding-top: 18px;
}

/* HELP TEXT */
.help-text {
  font-size: 0.82rem;
  color: var(--g-muted);
  margin-top: 8px;
  line-height: 1.5;
}

@media (max-width: 860px) {
  body.force-glass {
    background:
      radial-gradient(circle at top, rgba(37, 99, 235, 0.22), transparent 40%),
      linear-gradient(180deg, var(--g-bg) 0%, var(--g-bg-soft) 100%) !important;
  }
}
