/* corporatesell.css - Estilos consolidados para o módulo corporatesell */

:root {
  /* Cores baseadas na logo Meu Preceptor */
  --color-primary-dark: #173234; /* Teal escuro da logo - background principal */
  --color-primary-dark-hover: #1f4245; /* Teal escuro mais claro para hover */
  --color-accent-green: #8CC63F; /* Verde lima do ícone */
  --color-accent-green-dark: #6B9E32; /* Verde mais escuro para hover */
  --color-accent-green-light: #A8D85F; /* Verde claro para backgrounds sutis */
  --color-accent-green-subtle: rgba(140, 198, 63, 0.1); /* Verde muito sutil */
  
  /* Cores neutras para layout minimalista e clean */
  --color-background: #FAFAFA; /* Branco suave */
  --color-background-alt: #FFFFFF; /* Branco puro */
  --color-background-subtle: #F5F5F5; /* Cinza muito claro */
  --color-text-primary: #1A363A; /* Texto principal escuro */
  --color-text-secondary: #64748B; /* Texto secundário */
  --color-text-light: #FFFFFF; /* Texto claro */
  --color-text-muted: #94A3B8; /* Texto desbotado */
  --color-border: #E2E8F0; /* Borda suave */
  --color-border-light: #F1F5F9; /* Borda muito clara */
  --color-shadow: rgba(23, 50, 52, 0.06); /* Sombra suave */
  --color-shadow-hover: rgba(23, 50, 52, 0.12); /* Sombra hover */
  --color-shadow-lg: rgba(23, 50, 52, 0.15); /* Sombra grande */
  
  /* Estados */
  --color-success: #22C55E;
  --color-success-light: #D1FAE5;
  --color-error: #EF4444;
  --color-error-light: #FEE2E2;
  --color-warning: #F59E0B;
  --color-warning-light: #FEF3C7;
  
  /* Espaçamentos */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-2xl: 48px;
  
  /* Bordas */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  
  /* Transições */
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
}

/* Reset e Base */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background-color: var(--color-background);
  color: var(--color-text-primary);
  line-height: 1.6;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.01em;
}

/* Header */
.header {
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  padding: var(--spacing-lg) 0;
  box-shadow: 0 1px 3px var(--color-shadow);
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.header-content {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--spacing-xl);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

.header-logo {
  height: 44px;
  width: auto;
  object-fit: contain;
  filter: brightness(1.05);
}

.company-info h1 {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 2px;
  color: var(--color-text-light);
  letter-spacing: -0.02em;
}

.company-info p {
  font-size: 13px;
  opacity: 0.75;
  color: var(--color-text-light);
  font-weight: 400;
}

.header-content h1 {
  font-size: 20px;
  font-weight: 600;
  color: var(--color-text-light);
  letter-spacing: -0.02em;
}

/* Navigation */
.nav {
  display: flex;
  gap: var(--spacing-xs);
}

.nav a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 500;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  position: relative;
}

.nav a:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-text-light);
}

.nav a.active {
  background: rgba(140, 198, 63, 0.15);
  color: var(--color-accent-green);
  font-weight: 600;
}

.nav a.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60%;
  height: 2px;
  background: var(--color-accent-green);
  border-radius: 2px;
}

/* Container */
.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--spacing-2xl) var(--spacing-xl);
}

/* Page Header */
.page-header {
  margin-bottom: var(--spacing-2xl);
  padding-bottom: var(--spacing-lg);
  border-bottom: 1px solid var(--color-border-light);
}

.page-header h2 {
  font-size: 32px;
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-sm);
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.page-header p {
  color: var(--color-text-secondary);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
}

/* Cards e Sections */
.section {
  background: var(--color-background-alt);
  padding: var(--spacing-2xl);
  border-radius: var(--radius-xl);
  box-shadow: 0 1px 3px var(--color-shadow);
  border: 1px solid var(--color-border);
  margin-bottom: var(--spacing-xl);
  transition: all var(--transition-base);
}

.section:hover {
  box-shadow: 0 4px 12px var(--color-shadow-hover);
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-xl);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid var(--color-border-light);
}

.section-header h2 {
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
}

.count-badge {
  background: var(--color-background-subtle);
  color: var(--color-text-secondary);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* Stats Grid */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-2xl);
}

.stat-card {
  background: var(--color-background-alt);
  padding: var(--spacing-xl);
  border-radius: var(--radius-xl);
  box-shadow: 0 1px 3px var(--color-shadow);
  border: 1px solid var(--color-border);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-accent-green), var(--color-accent-green-light));
  opacity: 0;
  transition: opacity var(--transition-base);
}

.stat-card:hover {
  box-shadow: 0 8px 16px var(--color-shadow-hover);
  transform: translateY(-4px);
  border-color: var(--color-accent-green-subtle);
}

.stat-card:hover::before {
  opacity: 1;
}

.stat-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--spacing-lg);
}

.stat-card-header h3 {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.stat-card .value {
  font-size: 36px;
  font-weight: 700;
  color: var(--color-primary-dark);
  line-height: 1;
  letter-spacing: -0.03em;
}

.stat-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}

.stat-icon.blue {
  background: rgba(59, 130, 246, 0.1);
  color: #3B82F6;
}

.stat-icon.green {
  background: var(--color-accent-green-subtle);
  color: var(--color-accent-green-dark);
}

.stat-icon.purple {
  background: rgba(139, 92, 246, 0.1);
  color: #8B5CF6;
}

.badge-warning {
  background: var(--color-warning-light);
  color: #92400E;
}

/* Forms */
.form-group {
  margin-bottom: var(--spacing-lg);
}

.form-group label {
  display: block;
  margin-bottom: var(--spacing-sm);
  color: var(--color-text-primary);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.01em;
}

.form-group label .required {
  color: var(--color-error);
}

.form-group input,
.form-group select {
  width: 100%;
  padding: var(--spacing-md) var(--spacing-lg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 15px;
  transition: all var(--transition-base);
  background: var(--color-background-alt);
  color: var(--color-text-primary);
  font-family: inherit;
}

.form-group input::placeholder {
  color: var(--color-text-muted);
}

.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--color-accent-green);
  box-shadow: 0 0 0 4px var(--color-accent-green-subtle);
  background: var(--color-background-alt);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}

.form-section {
  margin-bottom: var(--spacing-2xl);
}

.form-section-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 2px solid var(--color-border-light);
  letter-spacing: -0.02em;
}

/* Buttons */
button,
.button {
  padding: var(--spacing-md) var(--spacing-xl);
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border: none;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  transition: all var(--transition-base);
  font-family: inherit;
  letter-spacing: -0.01em;
  position: relative;
  overflow: hidden;
}

button::before,
.button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  transition: left var(--transition-slow);
}

button:hover::before,
.button:hover::before {
  left: 100%;
}

button:hover,
.button:hover {
  background: var(--color-primary-dark-hover);
  transform: translateY(-2px);
  box-shadow: 0 6px 12px var(--color-shadow-hover);
}

button:active,
.button:active {
  transform: translateY(0);
  box-shadow: 0 2px 4px var(--color-shadow);
}

.button.secondary {
  background: var(--color-background-alt);
  color: var(--color-primary-dark);
  border: 1.5px solid var(--color-primary-dark);
}

.button.secondary:hover {
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border-color: var(--color-primary-dark);
}

/* Botões alternativos (para compatibilidade) */
.btn-primary {
  padding: var(--spacing-md) var(--spacing-xl);
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border: none;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  transition: all var(--transition-base);
  font-family: inherit;
  letter-spacing: -0.01em;
}

.btn-primary:hover {
  background: var(--color-primary-dark-hover);
  transform: translateY(-2px);
  box-shadow: 0 6px 12px var(--color-shadow-hover);
}

.btn-secondary {
  padding: var(--spacing-md) var(--spacing-xl);
  background: var(--color-background-alt);
  color: var(--color-primary-dark);
  border: 1.5px solid var(--color-primary-dark);
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  transition: all var(--transition-base);
  font-family: inherit;
  letter-spacing: -0.01em;
}

.btn-secondary:hover {
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border-color: var(--color-primary-dark);
}

/* Form actions */
.form-actions {
  display: flex;
  gap: var(--spacing-md);
  margin-top: var(--spacing-xl);
  flex-wrap: wrap;
}

.form-actions button,
.form-actions .btn-primary,
.form-actions .btn-secondary {
  flex: 1;
  min-width: 200px;
}

/* Alerts */
.error,
.alert {
  background: var(--color-error-light);
  color: #991B1B;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-xl);
  font-size: 14px;
  border: 1px solid rgba(239, 68, 68, 0.2);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.success {
  background: var(--color-success-light);
  color: #166534;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-xl);
  font-size: 14px;
  border: 1px solid rgba(34, 197, 94, 0.2);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

th, td {
  padding: var(--spacing-lg);
  text-align: left;
  border-bottom: 1px solid var(--color-border-light);
}

th {
  background: var(--color-background-subtle);
  font-weight: 600;
  color: var(--color-text-secondary);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

td {
  color: var(--color-text-primary);
  font-size: 14px;
  font-weight: 400;
}

tbody tr {
  transition: all var(--transition-fast);
}

tbody tr:hover {
  background: var(--color-background-subtle);
}

tbody tr:last-child td {
  border-bottom: none;
}

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.badge-success {
  background: var(--color-success-light);
  color: #065F46;
}

.badge-danger {
  background: var(--color-error-light);
  color: #991B1B;
}

/* Code Cell */
.code-cell {
  font-family: 'Courier New', 'Monaco', monospace;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-accent-green-dark);
}

/* Action Links */
.action-link {
  color: var(--color-accent-green-dark);
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  transition: all var(--transition-base);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.action-link:hover {
  color: var(--color-accent-green);
  text-decoration: none;
  gap: var(--spacing-sm);
}

/* Pagination */
.pagination {
  margin-top: var(--spacing-xl);
  display: flex;
  justify-content: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}

.pagination a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-background-alt);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 500;
  border: 1px solid var(--color-border);
  transition: all var(--transition-base);
  min-width: 40px;
}

.pagination a:hover {
  background: var(--color-background-subtle);
  border-color: var(--color-accent-green);
  color: var(--color-accent-green-dark);
}

.pagination a.active {
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border-color: var(--color-primary-dark);
}

/* Filters */
.filters {
  background: var(--color-background-alt);
  padding: var(--spacing-lg) var(--spacing-xl);
  border-radius: var(--radius-xl);
  box-shadow: 0 1px 3px var(--color-shadow);
  border: 1px solid var(--color-border);
  margin-bottom: var(--spacing-xl);
  display: flex;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}

.filters a {
  padding: var(--spacing-sm) var(--spacing-lg);
  border-radius: var(--radius-md);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  transition: all var(--transition-base);
  background: var(--color-background-subtle);
  color: var(--color-text-secondary);
  border: 1px solid transparent;
}

.filters a:hover {
  background: var(--color-border-light);
  border-color: var(--color-border);
}

.filters a.active {
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border-color: var(--color-primary-dark);
}

/* Empty State */
.empty-state {
  text-align: center;
  padding: var(--spacing-2xl) var(--spacing-xl);
  color: var(--color-text-secondary);
}

.empty-state svg {
  width: 80px;
  height: 80px;
  margin-bottom: var(--spacing-xl);
  opacity: 0.3;
  color: var(--color-text-muted);
}

.empty-state h3 {
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-sm);
  letter-spacing: -0.02em;
}

.empty-state p {
  font-size: 16px;
  margin-bottom: var(--spacing-xl);
  color: var(--color-text-secondary);
}

/* Auth Pages */
body.auth-page {
  background: linear-gradient(135deg, #FAFAFA 0%, #F5F5F5 50%, #FAFAFA 100%);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  position: relative;
}

body.auth-page::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    radial-gradient(circle at 20% 30%, rgba(140, 198, 63, 0.05) 0%, transparent 60%),
    radial-gradient(circle at 80% 70%, rgba(23, 50, 52, 0.03) 0%, transparent 60%);
  pointer-events: none;
}

body.register-page {
  background: linear-gradient(135deg, #FAFAFA 0%, #F5F5F5 50%, #FAFAFA 100%);
  min-height: 100vh;
  padding: var(--spacing-2xl) var(--spacing-xl);
  position: relative;
}

body.register-page::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    radial-gradient(circle at 20% 30%, rgba(140, 198, 63, 0.05) 0%, transparent 60%),
    radial-gradient(circle at 80% 70%, rgba(23, 50, 52, 0.03) 0%, transparent 60%);
  pointer-events: none;
}

.auth-container {
  background: var(--color-primary-dark);
  border-radius: var(--radius-2xl);
  box-shadow: 
    0 20px 60px -12px rgba(23, 50, 52, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.08);
  padding: var(--spacing-2xl) var(--spacing-xl);
  max-width: 440px;
  width: 100%;
  position: relative;
  z-index: 1;
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
}

.auth-container .logo {
  text-align: center;
  margin-bottom: 0;
  padding: 0;
  border-bottom: none;
  margin-top: -8px;
}

.auth-container .logo img {
  height: 80px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.3));
  margin-bottom: 24px;
}

.auth-container h1 {
  color: var(--color-text-light);
  margin-bottom: var(--spacing-md);
  margin-top: 0;
  text-align: center;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.auth-container .subtitle {
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin-bottom: var(--spacing-2xl);
  font-size: 15px;
  line-height: 1.6;
  font-weight: 400;
}

.auth-container .register-link,
.auth-container .login-link {
  text-align: center;
  margin-top: 24px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
}

.auth-container .register-link a,
.auth-container .login-link a {
  color: var(--color-accent-green);
  text-decoration: none;
  font-weight: 500;
}

.auth-container .register-link a:hover,
.auth-container .login-link a:hover {
  color: var(--color-accent-green-light);
  text-decoration: underline;
}

/* Form styles dentro do auth-container */
.auth-container .form-group label {
  color: rgba(255, 255, 255, 0.9);
}

.auth-container .form-group input {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--color-text-primary);
}

.auth-container .form-group input:focus {
  background: var(--color-background);
  border-color: var(--color-accent-green);
  box-shadow: 0 0 0 3px rgba(140, 198, 63, 0.2);
}

.auth-container .error {
  background: rgba(239, 68, 68, 0.15);
  color: #FEE2E2;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

.auth-container button,
.auth-container button[type="submit"] {
  background: var(--color-accent-green) !important;
  color: var(--color-text-light) !important;
  width: 100%;
  margin-top: 8px;
}

.auth-container button:hover,
.auth-container button[type="submit"]:hover {
  background: var(--color-accent-green-light) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(140, 198, 63, 0.3);
}

/* Register Page */
.register-container {
  max-width: 900px;
  margin: 0 auto;
  background: var(--color-primary-dark);
  border-radius: var(--radius-2xl);
  box-shadow: 
    0 20px 60px -12px rgba(23, 50, 52, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.08);
  padding: var(--spacing-2xl) var(--spacing-2xl);
  position: relative;
  z-index: 1;
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
}

.register-container .header {
  text-align: center;
  margin-bottom: 48px;
  background: transparent;
  box-shadow: none;
  position: static;
  padding-bottom: 32px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.register-container .header h1 {
  color: var(--color-text-light);
}

.register-container .header .subtitle {
  color: rgba(255, 255, 255, 0.85);
}

.register-container .header .logo {
  margin-bottom: 24px;
  text-align: center;
}

.register-container .header .logo img {
  height: 72px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.3));
}

/* Form styles dentro do register-container */
.register-container .form-group label {
  color: rgba(255, 255, 255, 0.9);
}

.register-container .form-group input,
.register-container .form-group select {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--color-text-primary);
}

.register-container .form-group input:focus,
.register-container .form-group select:focus {
  background: var(--color-background);
  border-color: var(--color-accent-green);
  box-shadow: 0 0 0 3px rgba(140, 198, 63, 0.2);
}

.register-container .form-section-title {
  color: var(--color-text-light);
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

.register-container .error {
  background: rgba(239, 68, 68, 0.15);
  color: #FEE2E2;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

.register-container button,
.register-container button[type="submit"] {
  background: var(--color-accent-green) !important;
  color: var(--color-text-light) !important;
  width: 100%;
  margin-top: 8px;
}

.register-container button:hover,
.register-container button[type="submit"]:hover {
  background: var(--color-accent-green-light) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px rgba(140, 198, 63, 0.3);
}

.register-container .login-link {
  color: rgba(255, 255, 255, 0.8);
}

.register-container .login-link a {
  color: var(--color-accent-green);
}

.register-container .login-link a:hover {
  color: var(--color-accent-green-light);
}

/* Packages Page */
.packages-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--spacing-xl);
}

.package-card {
  background: var(--color-background-alt);
  border-radius: var(--radius-xl);
  box-shadow: 0 1px 3px var(--color-shadow);
  border: 1.5px solid var(--color-border);
  overflow: hidden;
  transition: all var(--transition-base);
  display: flex;
  flex-direction: column;
  position: relative;
}

.package-card:hover {
  box-shadow: 0 12px 32px -8px var(--color-shadow-hover);
  transform: translateY(-6px);
  border-color: var(--color-accent-green);
}

.package-card.featured {
  border: 2px solid var(--color-accent-green);
  position: relative;
}

.package-card.featured::before {
  content: 'Mais Popular';
  position: absolute;
  top: 20px;
  right: -32px;
  background: var(--color-accent-green);
  color: var(--color-text-light);
  padding: var(--spacing-xs) 44px;
  font-size: 11px;
  font-weight: 700;
  transform: rotate(45deg);
  box-shadow: 0 4px 8px rgba(23, 50, 52, 0.2);
  letter-spacing: 0.5px;
  z-index: 10;
}

.package-header {
  padding: var(--spacing-2xl) var(--spacing-xl) var(--spacing-xl);
  background: var(--color-background-subtle);
  border-bottom: 1px solid var(--color-border-light);
}

.package-card h3 {
  font-size: 26px;
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-sm);
  letter-spacing: -0.02em;
}

.package-card .description {
  color: var(--color-text-secondary);
  font-size: 15px;
  line-height: 1.6;
  font-weight: 400;
}

.package-price {
  padding: var(--spacing-xl);
  text-align: center;
  background: var(--color-background-subtle);
  border-bottom: 1px solid var(--color-border-light);
}

.package-price .price {
  font-size: 52px;
  font-weight: 700;
  color: var(--color-accent-green-dark);
  line-height: 1;
  margin-bottom: var(--spacing-sm);
  letter-spacing: -0.03em;
}

.package-price .price-label {
  color: var(--color-text-secondary);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 600;
}

.package-details {
  padding: var(--spacing-xl);
  flex-grow: 1;
}

.package-details h4 {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: var(--spacing-lg);
}

.detail-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border-light);
}

.detail-item:last-child {
  border-bottom: none;
}

.detail-item .label {
  color: var(--color-text-secondary);
  font-size: 14px;
}

.detail-item .value {
  color: var(--color-text-primary);
  font-weight: 600;
  font-size: 14px;
}

.package-footer {
  padding: var(--spacing-xl);
  border-top: 1px solid var(--color-border-light);
  background: var(--color-background-subtle);
}

.package-card button {
  width: 100%;
  padding: var(--spacing-md) var(--spacing-xl);
  background: var(--color-primary-dark);
  color: var(--color-text-light);
  border: none;
  border-radius: var(--radius-md);
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  letter-spacing: -0.01em;
}

.package-card button:hover {
  background: var(--color-accent-green-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 12px var(--color-shadow-hover);
}

.package-card button:active {
  transform: translateY(0);
}

.package-card button:disabled {
  background: var(--color-text-muted);
  cursor: not-allowed;
  transform: none;
  opacity: 0.6;
}

/* Coupon Details */
.card {
  background: var(--color-background-alt);
  padding: var(--spacing-2xl);
  border-radius: var(--radius-xl);
  box-shadow: 0 1px 3px var(--color-shadow);
  border: 1px solid var(--color-border);
}

.coupon-code {
  font-size: 40px;
  font-weight: 700;
  color: var(--color-accent-green-dark);
  text-align: center;
  margin: var(--spacing-2xl) 0;
  font-family: 'Courier New', 'Monaco', monospace;
  padding: var(--spacing-xl);
  background: var(--color-accent-green-subtle);
  border-radius: var(--radius-lg);
  border: 2px dashed var(--color-accent-green);
  letter-spacing: 3px;
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-lg);
  margin: var(--spacing-2xl) 0;
}

.info-item {
  padding: var(--spacing-lg);
  background: var(--color-background-subtle);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  transition: all var(--transition-base);
}

.info-item:hover {
  border-color: var(--color-accent-green-subtle);
  box-shadow: 0 2px 8px var(--color-shadow);
}

.info-item label {
  display: block;
  color: var(--color-text-secondary);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}

.info-item .value {
  font-size: 18px;
  font-weight: 600;
  color: var(--color-text-primary);
}

.usage-section {
  margin-top: var(--spacing-2xl);
  padding: var(--spacing-xl);
  background: var(--color-warning-light);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.usage-section h3 {
  font-size: 18px;
  font-weight: 600;
  color: #92400E;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Purchase Success */
.success-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 24px;
  background: var(--color-success);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-light);
  font-size: 40px;
  animation: scaleIn 0.5s ease-out;
}

@keyframes scaleIn {
  from {
    transform: scale(0);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

.purchase-container {
  background: var(--color-background-alt);
  padding: var(--spacing-2xl);
  border-radius: var(--radius-xl);
  box-shadow: 0 20px 25px -5px var(--color-shadow-lg);
  max-width: 600px;
  width: 100%;
  text-align: center;
  border: 1px solid var(--color-border);
}

.purchase-container h1 {
  color: var(--color-text-primary);
  margin-bottom: 12px;
  font-size: 28px;
  font-weight: 600;
}

.purchase-container .message {
  color: var(--color-text-secondary);
  margin-bottom: 32px;
  font-size: 16px;
  line-height: 1.6;
}

.coupons-list {
  text-align: left;
  margin: var(--spacing-2xl) 0;
  padding: var(--spacing-xl);
  background: var(--color-background-subtle);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  max-height: 300px;
  overflow-y: auto;
}

.coupons-list h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 16px;
}

.coupon-item {
  padding: 12px 16px;
  margin: 8px 0;
  background: var(--color-background);
  border-radius: 8px;
  font-family: 'Courier New', 'Monaco', monospace;
  font-size: 14px;
  font-weight: 600;
  color: var(--color-accent-green-dark);
  border: 1px solid var(--color-border-light);
}

.buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Error Page */
.error-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 24px;
  background: var(--color-error);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-light);
  font-size: 40px;
  animation: scaleIn 0.5s ease-out;
}

.error-container {
  background: var(--color-background-alt);
  padding: var(--spacing-2xl);
  border-radius: var(--radius-xl);
  box-shadow: 0 20px 25px -5px var(--color-shadow-lg);
  max-width: 600px;
  width: 100%;
  text-align: center;
  border: 1px solid var(--color-border);
}

.error-container h1 {
  color: var(--color-text-primary);
  margin-bottom: 12px;
  font-size: 28px;
  font-weight: 600;
}

.error-container .message {
  color: var(--color-text-secondary);
  margin-bottom: 32px;
  font-size: 16px;
  line-height: 1.6;
}

/* Loading */
.loading {
  text-align: center;
  padding: 48px;
  color: var(--color-text-secondary);
}

/* Responsive */
@media (max-width: 768px) {
  .header-content {
    flex-direction: column;
    gap: var(--spacing-lg);
    padding: 0 var(--spacing-md);
  }
  
  .header-left {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-md);
  }
  
  .nav {
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }
  
  .nav a {
    font-size: 13px;
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .container {
    padding: var(--spacing-xl) var(--spacing-md);
  }
  
  .page-header h2 {
    font-size: 26px;
  }
  
  .stats {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  
  .section {
    padding: var(--spacing-lg);
  }
  
  .auth-container,
  .register-container {
    padding: var(--spacing-xl) var(--spacing-lg);
    margin: var(--spacing-md);
  }
  
  .form-row {
    grid-template-columns: 1fr;
  }
  
  .packages-grid {
    grid-template-columns: 1fr;
  }
  
  .info-grid {
    grid-template-columns: 1fr;
  }
  
  .coupon-code {
    font-size: 28px;
    letter-spacing: 2px;
    padding: var(--spacing-lg);
  }
  
  table {
    font-size: 13px;
    display: block;
    overflow-x: auto;
  }
  
  th, td {
    padding: var(--spacing-md) var(--spacing-sm);
    white-space: nowrap;
  }
  
  .package-card.featured::before {
    font-size: 10px;
    padding: 3px 36px;
    top: 16px;
    right: -28px;
  }
}

