@charset "UTF-8";

/* ============================================
   TABLE OF CONTENTS
   ============================================
   1. CSS Custom Properties (Variables)
   2. CSS Reset & Normalize
   3. Base Styles & Typography
   4. Layout Components (Container, Grid)
   5. Header & Navigation
      5.1 Header Structure
      5.2 Top Navigation
      5.3 Search Form
      5.4 Primary Navigation
      5.5 Mobile Navigation
   6. Main Content
   7. Footer
   8. Utility Classes
   9. Media Queries
   ============================================ */


/* ============================================
   1. CSS CUSTOM PROPERTIES (VARIABLES)
   ============================================
   Brand colors and design tokens for ReBoost
   ============================================ */
:root {
  /* Brand Colors */
  --color-primary: #F7941D;
  /* ReBoost Red - Primary brand color */
  --color-secondary: #2b2b2b;
  /* Dark Gray - Secondary brand color */
  --color-white: #ffffff;
  --color-black: #000000;

  /* Neutral Colors */
  /* todo: confirm if these are the colors we will need, else remove*/
  --color-gray-100: #f7f5f2;
  /* Light background */
  --color-gray-200: #e1e1e1;
  /* Border color */
  --color-gray-300: #c0c0c0;
  /* Medium gray */
  --color-gray-400: #666666;
  /* Dark gray text */

  /* Typography
     Using Zalando Sans Expanded - a modern variable font supporting weights 200-900
     Falls back to system fonts if Google Fonts fails to load */
  --font-family-primary: "Zalando Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, "Helvetica Neue", Arial, sans-serif;
  --font-size-base: 16px;
  --font-size-small: 13px;
  --font-size-medium: 14px;
  --line-height-base: 1.5;
  --font-weight-normal: 400;
  --font-weight-bold: 700;

  /* Spacing - Converted to viewport units for responsive scaling
     Using clamp() to ensure minimum and maximum values */
  --spacing-xs: clamp(0.25rem, 0.5vw, 0.5rem);
  /* ~4-8px */
  --spacing-sm: clamp(0.5rem, 1vw, 1rem);
  /* ~8-16px */
  --spacing-md: clamp(0.75rem, 1.5vw, 1.5rem);
  /* ~12-24px */
  --spacing-lg: clamp(1rem, 2.5vw, 2rem);
  /* ~16-32px */
  --spacing-xl: clamp(1.5rem, 3.5vw, 3rem);
  /* ~24-48px */
  --spacing-xxl: clamp(2rem, 5vw, 4rem);
  /* ~32-64px */

  /* Layout */
  --container-max-width: min(90vw, 1140px);
  /*on very large screens, the content doesn't stretch excessively wide */
  --container-padding: clamp(0.75rem, 2vw, 1.5rem);
  /* small screen where content actually stretches to edges, responsive padding */

  /* Transitions */
  --transition-fast: 0.2s ease;
  --transition-normal: 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --transition-slow: 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);

  /* Z-index Scale */
  --z-index-header: 10;
  --z-index-dropdown: 20;
  --z-index-modal: 30;
}


/* ============================================
   2. CSS RESET & NORMALIZE
   ============================================
   Modern CSS reset with webkit compatibility
   ============================================ */

/* Box sizing rules, removes browser defaults*/
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Set core root defaults with webkit prefix */
html {
  box-sizing: border-box;
  /* -ms-overflow-style: scrollbar; ms = microsoft, ms is no longer needed. */
  /* overflow: auto; */
  scrollbar-width: none;
  /* For thin scrollbar */
  /* scroll-behavior: smooth; - Removed, now handled by Lenis library */
}

html,
body {
  width: 100% !important;
  overflow-x: hidden !important;
}

/* html::-webkit-scrollbar {
  width: 8px;
  height: 8px; /*8px for horizontal scrolling
}

html::-webkit-scrollbar-track {
  background: transparent;
}

html::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.3);
  border-radius: 4px;
}

html::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.5);
}
 */

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: var(--line-height-base);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-optical-sizing: auto;
  color: var(--color-secondary);
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Remove list styles */
ul,
ol {
  list-style: none;
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove default button styles */
button {
  background: none;
  border: none;
  cursor: pointer;
}

/* Remove text decoration from links */
a {
  text-decoration: none;
  color: inherit;
}

/* Remove animations for people who've turned them off */
@media (prefers-reduced-motion: reduce) {

  *,
  *::before,
  *::after {
    -webkit-animation-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
    -o-transition-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}


/* ============================================
   3. BASE STYLES & TYPOGRAPHY
   ============================================
   Foundation styles for the entire site
   ============================================ */

/* Focus styles for accessibility */
:focus-visible {
  outline: 2px solid var(--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;
}


/* ============================================
   4. LAYOUT COMPONENTS (CONTAINER, GRID)
   ============================================
   Bootstrap-inspired responsive container system
   ============================================ */

/* Container - Centers content with max-width */
.container {
  width: 100%;
  padding-right: var(--container-padding);
  padding-left: var(--container-padding);
  margin-right: auto;
  margin-left: auto;
  /* positions container itself in middle of page  */
}

/* Responsive container breakpoints */
@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .container {
    max-width: var(--container-max-width);
  }
}


/* ============================================
   5. HEADER & NAVIGATION
   ============================================
   Fixed header with two-tier navigation system
   Following BEM methodology for class naming
   ============================================ */

/* ============================================
   5.1 HEADER STRUCTURE
   ============================================ */

/* Main header container - fixed to top */
.header {
  /* Converted from 15px to viewport units for responsive scaling
     Min: 0.5rem (8px), Preferred: 1.5vh, Max: 2rem (32px) */
  padding: clamp(0.5rem, 1.5vh, 2rem) 0;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: var(--z-index-header);
}

/* Header background - white overlay */
.header__bg {
  background: var(--color-white);
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}

/* Position container relatively for absolute children */
.header>.container {
  position: relative;
}

/* Mobile navigation hidden by default on desktop */
.header__mobile {
  display: none;
}


/* ============================================
   5.2 TOP NAVIGATION
   ============================================
   Small utility navigation with search
   ============================================ */

/* Top navigation wrapper - flexbox layout */
.header__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  /* Converted from 30px to viewport units
     Min: 1rem (16px), Preferred: 2.5vh, Max: 2.5rem (40px) */
  margin-bottom: clamp(1rem, 2.5vh, 2.5rem);
}

/* Top navigation menu - horizontal list */
.nav-top__menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/* Spacing between top nav items */
.nav-top__item:not(:last-child) {
  /* Converted from 40px to viewport units
     Min: 1.5rem (24px), Preferred: 3vw, Max: 2.5rem (40px) */
  margin-right: clamp(1.5rem, 3vw, 2.5rem);
}

/* .nav-top__item:first-child {
  margin-right: 65px;
}
.nav-top__item:nth-child(2) {
  margin-right: 30px;
} */

/* Top navigation link styles */
.nav-top__link {
  font-size: var(--font-size-small);
  /* Converted from 24px to viewport units
     Min: 1.25rem (20px), Preferred: 2vh, Max: 1.75rem (28px) */
  line-height: clamp(1.25rem, 2vh, 1.75rem);
  letter-spacing: 0.1px;
  color: var(--color-secondary);
  -webkit-transition: color var(--transition-normal);
  -o-transition: color var(--transition-normal);
  transition: color var(--transition-normal);
}

/* Hover state for top nav links */
.nav-top__link:hover {
  color: var(--color-primary);
}


/* ============================================
   5.3 SEARCH FORM
   ============================================
   Inline search with button
   ============================================ */

/* Search form wrapper */
.search-form__wrapper {
  position: relative;
  /* Converted from 270px to viewport units
     Min: 200px, Preferred: 20vw, Max: 300px */
  width: clamp(200px, 20vw, 300px);
}

/* Search input field */
.search-form__input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  font-size: var(--font-size-small);
  /* Converted from 14px to rem units
     0.875rem = 14px at 16px root font size */
  line-height: 0.875rem;
  padding: var(--spacing-md);
  color: #ffffff;
  background-color: var(--color-secondary);
  border: 1px solid transparent;
  border-radius: 0;
  outline: none;
  -webkit-transition: border-color var(--transition-normal);
  -o-transition: border-color var(--transition-normal);
  transition: border-color var(--transition-normal);
}

/* Search input placeholder */
.search-form__input::-webkit-input-placeholder {
  color: #ffffff;
  letter-spacing: 0.1px;
}

.search-form__input::-moz-placeholder {
  color: #ffffff;
  letter-spacing: 0.1px;
}

.search-form__input:-ms-input-placeholder {
  color: #ffffff;
  letter-spacing: 0.1px;
}

.search-form__input::-ms-input-placeholder {
  color: #ffffff;
  letter-spacing: 0.1px;
}

.search-form__input::placeholder {
  color: #ffffff;
  letter-spacing: 0.1px;
}

/* Search input focus state */
.search-form__input:focus {
  border-color: var(--color-primary);
}

/* Search button - positioned absolutely over input */
.search-form__button {
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #F7941D;
  /* Converted from 11px to viewport units
     Min: 0.5rem (8px), Preferred: 1vh, Max: 0.875rem (14px) */
  padding: clamp(0.5rem, 1vh, 0.875rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background-color var(--transition-normal);
  -o-transition: background-color var(--transition-normal);
  transition: background-color var(--transition-normal);
  cursor: not-allowed;
}

/* Search button hover state */
.search-form__button:not(:disabled):hover {
  background-color: var(--color-primary);
  cursor: pointer;
}

/* Search button SVG sizing */
.search-form__button svg {
  display: block;
  /* Converted from 18px to viewport units
     Min: 16px, Preferred: 1.5vw, Max: 20px */
  width: clamp(16px, 1.5vw, 20px);
  height: clamp(16px, 1.5vw, 20px);
}


/* SOCIAL ICONS START */
.social_icons {
  display: flex;
  align-items: center;
  justify-content: center;
  /* Converted from 15px to viewport units
     Min: 0.75rem (12px), Preferred: 1.5vw, Max: 1.25rem (20px) */
  gap: clamp(0.75rem, 1.5vw, 1.25rem);
}

.social_icons .social_icon {
  /* Converted from 40px to viewport units for responsive scaling
     Min: 32px, Preferred: 8vw, Max: 48px */
  width: clamp(32px, 8vw, 48px);
  height: clamp(32px, 8vw, 48px);
  background-color: #ddd;
  /* Converted from 5px to viewport units
     Min: 0.25rem (4px), Preferred: 0.5vw, Max: 0.5rem (8px) */
  padding: clamp(0.25rem, 0.5vw, 0.5rem);
  border-radius: 8px;
  transition: all ease-in-out 0.3s;
}

.social_icons .social_icon:hover {
  box-shadow: 2px 2px 10px #9f9f9f;
}

/* SOCIAL ICONS END */

/* ============================================
   5.4 PRIMARY NAVIGATION & LOGO
   ============================================
   Main navigation menu with dropdown indicators
   ============================================ */

/* Bottom header section - contains logo and primary nav */
.header__bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

/* Logo container */
.header__logo {
  display: flex;
  align-items: center;
}

/* Logo link */
.logo {
  display: block;
  -webkit-transition: opacity var(--transition-normal);
  -o-transition: opacity var(--transition-normal);
  transition: opacity var(--transition-normal);
}

.logo:hover {
  opacity: 0.8;
}

/* Logo image - SVG scales based on height */
.logo__image {
  display: block;
  /* Converted from 110px to viewport units for responsive scaling
     Min: 60px, Preferred: 8vw, Max: 110px */
  height: clamp(60px, 8vw, 110px);
  width: auto;
  /* Maintains aspect ratio */
  max-width: 100%;
  /* Prevents overflow on small screens */
}

/* Primary navigation menu - horizontal list */
.nav-primary__menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

nav.nav-primary {
  width: 100%;
}

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

/* Header middle section - social links */
.header_middle {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
}

.social-links {
  display: flex;
  flex-direction: column;
  /* Stack vertically */
  align-items: flex-start;
  /* Align to the left */
  gap: 1.1vw;
  /* Vertical spacing between links */
}

.social-link {
  display: flex;
  align-items: center;
  gap: 0.4vw;
  /* Space between icon and text */
  text-decoration: none;
  color: var(--color-secondary);
  transition: opacity var(--transition-fast);
}

.social-link:hover {
  opacity: 0.7;
  color: var(--color-primary);
}

/* 
  TO MAKE ICONS LARGER:
  Increase the width/height values below (e.g., change 1.2vw to 1.8vw or 2vw)
  Also adjust max-width/max-height if you want them to grow beyond 24px
*/
.social-icon {
  /* Converted to viewport units with better constraints
     Min: 16px, Preferred: 1.5vw, Max: 28px */
  width: clamp(16px, 1.5vw, 28px);
  height: clamp(16px, 1.5vw, 28px);
  min-width: 16px;
  min-height: 16px;
  max-width: 28px;
  max-height: 28px;
  object-fit: contain;
}

/* 
  TO MAKE TEXT LARGER:
  Increase the font-size value below (e.g., change 0.9vw to 1.2vw or 1.5vw)
*/
.social-text {
  font-size: 0.9vw;
  /* Change this to make text larger (e.g., 1.2vw, 1.5vw) */
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}

/* Primary nav item - positioned relative for absolute dropdown positioning */
.nav-primary__item {
  position: relative;
  /* Converted from 10px to viewport units
     Min: 0.5rem (8px), Preferred: 1vw, Max: 1rem (16px) */
  margin: 0 clamp(0.5rem, 1vw, 1rem);
}

.nav-primary__menu li:first-child {
  margin-left: 0;
}

.nav-primary__menu li:last-child {
  margin-right: 0;
}

/* Spacing between primary nav items */
/* .nav-primary__item:not(:last-child) {
  margin-right: 50px;
} */

/* Primary navigation link - flex container for label and icon */
.nav-primary__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 4px;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  -webkit-transition: color var(--transition-normal);
  -o-transition: color var(--transition-normal);
  transition: color var(--transition-normal);
}

/* Primary nav label text */
.nav-primary__label {
  font-size: var(--font-size-medium);
  /* Converted from 20px to viewport units
     Min: 1.125rem (18px), Preferred: 1.8vh, Max: 1.5rem (24px) */
  line-height: clamp(1.125rem, 1.8vh, 1.5rem);
  letter-spacing: 0.1px;
}

/* Dropdown icon container */
.nav-primary__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: -webkit-transform var(--transition-normal);
  transition: -webkit-transform var(--transition-normal);
  -o-transition: -o-transform var(--transition-normal);
  transition: transform var(--transition-normal);
  transition: transform var(--transition-normal), -webkit-transform var(--transition-normal), -o-transform var(--transition-normal);
}

/* Icon SVG polygon fill transition */
.nav-primary__icon svg polygon {
  -webkit-transition: fill var(--transition-normal);
  -o-transition: fill var(--transition-normal);
  transition: fill var(--transition-normal);
}

/* Primary nav hover and active states */
.nav-primary__link:hover,
.nav-primary__link.is-active {
  color: var(--color-primary);
}

.nav-primary__link:hover .nav-primary__icon,
.nav-primary__link.is-active .nav-primary__icon {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg);
}

.nav-primary__link:hover .nav-primary__icon svg polygon,
.nav-primary__link.is-active .nav-primary__icon svg polygon {
  fill: var(--color-primary);
}


/* ============================================
   5.5 DESKTOP DROPDOWN MENUS
   ============================================
   Dropdown menus that appear on hover for desktop navigation
   ============================================ */

/* Dropdown container - hidden by default */
.nav-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  background-color: var(--color-white);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(-10px);
  -ms-transform: translateY(-10px);
  -o-transform: translateY(-10px);
  transform: translateY(-10px);
  -webkit-transition: opacity var(--transition-normal), visibility var(--transition-normal), -webkit-transform var(--transition-normal);
  transition: opacity var(--transition-normal), visibility var(--transition-normal), -webkit-transform var(--transition-normal);
  -o-transition: opacity var(--transition-normal), visibility var(--transition-normal), -o-transform var(--transition-normal);
  transition: opacity var(--transition-normal), visibility var(--transition-normal), transform var(--transition-normal);
  transition: opacity var(--transition-normal), visibility var(--transition-normal), transform var(--transition-normal), -webkit-transform var(--transition-normal), -o-transform var(--transition-normal);
  z-index: var(--z-index-dropdown);
  padding: var(--spacing-md) 0;
}

/* Show dropdown on parent hover */
.nav-primary__item--has-dropdown:hover .nav-dropdown {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  -o-transform: translateY(0);
  transform: translateY(0);
}

/* Dropdown inner padding */
.nav-dropdown__inner {
  padding: 0 var(--spacing-lg);
}

/* Dropdown list */
.nav-dropdown__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

/* Dropdown item */
.nav-dropdown__item {
  position: relative;
  border-bottom: 1px solid var(--color-gray-200);
}

.nav-dropdown__item:last-child {
  border-bottom: none;
}

/* Dropdown link */
.nav-dropdown__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: var(--spacing-sm) 0;
  color: var(--color-secondary);
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-normal);
  -webkit-transition: color var(--transition-fast);
  -o-transition: color var(--transition-fast);
  transition: color var(--transition-fast);
}

.nav-dropdown__link:hover {
  color: var(--color-primary);
}

/* Parent link (has nested dropdown) */
.nav-dropdown__link--parent {
  font-weight: var(--font-weight-bold);
}

/* Nested dropdown icon */
.nav-dropdown__nested-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  -o-transform: rotate(-90deg);
  transform: rotate(-90deg);
  -webkit-transition: -webkit-transform var(--transition-fast);
  transition: -webkit-transform var(--transition-fast);
  -o-transition: -o-transform var(--transition-fast);
  transition: transform var(--transition-fast);
  transition: transform var(--transition-fast), -webkit-transform var(--transition-fast), -o-transform var(--transition-fast);
}

/* Nested dropdown container */
.nav-dropdown__nested {
  position: absolute;
  left: 100%;
  top: 0;
  min-width: 220px;
  background-color: var(--color-white);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateX(-10px);
  -ms-transform: translateX(-10px);
  -o-transform: translateX(-10px);
  transform: translateX(-10px);
  -webkit-transition: opacity var(--transition-fast), visibility var(--transition-fast), -webkit-transform var(--transition-fast);
  transition: opacity var(--transition-fast), visibility var(--transition-fast), -webkit-transform var(--transition-fast);
  -o-transition: opacity var(--transition-fast), visibility var(--transition-fast), -o-transform var(--transition-fast);
  transition: opacity var(--transition-fast), visibility var(--transition-fast), transform var(--transition-fast);
  transition: opacity var(--transition-fast), visibility var(--transition-fast), transform var(--transition-fast), -webkit-transform var(--transition-fast), -o-transform var(--transition-fast);
  padding: var(--spacing-sm) 0;
  z-index: calc(var(--z-index-dropdown) + 1);
}

/* Show nested dropdown on parent hover */
.nav-dropdown__item--has-nested:hover .nav-dropdown__nested {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  -o-transform: translateX(0);
  transform: translateX(0);
}

/* Rotate icon when nested dropdown is shown */
.nav-dropdown__item--has-nested:hover .nav-dropdown__nested-icon {
  -webkit-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
}

/* Nested dropdown item */
.nav-dropdown__nested-item {
  /* Items are styled through their links */
}

/* Nested dropdown link */
.nav-dropdown__nested-link {
  display: block;
  padding: var(--spacing-xs) var(--spacing-lg);
  color: var(--color-secondary);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-normal);
  -webkit-transition: all var(--transition-fast);
  -o-transition: all var(--transition-fast);
  transition: all var(--transition-fast);
}

.nav-dropdown__nested-link:hover {
  background-color: var(--color-gray-100);
  color: var(--color-primary);
}


/* ============================================
   5.6 MOBILE NAVIGATION
   ============================================
   Hamburger menu for mobile devices
   ============================================ */

/* Mobile header container - flexbox layout */
.header__mobile {
  display: none;
  /* Hidden by default, shown in media queries */
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  /* Converted from 5px to viewport units
     Min: 0.25rem (4px), Preferred: 0.8vh, Max: 0.625rem (10px) */
  padding: clamp(0.25rem, 0.8vh, 0.625rem) 0;
}

/* Mobile logo - smaller than desktop */
.header__mobile .logo__image {
  /* Converted from 70px to viewport units for mobile scaling
     Min: 50px, Preferred: 12vw, Max: 80px */
  height: clamp(50px, 12vw, 80px);
}

/* Burger menu button container */
.header__mobile-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: var(--spacing-xs);
}

/* Burger button wrapper */
.burger {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: var(--spacing-xs);
  cursor: pointer;
}

/* Burger label text */
.burger__label {
  text-transform: uppercase;
  color: var(--color-primary);
  /* Converted from 10px to rem units
     0.625rem = 10px at 16px root font size */
  font-size: 0.625rem;
  letter-spacing: 1.43px;
  /* Converted from 12px to rem units
     0.75rem = 12px at 16px root font size */
  line-height: 0.75rem;
  font-weight: var(--font-weight-bold);
}

/* Burger icon container */
.burger__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 4px;
  /* Converted from 24px to viewport units
     Min: 20px, Preferred: 5vw, Max: 32px */
  width: clamp(20px, 5vw, 32px);
}

/* Burger icon bars */
.burger__icon span {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--color-secondary);
  -webkit-transition: all var(--transition-normal);
  -o-transition: all var(--transition-normal);
  transition: all var(--transition-normal);
}

/* Animated burger icon when open */
.burger.is-open .burger__icon span:first-child {
  -webkit-transform: rotate(45deg) translate(5px, 5px);
  -ms-transform: rotate(45deg) translate(5px, 5px);
  -o-transform: rotate(45deg) translate(5px, 5px);
  transform: rotate(45deg) translate(5px, 5px);
}

.burger.is-open .burger__icon span:nth-child(2) {
  opacity: 0;
}

.burger.is-open .burger__icon span:last-child {
  -webkit-transform: rotate(-45deg) translate(5px, -5px);
  -ms-transform: rotate(-45deg) translate(5px, -5px);
  -o-transform: rotate(-45deg) translate(5px, -5px);
  transform: rotate(-45deg) translate(5px, -5px);
}


/* ============================================
   5.6 MOBILE MENU PANEL
   ============================================
   Full-screen slide-in menu for mobile devices
   ============================================ */

/* Mobile menu container - slides in from right */
.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  /* Converted from 320px to viewport units
     Min: 280px, Preferred: 85vw, Max: 400px */
  max-width: clamp(280px, 85vw, 400px);
  height: 100vh;
  background-color: var(--color-white);
  -webkit-box-shadow: -2px 0 8px rgba(0, 0, 0, 0.1);
  box-shadow: -2px 0 8px rgba(0, 0, 0, 0.1);
  z-index: 999;
  overflow-y: auto;
  -webkit-transform: translateX(100%);
  -ms-transform: translateX(100%);
  -o-transform: translateX(100%);
  transform: translateX(100%);
  -webkit-transition: -webkit-transform var(--transition-normal);
  transition: -webkit-transform var(--transition-normal);
  -o-transition: -o-transform var(--transition-normal);
  transition: transform var(--transition-normal);
  transition: transform var(--transition-normal), -webkit-transform var(--transition-normal), -o-transform var(--transition-normal);
  visibility: hidden;
}

/* Mobile menu open state */
.mobile-menu.is-open {
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  -o-transform: translateX(0);
  transform: translateX(0);
  visibility: visible;
}

/* Mobile menu navigation wrapper */
.mobile-menu__nav {
  padding: var(--spacing-xl) var(--spacing-lg);
  /* Converted from 80px to viewport units
     Min: 60px, Preferred: 15vh, Max: 100px */
  padding-top: clamp(60px, 15vh, 100px);
  /* Space for fixed header */
}

/* Mobile menu section */
.mobile-menu__section {
  margin-bottom: var(--spacing-xl);
}

/* Mobile menu section title */
.mobile-menu__section-title {
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-gray-400);
  margin-bottom: var(--spacing-md);
}

/* Secondary section styling */
.mobile-menu__section--secondary {
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--color-gray-200);
}

/* Mobile menu list */
.mobile-menu__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: var(--spacing-xs);
}

/* Mobile menu item */
/* Items are styled through their links */
/* .mobile-menu__item {
} */

/* Mobile menu link */
.mobile-menu__link {
  display: block;
  padding: var(--spacing-md) var(--spacing-sm);
  /* Converted from 14px to rem units
     0.875rem = 14px at 16px root font size */
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  -webkit-transition: all var(--transition-fast);
  -o-transition: all var(--transition-fast);
  transition: all var(--transition-fast);
  border-radius: 4px;
}

/* Small link variant for secondary items */
.mobile-menu__link--small {
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-normal);
}

/* Mobile menu link hover state */
.mobile-menu__link:hover,
.mobile-menu__link:focus {
  background-color: var(--color-gray-100);
  color: var(--color-primary);
  -webkit-transform: translateX(4px);
  -ms-transform: translateX(4px);
  -o-transform: translateX(4px);
  transform: translateX(4px);
}

/* Backdrop overlay when menu is open */
.mobile-menu-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 998;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity var(--transition-normal), visibility var(--transition-normal);
  -o-transition: opacity var(--transition-normal), visibility var(--transition-normal);
  transition: opacity var(--transition-normal), visibility var(--transition-normal);
}

/* Backdrop visible state */
.mobile-menu-backdrop.is-visible {
  opacity: 1;
  visibility: visible;
}

/* Prevent body scroll when mobile menu is open */
body.mobile-menu-open {
  overflow: hidden;
}

/* Mobile menu expandable link (parent button) */
.mobile-menu__link--parent {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/* Expand icon */
.mobile-menu__expand-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: -webkit-transform var(--transition-normal);
  transition: -webkit-transform var(--transition-normal);
  -o-transition: -o-transform var(--transition-normal);
  transition: transform var(--transition-normal);
  transition: transform var(--transition-normal), -webkit-transform var(--transition-normal), -o-transform var(--transition-normal);
}

/* Rotate icon when expanded */
.mobile-menu__link--parent[aria-expanded="true"] .mobile-menu__expand-icon {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg);
}

/* Submenu - hidden by default */
.mobile-menu__submenu {
  display: none;
  padding-left: var(--spacing-md);
  margin-top: var(--spacing-xs);
}

/* Show submenu when expanded */
.mobile-menu__item--expandable[data-expanded="true"] .mobile-menu__submenu {
  display: block;
}

/* Submenu item */
.mobile-menu__submenu-item {
  /* Items are styled through their links */
}

/* Submenu link */
.mobile-menu__submenu-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: var(--spacing-sm);
  color: var(--color-secondary);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-normal);
  -webkit-transition: all var(--transition-fast);
  -o-transition: all var(--transition-fast);
  transition: all var(--transition-fast);
  border-radius: 4px;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
}

/* Parent submenu link (has nested) */
.mobile-menu__submenu-link--parent {
  font-weight: var(--font-weight-bold);
}

.mobile-menu__submenu-link:hover,
.mobile-menu__submenu-link:focus {
  background-color: var(--color-gray-100);
  color: var(--color-primary);
}

/* Nested menu (third level) - hidden by default */
.mobile-menu__nested {
  display: none;
  padding-left: var(--spacing-md);
  margin-top: var(--spacing-xs);
}

/* Show nested when expanded */
.mobile-menu__submenu-item--expandable[data-expanded="true"] .mobile-menu__nested {
  display: block;
}

/* Rotate nested expand icon when expanded */
.mobile-menu__submenu-link--parent[aria-expanded="true"] .mobile-menu__expand-icon {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg);
}

/* Nested item */
.mobile-menu__nested-item {
  /* Items are styled through their links */
}

/* Nested link */
.mobile-menu__nested-link {
  display: block;
  padding: var(--spacing-xs) var(--spacing-sm);
  color: var(--color-secondary);
  font-size: 12px;
  font-weight: var(--font-weight-normal);
  -webkit-transition: all var(--transition-fast);
  -o-transition: all var(--transition-fast);
  transition: all var(--transition-fast);
  border-radius: 4px;
}

.mobile-menu__nested-link:hover,
.mobile-menu__nested-link:focus {
  background-color: var(--color-gray-100);
  color: var(--color-primary);
}


/* ============================================
   6. MAIN CONTENT
   ============================================
   Main content area with padding for fixed header
   ============================================ */

.main-content {
  /* Add top padding to account for fixed header
     Converted from 140px to viewport units
     Min: 100px, Preferred: 15vh, Max: 160px */
  padding-top: clamp(100px, 15vh, 160px);
  min-height: calc(100vh - 140px);
  max-width: 100vw;
  /* Prevent any child sections from causing page overflow */
  overflow-x: hidden;
  /* Contain horizontal overflow within sections */
}


/* ============================================
   6.1 HERO CAROUSEL
   ============================================
   High-performance carousel using CSS scroll-snap
   - Native browser scrolling for optimal performance
   - Scroll-snap for smooth slide transitions
   - Touch-friendly with swipe gestures
   - Minimal JavaScript (only for auto-play and controls)
   ============================================ */

/* Carousel container - positioned relative for absolute controls */
.carousel {
  position: relative;
  width: 100%;
  max-width: 100vw;
  /* Prevent overflow beyond viewport */
  /* Maintain aspect ratio: 16:9 for desktop */
  aspect-ratio: 16 / 9;
  background-color: var(--color-gray-light);
  overflow: hidden;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  /* Add top margin to prevent overlap with fixed header */
  /* margin-top: 20px; */
}

/* Viewport wrapper - handles overflow and scroll hiding */
.carousel__viewport {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

/* Scrollable container with snap points */
.carousel__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  /* Scroll snap for smooth slide transitions */
  -ms-scroll-snap-type: x mandatory;
  scroll-snap-type: x mandatory;
  /* NOTE: scroll-behavior removed - controlled via JavaScript for better infinite loop control */
  /* Hide scrollbar while maintaining functionality */
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* IE/Edge */
  /* Enable momentum scrolling on iOS */
  -webkit-overflow-scrolling: touch;
  /* Optimize for touch interactions */
  -ms-touch-action: pan-x;
  touch-action: pan-x;
}

/* Hide scrollbar in WebKit browsers */
.carousel__container::-webkit-scrollbar {
  display: none;
}

/* Individual slide */
.carousel__slide {
  /* Each slide takes full width */
  -webkit-box-flex: 0;
  -ms-flex: 0 0 100%;
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  /* Snap to start of container */
  scroll-snap-align: start;
  scroll-snap-stop: always;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

/* Carousel image */
.carousel__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
  /* Improve image rendering */
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}

/* Navigation arrows - positioned absolutely */
.carousel__arrow {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 2;
  background-color: rgba(255, 255, 255, 0.9);
  border: none;
  /* Converted from 48px to viewport units
     Min: 40px, Preferred: 8vw, Max: 56px */
  width: clamp(40px, 8vw, 56px);
  height: clamp(40px, 8vw, 56px);
  border-radius: 50%;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background-color var(--transition-normal), -webkit-transform var(--transition-fast), -webkit-box-shadow var(--transition-normal);
  transition: background-color var(--transition-normal), -webkit-transform var(--transition-fast), -webkit-box-shadow var(--transition-normal);
  -o-transition: background-color var(--transition-normal), -o-transform var(--transition-fast), box-shadow var(--transition-normal);
  transition: background-color var(--transition-normal), transform var(--transition-fast), box-shadow var(--transition-normal);
  transition: background-color var(--transition-normal), transform var(--transition-fast), box-shadow var(--transition-normal), -webkit-transform var(--transition-fast), -webkit-box-shadow var(--transition-normal), -o-transform var(--transition-fast);
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.carousel__arrow:hover {
  background-color: var(--color-white);
  -webkit-transform: translateY(-50%) scale(1.1);
  -ms-transform: translateY(-50%) scale(1.1);
  -o-transform: translateY(-50%) scale(1.1);
  transform: translateY(-50%) scale(1.1);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.carousel__arrow:active {
  -webkit-transform: translateY(-50%) scale(0.95);
  -ms-transform: translateY(-50%) scale(0.95);
  -o-transform: translateY(-50%) scale(0.95);
  transform: translateY(-50%) scale(0.95);
}

.carousel__arrow svg {
  /* Converted from 24px to viewport units
     Min: 20px, Preferred: 4vw, Max: 28px */
  width: clamp(20px, 4vw, 28px);
  height: clamp(20px, 4vw, 28px);
  color: var(--color-secondary);
}

/* Position left and right arrows */
.carousel__arrow--prev {
  /* Converted from 20px to viewport units
     Min: 1rem (16px), Preferred: 2vw, Max: 1.5rem (24px) */
  left: clamp(1rem, 2vw, 1.5rem);
}

.carousel__arrow--next {
  /* Converted from 20px to viewport units
     Min: 1rem (16px), Preferred: 2vw, Max: 1.5rem (24px) */
  right: clamp(1rem, 2vw, 1.5rem);
}

/* Pause button - desktop only, top-right corner */
.carousel__pause {
  position: absolute;
  /* Converted from 20px to viewport units
     Min: 1rem (16px), Preferred: 2vw, Max: 1.5rem (24px) */
  top: clamp(1rem, 2vw, 1.5rem);
  right: clamp(1rem, 2vw, 1.5rem);
  z-index: 2;
  background-color: rgba(255, 255, 255, 0.9);
  border: none;
  /* Converted from 40px to viewport units
     Min: 36px, Preferred: 7vw, Max: 48px */
  width: clamp(36px, 7vw, 48px);
  height: clamp(36px, 7vw, 48px);
  border-radius: 50%;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background-color var(--transition-normal), -webkit-transform var(--transition-fast), -webkit-box-shadow var(--transition-normal);
  transition: background-color var(--transition-normal), -webkit-transform var(--transition-fast), -webkit-box-shadow var(--transition-normal);
  -o-transition: background-color var(--transition-normal), -o-transform var(--transition-fast), box-shadow var(--transition-normal);
  transition: background-color var(--transition-normal), transform var(--transition-fast), box-shadow var(--transition-normal);
  transition: background-color var(--transition-normal), transform var(--transition-fast), box-shadow var(--transition-normal), -webkit-transform var(--transition-fast), -webkit-box-shadow var(--transition-normal), -o-transform var(--transition-fast);
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.carousel__pause:hover {
  background-color: var(--color-white);
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  -o-transform: scale(1.1);
  transform: scale(1.1);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.carousel__pause:active {
  -webkit-transform: scale(0.95);
  -ms-transform: scale(0.95);
  -o-transform: scale(0.95);
  transform: scale(0.95);
}

.carousel__pause svg {
  /* Converted from 16px to viewport units
     Min: 14px, Preferred: 3vw, Max: 20px */
  width: clamp(14px, 3vw, 20px);
  height: clamp(14px, 3vw, 20px);
  color: var(--color-secondary);
}

/* Dot indicators - centered at bottom */
.carousel__dots {
  position: absolute;
  /* Converted from 20px to viewport units
     Min: 1rem (16px), Preferred: 2.5vh, Max: 1.5rem (24px) */
  bottom: clamp(1rem, 2.5vh, 1.5rem);
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* Converted from 12px to viewport units
     Min: 0.5rem (8px), Preferred: 1.2vw, Max: 1rem (16px) */
  gap: clamp(0.5rem, 1.2vw, 1rem);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/* Individual dot indicator */
.carousel__dot {
  /* Converted from 12px to viewport units
     Min: 10px, Preferred: 2vw, Max: 14px */
  width: clamp(10px, 2vw, 14px);
  height: clamp(10px, 2vw, 14px);
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.6);
  border: 2px solid var(--color-white);
  cursor: pointer;
  -webkit-transition: background-color var(--transition-fast), -webkit-transform var(--transition-fast);
  transition: background-color var(--transition-fast), -webkit-transform var(--transition-fast);
  -o-transition: background-color var(--transition-fast), -o-transform var(--transition-fast);
  transition: background-color var(--transition-fast), transform var(--transition-fast);
  transition: background-color var(--transition-fast), transform var(--transition-fast), -webkit-transform var(--transition-fast), -o-transform var(--transition-fast);
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.carousel__dot:hover {
  background-color: rgba(255, 255, 255, 0.8);
  -webkit-transform: scale(1.2);
  -ms-transform: scale(1.2);
  -o-transform: scale(1.2);
  transform: scale(1.2);
}

/* Active dot indicator */
.carousel__dot--active {
  background-color: var(--color-white);
  width: 14px;
  height: 14px;
}


/* ============================================
   6.2 ABOUT US SECTION
   ============================================
   ============================================ */

/* about section container */
.about-section {
  width: 100%;
  padding: var(--spacing-xxl) 0;
  background-image: url("../media/bg-design.png");
  background-position: bottom left;
  background-repeat: no-repeat;
  background-size: 50% 30%;
}

/* About section header */
.about-section__header {
  text-align: center;
  margin-bottom: var(--spacing-xxl);
}

/* about section title */
.about-section__title {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
  line-height: 1.2;
  position: relative;
  /* Converted from 30px to viewport units
     Min: 1.5rem (24px), Preferred: 2.5vw, Max: 2rem (32px) */
  padding-left: clamp(1.5rem, 2.5vw, 2rem);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

/* Orange dot accent before title */
.about-section__title::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  /* Converted from 16px to viewport units
     Min: 12px, Preferred: 1.5vw, Max: 18px */
  width: clamp(12px, 1.5vw, 18px);
  height: clamp(12px, 1.5vw, 18px);
  background-color: #ff8c42;
  border-radius: 50%;
}

/* about section description */
.about-section__description {
  font-size: var(--font-size-medium);
  color: var(--color-gray);
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.6;
}

.about-section .about-image {
  /* Converted from 360px to viewport units
     Min: 250px, Preferred: 40vh, Max: 450px */
  height: clamp(250px, 40vh, 450px);
  margin-bottom: var(--spacing-xxl);
}

.about-section .about-image img {
  width: 100%;
  height: 100%;
  /* Converted from 16px to viewport units
     Min: 12px, Preferred: 1.5vw, Max: 20px */
  border-radius: clamp(12px, 1.5vw, 20px);
}

.about-vision-mission {
  margin-bottom: var(--spacing-xxl);
  display: flex;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  /* Converted from 50px to viewport units
     Min: 2rem (32px), Preferred: 5vw, Max: 4rem (64px) */
  gap: clamp(2rem, 5vw, 4rem);
}

.icon-title {
  display: flex;
  /* Converted from 15px to viewport units */
  gap: clamp(0.75rem, 1.5vw, 1.25rem);
  align-items: center;
  /* Converted from 20px to viewport units */
  margin-bottom: clamp(1rem, 2vh, 1.5rem);
}

.icon-title img {
  /* Converted from 58px to viewport units */
  width: clamp(48px, 8vw, 68px);
  height: clamp(48px, 8vw, 68px);
  /* Converted from 15px to viewport units */
  padding: clamp(0.75rem, 1.5vw, 1.25rem);
  background-color: #dddddd;
  /* Converted from 16px to viewport units */
  border-radius: clamp(12px, 1.5vw, 20px);
}

.vision__title,
.mission__title {
  font-size: 1.4rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  line-height: 1.2;
}

.vision__description,
.mission__description {
  font-size: var(--font-size-medium);
  color: var(--color-gray);
  line-height: 1.6;
}



/* coming soon section container */
.coming-soon-section {
  padding-top: 0px;
}

.coming-soon-btns {
  margin-bottom: var(--spacing-xxl);
  display: flex;
  justify-content: center;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  gap: 20px;
}

.coming-soon-btns button {
  height: 50px;
  width: 200px;
  background-color: var(--color-white);
  border-radius: 100px;
  color: var(--color-secondary);
  transition: all ease-in-out 0.3s;
  border: 1px solid var(--color-gray-light);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);
  font-weight: var(--font-weight-bold);
  font-size: 0.9rem;
}

.coming-soon-btns button:hover {
  box-shadow: 4px 4px 10px #9f9f9f;
}




/* about us page start */
/* hero section start */
.about_us_image {
  width: 100%;
  height: 500px;
}

.about_us_image img {
  width: 100%;
  height: 100%;
}

.about_us_section .about-section__description {
  width: 90%;
  max-width: 90%;
}

/* hero section end */
/* our team section start */
.our_team {
  width: 100%;
  padding: var(--spacing-xxl) 0;
}

.our_team_title {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
  line-height: 1.2;
  position: relative;
  padding-left: 30px;
  width: fit-content;
  margin-right: auto;
}

.our_team_title::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-color: #ff8c42;
  border-radius: 50%;
}

.our_team_description {
  font-size: var(--font-size-medium);
  color: var(--color-gray);
  line-height: 1.6;
}

.our_team .container {
  display: flex;
  gap: 40px;
}

.our_team .container .our_team_text {
  width: 40%;
}

.our_team .container .our_team_cards {
  width: 60%;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
}

.our_team .container .our_team_cards .card {
  width: 48%;
}

.our_team .container .our_team_cards .card h3 {
  font-size: var(--font-size-medium);
}

.our_team .container .our_team_cards .card p {
  font-size: var(--font-size-medium);
}

/* our team section end */
/* core values section start */
.core_values {
  width: 100%;
  padding: var(--spacing-xxl) 0;
  background-image: url("../media/bg-design-2.png");
  background-position: top right;
  background-repeat: no-repeat;
  background-size: 50% 30%;
}

.core_values_title {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
  line-height: 1.2;
  position: relative;
  padding-left: 30px;
  width: fit-content;
  margin-right: auto;
}

.core_values_title::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-color: #ff8c42;
  border-radius: 50%;
}

.core_values_description {
  font-size: var(--font-size-medium);
  color: var(--color-gray);
  line-height: 1.6;
  margin-bottom: var(--spacing-md);
  max-width: 400px;
}

.core_values .core_values_content {
  display: flex;
  gap: 40px;
}

.core_values .core_values_content .core_values_left {
  width: 40%;
}

.core_values .core_values_content .core_values_left img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
}

.core_values .core_values_content .core_values_right {
  width: 60%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.core_values .core_values_content .core_values_right .point {
  margin-bottom: var(--spacing-md);
}

.core_values .core_values_content .core_values_right .point:last-child {
  margin-bottom: 0px;
}

.core_values .core_values_content .core_values_right .point h3 {
  font-size: var(--font-size-medium);
  color: #F7941D;
  position: relative;
  padding-left: 15px;
  width: fit-content;
  margin-right: auto;
}

.core_values .core_values_content .core_values_right .point h3::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  background-color: #ff8c42;
  border-radius: 50%;
}

.core_values .core_values_content .core_values_right .point p {
  font-size: var(--font-size-medium);
}

/* core values team section end */
/* about us page end */



/* ============================================
   6.3 PORTFOLIO SNAPSHOT SECTION
   ============================================
   Showcases company portfolio across different sectors
   - Responsive CSS Grid layout with staggered middle column
   - 3 columns on desktop, 2 on tablet, 1 on mobile
   - All cards equal size, middle column offset downward
   - Follows BEM naming convention
   ============================================ */

/* Portfolio section container */
.portfolio-snapshot {
  width: 100%;
  padding: var(--spacing-xxl) 0 calc(var(--spacing-xxl) * 2) 0;
  background-color: var(--color-white);


}

/* Portfolio section header */
.portfolio-snapshot__header {
  margin-bottom: var(--spacing-xl);
}

/* Portfolio section title */
.portfolio-snapshot__title {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  line-height: 1.2;
  position: relative;
  /* Converted from 30px to viewport units
     Min: 1.5rem (24px), Preferred: 2.5vw, Max: 2rem (32px) */
  padding-left: clamp(1.5rem, 2.5vw, 2rem);
}

/* Orange dot accent before title */
.portfolio-snapshot__title::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  /* Converted from 16px to viewport units
     Min: 12px, Preferred: 1.5vw, Max: 18px */
  width: clamp(12px, 1.5vw, 18px);
  height: clamp(12px, 1.5vw, 18px);
  background-color: #ff8c42;
  /* Orange accent color from design */
  border-radius: 50%;
}

/* Portfolio grid layout - Staggered 3-column grid */
.portfolio-snapshot__grid {
  display: -ms-grid;
  display: grid;
  /* Desktop: 3 columns, 2 rows */
  -ms-grid-columns: 1fr var(--spacing-lg) 1fr var(--spacing-lg) 1fr;
  grid-template-columns: repeat(3, 1fr);
  -ms-grid-rows: 280px var(--spacing-lg) 280px;
  grid-template-rows: repeat(2, 280px);
  gap: var(--spacing-lg);
}

/* Portfolio card - individual portfolio item */
.portfolio-card {
  position: relative;
  /* Converted from 16px to viewport units
     Min: 12px, Preferred: 1.5vw, Max: 20px */
  border-radius: clamp(12px, 1.5vw, 20px);
  overflow: hidden;
  background-color: var(--color-gray-100);
  -webkit-transition: -webkit-transform var(--transition-normal), -webkit-box-shadow var(--transition-normal);
  transition: -webkit-transform var(--transition-normal), -webkit-box-shadow var(--transition-normal);
  -o-transition: -o-transform var(--transition-normal), box-shadow var(--transition-normal);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal), -webkit-transform var(--transition-normal), -webkit-box-shadow var(--transition-normal), -o-transform var(--transition-normal);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  cursor: pointer;
}

/* COMMENTED OUT: Offset middle column cards downward (cards 2 and 5: Re-Boost and Construction) */
/* This was used to create a staggered/offset layout for the middle column */
/* .portfolio-card:nth-child(2),
.portfolio-card:nth-child(5) {
  -webkit-transform: translateY(clamp(2rem, 4vh, 3rem));
  -ms-transform: translateY(clamp(2rem, 4vh, 3rem));
  -o-transform: translateY(clamp(2rem, 4vh, 3rem));
  transform: translateY(clamp(2rem, 4vh, 3rem));
} */

/* Card hover effect - preserve the offset while lifting */
.portfolio-card:hover {
  -webkit-box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
}

/* Hover for all cards - unified hover effect */
.portfolio-card:hover {
  -webkit-transform: translateY(-8px);
  -ms-transform: translateY(-8px);
  -o-transform: translateY(-8px);
  transform: translateY(-8px);
}

/* COMMENTED OUT: Previous separate hover effects for offset and non-offset cards */
/* .portfolio-card:nth-child(1):hover,
.portfolio-card:nth-child(3):hover,
.portfolio-card:nth-child(4):hover,
.portfolio-card:nth-child(6):hover {
  -webkit-transform: translateY(-8px);
  -ms-transform: translateY(-8px);
  -o-transform: translateY(-8px);
  transform: translateY(-8px);
} */

/* COMMENTED OUT: Hover for offset cards - maintain the 40px offset while lifting */
/* .portfolio-card:nth-child(2):hover,
.portfolio-card:nth-child(5):hover {
  -webkit-transform: translateY(32px);
  -ms-transform: translateY(32px);
  -o-transform: translateY(32px);
  transform: translateY(32px);
} */

/* Image wrapper - maintains aspect ratio and positioning */
.portfolio-card__image-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* Card image */
.portfolio-card__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
  -webkit-transition: -webkit-transform var(--transition-slow);
  transition: -webkit-transform var(--transition-slow);
  -o-transition: -o-transform var(--transition-slow);
  transition: transform var(--transition-slow);
  transition: transform var(--transition-slow), -webkit-transform var(--transition-slow), -o-transform var(--transition-slow);
}

/* Image zoom on hover */
.portfolio-card:hover .portfolio-card__image {
  -webkit-transform: scale(1.05);
  -ms-transform: scale(1.05);
  -o-transform: scale(1.05);
  transform: scale(1.05);
}

/* Gradient overlay on image */
.portfolio-card__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), color-stop(60%, rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.4)));
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.4) 100%);
  background: -o-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.4) 100%);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.4) 100%);
  -webkit-transition: background var(--transition-normal);
  -o-transition: background var(--transition-normal);
  transition: background var(--transition-normal);
  pointer-events: none;
}

/* Darker overlay on hover */
.portfolio-card:hover .portfolio-card__overlay {
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), color-stop(50%, rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.5)));
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
  background: -o-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
}

/* Card content - positioned at bottom */
.portfolio-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--spacing-lg);
  z-index: 1;
}

/* Card title */
.portfolio-card__title {
  font-size: 1.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  line-height: 1.3;
  margin: 0;
  position: relative;
  padding-left: 20px;
  -webkit-transition: -webkit-transform var(--transition-normal);
  transition: -webkit-transform var(--transition-normal);
  -o-transition: -o-transform var(--transition-normal);
  transition: transform var(--transition-normal);
  transition: transform var(--transition-normal), -webkit-transform var(--transition-normal), -o-transform var(--transition-normal);
}

/* White bullet point before title */
.portfolio-card__title::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--color-white);
  font-size: 1.5rem;
  line-height: 1.3;
}

/* Title moves up slightly on hover */
.portfolio-card:hover .portfolio-card__title {
  -webkit-transform: translateY(-4px);
  -ms-transform: translateY(-4px);
  -o-transform: translateY(-4px);
  transform: translateY(-4px);
}

/* ============================================
   INSURANCE CARD HOVER OVERLAY
   ============================================
   Interactive hover overlay for Insurance card
   - Blur and darken background on hover
   - Display 3 clickable options with logos
   - Smooth transitions with delay on mouse-out
   ============================================ */

/* Hover overlay container - hidden by default */
.portfolio-card__hover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.75);
  /* Dark overlay for text contrast */
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  /* Blur effect for Safari */
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 2;
  /* Above the gradient overlay */
}

/* Show overlay on card hover */
.portfolio-card--insurance:hover .portfolio-card__hover-overlay {
  opacity: 1;
  visibility: visible;
  transition-delay: 0s;
  /* Immediate on hover */
}

/* Hide overlay with delay on mouse out */
.portfolio-card--insurance .portfolio-card__hover-overlay {
  transition-delay: 300ms;
  /* 300ms delay before hiding */
}

/* Blur the image when overlay is active */
.portfolio-card--insurance:hover .portfolio-card__image {
  filter: blur(4px);
  -webkit-filter: blur(4px);
}

/* Options container - vertical flex layout */
.portfolio-card__hover-options {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2vw, 1.5rem);
  padding: clamp(1rem, 3vw, 2rem);
  width: 100%;
  max-width: 85%;
}

/* Individual option item */
.portfolio-card__option {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 1.5vw, 1rem);
  padding: clamp(0.75rem, 1.5vw, 1rem);
  /* background: rgba(255, 255, 255, 0.1); */
  /* border-radius: clamp(8px, 1vw, 12px); */
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  color: inherit;
}

/* Option hover effect */
.portfolio-card__option:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.4);
  transform: translateX(8px);
}

/* Option logo */
.portfolio-card__option-logo {
  width: clamp(32px, 5vw, 48px);
  height: clamp(32px, 5vw, 48px);
  flex-shrink: 0;
  filter: brightness(0) invert(1);
  /* Make logos white */
}

/* Option text */
.portfolio-card__option-text {
  font-size: clamp(0.875rem, 1.5vw, 1.125rem);
  font-weight: var(--font-weight-semibold);
  color: var(--color-white);
  line-height: 1.3;
  margin: 0;
}



/* ============================================
   6.3 TIMELINE SECTION
   ============================================
   Interactive horizontal timeline carousel
   - Looping navigation with infinite scroll
   - Active state animations (year scales, description fades)
   - Responsive design across all breakpoints
   - Accessibility features with ARIA support
   ============================================ */

/* Timeline section container */
.timeline-section {
  width: 100%;
  padding: var(--spacing-xxl) 0;
  background-color: var(--color-white);
  /* White background */
  color: var(--color-secondary);
  overflow: hidden;
  /* Prevent horizontal scroll */
}

/* Timeline section header */
.timeline-section__header {
  margin-bottom: var(--spacing-xl);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/* Timeline section title */
.timeline-section__title {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  line-height: 1.2;
  margin: 0;
  position: relative;
  padding-left: 30px;
  /* Space for orange dot */
}

/* Orange dot accent before title */
.timeline-section__title::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-color: var(--color-primary);
  /* Orange accent color */
  border-radius: 50%;
}

/* Navigation buttons container */
.timeline__navigation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  /* Positioned in header via flexbox */
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: var(--spacing-md);
}

/* Navigation arrow buttons */
.timeline__arrow {
  background-color: rgba(247, 148, 29, 0.1);
  border: 2px solid var(--color-primary);
  border-radius: 0.94rem;
  width: 3.75rem;
  /* 60px */
  height: 3.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  -webkit-transition: all var(--transition-normal);
  -o-transition: all var(--transition-normal);
  transition: all var(--transition-normal);
  color: var(--color-primary);
}

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

.timeline__arrow svg {
  width: 24px;
  height: 24px;
}

/* Timeline carousel viewport */
.timeline__carousel {
  width: 100%;
  max-width: 100vw;
  /* Prevent overflow beyond viewport */
  overflow: hidden;
  position: relative;
}

/* Timeline container - scrollable */
.timeline__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  /* Smooth scrolling on iOS */
  scrollbar-width: none;
  /* Hide scrollbar Firefox */
  -ms-overflow-style: none;
  /* Hide scrollbar IE/Edge */
  gap: var(--spacing-lg);
  padding: var(--spacing-lg) 0;
}

/* Hide scrollbar Webkit */
.timeline__container::-webkit-scrollbar {
  display: none;
}

/* Individual timeline slide */
.timeline__slide {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 26rem;
  flex: 0 0 26rem;
  /* 416px - fixed width, no grow/shrink */
  width: 26rem;
  height: 27rem;
  /* 432px */
  scroll-snap-align: start;
  scroll-snap-stop: always;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  /* Changed from space-between to flex-end */
  position: relative;
  -webkit-transition: all 0.6s ease;
  -o-transition: all 0.6s ease;
  transition: all 0.6s ease;
  overflow: visible;
  /* Allow year to overflow without affecting layout */
  padding-top: 6rem;
  /* Space for absolute positioned year */
}

/* Clone slides for infinite loop */
.timeline__slide--clone {
  /* Same styling as regular slides */
}

/* Timeline year text */
.timeline__year {
  position: absolute;
  /* Position absolutely to prevent layout shift */
  top: 0;
  left: 0;
  font-size: 1.5rem;
  /* 24px default */
  line-height: 1;
  color: var(--color-secondary);
  font-weight: var(--font-weight-bold);
  -webkit-transition: font-size 0.6s ease;
  -o-transition: font-size 0.6s ease;
  transition: font-size 0.6s ease;
  -webkit-transform-origin: top left;
  -ms-transform-origin: top left;
  -o-transform-origin: top left;
  transform-origin: top left;
  /* Scale from top-left corner */
}

/* Active slide year - scales up dramatically */
.timeline__slide.is-active .timeline__year {
  font-size: 8rem;
  /* 160px - large display */
}

/* Timeline horizontal line separator */
.timeline__line {
  position: relative;
  width: calc(100% + var(--spacing-lg));
  /* Extend to connect with next slide */
  height: 2px;
  background-color: var(--color-primary);
  margin-bottom: var(--spacing-md);
}

/* Timeline circle indicator */
.timeline__circle {
  position: absolute;
  top: 0;
  left: 0;
  width: 0.75rem;
  /* 12px */
  height: 0.75rem;
  border-radius: 50%;
  background-color: var(--color-primary);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

/* Timeline description container */
.timeline__description {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  gap: 1rem;
  /* 16px */
  opacity: 0;
  /* Hidden by default */
  max-width: 33ch;
  /* Limit text width */
  height: 7rem;
  /* 112px */
  font-size: 1.25rem;
  /* 20px */
  padding-top: 0.8rem;
  padding-left: 1.5rem;
  position: relative;
  -webkit-transition: opacity 0.6s ease;
  -o-transition: opacity 0.6s ease;
  transition: opacity 0.6s ease;
  line-height: 1.4;
}

/* Active slide description - fades in */
.timeline__slide.is-active .timeline__description {
  opacity: 1;
}

/* Vertical timeline line connector */
.timeline__line-vert {
  position: absolute;
  left: 0;
  top: -0.8rem;
  width: 2px;
  height: 1.5rem;
  background-color: var(--color-primary);
}

/* Description text */
.timeline__description-text {
  color: var(--color-secondary);
  margin: 0;
}

/* Mobile message for small screens */
.timeline__mobile-message {
  display: none;
  /* Hidden by default */
  text-align: center;
  padding: clamp(2rem, 8vh, 4rem) clamp(1rem, 4vw, 2rem);
  background-color: var(--color-gray-100);
  border-radius: clamp(12px, 1.5vw, 20px);
  margin-top: 2rem;
}

.timeline__mobile-message svg {
  color: var(--color-primary);
  margin: 0 auto 1.5rem;
  display: block;
}

.timeline__mobile-message h3 {
  font-size: clamp(1.25rem, 3vw, 1.75rem);
  color: var(--color-secondary);
  margin-bottom: 1rem;
}

.timeline__mobile-message p {
  font-size: clamp(0.875rem, 2vw, 1.125rem);
  color: var(--color-gray-600);
  max-width: 400px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Hide timeline and show message on screens < 787px */
@media (max-width: 786px) {

  .timeline__carousel,
  .timeline__navigation {
    display: none !important;
  }

  .timeline__mobile-message {
    display: block;
  }
}


/* ============================================
   6.4 OUR BRANDS SECTION
   ============================================
   Partner brand logos display
   - Inspired by Couche-Tard design
   - Responsive grid layout
   - Centered content with description
   ============================================ */

/* Brands section container */
.brands-section {
  width: 100%;
  padding: var(--spacing-xxl) 0;
  background-color: #f8f8f8;
  /* Light gray background */
}

/* Brands section header */
.brands-section__header {
  text-align: center;
  margin-bottom: var(--spacing-xxl);
}

/* Brands section title */
.brands-section__title {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
  line-height: 1.2;
}

/* Brands section description */
.brands-section__description {
  font-size: var(--font-size-medium);
  color: var(--color-gray);
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Logos grid container */
.brands-section__logos {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr var(--spacing-xl) 1fr var(--spacing-xl) 1fr var(--spacing-xl) 1fr;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-xl);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  max-width: 1000px;
  margin: 0 auto;
}

/* Individual brand logo wrapper */
.brand-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: var(--spacing-lg);
  background-color: var(--color-white);
  border-radius: 8px;
  -webkit-transition: -webkit-transform var(--transition-normal), -webkit-box-shadow var(--transition-normal);
  transition: -webkit-transform var(--transition-normal), -webkit-box-shadow var(--transition-normal);
  -o-transition: -o-transform var(--transition-normal), box-shadow var(--transition-normal);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal), -webkit-transform var(--transition-normal), -webkit-box-shadow var(--transition-normal), -o-transform var(--transition-normal);
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  min-height: 120px;
}

.brand-logo:hover {
  -webkit-transform: translateY(-5px);
  -ms-transform: translateY(-5px);
  -o-transform: translateY(-5px);
  transform: translateY(-5px);
  -webkit-box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

/* Brand logo image - fixed square size */
.brand-logo__image {
  width: 160px;
  height: 160px;
  display: block;
  -o-object-fit: contain;
  object-fit: contain;
}


/* ============================================
   7. FOOTER
   ============================================
   Site footer with navigation and legal links
   - Inspired by Couche-Tard footer design
   - Two-tier structure: navigation top, legal bottom
   - Responsive column layout
   ============================================ */

/* Footer container */
.footer {
  background-color: var(--color-secondary);
  color: var(--color-white);
}

/* Footer top section - navigation links */
.footer__top {
  padding: var(--spacing-xl) 0 var(--spacing-sm) 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* Footer grid layout */
.footer__grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr var(--spacing-xl) 1fr var(--spacing-xl) 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-l);
}

/* Footer column */
.footer__column {
  /* Default column styles */
}

/* Secondary column (quick links on right) */
.footer__column--secondary {
  -ms-grid-column-align: end;
  justify-self: end;
  text-align: right;
}

/* Footer column title */
.footer__title {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  margin-bottom: var(--spacing-md);
  line-height: 1.3;
}

/* Footer menu list */
.footer__menu {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Footer menu item */
.footer__menu-item {
  margin-bottom: var(--spacing-sm);
}

/* Footer link */
.footer__link {
  color: rgba(255, 255, 255, 0.8);
  font-size: var(--font-size-base);
  -webkit-transition: color var(--transition-fast);
  -o-transition: color var(--transition-fast);
  transition: color var(--transition-fast);
  line-height: 1.6;
}

.footer__link:hover {
  color: var(--color-white);
  text-decoration: underline;
}

/* Secondary menu (quick links) - no title */
.footer__menu--secondary {
  margin-top: 0;
}

/* Footer bottom section - copyright and legal */
.footer__bottom {
  padding: var(--spacing-lg) 0;
}

/* Footer bottom content wrapper */
.footer__bottom-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

/* Copyright text */
.footer__copyright {
  color: rgba(255, 255, 255, 0.6);
  font-size: var(--font-size-small);
  margin: 0;
}

/* Legal links wrapper */
.footer__legal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--spacing-lg);
}

/* Legal link */
.footer__legal-link {
  color: rgba(255, 255, 255, 0.6);
  font-size: var(--font-size-small);
  -webkit-transition: color var(--transition-fast);
  -o-transition: color var(--transition-fast);
  transition: color var(--transition-fast);
}

.footer__legal-link:hover {
  color: var(--color-white);
  text-decoration: underline;
}


/* ============================================
   8. UTILITY CLASSES
   ============================================
   Reusable utility classes
   ============================================ */

/* Text alignment */
.text-center {
  text-align: center;
}

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

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

/* Display utilities */
.d-none {
  display: none !important;
}

.d-block {
  display: block !important;
}

/* Visibility */
.hidden {
  visibility: hidden;
}

.visible {
  visibility: visible;
}


/* ============================================
   9. MEDIA QUERIES
   ============================================
   Responsive breakpoints for different screen sizes
   ============================================ */

/* Tablet and below (< 1200px) */
@media (max-width: 1200px) {
  .nav-primary__item {
    margin: 0px 8px;
  }

  .nav-primary__label {
    font-size: 12px;
    line-height: 16px;
  }
}

/* Tablet and below (< 1100px) */
@media (max-width: 1100px) {
  .nav-primary__item {
    margin: 0px 8px;
  }

  /* .nav-primary__label {
    font-size: 12px;
  } */
}

/* Tablet and below (< 992px) */
@media (max-width: 991px) {

  /* Hide desktop navigation */
  .header__desktop {
    display: none;
  }

  /* Show mobile navigation */
  .header__mobile {
    display: flex;
  }

  /* Adjust header padding for mobile */
  .header {
    /* Converted from 10px to viewport units for mobile
       Min: 0.375rem (6px), Preferred: 1.2vh, Max: 0.875rem (14px) */
    padding: clamp(0.375rem, 1.2vh, 0.875rem) 0;
  }

  /* Adjust main content padding */
  .main-content {
    /* Converted from 100px to viewport units for mobile
       Min: 80px, Preferred: 12vh, Max: 120px */
    padding-top: clamp(80px, 12vh, 120px);
  }

  /* Carousel mobile adjustments */
  .carousel {
    /* Adjust aspect ratio for tablets and mobile - 4:3 for better mobile viewing */
    aspect-ratio: 4 / 3;
    margin-top: 0px;
  }

  /* Smaller arrows on tablets */
  .carousel__arrow {
    width: 40px;
    height: 40px;
  }

  .carousel__arrow svg {
    width: 20px;
    height: 20px;
  }

  /* Hide pause button on mobile - tap on slide to pause instead */
  .carousel__pause {
    display: none;
  }

  /* Brands section tablet adjustments */
  .brands-section {
    padding: var(--spacing-xl) 0;
  }

  .brands-section__title {
    font-size: 2rem;
  }

  .brands-section__logos {
    -ms-grid-columns: 1fr var(--spacing-lg) 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
  }

  .brand-logo {
    padding: var(--spacing-md);
    min-height: 100px;
  }

  .brand-logo__image {
    width: 140px;
    height: 140px;
  }

  /* about section tablet adjustments */
  .about-section {
    padding: var(--spacing-lg) 0;
  }

  .about-section__title {
    font-size: 2rem;
  }

  .about-vision-mission {
    width: 100%;
    gap: 30px;
    flex-direction: column;
    margin-bottom: var(--spacing-lg);
  }

  .icon-title {
    gap: 10px;
    margin-bottom: 15px;
  }

  .icon-title img {
    width: 45px;
    height: 45px;
    padding: 12px;
    border-radius: 12px;
  }

  .about-section__header {
    margin-bottom: var(--spacing-lg);
  }

  .about-section .about-image {
    margin-bottom: var(--spacing-lg);
  }

  .vision__title,
  .mission__title {
    font-size: 1.2rem;
    line-height: 1.2;
  }

  .vision__description,
  .mission__description {
    font-size: var(--font-size-small);
    line-height: 1.3;
  }



  /* coming soon section container */
  .coming-soon-section {
    padding-top: 0px;
  }



  /* about us page start */
  /* hero section start */
  .about_us_image {
    height: 400px;
  }

  /* hero section end */

  /* our team section start */
  .our_team {
    padding: var(--spacing-lg) 0;
  }

  .our_team_title {
    font-size: 2rem;
  }

  .our_team .container {
    gap: 20px;
  }

  .our_team .container .our_team_cards .card {
    width: 46%;
  }

  .our_team .container .our_team_cards .card h3 {
    font-size: var(--font-size-small);
  }

  .our_team .container .our_team_cards .card p {
    font-size: var(--font-size-small);
  }

  /* our team section end */
  /* core values section start */
  .core_values {
    padding: var(--spacing-lg) 0;
  }

  .core_values_title {
    font-size: 2rem;
  }

  .core_values .core_values_content {
    gap: 20px;
  }

  .core_values .core_values_content .core_values_left {
    width: 40%;
  }

  .core_values .core_values_content .core_values_right {
    width: 60%;
  }

  .core_values .core_values_content .core_values_right .point {
    margin-bottom: var(--spacing-sm);
  }

  .core_values .core_values_content .core_values_right .point h3 {
    font-size: var(--font-size-small);
  }

  .core_values .core_values_content .core_values_right .point p {
    font-size: var(--font-size-small);
  }

  /* core values team section end */
  /* about us page end */




  /* Portfolio snapshot tablet adjustments */
  .portfolio-snapshot {
    padding: var(--spacing-xl) 0;
  }

  .portfolio-snapshot__title {
    font-size: 2rem;
  }

  .portfolio-snapshot__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 240px);
    gap: var(--spacing-md);
  }

  /* Remove offset on tablet - all cards aligned */
  .portfolio-card:nth-child(2),
  .portfolio-card:nth-child(5) {
    -webkit-transform: none;
    -ms-transform: none;
    -o-transform: none;
    transform: none;
  }

  /* Restore standard hover for all cards on tablet */
  .portfolio-card:hover {
    -webkit-transform: translateY(-8px);
    -ms-transform: translateY(-8px);
    -o-transform: translateY(-8px);
    transform: translateY(-8px);
  }

  .portfolio-card__title {
    font-size: 1.25rem;
  }

  .portfolio-card__content {
    padding: var(--spacing-md);
  }

  /* Footer tablet adjustments */
  .footer__grid {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: var(--spacing-xl);
  }

  .footer__column--secondary {
    -ms-grid-column-align: start;
    justify-self: start;
    text-align: left;
  }

  .footer__bottom-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }

  /* SOCIAL ICONS START */
  .social_icons {
    justify-content: flex-start;
    gap: 5px;
  }

  .social_icons .social_icon {
    width: 40px;
    height: 40px;
    border-radius: 3px;
  }

  .social_icons .social_icon:hover {
    background-color: var(--color-primary);
  }

  /* SOCIAL ICONS END */
}

/* Mobile devices (< 576px) */
@media (max-width: 575px) {

  /* Further reduce spacing on small screens */
  .header {
    padding: var(--spacing-sm) 0;
  }

  /* Smaller logo on very small screens */
  /* .header__mobile .logo__image {
    height: 28px;
  } */

  /* Adjust container padding */
  .container {
    padding-right: var(--spacing-sm);
    padding-left: var(--spacing-sm);
  }

  /* Carousel small mobile adjustments */
  .carousel {
    /* Square aspect ratio for small phones */
    aspect-ratio: 1 / 1;
    max-height: 400px;
  }

  /* Even smaller arrows on small phones */
  .carousel__arrow {
    width: 36px;
    height: 36px;
  }

  .carousel__arrow--prev {
    left: 10px;
  }

  .carousel__arrow--next {
    right: 10px;
  }

  /* Smaller dots */
  .carousel__dot {
    width: 10px;
    height: 10px;
  }

  .carousel__dot--active {
    width: 12px;
    height: 12px;
  }

  .carousel__dots {
    bottom: 12px;
    gap: 8px;
  }

  /* Brands section small mobile adjustments */
  .brands-section {
    padding: var(--spacing-lg) 0;
  }

  .brands-section__title {
    font-size: 1.75rem;
  }

  .brands-section__description {
    font-size: var(--font-size-base);
  }

  .brands-section__logos {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }

  .brand-logo {
    padding: var(--spacing-sm);
    min-height: 80px;
  }

  .brand-logo__image {
    width: 120px;
    height: 120px;
  }

  /* about section mobile adjustments */
  .about-section__title {
    font-size: 1.75rem;
    padding-left: 24px;
  }

  .about-section__title::before {
    width: 12px;
    height: 12px;
  }

  /* coming soon section container */
  .coming-soon-section {
    padding-top: 0px;
  }

  .coming-soon-btns {
    flex-direction: column;
    align-items: center;
  }

  /* about us page start */
  /* hero section start */
  .about_us_image {
    height: 350px;
  }

  /* hero section end */

  /* our team section start */
  .our_team_title {
    font-size: 1.75rem;
    padding-left: 24px;
    margin-left: auto;
  }

  .our_team_description {
    text-align: center;
  }

  .our_team .container {
    flex-direction: column;
    align-items: center;
  }

  .our_team .container .our_team_text {
    width: 100%;
  }

  .our_team .container .our_team_cards {
    width: 100%;
  }

  .our_team .container .our_team_cards .card {
    width: 46%;
  }

  .our_team .container .our_team_cards .card h3 {
    font-size: var(--font-size-small);
  }

  .our_team .container .our_team_cards .card p {
    font-size: var(--font-size-small);
  }

  /* our team section end */
  /* core values section start */
  .core_values {
    padding: var(--spacing-lg) 0;
  }

  .core_values_title {
    font-size: 1.75rem;
    padding-left: 24px;
    margin-left: auto;
  }

  .core_values_description {
    text-align: center;
    width: 100%;
    max-width: 100%;
  }

  .core_values .core_values_content {
    flex-direction: column;
    align-items: center;
  }

  .core_values .core_values_content .core_values_left {
    width: 100%;
  }

  .core_values .core_values_content .core_values_right {
    width: 100%;
  }

  /* core values team section end */
  /* about us page end */

  /* Portfolio snapshot mobile adjustments */
  .portfolio-snapshot {
    padding: var(--spacing-lg) 0;
  }

  .portfolio-snapshot__title {
    font-size: 1.75rem;
    padding-left: 24px;
  }

  .portfolio-snapshot__title::before {
    width: 12px;
    height: 12px;
  }

  .portfolio-snapshot__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(6, 220px);
    gap: var(--spacing-md);
  }

  /* Remove offset on mobile - all cards aligned */
  .portfolio-card:nth-child(2),
  .portfolio-card:nth-child(5) {
    -webkit-transform: none;
    -ms-transform: none;
    -o-transform: none;
    transform: none;
  }

  .portfolio-card__title {
    font-size: 1.125rem;
    padding-left: 16px;
  }

  .portfolio-card__title::before {
    font-size: 1.25rem;
  }

  .portfolio-card__content {
    padding: var(--spacing-sm) var(--spacing-md);
  }

  /* Footer mobile adjustments */
  .footer__top {
    padding: var(--spacing-xl) 0;
  }

  .footer__grid {
    gap: var(--spacing-lg);
  }

  .footer__title {
    font-size: var(--font-size-medium);
  }

  .footer__link {
    font-size: var(--font-size-small);
  }

  .footer__bottom {
    padding: var(--spacing-md) 0;
  }
}

/* Large desktop (> 1400px) */
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }

  /* Portfolio snapshot large desktop adjustments */
  .portfolio-snapshot__grid {
    grid-template-rows: repeat(2, 320px);
  }

  /* ============================================
     TIMELINE SECTION - LARGE DESKTOP
     ============================================ */

  .timeline__slide {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 28rem;
    flex: 0 0 28rem;
    /* Slightly larger slides on large screens */
    width: 28rem;
  }
}

/* ============================================
   TIMELINE SECTION - MOBILE RESPONSIVE
   ============================================ */

@media screen and (max-width: 767px) {
  .timeline-section {
    padding: var(--spacing-xl) 0;
  }

  .timeline-section__title {
    font-size: 1.75rem;
  }

  .timeline__arrow {
    width: 3rem;
    height: 3rem;
  }

  .timeline__arrow svg {
    width: 20px;
    height: 20px;
  }

  .timeline__slide {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 12rem;
    flex: 0 0 12rem;
    width: 12rem;
    height: 21rem;
    padding-top: 3rem;
    /* Add padding for absolute year */
  }

  .timeline__slide.is-active {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 17rem;
    flex: 0 0 17rem;
    width: 17rem;
    height: auto;
    min-height: 21rem;
    padding-top: 5rem;
    /* More padding for larger active year */
  }

  .timeline__year {
    font-size: 1.375rem;
  }

  .timeline__slide.is-active .timeline__year {
    font-size: 3.375rem;
    color: #5C88DA;
  }

  .timeline__description {
    max-width: 30ch;
    font-size: 0.9rem;
    height: auto;
  }
}

/* ============================================
   TIMELINE SECTION - TABLET RESPONSIVE
   ============================================ */

@media screen and (min-width: 768px) and (max-width: 991px) {
  .timeline-section__title {
    font-size: 2rem;
  }

  .timeline__slide {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 20rem;
    flex: 0 0 20rem;
    width: 20rem;
    height: 24rem;
    padding-top: 4rem;
    /* Add padding for absolute year */
  }

  .timeline__slide.is-active .timeline__year {
    font-size: 6rem;
  }

  .timeline__description {
    font-size: 1.1rem;
  }
}


/* ============================================
   END OF STYLESHEET
   ============================================ */
/* ============================================
   NEWS & STORIES PAGE STYLES
   ============================================ */

/* News Filters Section */
.news-filters {
  background-color: var(--color-white);
  padding: var(--spacing-md) 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.filter-buttons {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
  justify-content: center;
}

.filter-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border: 2px solid #FF8C00;
  border-radius: 50px;
  background-color: transparent;
  color: #2b2b2b;
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-small);
  cursor: pointer;
  transition: all var(--transition-normal);
}

.filter-btn:hover {
  background-color: #FF8C00;
  color: var(--color-white);
}

.filter-btn--active {
  background-color: #FF8C00;
  color: var(--color-white);
}

.filter-icon {
  color: #FF8C00;
  font-size: 12px;
}

.filter-btn--active .filter-icon,
.filter-btn:hover .filter-icon {
  color: var(--color-white);
}

/* News Section */
.news-section {
  padding: var(--spacing-xxl) 0;
  background-color: var(--color-white);
}

.news-section__header {
  margin-bottom: var(--spacing-xl);
}

.news-section__title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
}

.title-icon {
  color: #FF8C00;
  font-size: 24px;
}

.news-section__description {
  font-size: var(--font-size-medium);
  line-height: 1.6;
  color: #666;
  max-width: 900px;
}

/* News Grid */
.news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--spacing-xl);
}

/* News Card */
.news-card {
  background-color: var(--color-white);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.news-card__image-wrapper {
  width: 100%;
  height: 200px;
  overflow: hidden;
  background-color: #f5f5f5;
}

.news-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}

.news-card:hover .news-card__image {
  transform: scale(1.05);
}

.news-card__content {
  padding: var(--spacing-md);
}

.news-card__tags {
  display: flex;
  gap: 8px;
  margin-bottom: var(--spacing-sm);
  flex-wrap: wrap;
}

.news-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid #FF8C00;
  border-radius: 20px;
  font-size: 12px;
  color: #2b2b2b;
  background-color: transparent;
}

.tag-icon {
  color: #FF8C00;
  font-size: 8px;
}

.news-card__title {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-sm);
  line-height: 1.4;
}

.news-card__meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: var(--font-size-small);
  color: #666;
  flex-wrap: wrap;
}

.news-card__read-time,
.news-card__date {
  color: #999;
}

.news-card__link {
  color: #FF8C00;
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  margin-left: auto;
  transition: color var(--transition-normal);
}

.news-card__link:hover {
  color: #e67e00;
  text-decoration: underline;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .news-grid {
    grid-template-columns: 1fr;
  }

  .filter-buttons {
    justify-content: flex-start;
  }

  .news-section__title {
    font-size: 2rem;
  }
}

/* ============================================
   MEDIA RESOURCES PAGE STYLES
   ============================================ */

/* Media Resources Section */
.media-resources-section {
  padding: var(--spacing-xxl) 0;
  background-color: var(--color-white);
}

.media-resources__header {
  margin-bottom: var(--spacing-xl);
}

.media-resources__title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
}

.media-resources__description {
  font-size: var(--font-size-medium);
  line-height: 1.6;
  color: #666;
  max-width: 900px;
  margin-bottom: var(--spacing-xl);
}

/* Media Documents Grid */
.media-documents-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(450px, 1fr));
  gap: var(--spacing-xl);
  margin-bottom: var(--spacing-xxl);
}

/* Document Card */
.media-document-card {
  background-color: var(--color-white);
  border: 1px solid #ddd;
  border-radius: 16px;
  padding: var(--spacing-xl);
  transition: all var(--transition-normal);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.media-document-card:hover {
  border-color: #bbb;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.media-document-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.media-document-card__title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: var(--font-size-xlarge);
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  line-height: 1.3;
}

.media-document-card__subtitle {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-normal);
  color: #666;
}

.media-document-card__description {
  font-size: var(--font-size-medium);
  line-height: 1.6;
  color: #666;
}

.media-document-card__download {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0;
  background-color: transparent;
  border: none;
  color: var(--color-secondary);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-medium);
  cursor: pointer;
  transition: all var(--transition-normal);
  width: fit-content;
}

.media-document-card__download:hover {
  color: #000;
}

.media-document-card__download svg {
  width: 16px;
  height: 16px;
}

/* Logos Section */
.logos-section {
  padding: var(--spacing-xxl) 0;
  background-color: var(--color-white);
}

.logos-section__header {
  margin-bottom: var(--spacing-xl);
}

.logos-section__title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  margin-bottom: var(--spacing-md);
}

.logos-section__description {
  font-size: var(--font-size-medium);
  line-height: 1.6;
  color: #666;
  max-width: 900px;
  margin-bottom: var(--spacing-xl);
}

/* Logos Grid */
.logos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-xl);
}

/* Logo Card */
.media-logo-card {
  background-color: var(--color-white);
  border: 1px solid #ddd;
  border-radius: 16px;
  overflow: hidden;
  transition: all var(--transition-normal);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.media-logo-card:hover {
  border-color: #bbb;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.media-logo-card__preview {
  width: 100%;
  height: 180px;
  background-color: #fafafa;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-lg);
  border-bottom: 1px solid #eee;
}

.media-logo-card__preview img {
  max-width: 70%;
  max-height: 70%;
  object-fit: contain;
}

.media-logo-card__content {
  padding: var(--spacing-lg);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.media-logo-card__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
}

.media-logo-card__download {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0;
  background-color: transparent;
  border: none;
  color: var(--color-secondary);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-medium);
  cursor: pointer;
  transition: all var(--transition-normal);
  width: fit-content;
}

.media-logo-card__download:hover {
  color: #000;
}

.media-logo-card__download svg {
  width: 16px;
  height: 16px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .media-documents-grid {
    grid-template-columns: 1fr;
  }

  .logos-grid {
    grid-template-columns: 1fr;
  }

  .media-resources__title,
  .logos-section__title {
    font-size: 2rem;
  }
}