/* ==========================================================================
   Vote Manager Design System - Foundation
   ========================================================================== */

/* CSS Custom Properties (Design Tokens) */
:root {
  /* Material Design 3 Color System */
  --md-sys-color-primary: #1976d2;
  --md-sys-color-on-primary: #ffffff;
  --md-sys-color-primary-container: #d3e4fd;
  --md-sys-color-on-primary-container: #001b3e;

  --md-sys-color-secondary: #565f71;
  --md-sys-color-on-secondary: #ffffff;
  --md-sys-color-secondary-container: #dae2f9;
  --md-sys-color-on-secondary-container: #131c2b;

  --md-sys-color-tertiary: #705575;
  --md-sys-color-on-tertiary: #ffffff;
  --md-sys-color-tertiary-container: #fbd7fc;
  --md-sys-color-on-tertiary-container: #28132e;

  --md-sys-color-error: #ba1a1a;
  --md-sys-color-on-error: #ffffff;
  --md-sys-color-error-container: #ffdad6;
  --md-sys-color-on-error-container: #410002;

  --md-sys-color-background: #fefbff;
  --md-sys-color-on-background: #1a1c1e;

  --md-sys-color-surface: #fefbff;
  --md-sys-color-on-surface: #1a1c1e;
  --md-sys-color-surface-variant: #dfe2eb;
  --md-sys-color-on-surface-variant: #43474e;

  --md-sys-color-surface-container: #f0f0f7;
  --md-sys-color-surface-container-high: #e6e6ec;
  --md-sys-color-surface-container-highest: #e0e0e6;
  --md-sys-color-surface-container-low: #f7f7fd;

  --md-sys-color-outline: #74777f;
  --md-sys-color-outline-variant: #c4c6d0;

  /* Typography Scale */
  --md-sys-typescale-display-large-size: 3.5rem;
  --md-sys-typescale-display-large-weight: 400;
  --md-sys-typescale-display-large-line-height: 4rem;

  --md-sys-typescale-display-medium-size: 2.75rem;
  --md-sys-typescale-display-medium-weight: 400;
  --md-sys-typescale-display-medium-line-height: 3.25rem;

  --md-sys-typescale-display-small-size: 2.25rem;
  --md-sys-typescale-display-small-weight: 400;
  --md-sys-typescale-display-small-line-height: 2.75rem;

  --md-sys-typescale-headline-large-size: 2rem;
  --md-sys-typescale-headline-large-weight: 400;
  --md-sys-typescale-headline-large-line-height: 2.5rem;

  --md-sys-typescale-headline-medium-size: 1.75rem;
  --md-sys-typescale-headline-medium-weight: 400;
  --md-sys-typescale-headline-medium-line-height: 2.25rem;

  --md-sys-typescale-headline-small-size: 1.5rem;
  --md-sys-typescale-headline-small-weight: 400;
  --md-sys-typescale-headline-small-line-height: 2rem;

  --md-sys-typescale-title-large-size: 1.375rem;
  --md-sys-typescale-title-large-weight: 500;
  --md-sys-typescale-title-large-line-height: 1.75rem;

  --md-sys-typescale-title-medium-size: 1rem;
  --md-sys-typescale-title-medium-weight: 500;
  --md-sys-typescale-title-medium-line-height: 1.5rem;

  --md-sys-typescale-title-small-size: 0.875rem;
  --md-sys-typescale-title-small-weight: 500;
  --md-sys-typescale-title-small-line-height: 1.25rem;

  --md-sys-typescale-body-large-size: 1rem;
  --md-sys-typescale-body-large-weight: 400;
  --md-sys-typescale-body-large-line-height: 1.5rem;

  --md-sys-typescale-body-medium-size: 0.875rem;
  --md-sys-typescale-body-medium-weight: 400;
  --md-sys-typescale-body-medium-line-height: 1.25rem;

  --md-sys-typescale-body-small-size: 0.75rem;
  --md-sys-typescale-body-small-weight: 400;
  --md-sys-typescale-body-small-line-height: 1rem;

  --md-sys-typescale-label-large-size: 0.875rem;
  --md-sys-typescale-label-large-weight: 500;
  --md-sys-typescale-label-large-line-height: 1.25rem;

  --md-sys-typescale-label-medium-size: 0.75rem;
  --md-sys-typescale-label-medium-weight: 500;
  --md-sys-typescale-label-medium-line-height: 1rem;

  --md-sys-typescale-label-small-size: 0.6875rem;
  --md-sys-typescale-label-small-weight: 500;
  --md-sys-typescale-label-small-line-height: 0.875rem;

  /* Spacing Scale */
  --md-sys-spacing-1: 0.25rem;
  --md-sys-spacing-2: 0.5rem;
  --md-sys-spacing-3: 0.75rem;
  --md-sys-spacing-4: 1rem;
  --md-sys-spacing-5: 1.25rem;
  --md-sys-spacing-6: 1.5rem;
  --md-sys-spacing-8: 2rem;
  --md-sys-spacing-12: 3rem;
  --md-sys-spacing-16: 4rem;

  /* Shape/Corner Radius */
  --md-sys-shape-corner-none: 0;
  --md-sys-shape-corner-extra-small: 0.125rem;
  --md-sys-shape-corner-small: 0.25rem;
  --md-sys-shape-corner-medium: 0.375rem;
  --md-sys-shape-corner-large: 0.5rem;
  --md-sys-shape-corner-extra-large: 0.75rem;
  --md-sys-shape-corner-full: 9999px;

  /* Elevation */
  --md-sys-elevation-0: 0px 0px 0px 0px transparent;
  --md-sys-elevation-1: 0px 1px 2px 0px rgba(0, 0, 0, 0.05), 0px 1px 3px 0px rgba(0, 0, 0, 0.1), 0px 1px 3px 0px rgba(0, 0, 0, 0.12);
  --md-sys-elevation-2: 0px 1px 3px 0px rgba(0, 0, 0, 0.08), 0px 2px 6px 0px rgba(0, 0, 0, 0.1), 0px 4px 8px 0px rgba(0, 0, 0, 0.12);
  --md-sys-elevation-3: 0px 1px 3px 0px rgba(0, 0, 0, 0.11), 0px 4px 8px 0px rgba(0, 0, 0, 0.13), 0px 8px 16px 0px rgba(0, 0, 0, 0.15);

  /* Animation */
  --md-sys-motion-duration-short: 150ms;
  --md-sys-motion-duration-medium: 250ms;
  --md-sys-motion-duration-long: 350ms;
  --md-sys-motion-easing-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --md-sys-motion-easing-emphasized: cubic-bezier(0.05, 0.7, 0.1, 1);

  /* Component-specific tokens */
  --header-height: 4rem;
  --sidebar-width: 16rem;
  --content-max-width: 1200px;
  --border-radius-card: var(--md-sys-shape-corner-large);
  --border-radius-button: var(--md-sys-shape-corner-medium);
}

/* ==========================================================================
   Base Typography
   ========================================================================== */

h1, .typescale-display-large {
  font-size: var(--md-sys-typescale-display-large-size);
  font-weight: var(--md-sys-typescale-display-large-weight);
  line-height: var(--md-sys-typescale-display-large-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

h2, .typescale-display-medium {
  font-size: var(--md-sys-typescale-display-medium-size);
  font-weight: var(--md-sys-typescale-display-medium-weight);
  line-height: var(--md-sys-typescale-display-medium-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

h3, .typescale-headline-large {
  font-size: var(--md-sys-typescale-headline-large-size);
  font-weight: var(--md-sys-typescale-headline-large-weight);
  line-height: var(--md-sys-typescale-headline-large-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

h4, .typescale-headline-medium {
  font-size: var(--md-sys-typescale-headline-medium-size);
  font-weight: var(--md-sys-typescale-headline-medium-weight);
  line-height: var(--md-sys-typescale-headline-medium-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

h5, .typescale-title-large {
  font-size: var(--md-sys-typescale-title-large-size);
  font-weight: var(--md-sys-typescale-title-large-weight);
  line-height: var(--md-sys-typescale-title-large-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

h6, .typescale-title-medium {
  font-size: var(--md-sys-typescale-title-medium-size);
  font-weight: var(--md-sys-typescale-title-medium-weight);
  line-height: var(--md-sys-typescale-title-medium-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

p, .typescale-body-large {
  font-size: var(--md-sys-typescale-body-large-size);
  font-weight: var(--md-sys-typescale-body-large-weight);
  line-height: var(--md-sys-typescale-body-large-line-height);
  color: var(--md-sys-color-on-surface);
  margin: 0;
}

/* ==========================================================================
   Layout System
   ========================================================================== */

.page-container {
  min-height: 100vh;
  background: var(--md-sys-color-background);
  color: var(--md-sys-color-on-background);
}

.content-container {
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--md-sys-spacing-6);
}

.main-content {
  padding: var(--md-sys-spacing-6);
  background: var(--md-sys-color-surface);
  border-radius: var(--md-sys-shape-corner-large);
  box-shadow: var(--md-sys-elevation-1);
}

/* ==========================================================================
   Component Base Styles
   ========================================================================== */

/* Cards */
.card, .md-card {
  background: var(--md-sys-color-surface-container);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-large);
  box-shadow: var(--md-sys-elevation-1);
  padding: var(--md-sys-spacing-6);
  transition: all var(--md-sys-motion-duration-medium) var(--md-sys-motion-easing-standard);
}

.card:hover, .md-card:hover {
  box-shadow: var(--md-sys-elevation-2);
  border-color: var(--md-sys-color-outline);
}

/* Buttons */
button, .btn {
  border-radius: var(--md-sys-shape-corner-medium);
  font-weight: var(--md-sys-typescale-label-large-weight);
  transition: all var(--md-sys-motion-duration-medium) var(--md-sys-motion-easing-standard);
  cursor: pointer;
  border: none;
  padding: var(--md-sys-spacing-3) var(--md-sys-spacing-6);
  font-size: var(--md-sys-typescale-label-large-size);
}

/* Form Elements */
input, textarea, select {
  border: 1px solid var(--md-sys-color-outline);
  border-radius: var(--md-sys-shape-corner-small);
  padding: var(--md-sys-spacing-3);
  font-size: var(--md-sys-typescale-body-large-size);
  background: var(--md-sys-color-surface);
  color: var(--md-sys-color-on-surface);
  transition: all var(--md-sys-motion-duration-medium) var(--md-sys-motion-easing-standard);
}

input:focus, textarea:focus, select:focus {
  outline: 2px solid var(--md-sys-color-primary);
  outline-offset: 2px;
  border-color: var(--md-sys-color-primary);
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  background: var(--md-sys-color-surface-container);
  border-radius: var(--md-sys-shape-corner-medium);
  overflow: hidden;
}

th, td {
  padding: var(--md-sys-spacing-4);
  text-align: left;
  border-bottom: 1px solid var(--md-sys-color-outline-variant);
}

th {
  background: var(--md-sys-color-surface-container-high);
  font-weight: var(--md-sys-typescale-title-medium-weight);
  color: var(--md-sys-color-on-surface);
}

tbody tr:hover {
  background: var(--md-sys-color-surface-container-highest);
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--md-sys-spacing-1); }
.mb-2 { margin-bottom: var(--md-sys-spacing-2); }
.mb-3 { margin-bottom: var(--md-sys-spacing-3); }
.mb-4 { margin-bottom: var(--md-sys-spacing-4); }
.mb-6 { margin-bottom: var(--md-sys-spacing-6); }
.mb-8 { margin-bottom: var(--md-sys-spacing-8); }

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--md-sys-spacing-1); }
.mt-2 { margin-top: var(--md-sys-spacing-2); }
.mt-3 { margin-top: var(--md-sys-spacing-3); }
.mt-4 { margin-top: var(--md-sys-spacing-4); }
.mt-6 { margin-top: var(--md-sys-spacing-6); }
.mt-8 { margin-top: var(--md-sys-spacing-8); }

.d-flex { display: flex; }
.d-grid { display: grid; }
.d-block { display: block; }
.d-none { display: none; }

.align-items-center { align-items: center; }
.justify-content-center { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-end { justify-content: flex-end; }

.gap-1 { gap: var(--md-sys-spacing-1); }
.gap-2 { gap: var(--md-sys-spacing-2); }
.gap-3 { gap: var(--md-sys-spacing-3); }
.gap-4 { gap: var(--md-sys-spacing-4); }
.gap-6 { gap: var(--md-sys-spacing-6); }

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media (max-width: 768px) {
  .content-container {
    padding: var(--md-sys-spacing-4);
  }

  .main-content {
    padding: var(--md-sys-spacing-4);
  }

  .card, .md-card {
    padding: var(--md-sys-spacing-4);
  }

  h1, .typescale-display-large {
    font-size: var(--md-sys-typescale-headline-large-size);
    line-height: var(--md-sys-typescale-headline-large-line-height);
  }

  h2, .typescale-display-medium {
    font-size: var(--md-sys-typescale-headline-medium-size);
    line-height: var(--md-sys-typescale-headline-medium-line-height);
  }
}

@media (max-width: 480px) {
  .content-container {
    padding: var(--md-sys-spacing-2);
  }

  .main-content {
    padding: var(--md-sys-spacing-2);
  }

  .card, .md-card {
    padding: var(--md-sys-spacing-3);
  }
}

/* ==========================================================================
   Animation & Transitions
   ========================================================================== */

.fade-in {
  animation: fadeIn var(--md-sys-motion-duration-medium) var(--md-sys-motion-easing-standard);
}

.slide-up {
  animation: slideUp var(--md-sys-motion-duration-medium) var(--md-sys-motion-easing-standard);
}

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

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==========================================================================
   Accessibility Improvements
   ========================================================================== */

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

/* Focus indicators */
:focus-visible {
  outline: 2px solid var(--md-sys-color-primary);
  outline-offset: 2px;
}

/* Screen reader only content */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  :root {
    --md-sys-color-outline: #000000;
    --md-sys-color-outline-variant: #666666;
  }
}
