/* VEGGG Brand Style Guide - CSS Framework */
/* This file contains all the brand colors, typography, and component styles for the VEGGG application */

/* ==========================================================================
   CSS CUSTOM PROPERTIES (VARIABLES)
   ========================================================================== */

:root {
  /* Brand Primary Colors */
  --veggg-primary: #5062FF;
  --veggg-primary-hover: #3B4CF5;
  
  /* Accent & Feedback Colors */
  --veggg-accent: #5DE1E6;
  --veggg-success: #4ADE80;
  --veggg-warning: #FBBF24;
  --veggg-error: #F87171;
  
  /* Neutral Colors */
  --veggg-background: #F9FAFB;
  --veggg-white: #FFFFFF;
  --veggg-surface: #F3F4F6;
  --veggg-border: #E5E7EB;
  
  /* Text Colors */
  --veggg-text-primary: #111827;
  --veggg-text-secondary: #6B7280;
  --veggg-text-muted: #9CA3AF;
  
  /* Dark Mode Colors */
  --veggg-dark-background: #1F2937;
  --veggg-dark-surface: #374151;
  --veggg-dark-text: #F3F4F6;
  
  /* Spacing Scale */
  --veggg-space-xs: 0.25rem;   /* 4px */
  --veggg-space-sm: 0.5rem;    /* 8px */
  --veggg-space-md: 1rem;      /* 16px */
  --veggg-space-lg: 1.5rem;    /* 24px */
  --veggg-space-xl: 2rem;      /* 32px */
  --veggg-space-2xl: 3rem;     /* 48px */
  --veggg-space-3xl: 4rem;     /* 64px */
  
  /* Border Radius */
  --veggg-radius-sm: 0.25rem;  /* 4px */
  --veggg-radius-md: 0.5rem;   /* 8px */
  --veggg-radius-lg: 0.75rem;  /* 12px */
  --veggg-radius-xl: 1rem;     /* 16px */
  
  /* Shadows */
  --veggg-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --veggg-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --veggg-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

/* ==========================================================================
   FONT FACE DECLARATIONS
   ========================================================================== */

@font-face {
  font-family: 'Comma Base';
  src: url('../fonts/Comma Base Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Comma Base';
  src: url('../fonts/Comma Base Italic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: 'Comma Base';
  src: url('../fonts/Comma Base Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Comma Base';
  src: url('../fonts/Comma Base Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Comma Base';
  src: url('../fonts/Comma Base Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Comma Base';
  src: url('../fonts/Comma Base Black.ttf') format('truetype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

/* ==========================================================================
   BASE STYLES
   ========================================================================== */

body {
  font-family: 'Comma Base', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background-color: var(--veggg-background);
  color: var(--veggg-text-primary);
  line-height: 1.6;
}

.font-comma-base {
  font-family: 'Comma Base', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* ==========================================================================
   BACKGROUND COLORS
   ========================================================================== */

.bg-primary { background-color: var(--veggg-primary); }
.bg-primary-hover { background-color: var(--veggg-primary-hover); }
.bg-accent { background-color: var(--veggg-accent); }
.bg-success { background-color: var(--veggg-success); }
.bg-warning { background-color: var(--veggg-warning); }
.bg-error { background-color: var(--veggg-error); }
.bg-background { background-color: var(--veggg-background); }
.bg-surface { background-color: var(--veggg-surface); }
.bg-border { background-color: var(--veggg-border); }

/* ==========================================================================
   TEXT COLORS
   ========================================================================== */

.text-primary { color: var(--veggg-primary); }
.text-primary-hover { color: var(--veggg-primary-hover); }
.text-accent { color: var(--veggg-accent); }
.text-success { color: var(--veggg-success); }
.text-warning { color: var(--veggg-warning); }
.text-error { color: var(--veggg-error); }
.text-background { color: var(--veggg-background); }
.text-surface { color: var(--veggg-surface); }
.text-border { color: var(--veggg-border); }

/* ==========================================================================
   BORDER COLORS
   ========================================================================== */

.border-primary { border-color: var(--veggg-primary); }
.border-primary-hover { border-color: var(--veggg-primary-hover); }
.border-accent { border-color: var(--veggg-accent); }
.border-success { border-color: var(--veggg-success); }
.border-warning { border-color: var(--veggg-warning); }
.border-error { border-color: var(--veggg-error); }
.border-background { border-color: var(--veggg-background); }
.border-surface { border-color: var(--veggg-surface); }
.border-border { border-color: var(--veggg-border); }

/* ==========================================================================
   HOVER STATES
   ========================================================================== */

.hover\:bg-primary-hover:hover { background-color: var(--veggg-primary-hover); }
.hover\:text-primary:hover { color: var(--veggg-primary); }
.hover\:border-primary:hover { border-color: var(--veggg-primary); }

/* ==========================================================================
   GRADIENTS
   ========================================================================== */

.hero-gradient {
  background: linear-gradient(135deg, var(--veggg-primary) 0%, var(--veggg-primary-hover) 50%, var(--veggg-accent) 100%);
}

.gradient-primary {
  background: linear-gradient(135deg, var(--veggg-primary), var(--veggg-primary-hover));
}

.gradient-accent {
  background: linear-gradient(135deg, var(--veggg-accent), var(--veggg-primary));
}

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

/* Buttons */
.btn-primary {
  background-color: var(--veggg-primary);
  color: white;
  padding: var(--veggg-space-sm) var(--veggg-space-lg);
  border-radius: var(--veggg-radius-md);
  border: none;
  font-weight: 500;
  transition: all 0.2s ease;
  cursor: pointer;
}

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

.btn-secondary {
  background-color: var(--veggg-surface);
  color: var(--veggg-text-primary);
  padding: var(--veggg-space-sm) var(--veggg-space-lg);
  border-radius: var(--veggg-radius-md);
  border: 1px solid var(--veggg-border);
  font-weight: 500;
  transition: all 0.2s ease;
  cursor: pointer;
}

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

/* Cards */
.card {
  background-color: var(--veggg-white);
  border-radius: var(--veggg-radius-lg);
  box-shadow: var(--veggg-shadow-sm);
  border: 1px solid var(--veggg-border);
  padding: var(--veggg-space-lg);
  transition: all 0.2s ease;
}

.card:hover {
  box-shadow: var(--veggg-shadow-md);
  transform: translateY(-2px);
}

.card-surface {
  background-color: var(--veggg-surface);
  border-radius: var(--veggg-radius-lg);
  padding: var(--veggg-space-lg);
}

/* Forms */
.form-input {
  width: 100%;
  padding: var(--veggg-space-sm) var(--veggg-space-md);
  border: 1px solid var(--veggg-border);
  border-radius: var(--veggg-radius-md);
  font-family: inherit;
  transition: all 0.2s ease;
}

.form-input:focus {
  outline: none;
  border-color: var(--veggg-primary);
  box-shadow: 0 0 0 3px rgba(80, 98, 255, 0.1);
}

.form-select {
  width: 100%;
  padding: var(--veggg-space-sm) var(--veggg-space-md);
  border: 1px solid var(--veggg-border);
  border-radius: var(--veggg-radius-md);
  font-family: inherit;
  background-color: var(--veggg-white);
  transition: all 0.2s ease;
}

.form-select:focus {
  outline: none;
  border-color: var(--veggg-primary);
  box-shadow: 0 0 0 3px rgba(80, 98, 255, 0.1);
}

/* Alerts */
.alert {
  padding: var(--veggg-space-md);
  border-radius: var(--veggg-radius-md);
  border-left: 4px solid;
  margin-bottom: var(--veggg-space-md);
}

.alert-success {
  background-color: rgba(74, 222, 128, 0.1);
  border-left-color: var(--veggg-success);
  color: #065f46;
}

.alert-error {
  background-color: rgba(248, 113, 113, 0.1);
  border-left-color: var(--veggg-error);
  color: #991b1b;
}

.alert-warning {
  background-color: rgba(251, 191, 36, 0.1);
  border-left-color: var(--veggg-warning);
  color: #92400e;
}

.alert-info {
  background-color: rgba(80, 98, 255, 0.1);
  border-left-color: var(--veggg-primary);
  color: #1e3a8a;
}

/* Navigation */
.nav-link {
  color: var(--veggg-text-secondary);
  text-decoration: none;
  padding: var(--veggg-space-sm) var(--veggg-space-md);
  border-radius: var(--veggg-radius-md);
  transition: all 0.2s ease;
}

.nav-link:hover {
  color: var(--veggg-primary);
  background-color: rgba(80, 98, 255, 0.05);
}

.nav-link.active {
  color: var(--veggg-primary);
  background-color: rgba(80, 98, 255, 0.1);
  font-weight: 500;
}

/* Progress Bars */
.progress-bar {
  width: 100%;
  height: 8px;
  background-color: var(--veggg-border);
  border-radius: var(--veggg-radius-sm);
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  background-color: var(--veggg-primary);
  transition: width 0.3s ease;
}

/* Badges */
.badge {
  display: inline-block;
  padding: var(--veggg-space-xs) var(--veggg-space-sm);
  border-radius: var(--veggg-radius-sm);
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.badge-primary {
  background-color: var(--veggg-primary);
  color: white;
}

.badge-success {
  background-color: var(--veggg-success);
  color: white;
}

.badge-warning {
  background-color: var(--veggg-warning);
  color: #92400e;
}

.badge-error {
  background-color: var(--veggg-error);
  color: white;
}

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

/* Spacing */
.p-xs { padding: var(--veggg-space-xs); }
.p-sm { padding: var(--veggg-space-sm); }
.p-md { padding: var(--veggg-space-md); }
.p-lg { padding: var(--veggg-space-lg); }
.p-xl { padding: var(--veggg-space-xl); }

.m-xs { margin: var(--veggg-space-xs); }
.m-sm { margin: var(--veggg-space-sm); }
.m-md { margin: var(--veggg-space-md); }
.m-lg { margin: var(--veggg-space-lg); }
.m-xl { margin: var(--veggg-space-xl); }

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

/* Shadows */
.shadow-sm { box-shadow: var(--veggg-shadow-sm); }
.shadow-md { box-shadow: var(--veggg-shadow-md); }
.shadow-lg { box-shadow: var(--veggg-shadow-lg); }

/* Transitions */
.transition { transition: all 0.2s ease; }
.transition-colors { transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease; }
.transition-transform { transition: transform 0.2s ease; }

/* ==========================================================================
   RESPONSIVE DESIGN
   ========================================================================== */

@media (max-width: 768px) {
  .card {
    padding: var(--veggg-space-md);
  }
  
  .btn-primary,
  .btn-secondary {
    padding: var(--veggg-space-md) var(--veggg-space-lg);
    width: 100%;
  }
}

/* ==========================================================================
   DARK MODE SUPPORT
   ========================================================================== */

@media (prefers-color-scheme: dark) {
  :root {
    --veggg-background: var(--veggg-dark-background);
    --veggg-surface: var(--veggg-dark-surface);
    --veggg-text-primary: var(--veggg-dark-text);
    --veggg-border: #4B5563;
  }
  
  .card {
    background-color: var(--veggg-white);
    border-color: #4B5563;
  }
  
  .form-input,
  .form-select {
    background-color: var(--veggg-dark-background);
    border-color: #4B5563;
    color: var(--veggg-dark-text);
  }
}
