/* ─── Mathera Sistemas — Identidade Visual Unificada ──────────────────────
 * Compartilhada entre Mathera ERP e Mathera Personal.
 * Variáveis CSS centralizadas pra manter coerência visual entre produtos.
 * Inspirada em: Apple, Notion, Nubank, Duolingo.
 * ───────────────────────────────────────────────────────────────────────── */

:root {
  /* ── Cores base (dark navy, mesmas do ERP) ──────────────────────────── */
  --ms-bg:           #060814;
  --ms-bg-2:         #0a0f25;
  --ms-surface:      #131730;
  --ms-surface-2:    #1a1f3e;
  --ms-border:       #2a2f55;
  --ms-text:         #f1f5f9;
  --ms-text-soft:    #cbd5e1;
  --ms-text-muted:   #94a3b8;
  --ms-text-subtle:  #64748b;

  /* ── Cores da marca ──────────────────────────────────────────────────── */
  --ms-primary:      #6366f1;
  --ms-primary-soft: rgba(99, 102, 241, 0.15);
  --ms-primary-glow: rgba(99, 102, 241, 0.4);
  --ms-accent:       #22d3ee;
  --ms-accent-soft:  rgba(34, 211, 238, 0.15);

  /* ── Status ──────────────────────────────────────────────────────────── */
  --ms-success:      #10b981;
  --ms-warning:      #f59e0b;
  --ms-danger:       #f87171;
  --ms-info:         #3b82f6;

  /* ── Cores específicas do Personal ───────────────────────────────────── */
  /* Ranking/streaks/conquistas — paleta mais "energia positiva" */
  --ms-personal-streak: #f59e0b;        /* laranja calorzinho */
  --ms-personal-meta:   #10b981;        /* verde meta cumprida */
  --ms-personal-saldo:  #6366f1;        /* indigo saldo positivo */
  --ms-personal-alerta: #ef4444;        /* vermelho gastou demais */

  /* ── Categorias de gasto (Personal) ──────────────────────────────────── */
  --ms-cat-alimentacao: #f97316;
  --ms-cat-transporte:  #06b6d4;
  --ms-cat-moradia:     #a855f7;
  --ms-cat-lazer:       #ec4899;
  --ms-cat-saude:       #10b981;
  --ms-cat-educacao:    #3b82f6;
  --ms-cat-compras:     #f59e0b;
  --ms-cat-investimento: #14b8a6;
  --ms-cat-outros:      #94a3b8;

  /* ── Tipografia ──────────────────────────────────────────────────────── */
  --ms-font-base: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
                  'Helvetica Neue', Arial, sans-serif;
  --ms-font-mono: 'SF Mono', Menlo, Monaco, Consolas, 'Courier New', monospace;

  /* ── Espaçamentos e radius ───────────────────────────────────────────── */
  --ms-radius-sm: 8px;
  --ms-radius:    12px;
  --ms-radius-lg: 18px;
  --ms-radius-xl: 24px;

  /* ── Sombras ─────────────────────────────────────────────────────────── */
  --ms-shadow-sm: 0 4px 12px rgba(0, 0, 0, 0.2);
  --ms-shadow:    0 10px 30px rgba(0, 0, 0, 0.3);
  --ms-shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.4);
  --ms-glow:      0 0 40px var(--ms-primary-glow);

  /* ── Transições ──────────────────────────────────────────────────────── */
  --ms-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ms-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ────────────────────────────────────────────────────────────────────────
 * Reset + base
 * ──────────────────────────────────────────────────────────────────────── */
* { box-sizing: border-box; }

body {
  margin: 0; padding: 0;
  font-family: var(--ms-font-base);
  background: var(--ms-bg);
  color: var(--ms-text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

a { color: var(--ms-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ────────────────────────────────────────────────────────────────────────
 * Botões padrão
 * ──────────────────────────────────────────────────────────────────────── */
.ms-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: inherit; cursor: pointer; border: 0;
  padding: 12px 22px; border-radius: var(--ms-radius);
  font-weight: 700; font-size: 14.5px;
  transition: transform 0.15s var(--ms-ease), box-shadow 0.15s;
  text-decoration: none;
  white-space: nowrap;
}
.ms-btn:hover { transform: translateY(-1px); }
.ms-btn-primary {
  background: linear-gradient(135deg, var(--ms-primary), var(--ms-accent));
  color: #fff !important;
  box-shadow: 0 8px 24px var(--ms-primary-glow);
}
.ms-btn-secondary {
  background: var(--ms-surface);
  color: var(--ms-text) !important;
  border: 1px solid var(--ms-border);
}
.ms-btn-ghost {
  background: transparent;
  color: var(--ms-text-soft) !important;
}
.ms-btn-lg { padding: 14px 28px; font-size: 15px; }
.ms-btn-xl { padding: 16px 32px; font-size: 16px; }
.ms-btn-block { width: 100%; }

/* ────────────────────────────────────────────────────────────────────────
 * Cards
 * ──────────────────────────────────────────────────────────────────────── */
.ms-card {
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius-lg);
  padding: 24px;
}
.ms-card-elevated {
  background: linear-gradient(180deg, var(--ms-surface), var(--ms-surface-2));
  box-shadow: var(--ms-shadow);
}

/* ────────────────────────────────────────────────────────────────────────
 * Topbar/brand padrão (compartilhado entre ERP e Personal)
 * ──────────────────────────────────────────────────────────────────────── */
.ms-topbar {
  position: sticky; top: 0; z-index: 100;
  padding: 16px 24px;
  background: rgba(6, 8, 20, 0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--ms-border);
  display: flex; justify-content: space-between; align-items: center;
}
.ms-brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 800; font-size: 18px; color: #fff;
  text-decoration: none;
}
.ms-brand-icon {
  height: 38px; display: flex; align-items: center;
  background: transparent; color: transparent; font-size: 0;
  flex-shrink: 0;
}
.ms-brand-icon img {
  height: 100%; width: auto; display: block;
  font-size: 0; color: transparent;
}
.ms-brand-product {
  font-size: 12px; font-weight: 700;
  padding: 3px 10px; border-radius: 999px;
  margin-left: 4px;
  background: var(--ms-primary-soft);
  color: var(--ms-accent);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ms-nav { display: flex; gap: 18px; align-items: center; }
.ms-nav a {
  color: var(--ms-text-soft); font-size: 14px; font-weight: 600;
  text-decoration: none;
}
.ms-nav a:hover { color: #fff; }

/* ────────────────────────────────────────────────────────────────────────
 * Container padrão
 * ──────────────────────────────────────────────────────────────────────── */
.ms-container {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
}
.ms-container-narrow {
  max-width: 720px; margin: 0 auto; padding: 0 24px;
}

/* ────────────────────────────────────────────────────────────────────────
 * Tipografia destacada (heros, sections)
 * ──────────────────────────────────────────────────────────────────────── */
.ms-display {
  font-size: clamp(36px, 6vw, 64px);
  font-weight: 900; line-height: 1.05;
  letter-spacing: -0.03em; margin: 0;
  background: linear-gradient(135deg, #fff 0%, #c4b5fd 50%, var(--ms-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.ms-h1 {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 900; margin: 0 0 16px;
  letter-spacing: -0.02em; color: #fff;
}
.ms-lead {
  font-size: clamp(15px, 2vw, 18px);
  color: var(--ms-text-soft);
  line-height: 1.6;
}

/* ────────────────────────────────────────────────────────────────────────
 * Pill / Badge
 * ──────────────────────────────────────────────────────────────────────── */
.ms-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 999px;
  font-size: 12.5px; font-weight: 700;
  background: var(--ms-primary-soft);
  color: var(--ms-accent);
  border: 1px solid rgba(99, 102, 241, 0.3);
}
.ms-pill-success { background: rgba(16, 185, 129, 0.15); color: var(--ms-success); border-color: rgba(16, 185, 129, 0.3); }
.ms-pill-warning { background: rgba(245, 158, 11, 0.15); color: var(--ms-warning); border-color: rgba(245, 158, 11, 0.3); }
.ms-pill-danger  { background: rgba(248, 113, 113, 0.15); color: var(--ms-danger); border-color: rgba(248, 113, 113, 0.3); }

/* ────────────────────────────────────────────────────────────────────────
 * Footer compartilhado
 * ──────────────────────────────────────────────────────────────────────── */
.ms-footer {
  border-top: 1px solid var(--ms-border);
  padding: 30px 24px;
  text-align: center;
  font-size: 13px; color: var(--ms-text-muted);
}
.ms-footer a { color: var(--ms-text-soft); margin: 0 10px; }

/* ────────────────────────────────────────────────────────────────────────
 * Animações utilitárias
 * ──────────────────────────────────────────────────────────────────────── */
@keyframes ms-fadein {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes ms-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}
.ms-animate-in { animation: ms-fadein 0.5s var(--ms-ease); }

/* Mobile */
@media (max-width: 720px) {
  .ms-nav a:not(.ms-btn) { display: none; }
}
