/**
 * Base Styles
 * Resets, normalization, and global element styling
 */

/* Import Roboto Font */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;600;700&display=swap');

/* Box Sizing Reset */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Root & Body */
html {
  font-size: 16px; /* Base font size - DO NOT CHANGE */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  margin: 0;
  font-family: var(--font-primary);
  font-size: var(--text-base);
  font-weight: var(--font-normal);
  line-height: var(--leading-body);
  color: var(--text-primary);
  background-color: var(--bg-page);
}

/* Remove default margins */
h1, h2, h3, h4, h5, h6,
p, ul, ol, dl, dd, blockquote, figure {
  margin: 0;
}


/* List reset */
ul, ol {
  padding: 0;
  list-style: none;
}

/* Link reset */
a {
  color: inherit;
  text-decoration: none;
}



/* Form elements */
input, button, textarea, select {
  font: inherit;
  color: inherit;
}

/* Button reset */
button {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

/* Remove button focus outline (add custom focus styles) */
button:focus-visible {
  outline: 2px solid var(--border-focus);
  outline-offset: 2px;
}

/* Prevent text overflow */
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

/* ==========================================
   GLOBAL LAYOUT CONSTRAINTS
   ========================================== */

:root {
  --container-max-width: 1200px;
  --container-padding: 20px;
  --container-padding-mobile: 15px;
}

.container {
  max-width: var(--container-max-width) !important;
  margin: 0 auto !important;
  padding-left: var(--container-padding) !important;
  padding-right: var(--container-padding) !important;
}

/* Mobile: Reduce padding */
@media (max-width: 768px) {
  .container {
    padding-left: var(--container-padding-mobile) !important;
    padding-right: var(--container-padding-mobile) !important;
  }
}
