/*
 * Conformo Brand Styles
 * Custom CSS for brand guidelines and visual identity
 */

:root {
  /* Primary Colors */
  --color-primary: #2F54A6;
  --color-primary-dark: #244182;
  --color-primary-light: #4A6BC2;
  
  /* Secondary Colors */
  --color-secondary: #1B9F7E;
  --color-secondary-dark: #158065;
  --color-secondary-light: #2CB996;
  
  /* Accent Colors */
  --color-accent: #F68C3B;
  --color-accent-dark: #E57A2A;
  --color-accent-light: #F9A461;
  
  /* Neutral Colors */
  --color-gray-900: #1A202C;
  --color-gray-800: #2D3748;
  --color-gray-700: #4A5568;
  --color-gray-600: #718096;
  --color-gray-500: #A0AEC0;
  --color-gray-400: #CBD5E0;
  --color-gray-300: #E2E8F0;
  --color-gray-200: #EDF2F7;
  --color-gray-100: #F7FAFC;
  
  /* Semantic Colors */
  --color-success: #1B9F7E;
  --color-warning: #F68C3B;
  --color-error: #E53E3E;
  --color-info: #2F54A6;
  
  /* Spacing */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  
  /* Border Radius */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 12px;
  
  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1);
  --shadow-md: 0 2px 8px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Override Minima theme colors with brand colors */
.site-header {
  background-color: var(--color-primary);
  border-bottom: none;
}

.site-title,
.site-title:visited {
  color: white;
}

.site-nav .page-link {
  color: rgba(255, 255, 255, 0.9);
}

.site-nav .page-link:hover {
  color: white;
}

/* Links */
a {
  color: var(--color-primary);
}

a:hover {
  color: var(--color-primary-dark);
}

/* Buttons */
.btn-primary {
  background-color: var(--color-primary);
  color: white;
  padding: 12px 24px;
  border-radius: var(--radius-md);
  border: none;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  transition: background-color 0.2s;
}

.btn-primary:hover {
  background-color: var(--color-primary-dark);
  color: white;
}

.btn-secondary {
  background-color: var(--color-secondary);
  color: white;
  padding: 12px 24px;
  border-radius: var(--radius-md);
  border: none;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  transition: background-color 0.2s;
}

.btn-secondary:hover {
  background-color: var(--color-secondary-dark);
  color: white;
}

.btn-accent {
  background-color: var(--color-accent);
  color: white;
  padding: 12px 24px;
  border-radius: var(--radius-md);
  border: none;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  transition: background-color 0.2s;
}

.btn-accent:hover {
  background-color: var(--color-accent-dark);
  color: white;
}

/* Cards */
.card {
  background: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
  transition: box-shadow 0.2s;
}

.card:hover {
  box-shadow: var(--shadow-lg);
}

/* Status Badges */
.status-success {
  background-color: var(--color-success);
  color: white;
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 600;
  display: inline-block;
}

.status-warning {
  background-color: var(--color-warning);
  color: white;
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 600;
  display: inline-block;
}

.status-error {
  background-color: var(--color-error);
  color: white;
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 600;
  display: inline-block;
}

.status-info {
  background-color: var(--color-info);
  color: white;
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 600;
  display: inline-block;
}

/* Code blocks with brand colors */
code {
  background-color: var(--color-gray-100);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-sm);
  padding: 2px 6px;
  font-size: 0.9em;
}

pre code {
  background-color: var(--color-gray-900);
  color: var(--color-gray-100);
  border: none;
  display: block;
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  overflow-x: auto;
}

/* Responsive design helpers */
@media (max-width: 768px) {
  .btn-primary,
  .btn-secondary,
  .btn-accent {
    display: block;
    width: 100%;
    text-align: center;
  }
  
  .card {
    padding: var(--spacing-md);
  }
}

/* Accessibility: Focus states */
a:focus,
button:focus,
.btn-primary:focus,
.btn-secondary:focus,
.btn-accent:focus {
  outline: 3px solid var(--color-primary-light);
  outline-offset: 2px;
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
