/* ===============================
LiteGrid.css is less than 10kb (uncompressed)
and has the following style groups:
1. Universal Reset
2. Responsive Fonts (using clamp)
3. Typography Utilities
4. Container System
5. Grid System with media queries
6. Auto Columns and Rows
7. Alignment Utilities
8. Full-Bleed Utilities
9. Max Width Constraints
10. Spacing Utilities
11. Aspect Ratios
12. Images
================================= */

  /* ===============================
  1. UNIVERSAL RESET
  =============================== */

*, *::before, *::after {
  box-sizing: border-box;
}

/* Remove default spacing */
html, body {
  margin: 0;
  padding: 0;
  font-size: 100%;
  font-family: 'Roboto', Arial, sans-serif;
  color: #222;
  overflow-x: hidden; /* Helps avoid 100vw overflow issues */
}


html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}


/* ===============================
   2. RESPONSIVE FONTS
   =============================== */
:root {
  --font-sm: clamp(0.875rem, 0.85rem + 0.25vw, 1rem);
  --font-md: clamp(1rem, 1vw + 0.5rem, 1.25rem);
  --font-lg: clamp(1.25rem, 1.5vw, 1.75rem);
  --font-xl: clamp(1.5rem, 2vw, 2.25rem);
  --font-xxl: clamp(2rem, 4vw, 3rem);
}

body {font-size: var(--font-md); font-family: sans-serif; }
h1, .h1 { font-size: var(--font-xxl); }
h2, .h2 { font-size: var(--font-xl); }
h3, .h3 { font-size: var(--font-lg); }
h4, .h4 { font-size: var(--font-md); }
p, li { font-size: var(--font-lg); }

/* ===============================
   3. TYPOGRAPHY UTILITIES
   =============================== */
.bold {  font-weight: bold;}
.italic {  font-style: italic;}
.lead { font-size: 1.25rem; font-weight: 300;}
.uppercase {  text-transform: uppercase;}
.smallFont {  font-size: 10px;}
.skinnyText {  word-spacing: -2px;}
.underline {  text-decoration: underline;}
.no-underline {  text-decoration: none;}
.no-underline:hover {  text-decoration: none;}
.no-bullets {  padding-left: 0;  list-style: none;  line-height: 1.5;}
ul {  list-style-position: inside;  list-style-type: square;}
.shadow {  box-shadow: 0 0.5rem 1rem rgba(9, 9, 9, 0.845);}
a:hover,button:hover {  cursor: pointer;}

/* ===============================
   4. CONTAINER SYSTEM
   =============================== */

/* Adaptive container (automatically changes width at breakpoints) */
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}
/* Full-width container with padding */
.container-fluid {
  width: 100%;
  margin-inline: auto;
  padding-inline: 1rem;
}

@media (min-width: 576px)  { .container { max-width: 800px; } }   /* SM */
@media (min-width: 768px)  { .container { max-width: 1200px; } }  /* MD */
@media (min-width: 1200px) { .container { max-width: 1500px; } }  /* LG */
@media (min-width: 1600px) { .container { max-width: 2000px; } }  /* XL */

/* Fixed-width containers */
.container-SM { max-width: 800px;  margin-inline: auto; padding-inline: 1rem; }
.container-MD { max-width: 1200px; margin-inline: auto; padding-inline: 1rem; }
.container-LG { max-width: 1500px; margin-inline: auto; padding-inline: 1rem; }
.container-XL { max-width: 2000px; margin-inline: auto; padding-inline: 1rem; }



/* ===============================
   5. GRID SYSTEM
   =============================== */

.row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1rem;
}

/* Column spans (default: mobile-first, full width) */
[class^="col-"] {
  grid-column: span 6;
}

/* ======= GRID SYSTEM MEDIA QUERIES ======= */

/* --- SM --- */
@media (min-width: 576px) {
  .col-sm-1 { grid-column: span 1; }
  .col-sm-2 { grid-column: span 2; }
  .col-sm-3 { grid-column: span 3; }
  .col-sm-4 { grid-column: span 4; }
  .col-sm-5 { grid-column: span 5; }
  .col-sm-6 { grid-column: span 6; }
}

/* --- MD --- */
@media (min-width: 768px) {
  .col-md-1 { grid-column: span 1; }
  .col-md-2 { grid-column: span 2; }
  .col-md-3 { grid-column: span 3; }
  .col-md-4 { grid-column: span 4; }
  .col-md-5 { grid-column: span 5; }
  .col-md-6 { grid-column: span 6; }
}

/* --- LG --- */
@media (min-width: 992px) {
  .col-lg-1 { grid-column: span 1; }
  .col-lg-2 { grid-column: span 2; }
  .col-lg-3 { grid-column: span 3; }
  .col-lg-4 { grid-column: span 4; }
  .col-lg-5 { grid-column: span 5; }
  .col-lg-6 { grid-column: span 6; }
}

/* --- XL --- */
@media (min-width: 1200px) {
  .col-xl-1 { grid-column: span 1; }
  .col-xl-2 { grid-column: span 2; }
  .col-xl-3 { grid-column: span 3; }
  .col-xl-4 { grid-column: span 4; }
  .col-xl-5 { grid-column: span 5; }
  .col-xl-6 { grid-column: span 6; }
}

/* ===============================
   6. GRID AUTO-COLS (AUTO SIZING)
   =============================== */
/* AUTO COLUMNS AND ROWS */
.row-auto-cols {
  display: grid;
  grid-template-columns: auto auto auto;
  gap: 1rem;
}

.row-auto-center {
  display: grid;
  grid-template-columns: auto auto;
  justify-content: center;
  gap: 1rem;
}
.row-center-grid {
  display: grid;
  grid-template-columns: auto;
  justify-content: center;
}

.row-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1rem;
}


/* ===============================
   7. ALIGNMENT UTILITIES
   =============================== */
/* Text alignment */
.center {text-align:center;}
.left {text-align:left;}
.right {text-align:right;}

/* Vertical alignment (for grid rows) */
.align-start    { align-items: start; }
.align-center   { align-items: center; }
.align-end      { align-items: end; }
.align-stretch  { align-items: stretch; }

/* Horizontal alignment of items - applies to grid children*/
.justify-items-start    { justify-items: start; }
.justify-items-center   { justify-items: center; } /* center the content inside each grid item */
.justify-items-end      { justify-items: end; }
.justify-items-stretch  { justify-items: stretch; }

/* Justify spacing between columns -applies to grid container*/
.justify-start    { justify-content: start; }
.justify-center   { justify-content: center; } /* center the entire group of items */
.justify-end      { justify-content: end; }
.justify-between  { justify-content: space-between; }
.justify-around   { justify-content: space-around; }
.justify-evenly   { justify-content: space-evenly; }


/* ===============================
   8. FULL-BLEED UTILITIES
   =============================== */

/* Full-bleed section that truly fills the viewport */
.full-bleed {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
  max-width: 100vw;
}

/* Make sure the image respects the container */
.hero-img {
  width: 100%;
  height: auto;
  display: block;
}

/* ===============================
   9. MAX WIDTH CONSTRAINTS
   =============================== */

/* CONSTRAIN WIDTH OF ELEMENTS */
.max400 { max-width: 400px; }
.max600 { max-width: 600px; }
.max800 { max-width: 800px; }
.max1000 { max-width: 1000px; }

/* Constrain number of characters */
.max40ch {  max-width: 40ch;}
.max50ch {  max-width: 50ch;}
.max60ch {  max-width: 60ch;}
.max70ch {  max-width: 70ch;}


/* ===============================
   10. SPACING UTILITIES
   =============================== */
:root {
  --sp-0: 0;
  --sp-1: 1rem;
  --sp-2: 2rem;
  --sp-3: 3rem;
  --sp-4: 4rem;
  --sp-5: 5rem;
}
/* Padding */
.p-0  { padding: var(--sp-0); }
.p-1  { padding: var(--sp-1); }
.p-2  { padding: var(--sp-2); }
.p-3  { padding: var(--sp-3); }
.p-4  { padding: var(--sp-4); }
.p-5  { padding: var(--sp-5); }

.pt-1 { padding-top: var(--sp-1); }
.pt-2 { padding-top: var(--sp-2); }
.pt-3 { padding-top: var(--sp-3); }
.pt-4 { padding-top: var(--sp-4); }

.pb-1 { padding-bottom: var(--sp-1); }
.pb-2 { padding-bottom: var(--sp-2); }
.pb-3 { padding-bottom: var(--sp-3); }
.pb-4 { padding-bottom: var(--sp-4); }

.pl-1 { padding-left: var(--sp-1); }
.pl-2 { padding-left: var(--sp-2); }
.pl-3 { padding-left: var(--sp-3); }

.pr-1 { padding-right: var(--sp-1); }
.pr-2 { padding-right: var(--sp-2); }
.pr-3 { padding-right: var(--sp-3); }

.px-1 {padding:0 1rem;}
.px-2 {padding:0 2rem;}
.px-3 {padding:0 3rem;}


/* Margin */
.m-0  { margin: var(--sp-0); }
.m-1  { margin: var(--sp-1); }
.m-2  { margin: var(--sp-2); }
.m-3  { margin: var(--sp-3); }
.m-4  { margin: var(--sp-4); }
.m-5  { margin: var(--sp-5); }

.mt-1 { margin-top: var(--sp-1); }
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }

.mb-1 { margin-bottom: var(--sp-1); }
.mb-2 { margin-bottom: var(--sp-2); }
.mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); }

.ml-1 { margin-left: var(--sp-1); }
.ml-2 { margin-left: var(--sp-2); }

.mr-1 { margin-right: var(--sp-1); }
.mr-2 { margin-right: var(--sp-2); }

.mx-auto { margin-left: auto; margin-right: auto; }
.my-auto { margin-top: auto; margin-bottom: auto; }

/* ===============================
   11. ASPECT RATIOS 
   =============================== */
.ar1x1 {  aspect-ratio: auto 1/1;}
.ar2x1 {  aspect-ratio: auto 2/1;}
.ar3x2 {  aspect-ratio: auto 3/2;}
.ar4x3 {  aspect-ratio: auto 4/3;}
.ar16x9 {  aspect-ratio: auto 16/9;}
.ar21x9 {  aspect-ratio: auto 21/9;}


/* ===============================
   12. IMAGES
   =============================== */ 

/* Make images always responsive */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* fills container completely, cropping if needed */
img.object-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* fits the entire image inside the container, preserving aspect ratio, might leave gaps. */
img.object-contain {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

