/**
 * Modern Mood - Design System para Mood CRM
 * ==========================================
 * Tokens CSS padronizados para consistência de marca
 * 
 * Cores Principais:
 * - Creme #F8F3EB (background)
 * - Preto #141414 (textos, bordas)
 * - Lima #E0F431 (destaque, sucesso)
 * - Laranja #EC7014 (CTA, links)
 * - Rosa #F1B3C2 (cards especiais)
 * 
 * Características:
 * - Sombras sólidas (4px 4px 0 0)
 * - Bordas 2px
 * - Border-radius 6px
 */

/* ===================================================================
   GOOGLE FONTS
   =================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Dela+Gothic+One&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ===================================================================
   CSS VARIABLES (TOKENS)
   =================================================================== */
:root {
  /* Cores Primárias Modern Mood */
  --mm-creme: #F8F3EB;
  --mm-black: #141414;
  --mm-lima: #E0F431;
  --mm-orange: #EC7014;
  --mm-pink: #F1B3C2;
  
  /* Cores Secundárias */
  --mm-navy: #041E42;
  --mm-purple: #C789FF;
  --mm-hot-pink: #FF69AE;
  --mm-gold: #FFD166;
  --mm-gray: #EAEBED;
  --mm-white: #FFFFFF;
  
  /* Cores com Alpha */
  --mm-creme-rgb: 248, 243, 235;
  --mm-black-rgb: 20, 20, 20;
  --mm-lima-rgb: 224, 244, 49;
  --mm-orange-rgb: 236, 112, 20;
  --mm-pink-rgb: 241, 179, 194;
  
  /* Cores Funcionais */
  --mm-success: #10B981;
  --mm-warning: #F59E0B;
  --mm-danger: #EF4444;
  --mm-info: #3B82F6;
  
  /* Tipografia */
  --mm-font-heading: 'Dela Gothic One', 'Arial Black', sans-serif;
  --mm-font-body: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mm-font-mono: 'Space Grotesk', 'SF Mono', Monaco, Consolas, monospace;
  
  /* Tamanhos de Fonte */
  --mm-text-xs: 0.625rem;   /* 10px */
  --mm-text-sm: 0.75rem;    /* 12px */
  --mm-text-base: 0.8125rem; /* 13px */
  --mm-text-md: 0.875rem;   /* 14px */
  --mm-text-lg: 1rem;       /* 16px */
  --mm-text-xl: 1.25rem;    /* 20px */
  --mm-text-2xl: 1.5rem;    /* 24px */
  --mm-text-3xl: 1.875rem;  /* 30px */
  --mm-text-4xl: 2.25rem;   /* 36px */
  
  /* Line Heights */
  --mm-leading-tight: 0.9;
  --mm-leading-snug: 1.1;
  --mm-leading-normal: 1.2;
  --mm-leading-relaxed: 1.4;
  --mm-leading-loose: 1.6;
  
  /* Espaçamentos */
  --mm-space-1: 0.25rem;    /* 4px */
  --mm-space-2: 0.5rem;     /* 8px */
  --mm-space-3: 0.75rem;    /* 12px */
  --mm-space-4: 1rem;       /* 16px */
  --mm-space-5: 1.25rem;    /* 20px */
  --mm-space-6: 1.5rem;     /* 24px */
  --mm-space-8: 2rem;       /* 32px */
  --mm-space-10: 2.5rem;    /* 40px */
  --mm-space-12: 3rem;      /* 48px */
  
  /* Bordas */
  --mm-border-width: 2px;
  --mm-radius-sm: 6px;
  --mm-radius-md: 8px;
  --mm-radius-lg: 12px;
  --mm-radius-full: 9999px;
  
  /* Sombras Sólidas Modern Mood */
  --mm-shadow-sm: 4px 4px 0 0;
  --mm-shadow-md: 6px 6px 0 0;
  --mm-shadow-lg: 10px 10px 0 0;
  
  /* Sombras Prontas (com cor) */
  --mm-shadow-lima: 4px 4px 0 0 var(--mm-lima);
  --mm-shadow-orange: 4px 4px 0 0 var(--mm-orange);
  --mm-shadow-black: 4px 4px 0 0 var(--mm-black);
  --mm-shadow-pink: 4px 4px 0 0 var(--mm-pink);
  
  /* Transições */
  --mm-transition-fast: 150ms ease;
  --mm-transition-normal: 250ms ease;
  --mm-transition-slow: 350ms ease;
  
  /* Z-Index Scale */
  --mm-z-dropdown: 1000;
  --mm-z-sticky: 1020;
  --mm-z-fixed: 1030;
  --mm-z-modal-backdrop: 1040;
  --mm-z-modal: 1050;
  --mm-z-popover: 1060;
  --mm-z-tooltip: 1070;
}

/* ===================================================================
   BASE STYLES
   =================================================================== */
*, *::before, *::after {
  box-sizing: border-box;
}

body.mm-theme {
  font-family: var(--mm-font-body);
  font-size: var(--mm-text-md);
  line-height: var(--mm-leading-relaxed);
  color: var(--mm-black);
  background-color: var(--mm-creme);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ===================================================================
   TYPOGRAPHY
   =================================================================== */
.mm-heading {
  font-family: var(--mm-font-heading);
  font-weight: 400;
  line-height: var(--mm-leading-tight);
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--mm-black);
}

.mm-heading-1 { font-size: var(--mm-text-4xl); }
.mm-heading-2 { font-size: var(--mm-text-3xl); }
.mm-heading-3 { font-size: var(--mm-text-2xl); }
.mm-heading-4 { font-size: var(--mm-text-xl); }
.mm-heading-5 { font-size: var(--mm-text-lg); }

.mm-text-xs { font-size: var(--mm-text-xs); }
.mm-text-sm { font-size: var(--mm-text-sm); }
.mm-text-base { font-size: var(--mm-text-base); }
.mm-text-md { font-size: var(--mm-text-md); }
.mm-text-lg { font-size: var(--mm-text-lg); }
.mm-text-xl { font-size: var(--mm-text-xl); }

.mm-text-muted { color: #6B7280; }
.mm-text-lima { color: var(--mm-lima); }
.mm-text-orange { color: var(--mm-orange); }
.mm-text-pink { color: var(--mm-pink); }

/* ===================================================================
   BUTTONS - MODERN MOOD STYLE
   =================================================================== */
.mm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--mm-space-2);
  padding: var(--mm-space-3) var(--mm-space-5);
  font-family: var(--mm-font-body);
  font-size: var(--mm-text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-decoration: none;
  border: var(--mm-border-width) solid var(--mm-black);
  border-radius: var(--mm-radius-sm);
  cursor: pointer;
  transition: transform var(--mm-transition-fast), box-shadow var(--mm-transition-fast);
}

.mm-btn:hover {
  transform: translate(-2px, -2px);
}

.mm-btn:active {
  transform: translate(0, 0);
  box-shadow: none !important;
}

/* Primary Button - Black with Lima */
.mm-btn-primary {
  background: var(--mm-black);
  color: var(--mm-lima);
  box-shadow: var(--mm-shadow-lima);
}

.mm-btn-primary:hover {
  box-shadow: 6px 6px 0 0 var(--mm-lima);
}

/* Secondary Button - Orange */
.mm-btn-secondary {
  background: var(--mm-orange);
  color: var(--mm-white);
  box-shadow: var(--mm-shadow-black);
}

.mm-btn-secondary:hover {
  box-shadow: 6px 6px 0 0 var(--mm-black);
}

/* Outline Button */
.mm-btn-outline {
  background: transparent;
  color: var(--mm-black);
  box-shadow: var(--mm-shadow-black);
}

.mm-btn-outline:hover {
  background: var(--mm-black);
  color: var(--mm-lima);
}

/* Ghost Button */
.mm-btn-ghost {
  background: transparent;
  color: var(--mm-black);
  border-color: transparent;
  box-shadow: none;
}

.mm-btn-ghost:hover {
  background: rgba(var(--mm-black-rgb), 0.05);
  transform: none;
}

/* Button Sizes */
.mm-btn-sm {
  padding: var(--mm-space-2) var(--mm-space-3);
  font-size: var(--mm-text-xs);
}

.mm-btn-lg {
  padding: var(--mm-space-4) var(--mm-space-8);
  font-size: var(--mm-text-md);
}

/* Success/Danger Variants */
.mm-btn-success {
  background: var(--mm-lima);
  color: var(--mm-black);
  box-shadow: var(--mm-shadow-black);
}

.mm-btn-danger {
  background: var(--mm-danger);
  color: var(--mm-white);
  box-shadow: var(--mm-shadow-black);
}

/* ===================================================================
   CARDS - MODERN MOOD STYLE
   =================================================================== */
.mm-card {
  background: var(--mm-white);
  border: var(--mm-border-width) solid var(--mm-black);
  border-radius: var(--mm-radius-sm);
  box-shadow: var(--mm-shadow-black);
  overflow: hidden;
}

.mm-card-header {
  padding: var(--mm-space-4) var(--mm-space-5);
  border-bottom: var(--mm-border-width) solid var(--mm-black);
  background: var(--mm-creme);
}

.mm-card-title {
  font-family: var(--mm-font-heading);
  font-size: var(--mm-text-lg);
  text-transform: uppercase;
  margin: 0;
}

.mm-card-body {
  padding: var(--mm-space-5);
}

.mm-card-footer {
  padding: var(--mm-space-4) var(--mm-space-5);
  border-top: 1px solid var(--mm-gray);
  background: var(--mm-creme);
}

/* Card Variants */
.mm-card-lima {
  box-shadow: var(--mm-shadow-lima);
}

.mm-card-orange {
  box-shadow: var(--mm-shadow-orange);
}

.mm-card-pink {
  background: var(--mm-pink);
  box-shadow: var(--mm-shadow-black);
}

.mm-card-dark {
  background: var(--mm-black);
  color: var(--mm-creme);
  box-shadow: var(--mm-shadow-lima);
}

.mm-card-dark .mm-card-header {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.1);
}

/* Hover Effect */
.mm-card-hover {
  transition: transform var(--mm-transition-fast), box-shadow var(--mm-transition-fast);
}

.mm-card-hover:hover {
  transform: translate(-4px, -4px);
  box-shadow: 8px 8px 0 0 var(--mm-black);
}

/* ===================================================================
   INPUTS - MODERN MOOD STYLE
   =================================================================== */
.mm-input {
  width: 100%;
  padding: var(--mm-space-3) var(--mm-space-4);
  font-family: var(--mm-font-body);
  font-size: var(--mm-text-md);
  color: var(--mm-black);
  background: var(--mm-white);
  border: var(--mm-border-width) solid var(--mm-black);
  border-radius: var(--mm-radius-sm);
  transition: box-shadow var(--mm-transition-fast);
}

.mm-input:focus {
  outline: none;
  box-shadow: var(--mm-shadow-lima);
}

.mm-input::placeholder {
  color: #9CA3AF;
}

.mm-input-error {
  border-color: var(--mm-danger);
  box-shadow: 4px 4px 0 0 var(--mm-danger);
}

/* Textarea */
.mm-textarea {
  min-height: 100px;
  resize: vertical;
}

/* Select */
.mm-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23141414' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: var(--mm-space-10);
}

/* Label */
.mm-label {
  display: block;
  font-size: var(--mm-text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--mm-space-2);
  color: var(--mm-black);
}

/* Form Group */
.mm-form-group {
  margin-bottom: var(--mm-space-5);
}

/* ===================================================================
   BADGES & TAGS
   =================================================================== */
.mm-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--mm-space-1) var(--mm-space-3);
  font-size: var(--mm-text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--mm-radius-full);
  border: 1px solid currentColor;
}

.mm-badge-lima {
  background: var(--mm-lima);
  color: var(--mm-black);
  border-color: var(--mm-black);
}

.mm-badge-orange {
  background: var(--mm-orange);
  color: var(--mm-white);
  border-color: var(--mm-orange);
}

.mm-badge-pink {
  background: var(--mm-pink);
  color: var(--mm-black);
  border-color: var(--mm-black);
}

.mm-badge-dark {
  background: var(--mm-black);
  color: var(--mm-lima);
  border-color: var(--mm-black);
}

.mm-badge-success {
  background: rgba(16, 185, 129, 0.15);
  color: #059669;
  border-color: #059669;
}

.mm-badge-warning {
  background: rgba(245, 158, 11, 0.15);
  color: #D97706;
  border-color: #D97706;
}

.mm-badge-danger {
  background: rgba(239, 68, 68, 0.15);
  color: #DC2626;
  border-color: #DC2626;
}

/* ===================================================================
   TABLES
   =================================================================== */
.mm-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.mm-table th,
.mm-table td {
  padding: var(--mm-space-3) var(--mm-space-4);
  text-align: left;
  border-bottom: 1px solid var(--mm-gray);
}

.mm-table th {
  font-family: var(--mm-font-body);
  font-size: var(--mm-text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6B7280;
  background: var(--mm-creme);
}

.mm-table tbody tr:hover {
  background: rgba(var(--mm-lima-rgb), 0.1);
}

/* ===================================================================
   MODALS
   =================================================================== */
.mm-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(var(--mm-black-rgb), 0.6);
  backdrop-filter: blur(4px);
  z-index: var(--mm-z-modal-backdrop);
}

.mm-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--mm-white);
  border: var(--mm-border-width) solid var(--mm-black);
  border-radius: var(--mm-radius-sm);
  box-shadow: 8px 8px 0 0 var(--mm-black);
  z-index: var(--mm-z-modal);
}

.mm-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--mm-space-4) var(--mm-space-5);
  border-bottom: var(--mm-border-width) solid var(--mm-black);
  background: var(--mm-lima);
}

.mm-modal-title {
  font-family: var(--mm-font-heading);
  font-size: var(--mm-text-lg);
  text-transform: uppercase;
  margin: 0;
}

.mm-modal-close {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--mm-black);
  color: var(--mm-lima);
  border: none;
  border-radius: var(--mm-radius-sm);
  cursor: pointer;
  font-size: 1.2rem;
}

.mm-modal-body {
  padding: var(--mm-space-5);
}

.mm-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--mm-space-3);
  padding: var(--mm-space-4) var(--mm-space-5);
  border-top: 1px solid var(--mm-gray);
  background: var(--mm-creme);
}

/* ===================================================================
   SIDEBAR NAVIGATION
   =================================================================== */
.mm-sidebar {
  width: 260px;
  background: var(--mm-white);
  border-right: var(--mm-border-width) solid var(--mm-black);
  height: 100vh;
  position: fixed;
  overflow-y: auto;
}

.mm-sidebar-logo {
  padding: var(--mm-space-5);
  border-bottom: var(--mm-border-width) solid var(--mm-black);
  background: var(--mm-creme);
}

.mm-sidebar-logo img {
  max-width: 140px;
  height: auto;
}

.mm-nav-item {
  display: flex;
  align-items: center;
  gap: var(--mm-space-3);
  padding: var(--mm-space-3) var(--mm-space-5);
  color: var(--mm-black);
  text-decoration: none;
  font-size: var(--mm-text-md);
  font-weight: 500;
  border-left: 3px solid transparent;
  transition: all var(--mm-transition-fast);
}

.mm-nav-item:hover {
  background: rgba(var(--mm-lima-rgb), 0.2);
  border-left-color: var(--mm-lima);
}

.mm-nav-item.active {
  background: var(--mm-lima);
  color: var(--mm-black);
  font-weight: 600;
  border-left-color: var(--mm-black);
}

.mm-nav-icon {
  width: 20px;
  text-align: center;
}

.mm-nav-badge {
  margin-left: auto;
  background: var(--mm-orange);
  color: var(--mm-white);
  padding: 2px 8px;
  border-radius: var(--mm-radius-full);
  font-size: var(--mm-text-xs);
  font-weight: 700;
}

/* ===================================================================
   STATS / KPI CARDS
   =================================================================== */
.mm-stat-card {
  background: var(--mm-white);
  border: var(--mm-border-width) solid var(--mm-black);
  border-radius: var(--mm-radius-sm);
  padding: var(--mm-space-5);
  box-shadow: var(--mm-shadow-black);
  transition: transform var(--mm-transition-fast), box-shadow var(--mm-transition-fast);
}

.mm-stat-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 0 var(--mm-black);
}

.mm-stat-label {
  font-size: var(--mm-text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #6B7280;
  margin-bottom: var(--mm-space-2);
}

.mm-stat-value {
  font-family: var(--mm-font-heading);
  font-size: var(--mm-text-3xl);
  color: var(--mm-black);
  line-height: 1;
}

.mm-stat-change {
  display: inline-flex;
  align-items: center;
  gap: var(--mm-space-1);
  font-size: var(--mm-text-sm);
  margin-top: var(--mm-space-2);
}

.mm-stat-change.positive { color: var(--mm-success); }
.mm-stat-change.negative { color: var(--mm-danger); }

/* Colored Stat Cards */
.mm-stat-card-lima {
  box-shadow: var(--mm-shadow-lima);
}

.mm-stat-card-orange {
  box-shadow: var(--mm-shadow-orange);
}

.mm-stat-card-pink {
  background: var(--mm-pink);
}

/* ===================================================================
   ALERTS / NOTIFICATIONS
   =================================================================== */
.mm-alert {
  display: flex;
  align-items: flex-start;
  gap: var(--mm-space-3);
  padding: var(--mm-space-4);
  border: var(--mm-border-width) solid var(--mm-black);
  border-radius: var(--mm-radius-sm);
  margin-bottom: var(--mm-space-4);
}

.mm-alert-icon {
  font-size: 1.25rem;
  flex-shrink: 0;
}

.mm-alert-title {
  font-weight: 700;
  margin-bottom: var(--mm-space-1);
}

.mm-alert-success {
  background: rgba(var(--mm-lima-rgb), 0.3);
  border-color: var(--mm-black);
}

.mm-alert-warning {
  background: var(--mm-gold);
  border-color: var(--mm-black);
}

.mm-alert-danger {
  background: rgba(239, 68, 68, 0.15);
  border-color: var(--mm-danger);
}

.mm-alert-info {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--mm-info);
}

/* ===================================================================
   LOADING STATES
   =================================================================== */
.mm-spinner {
  width: 24px;
  height: 24px;
  border: 3px solid var(--mm-gray);
  border-top-color: var(--mm-orange);
  border-radius: 50%;
  animation: mm-spin 0.8s linear infinite;
}

@keyframes mm-spin {
  to { transform: rotate(360deg); }
}

.mm-skeleton {
  background: linear-gradient(90deg, var(--mm-gray) 25%, #f5f5f5 50%, var(--mm-gray) 75%);
  background-size: 200% 100%;
  animation: mm-shimmer 1.5s infinite;
  border-radius: var(--mm-radius-sm);
}

@keyframes mm-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ===================================================================
   UTILITY CLASSES
   =================================================================== */

/* Backgrounds */
.mm-bg-creme { background-color: var(--mm-creme); }
.mm-bg-black { background-color: var(--mm-black); }
.mm-bg-lima { background-color: var(--mm-lima); }
.mm-bg-orange { background-color: var(--mm-orange); }
.mm-bg-pink { background-color: var(--mm-pink); }
.mm-bg-white { background-color: var(--mm-white); }

/* Text Colors */
.mm-color-black { color: var(--mm-black); }
.mm-color-lima { color: var(--mm-lima); }
.mm-color-orange { color: var(--mm-orange); }
.mm-color-pink { color: var(--mm-pink); }
.mm-color-creme { color: var(--mm-creme); }

/* Borders */
.mm-border { border: var(--mm-border-width) solid var(--mm-black); }
.mm-border-lima { border-color: var(--mm-lima); }
.mm-border-orange { border-color: var(--mm-orange); }
.mm-border-pink { border-color: var(--mm-pink); }

/* Shadows */
.mm-shadow { box-shadow: var(--mm-shadow-black); }
.mm-shadow-lima { box-shadow: var(--mm-shadow-lima); }
.mm-shadow-orange { box-shadow: var(--mm-shadow-orange); }
.mm-shadow-pink { box-shadow: var(--mm-shadow-pink); }
.mm-shadow-none { box-shadow: none; }

/* Border Radius */
.mm-rounded { border-radius: var(--mm-radius-sm); }
.mm-rounded-md { border-radius: var(--mm-radius-md); }
.mm-rounded-lg { border-radius: var(--mm-radius-lg); }
.mm-rounded-full { border-radius: var(--mm-radius-full); }

/* Flexbox */
.mm-flex { display: flex; }
.mm-flex-center { display: flex; align-items: center; justify-content: center; }
.mm-flex-between { display: flex; align-items: center; justify-content: space-between; }
.mm-gap-1 { gap: var(--mm-space-1); }
.mm-gap-2 { gap: var(--mm-space-2); }
.mm-gap-3 { gap: var(--mm-space-3); }
.mm-gap-4 { gap: var(--mm-space-4); }
.mm-gap-5 { gap: var(--mm-space-5); }

/* Padding */
.mm-p-1 { padding: var(--mm-space-1); }
.mm-p-2 { padding: var(--mm-space-2); }
.mm-p-3 { padding: var(--mm-space-3); }
.mm-p-4 { padding: var(--mm-space-4); }
.mm-p-5 { padding: var(--mm-space-5); }
.mm-p-6 { padding: var(--mm-space-6); }

/* Margin */
.mm-m-0 { margin: 0; }
.mm-mb-1 { margin-bottom: var(--mm-space-1); }
.mm-mb-2 { margin-bottom: var(--mm-space-2); }
.mm-mb-3 { margin-bottom: var(--mm-space-3); }
.mm-mb-4 { margin-bottom: var(--mm-space-4); }
.mm-mb-5 { margin-bottom: var(--mm-space-5); }

/* Text */
.mm-uppercase { text-transform: uppercase; }
.mm-font-bold { font-weight: 700; }
.mm-text-center { text-align: center; }
.mm-text-right { text-align: right; }

/* ===================================================================
   DARK MODE OVERRIDE
   =================================================================== */
@media (prefers-color-scheme: dark) {
  :root.mm-auto-dark {
    --mm-creme: #1a1a1a;
    --mm-white: #242424;
    --mm-black: #F8F3EB;
    --mm-gray: #333333;
  }
}

/* Manual Dark Mode Class */
.mm-dark {
  --mm-creme: #1a1a1a;
  --mm-white: #242424;
  --mm-black: #F8F3EB;
  --mm-gray: #333333;
}
