/* FIN Components - Reusable UI components */

/* Button Components */
.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  padding: var(--spacing-3) var(--spacing-6);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-fast);
}

.btn-primary:hover {
  background-color: var(--color-primary-dark);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.btn-secondary {
  background-color: var(--color-white);
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  padding: var(--spacing-3) var(--spacing-6);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  border-radius: var(--border-radius-md);
  transition: all var(--transition-fast);
}

.btn-secondary:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: translateY(-1px);
}

.btn-tool, .btn-card, .btn-strategy, .btn-invest, .btn-transition {
  background-color: var(--color-gray-100);
  color: var(--color-gray-800);
  border: 1px solid var(--color-gray-300);
  padding: var(--spacing-2) var(--spacing-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  border-radius: var(--border-radius);
  transition: all var(--transition-fast);
  width: 100%;
}

.btn-tool:hover, .btn-card:hover, .btn-strategy:hover,
.btn-invest:hover, .btn-transition:hover {
  background-color: var(--color-primary-light);
  color: var(--color-white);
  border-color: var(--color-primary);
  transform: translateY(-1px);
}

.btn-privacy {
  background-color: var(--color-accent);
  color: var(--color-white);
  padding: var(--spacing-2) var(--spacing-4);
  font-size: var(--font-size-sm);
  border-radius: var(--border-radius);
  transition: all var(--transition-fast);
}

.btn-privacy:hover {
  background-color: #c53030;
  transform: translateY(-1px);
}

/* CTA Buttons */
.cta-primary {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
  color: var(--color-white);
  padding: var(--spacing-4) var(--spacing-8);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-lg);
  transition: all var(--transition-normal);
}

.cta-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.cta-secondary {
  background-color: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  padding: var(--spacing-4) var(--spacing-8);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  border-radius: var(--border-radius-lg);
  transition: all var(--transition-normal);
}

.cta-secondary:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* Card Components */
.benefit-card, .tool-card, .strategy-card, .invest-card, .transition-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-6);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-normal);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}

.benefit-card:hover, .tool-card:hover, .strategy-card:hover,
.invest-card:hover, .transition-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
  border-color: var(--color-primary-light);
}

.benefit-card h3, .tool-card h3, .strategy-card h3,
.invest-card h3, .transition-card h3 {
  color: var(--color-primary);
  font-size: var(--font-size-xl);
  margin-bottom: var(--spacing-2);
}

.benefit-card p, .tool-card p, .strategy-card p,
.invest-card p, .transition-card p {
  color: var(--color-gray-600);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  flex-grow: 1;
  margin-bottom: 0;
}

/* Dashboard Preview Component */
.financial-dashboard-preview {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--border-radius-xl);
  padding: var(--spacing-6);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
  max-width: 300px;
}

.dashboard-card {
  background-color: var(--color-gray-50);
  border-radius: var(--border-radius-md);
  padding: var(--spacing-4);
  text-align: center;
}

.dashboard-card h3 {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-gray-700);
  margin-bottom: var(--spacing-2);
}

/* Progress Bar Component */
.progress-bar {
  background-color: var(--color-gray-200);
  height: 8px;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  margin: var(--spacing-2) 0;
}

.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--color-success), var(--color-secondary));
  border-radius: var(--border-radius-sm);
  transition: width var(--transition-slow);
}

/* Status Badges */
.status-active {
  background-color: var(--color-success);
  color: var(--color-white);
  padding: var(--spacing-1) var(--spacing-3);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
}

/* Feature Badges */
.feature-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  background-color: rgba(255, 255, 255, 0.2);
  color: var(--color-white);
  padding: var(--spacing-2) var(--spacing-4);
  border-radius: var(--border-radius-lg);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  backdrop-filter: blur(10px);
}

.privacy-badge {
  display: inline-block;
  background-color: var(--color-primary);
  color: var(--color-white);
  padding: var(--spacing-1) var(--spacing-2);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--spacing-2);
  margin-right: var(--spacing-2);
}

/* Privacy Badges Container */
.privacy-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-1);
  margin-bottom: var(--spacing-4);
}

/* Checklist Component */
.emergency-checklist, .checklist-item {
  list-style: none;
  padding: 0;
}

.emergency-checklist {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3);
  margin-bottom: var(--spacing-8);
}

.checklist-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-3);
  background-color: var(--color-white);
  padding: var(--spacing-4);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--border-radius-md);
  transition: all var(--transition-fast);
}

.checklist-item:hover {
  border-color: var(--color-primary-light);
  box-shadow: var(--shadow-sm);
}

.checklist-item input[type="checkbox"] {
  margin-top: var(--spacing-1);
  transform: scale(1.2);
  accent-color: var(--color-primary);
}

.checklist-item label {
  flex-grow: 1;
  cursor: pointer;
  line-height: var(--line-height-relaxed);
}

.checklist-item label strong {
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
}

/* Modal Component */
.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: var(--z-modal);
  backdrop-filter: blur(4px);
}

.modal.active {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-4);
}

.modal-content {
  background-color: var(--color-white);
  border-radius: var(--border-radius-xl);
  box-shadow: var(--shadow-lg);
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-6);
  border-bottom: 1px solid var(--color-gray-200);
}

.modal-header h2 {
  color: var(--color-primary);
  margin: 0;
}

.modal-close {
  background: none;
  border: none;
  font-size: var(--font-size-2xl);
  color: var(--color-gray-400);
  cursor: pointer;
  padding: var(--spacing-2);
  border-radius: var(--border-radius);
  transition: all var(--transition-fast);
}

.modal-close:hover {
  background-color: var(--color-gray-100);
  color: var(--color-gray-600);
}

.modal-body {
  padding: var(--spacing-6);
  overflow-y: auto;
  flex-grow: 1;
}

/* Tool List Component */
.tool-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}

.tool-list button {
  background: none;
  border: none;
  color: var(--color-primary);
  text-align: left;
  padding: var(--spacing-2);
  border-radius: var(--border-radius);
  transition: all var(--transition-fast);
  font-size: var(--font-size-sm);
}

.tool-list button:hover {
  background-color: var(--color-gray-100);
  color: var(--color-primary-dark);
  transform: translateX(4px);
}

/* Navigation Toggle (Mobile) */
.nav-toggle {
  display: none;
  flex-direction: column;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--spacing-2);
  gap: 4px;
}

.nav-toggle span {
  display: block;
  width: 25px;
  height: 3px;
  background-color: var(--color-primary);
  border-radius: 2px;
  transition: all var(--transition-fast);
}

/* Offline Indicator */
.offline-indicator {
  position: fixed;
  bottom: var(--spacing-4);
  left: var(--spacing-4);
  background-color: var(--color-warning);
  color: var(--color-white);
  padding: var(--spacing-2) var(--spacing-4);
  border-radius: var(--border-radius-lg);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-toast);
  display: none;
}

.offline-indicator.visible {
  display: block;
}

/* Stealth Mode Toggle */
.stealth-btn, .install-btn {
  background-color: var(--color-gray-100);
  border: 1px solid var(--color-gray-300);
  color: var(--color-gray-700);
  padding: var(--spacing-2);
  border-radius: var(--border-radius);
  font-size: var(--font-size-lg);
  transition: all var(--transition-fast);
  min-width: 40px;
  height: 40px;
}

.stealth-btn:hover, .install-btn:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* Responsive Design */
@media (max-width: 768px) {
  .nav-toggle {
    display: flex;
  }

  .financial-dashboard-preview {
    max-width: 100%;
    margin-top: var(--spacing-6);
  }

  .modal-content {
    margin: var(--spacing-2);
    max-height: 95vh;
  }

  .modal-header, .modal-body {
    padding: var(--spacing-4);
  }

  .cta-primary, .cta-secondary {
    padding: var(--spacing-3) var(--spacing-6);
    font-size: var(--font-size-base);
  }
}

@media (max-width: 480px) {
  .feature-badge {
    padding: var(--spacing-1) var(--spacing-3);
    font-size: var(--font-size-xs);
  }

  .checklist-item {
    flex-direction: column;
    gap: var(--spacing-2);
  }

  .checklist-item input[type="checkbox"] {
    align-self: flex-start;
  }
}

/* Animation Components */
@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.animate-slide-up {
  animation: slideInUp var(--transition-normal) ease-out;
}

.animate-fade-in {
  animation: fadeIn var(--transition-normal) ease-out;
}