/* Design tokens */
:root{
  /* Dark Navy Blue Palette */
  --color-primary:#0f172a;        /* Dark navy - primary actions */
  --color-secondary:#3b82f6;      /* Bright blue - secondary accents */
  --color-tertiary:#60a5fa;       /* Light blue - subtle accents */
  --color-accent:#475569;         /* Slate grey - accent elements */
  --color-gray:#e2e8f0;           /* Light grey - backgrounds, borders */
  --color-gray-medium:#94a3b8;    /* Medium grey - muted text */
  --color-gray-dark:#334155;      /* Dark grey - headings, text */
  --color-black:#0f172a;          /* Dark navy (same as primary) */
  --color-white:#FFFFFF;

  --radius-md:8px;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px;

  /* Typography: Montserrat for headings and body */
  --font-heading:"Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-body:"Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --fs-base:16px; --lh-base:26px;
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--color-gray-dark); background:#fff; font-family:var(--font-body); font-size:var(--fs-base); line-height:var(--lh-base);
}
a{color:var(--color-primary); text-decoration:none; transition:color .2s ease}
a:hover{color:var(--color-secondary)}
.container{max-width:1200px; margin:0 auto; padding:0 var(--space-5)}
.narrow{max-width:880px}

.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  font-weight:700;
  margin:0 0 var(--space-5) 0;
  color:var(--color-primary);
}
.h1,h1{font-size:48px; line-height:56px; letter-spacing:-0.01em}
.h2,h2{font-size:36px; line-height:44px}
.h3,h3{font-size:28px; line-height:36px}
.h4,h4{font-size:22px; line-height:30px}
.h5,h5{font-size:18px; line-height:26px}
.lead{font-size:18px; line-height:28px}
.muted{color:var(--color-gray-medium)}

/* Accessibility helpers */
.skip-link{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip-link:focus{position:static; width:auto; height:auto; padding:var(--space-3); background:var(--color-primary); color:#fff}
.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}

/* Secondary Header */
.header-secondary{background:var(--color-primary); color:#fff; padding:var(--space-2) 0; border-bottom:1px solid rgba(255,255,255,0.15)}
.header-secondary-inner{display:flex; align-items:center; justify-content:space-between; gap:var(--space-5)}
.header-secondary-contact{display:flex; align-items:center; gap:var(--space-5); font-size:14px}
.header-secondary-contact a{color:#fff; text-decoration:none; transition:opacity .2s ease}
.header-secondary-contact a:hover{opacity:0.8}
.header-secondary-contact a[href^="mailto:"]{display:flex; align-items:center; gap:4px}
.header-secondary-contact .social-link{display:flex; align-items:center; gap:6px}
.header-secondary-contact .social-icon{flex-shrink:0; width:16px; height:16px}
.header-secondary-right{display:flex; align-items:center; gap:var(--space-4)}
.header-secondary .btn{font-size:14px; padding:8px 16px}
.header-secondary .lang{position:relative}
.header-secondary .lang select{
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background:rgba(255,255,255,0.15); color:#fff; border:1px solid rgba(255,255,255,0.3);
  border-radius:999px; height:32px; line-height:32px; padding:0 32px 0 12px;
  font-weight:600; font-size:14px; cursor:pointer; transition:background .2s ease;
}
.header-secondary .lang select:hover{background:rgba(255,255,255,0.25)}
.header-secondary .lang select:focus{outline:2px solid #fff; outline-offset:2px}
.header-secondary .lang select option{color:#111; background:#fff}
.header-secondary .lang::after{content:"▾"; position:absolute; right:10px; top:50%; transform:translateY(-50%); color:#fff; font-size:10px; pointer-events:none}

/* Header */
.site-header{position:sticky; top:0; z-index:10; background:#fff; border-bottom:none}
.site-header{position:sticky}
.site-header::after{content:""; position:absolute; left:0; right:0; bottom:0; height:5px; background:linear-gradient(90deg, var(--color-secondary), var(--color-primary));}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:var(--space-3) 0; min-height:64px}
.brand-link{display:flex; align-items:center; gap:var(--space-3); text-decoration:none}
.brand-logo{height:71px; width:auto; display:block}

.site-nav ul{display:flex; list-style:none; gap:var(--space-5); padding:var(--space-2) 0; margin:0}
.site-nav a{color:var(--color-gray-dark); text-decoration:none; display:flex; align-items:center; height:44px; position:relative; transition:color .2s ease; font-size:18px}
.site-nav a::after{content:""; position:absolute; left:0; bottom:-4px; height:2px; width:100%; background:linear-gradient(90deg, var(--color-primary), var(--color-secondary)); transform:scaleX(0); transform-origin:left; transition:transform .2s ease}
.site-nav a:hover{color:var(--color-primary)}
.site-nav a:hover::after{transform:scaleX(1)}
.site-nav a[aria-current="page"]{color:var(--color-primary); font-weight:700}
.site-nav a[aria-current="page"]::after{transform:scaleX(1)}
.site-nav .btn{color:#fff !important; text-decoration:none}
.site-nav .btn:hover{text-decoration:none}
/* remove hover underline effect from header button */
.site-nav .btn::after{content:none; display:none}

/* Language switcher pill - removed from primary nav, now in secondary header */

/* Hamburger Menu Toggle Button */
.nav-toggle{
  display:none;
  background:none;
  border:none;
  padding:8px;
  cursor:pointer;
  position:relative;
  z-index:1001;
  width:40px;
  height:40px;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:6px;
  transition:all 0.3s ease;
}
.nav-toggle:focus{
  outline:2px solid var(--color-primary);
  outline-offset:2px;
  border-radius:var(--radius-md);
}
.nav-toggle span,
.nav-toggle::before,
.nav-toggle::after{
  content:"";
  display:block;
  width:24px;
  height:3px;
  background:var(--color-primary);
  border-radius:2px;
  transition:all 0.3s ease;
  transform-origin:center;
}
.nav-toggle::before{
  position:absolute;
  top:10px;
}
.nav-toggle::after{
  position:absolute;
  bottom:10px;
}
.nav-toggle span{
  position:relative;
}
/* Hamburger to X animation when menu is open */
.nav-toggle[aria-expanded="true"] span{
  opacity:0;
  transform:scaleX(0);
}
.nav-toggle[aria-expanded="true"]::before{
  top:50%;
  left:50%;
  transform:translate(-50%, -50%) rotate(45deg);
}
.nav-toggle[aria-expanded="true"]::after{
  bottom:auto;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%) rotate(-45deg);
}

/* Mobile Menu Overlay */
.menu-overlay{
  display:none;
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(15,23,42,0.5);
  z-index:999;
  opacity:0;
  transition:opacity 0.3s ease;
}
.menu-overlay.active{
  display:block;
  opacity:1;
}

/* Sections */
.section{padding:var(--space-8) 0}
.section-alt{background:#f1f5f9; border-top:1px solid var(--color-gray); border-bottom:1px solid var(--color-gray)}
.section-primary{background:var(--color-primary); color:#fff}
.section-primary a{color:#fff; text-decoration:underline}
.section-primary .card{background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.25)}
.section-dark{background:var(--color-primary); color:#fff}
.section-dark .h2{color:#fff}
.section-dark .card{background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.25); color:#fff}
.section-dark .card h3{color:#fff}
.section-dark .card p{color:rgba(255,255,255,0.9)}

/* Light blue tint like hero — exact secondary shade */
.section-tint{background:linear-gradient(180deg, rgba(59,130,246,0.12), rgba(59,130,246,0.12))}

/* Hero */
.hero{
  position:relative;
  color:var(--color-primary);
  background:#fff;
  overflow:hidden;
  padding:0;
}
.hero::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  width:100%;
  background:url("../../assets/images/premium_photo-1668490070398-4683ab16a68c.avif") center center/cover no-repeat;
  z-index:0;
}
.hero-inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:var(--space-8) var(--space-5);
  width:100% !important;
  max-width:75vw !important;
  margin:0 auto !important;
}
.page-home .hero-inner{
  min-height:70vh;
}
.hero-copy{
  max-width:90vw;
  width:100%;
  background:transparent;
  padding:var(--space-7);
  border-radius:12px;
  backdrop-filter:blur(2px);
  border:2px groove grey;
}
.hero .h1{color:#fff; text-shadow:0 2px 4px rgba(0,0,0,0.3); font-size:36px; line-height:44px}
/* Services page h1 size override */
#services-hero-heading{font-size:42px; line-height:50px; color:#fff; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-subtitle{
  color:#fff;
  font-weight:600;
  margin:0 0 var(--space-4);
  text-shadow:0 2px 4px rgba(0,0,0,0.3);
}
.hero .lead{color:#fff; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-copy p{color:#fff; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-copy ul{color:#fff; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-copy li{color:#fff; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-copy p[style*="color"]{color:#fff !important; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-copy ul[style*="color"]{color:#fff !important; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.hero-copy li[style*="color"]{color:#fff !important; text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.cta-group{display:flex; gap:var(--space-4); align-items:center; flex-wrap:wrap}

/* Letter from the CEO */
.ceo-letter{
  background:
    linear-gradient(rgba(0,0,0,0.4), rgba(0,0,0,0.4)),
    url("../../assets/images/fachrizal-maulana-X1BDnG-jdAw-unsplash.jpg") center/cover no-repeat;
}
.ceo-letter-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-6);
  align-items:start;
}
.ceo-letter-card{
  background:transparent;
  border-radius:var(--radius-md);
  padding:var(--space-6);
  box-shadow:none;
  text-align:left;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-calendar-placeholder{
  background:rgba(255,255,255,0.95);
  border-radius:var(--radius-md);
  padding:var(--space-6);
  min-height:400px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,0.08);
}
.ceo-letter-card .h2,
.ceo-letter-card h2{
  text-align:left;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-letter .h2,
.ceo-letter h2,
#ceo-letter .h2,
#ceo-letter h2{
  color:#fff !important;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-letter .ceo-quote{
  margin:0 0 var(--space-5);
  padding:0;
  padding-left:5px;
  border:none;
  font-style:italic;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-letter .ceo-quote blockquote{
  margin:0;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-letter .ceo-quote figcaption{
  margin-top:var(--space-3);
  font-style:normal;
  font-weight:600;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-letter p{
  margin-top:0;
  margin-bottom:var(--space-3);
  padding-left:5px;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.ceo-letter p.muted{
  font-weight:600;
  padding-left:5px;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,0.3);
}

/* Buttons - flat (no gradients) */
.btn{display:inline-block; border:1px solid transparent; border-radius:var(--radius-md); padding:12px 18px; text-decoration:none; font-weight:600}
.btn:focus{outline:2px solid var(--color-primary); outline-offset:2px}
.btn-primary{background:var(--color-primary); color:#fff}
.btn-primary:hover{background:#1e293b}
/* Accent primary CTAs */
.btn-accent{background:var(--color-secondary); color:#fff}
.btn-accent:hover{background:#1e40af; color:#fff}
.btn-secondary{background:var(--color-tertiary); color:#fff}
.btn-secondary:hover{background:#3b82f6}
.btn-lg{padding:14px 22px; font-size:18px}

/* Cards */
.cards{display:grid; grid-template-columns:repeat(2, 1fr); gap:var(--space-6)}
.cards.three{grid-template-columns:repeat(3, 1fr)}
.cards.five{grid-template-columns:repeat(5, 1fr)}
.card{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); padding:var(--space-5); border-top:4px solid var(--color-secondary); box-shadow:0 1px 3px rgba(15,23,42,0.05)}
/* Code of Conduct - ensure all cards match in size */
#code-of-conduct .cards.five{
  align-items:stretch;
  gap:var(--space-3);
}
#code-of-conduct .card{
  display:flex;
  flex-direction:column;
  height:100%;
}
#code-of-conduct .card .h4,
#code-of-conduct .card h4{
  font-size:20px;
  line-height:28px;
}
#code-of-conduct .card p{
  flex-grow:1;
  margin-bottom:0;
}
/* Optional image within cards */
.card-img{width:100%; height:180px; object-fit:cover; border-radius:6px; display:block; margin-bottom:var(--space-4)}

/* Feature rows (alternating image/text) */
.features{display:flex; flex-direction:column; gap:var(--space-7)}
.feature{display:grid; grid-template-columns:0.25fr 0.75fr; gap:var(--space-4); background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,0.08)}
.feature.reverse{grid-template-columns:0.75fr 0.25fr}
.feature.reverse .feature-media{order:2}
.feature.reverse .feature-copy{order:1}
.feature-media{display:flex; align-items:center; justify-content:center; overflow:hidden}
.feature-media img{width:100%; max-height:300px; object-fit:cover; display:block}
/* Leadership section background */
#leadership{
  background:
    linear-gradient(rgba(0,0,0,0.4), rgba(0,0,0,0.4)),
    url("../../assets/images/a-chosen-soul-RJNqruxgkhI-unsplash.jpg") center/cover no-repeat;
  position:relative;
}
#leadership .h2{
  color:#fff;
}
#leadership .feature{
  background:transparent;
  border-radius:var(--radius-md);
  box-shadow:none;
  backdrop-filter:blur(10px);
  border:2px groove grey;
}
/* Make all text white in leadership section */
#leadership .feature-copy,
#leadership .feature-copy p,
#leadership .feature-copy li,
#leadership .feature-media .h3,
#leadership .feature-media .h4,
#leadership .feature-copy .h3,
#leadership .feature-copy .h4{
  color:#fff;
}
/* Make links white in leadership section */
#leadership a{
  color:#fff;
}
/* Make links blue on hover in leadership section */
#leadership a:hover{
  color:var(--color-secondary);
}
/* Leadership section images - no special styling */
#leadership .feature-media{
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:var(--space-5);
}
#leadership .feature-media img{
  width:70%;
  max-width:280px;
  height:420px;
  object-fit:cover;
  display:block;
}
#leadership .feature-media .h3{
  margin-top:var(--space-4);
  margin-bottom:0;
  text-align:center;
  font-size:18px;
  line-height:26px;
}
#leadership .feature-media .h4{
  font-size:16px;
  line-height:22px;
  text-align:center;
}
#leadership .feature-media .h3 a,
#leadership .feature-media .h4 a{
  color:inherit;
  text-decoration:none;
  transition:color .2s ease;
}
#leadership .feature-media .h3 a:hover,
#leadership .feature-media .h4 a:hover{
  color:var(--color-secondary);
}
#leadership .feature.reverse{
  margin-top:1.4rem;
}
.feature-copy{padding:var(--space-4)}
.feature-copy .h3{margin-top:0}

/* Split section layout */
.split{display:grid; grid-template-columns:1.2fr 1fr; gap:var(--space-6); align-items:center}
.split-media img{width:100%; height:auto; display:block; border-radius:var(--radius-md); box-shadow:0 10px 24px rgba(0,0,0,0.12)}
.split-media iframe{width:100%; height:auto; aspect-ratio:16/9; display:block; border-radius:var(--radius-md); box-shadow:0 10px 24px rgba(0,0,0,0.12)}
.video-thumbnail-container{position:relative; width:100%; cursor:pointer; border-radius:var(--radius-md); overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,0.12); display:block; text-decoration:none}
.video-thumbnail-container:hover .video-play-button{transform:translate(-50%, -50%) scale(1.1)}
.video-thumbnail-container:focus{outline:2px solid var(--color-primary); outline-offset:4px; border-radius:var(--radius-md)}
.video-thumbnail{width:100%; height:auto; display:block; border-radius:var(--radius-md)}
.video-play-button{position:absolute; top:50%; left:50%; transform:translate(-50%, -50%); background:none; border:none; cursor:pointer; padding:0; transition:transform 0.2s ease; pointer-events:none}
.split-copy p{margin-bottom:0}

/* Image row */
.image-row{display:grid; grid-template-columns:repeat(4, 1fr); gap:var(--space-5); margin-bottom:var(--space-6)}
.image-row .media-card{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); box-shadow:0 8px 18px rgba(0,0,0,0.08); overflow:hidden}
.image-row img{width:100%; height:220px; object-fit:cover; display:block}

/* Media grid for testimonials */
.media-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:var(--space-5)}
.media-card{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); box-shadow:0 8px 18px rgba(0,0,0,0.08); overflow:hidden}
.media{width:100%; height:220px; display:block; object-fit:cover; background:#000}
.media.placeholder{background:linear-gradient(135deg, var(--color-gray), #f8fafc)}

/* Written Testimonials */
.testimonial-written{max-width:880px; margin:0 auto}
.testimonial-content{background:#fff; border:1px solid var(--color-gray); border-left:4px solid var(--color-secondary); border-radius:var(--radius-md); padding:var(--space-6); box-shadow:0 10px 24px rgba(0,0,0,0.08)}
.testimonial-title{color:var(--color-primary); font-size:24px; line-height:32px; font-weight:700; margin:0 0 var(--space-5) 0}
.testimonial-text{color:var(--color-gray-dark); line-height:1.8}
.testimonial-text p{margin:0 0 var(--space-4) 0}
.testimonial-text p:last-child{margin-bottom:var(--space-5)}
.testimonial-author{font-size:18px; font-weight:700; color:var(--color-primary); margin:var(--space-5) 0 0 0; padding-top:var(--space-4); border-top:1px solid var(--color-gray)}

/* Partner logos */
.logo-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--space-6); align-items:center}
.logo-cell{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); padding:var(--space-6); display:flex; align-items:center; justify-content:center; min-height:120px}
.logo-cell img{max-width:220px; max-height:80px; width:auto; height:auto; object-fit:contain; filter: grayscale(0); opacity:0.95; transition:opacity .2s ease}
.logo-cell img:hover{opacity:1}

/* Flickity Carousel for Partners */
.carousel{background:#fff; margin:var(--space-6) 0}
.carousel-cell{width:33.333%; margin-right:var(--space-4); background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); padding:var(--space-6); display:flex; align-items:center; justify-content:center; min-height:120px; transition:transform .3s ease, box-shadow .3s ease}
.carousel-cell:hover{transform:translateY(-4px); box-shadow:0 8px 18px rgba(0,0,0,0.12)}
.carousel-cell a{display:flex; align-items:center; justify-content:center; width:100%; height:100%; text-decoration:none}
.carousel-cell img{max-width:220px; max-height:80px; width:auto; height:auto; object-fit:contain; filter:grayscale(0); opacity:0.95; transition:opacity .2s ease}
.carousel-cell img:hover{opacity:1}
/* Flickity button styles */
.flickity-button{background:var(--color-primary); color:#fff; border:none; border-radius:50%; width:44px; height:44px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s ease, transform .2s ease}
.flickity-button:hover{background:var(--color-secondary); transform:scale(1.1)}
.flickity-button:disabled{opacity:0.3; cursor:not-allowed}
.flickity-button-icon{fill:#fff; width:20px; height:20px}
.flickity-prev-next-button{position:absolute; top:50%; transform:translateY(-50%); z-index:2}
.flickity-prev-next-button.previous{left:var(--space-4)}
.flickity-prev-next-button.next{right:var(--space-4)}
/* Hide default Flickity page dots since we're using wrapAround */
.flickity-page-dots{display:none}

/* Video Grid */
.video-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--space-6)}
.video-item{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); overflow:hidden; box-shadow:0 8px 18px rgba(0,0,0,0.08); transition:box-shadow .3s ease, transform .3s ease}
.video-item:hover{box-shadow:0 12px 24px rgba(0,0,0,0.12); transform:translateY(-4px)}
.video-thumbnail-link{display:block; position:relative; overflow:hidden; cursor:pointer}
.video-thumbnail{width:100%; display:block; aspect-ratio:16/9; object-fit:cover; transition:transform .3s ease}
.video-thumbnail-link:hover .video-thumbnail{transform:scale(1.05)}
.video-thumbnail-link .play-button{position:absolute; top:50%; left:50%; transform:translate(-50%, -50%); width:68px; height:48px; background-color:rgba(255, 0, 0, 0.8); border-radius:12px; display:flex; align-items:center; justify-content:center; transition:all 0.2s ease; box-shadow:0 4px 12px rgba(0,0,0,0.3)}
.video-thumbnail-link:hover .play-button{background-color:rgba(255, 0, 0, 1); transform:translate(-50%, -50%) scale(1.1)}
.video-item .h4{margin-top:var(--space-4); margin-bottom:var(--space-2); padding:0 var(--space-4)}
.video-item p{margin:0; padding:0 var(--space-4) var(--space-4) var(--space-4)}

/* Links Grid */
.links-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--space-6)}
.link-card{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); padding:var(--space-6); box-shadow:0 8px 18px rgba(0,0,0,0.08); transition:box-shadow .3s ease, transform .3s ease; display:flex; flex-direction:column; align-items:flex-start; text-align:left}
.link-card:hover{box-shadow:0 12px 24px rgba(0,0,0,0.12); transform:translateY(-4px)}
.link-card-icon{color:var(--color-secondary); margin-bottom:var(--space-4); width:48px; height:48px; display:flex; align-items:center; justify-content:center}
.link-card .h4{margin-top:0; margin-bottom:var(--space-3)}
.link-card p{margin-bottom:var(--space-4); flex-grow:1}
.btn-link-card{width:100%; text-align:center; display:inline-flex; align-items:center; justify-content:center}

@media (max-width: 900px){
  .logo-grid{grid-template-columns:repeat(2, 1fr); gap:var(--space-5)}
  .logo-cell{padding:var(--space-5); min-height:100px}
  .logo-cell img{max-width:180px; max-height:70px}
  .carousel-cell{width:50%; margin-right:var(--space-3); padding:var(--space-5); min-height:100px}
  .carousel-cell img{max-width:180px; max-height:70px}
  .flickity-prev-next-button.previous{left:var(--space-2)}
  .flickity-prev-next-button.next{right:var(--space-2)}
  .video-grid{grid-template-columns:repeat(2, 1fr)}
  .links-grid{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .logo-grid{grid-template-columns:repeat(2, 1fr); gap:var(--space-4)}
  .logo-cell{padding:var(--space-4); min-height:90px}
  .logo-cell img{max-width:140px; max-height:60px}
  .carousel-cell{width:100%; margin-right:var(--space-2); padding:var(--space-4); min-height:90px}
  .carousel-cell img{max-width:140px; max-height:60px}
  .flickity-prev-next-button{width:36px; height:36px}
  .flickity-prev-next-button.previous{left:var(--space-1)}
  .flickity-prev-next-button.next{right:var(--space-1)}
  .video-grid{grid-template-columns:1fr}
  .links-grid{grid-template-columns:1fr}
}

/* Lists */
.checklist{padding-left:1.2rem}
.checklist li{margin-bottom:var(--space-3)}

/* Benefit callout */
.benefit{border-left:4px solid var(--color-secondary); padding-left:var(--space-4); margin-top:var(--space-3)}

/* Footer */
.site-footer{border-top:1px solid var(--color-gray); background:#fff}
.footer-inner{display:flex; align-items:center; justify-content:space-between; padding:var(--space-6) 0}
.utility-links{display:flex; list-style:none; gap:var(--space-5); padding:0; margin:0}

/* Footer blue variant */
.site-footer.footer-primary{background:var(--color-primary); color:#fff; border-top-color:rgba(255,255,255,0.2)}
.site-footer.footer-primary a{color:#fff}

/* Secondary Footer */
.footer-secondary{background:#fff; border-top:1px solid var(--color-gray); padding:var(--space-6) 0}
/* Desktop: 901px and above - two columns with Hours on the right */
.footer-secondary-inner{display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6); padding:var(--space-5) 0}
.footer-secondary-contact{display:flex; flex-direction:column; gap:var(--space-4)}
.footer-secondary-contact h3{font-size:18px; margin:0 0 var(--space-3) 0; color:var(--color-primary)}
.footer-secondary-contact a{color:var(--color-gray-dark); text-decoration:none; display:flex; align-items:center; gap:6px; transition:color .2s ease; font-size:14px}
.footer-secondary-contact a:hover{color:var(--color-primary)}
.footer-secondary-contact a[href^="mailto:"]{display:flex; align-items:center; gap:6px}
.footer-secondary-contact .social-link{display:flex; align-items:center; gap:6px}
.footer-secondary-contact .social-icon{flex-shrink:0; width:16px; height:16px}
/* Facebook and LinkedIn icons in original brand colors */
.footer-secondary-contact .social-link-facebook .social-icon{fill:#1877F2}
.footer-secondary-contact .social-link-facebook:hover .social-icon{fill:#1877F2}
.footer-secondary-contact .social-link-linkedin .social-icon{fill:#0A66C2}
.footer-secondary-contact .social-link-linkedin:hover .social-icon{fill:#0A66C2}
.footer-secondary-contact p{margin:0 0 var(--space-2) 0; font-size:14px; color:var(--color-gray-dark)}
/* Desktop: Hours section right-aligned */
.footer-secondary-hours{text-align:right}
.footer-secondary-hours h3{font-size:18px; margin:0 0 var(--space-3) 0; color:var(--color-primary)}
.footer-secondary-hours p{margin:0 0 var(--space-2) 0; font-size:14px; color:var(--color-gray-dark)}

/* Responsive */
@media (max-width: 1000px){
  .cards.five{grid-template-columns:repeat(3, 1fr)}
  /* Code of Conduct - ensure cards match in size at 3 columns */
  #code-of-conduct .cards.five{
    align-items:stretch;
    gap:var(--space-3);
  }
  #code-of-conduct .card{
    display:flex;
    flex-direction:column;
    height:100%;
  }
  #code-of-conduct .card .h4,
  #code-of-conduct .card h4{
    font-size:20px;
    line-height:28px;
  }
  #code-of-conduct .card p{
    flex-grow:1;
    margin-bottom:0;
  }
}
/* Code of Conduct - keep 5 columns at 1080px with tighter spacing */
@media (min-width: 1001px) and (max-width: 1200px){
  #code-of-conduct .cards.five{
    grid-template-columns:repeat(5, 1fr);
    gap:var(--space-3);
    align-items:stretch;
  }
  #code-of-conduct .card{
    padding:var(--space-4);
    display:flex;
    flex-direction:column;
    height:100%;
  }
  #code-of-conduct .card .h4,
  #code-of-conduct .card h4{
    font-size:16px;
    line-height:22px;
  }
  #code-of-conduct .card p{
    font-size:14px;
    line-height:20px;
    flex-grow:1;
    margin-bottom:0;
  }
}
@media (max-width: 900px){
  .cards{grid-template-columns:1fr}
  .cards.three{grid-template-columns:1fr}
  .cards.five{grid-template-columns:repeat(2, 1fr)}
  /* Code of Conduct - ensure cards match in size on tablet */
  #code-of-conduct .cards.five{
    align-items:stretch;
    gap:var(--space-3);
  }
  #code-of-conduct .card{
    display:flex;
    flex-direction:column;
    height:100%;
  }
  #code-of-conduct .card .h4,
  #code-of-conduct .card h4{
    font-size:20px;
    line-height:28px;
  }
  #code-of-conduct .card p{
    flex-grow:1;
    margin-bottom:0;
  }
  .feature, .feature.reverse{grid-template-columns:1fr}
  .feature-media img{max-height:300px}
  /* Leadership images - no special styling on mobile */
  #leadership .feature-media img{
    width:100%;
  }
  /* CEO Letter two-column layout - stack on tablet and mobile */
  .ceo-letter-grid{
    grid-template-columns:1fr;
    gap:var(--space-5);
  }
  /* Hero responsive adjustments */
  .hero-inner{
    min-height:60vh;
    padding:var(--space-4) var(--space-4);
  }
  .page-home .hero-inner{
    padding:var(--space-6) var(--space-4);
  }
  .hero-copy{
    padding:var(--space-6);
  }
  /* Written testimonials responsive */
  .testimonial-content{
    padding:var(--space-5);
  }
}

@media (min-width: 721px) {
  .mobile-menu-logo{display:none}
  .mobile-menu-logo .brand-logo{display:none !important}
}

@media (max-width: 720px){
  .header-secondary-inner{flex-direction:column; gap:var(--space-3); align-items:flex-start}
  .header-secondary-contact{flex-wrap:wrap; gap:var(--space-3)}
  .header-secondary-right{width:100%; justify-content:space-between}
  
  /* Mobile Navigation Menu */
  .nav-toggle{
    display:flex;
    position:relative;
  }
  
  /* When menu is open, position close button absolutely in top right */
  .nav-toggle[aria-expanded="true"]{
    position:fixed;
    top:var(--space-4);
    right:var(--space-4);
    z-index:1002;
    background:rgba(15,23,42,0.9);
    border-radius:50%;
    width:44px;
    height:44px;
    box-shadow:0 2px 8px rgba(0,0,0,0.2);
  }
  
  /* Make close X white when menu is open */
  .nav-toggle[aria-expanded="true"]::before,
  .nav-toggle[aria-expanded="true"]::after{
    background:#fff;
  }
  
  .site-nav{
    position:fixed;
    top:0;
    right:0;
    width:min(320px, 85vw);
    height:100vh;
    background:#fff;
    border-left:1px solid var(--color-gray);
    padding:0;
    display:flex;
    flex-direction:column;
    z-index:1000;
    transform:translateX(100%);
    transition:transform 0.3s ease;
    box-shadow:-4px 0 24px rgba(0,0,0,0.15);
    overflow-y:auto;
  }
  .site-nav.open{
    transform:translateX(0);
  }
  
  /* Logo in mobile menu - only visible when menu is open */
  .site-nav .mobile-menu-logo{
    display:none; /* Hidden by default */
    padding:var(--space-5);
    border-bottom:1px solid var(--color-gray);
    background:var(--color-primary);
  }
  .site-nav.open .mobile-menu-logo{
    display:flex; /* Only show when menu is open */
  }
  .site-nav .mobile-menu-logo .brand-link{
    width:100%;
    justify-content:center;
  }
  .site-nav .mobile-menu-logo .brand-logo{
    height:60px;
    filter:brightness(0) invert(1); /* White logo on dark background */
    display:none; /* Hidden by default - only show in offcanvas */
  }
  .site-nav.open .mobile-menu-logo .brand-logo{
    display:block; /* Only show when offcanvas menu is open */
  }
  
  .site-nav ul{
    flex-direction:column;
    gap:0;
    padding:var(--space-4) 0;
    margin:0;
    list-style:none;
  }
  .site-nav ul li{
    border-bottom:1px solid var(--color-gray);
  }
  .site-nav a{
    display:flex;
    align-items:center;
    padding:var(--space-4) var(--space-5);
    height:auto;
    min-height:56px;
    color:var(--color-gray-dark);
    font-size:18px;
    font-weight:500;
    transition:background-color 0.2s ease, color 0.2s ease;
  }
  .site-nav a::after{
    display:none;
  }
  .site-nav a:hover,
  .site-nav a:focus{
    background:var(--color-gray);
    color:var(--color-primary);
  }
  .site-nav a[aria-current="page"]{
    background:rgba(59,130,246,0.1);
    color:var(--color-primary);
    font-weight:700;
    border-left:4px solid var(--color-secondary);
  }

  /* Hero mobile adjustments */
  .hero-inner{
    min-height:50vh;
    padding:var(--space-3) var(--space-4);
  }
  .page-home .hero-inner{
    padding:var(--space-5) var(--space-4);
  }
  .hero-copy{
    padding:var(--space-5);
    border-radius:8px;
  }
  .hero .h1{font-size:36px; line-height:44px}
  .hero .lead{font-size:16px; line-height:24px}
  .cards.five{grid-template-columns:1fr}
  /* Written testimonials mobile */
  .testimonial-content{
    padding:var(--space-4);
  }
  .testimonial-title{
    font-size:20px;
    line-height:28px;
  }
}

/* Heavier blue usage in sections */

/* Heading accents under each section title (solid colors per section) */
.section .h2{position:relative; padding-bottom:14px; color:var(--color-primary)}
.section .h2::after{content:""; position:absolute; left:0; bottom:0; height:6px; width:72px; border-radius:3px; background:var(--color-secondary)}
/* Challenge section - white background, black text */
#challenge{background:#fff; color:var(--color-gray-dark)}
#challenge .h2{color:var(--color-primary)}
#challenge p{color:var(--color-gray-dark)}
#challenge li{color:var(--color-gray-dark)}

/* Specific mappings */
#ceo-letter .h2::after{background:var(--color-secondary)}
#challenge .h2::after{background:var(--color-secondary)}
#mission .h2::after{background:var(--color-secondary)}
#services .h2::after{background:var(--color-secondary)}
#operational-process .h2::after{background:var(--color-secondary)}
#additional .h2::after{background:var(--color-secondary)}
#why .h2::after{background:var(--color-secondary)}
.cta-final .h2::after{background:var(--color-secondary)}


/* Contact page */
.hero-contact{background:
  linear-gradient(rgba(15,23,42,0.65), rgba(15,23,42,0.65)),
  url("../../assets/images/marcin-nowak-iXqTqC-f6jI-unsplash.jpg") center/cover no-repeat;
}
.page-contact .hero-inner{min-height:38vh}
.page-contact #contact-hero-heading{position:relative; padding-bottom:14px}
.page-contact #contact-hero-heading::after{content:""; position:absolute; left:0; bottom:0; height:6px; width:84px; border-radius:3px; background:var(--color-secondary)}

.contact-grid{display:grid; grid-template-columns:2fr 1fr; gap:var(--space-6); align-items:start}
.contact-card{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); box-shadow:0 10px 24px rgba(0,0,0,0.08); padding:var(--space-6)}
.contact-aside{display:flex; flex-direction:column; gap:var(--space-5)}
.info-card{background:#fff; border:1px solid var(--color-gray); border-radius:var(--radius-md); padding:var(--space-5)}

.contact-form .form-row{display:grid; grid-template-columns:1fr 1fr; gap:var(--space-5)}
.contact-form .form-field{display:flex; flex-direction:column; gap:6px; margin-bottom:var(--space-5)}
.contact-form label{font-weight:600}
.contact-form input, .contact-form textarea{
  width:100%; border:1px solid var(--color-gray); border-radius:var(--radius-md);
  padding:12px 14px; font:inherit; background:#fff; color:var(--color-gray-dark);
}
.contact-form textarea{resize:vertical}
.contact-form input:focus, .contact-form textarea:focus{outline:2px solid var(--color-primary); outline-offset:2px; border-color:var(--color-primary)}
.field-hint{min-height:18px; font-size:14px; color:var(--color-gray-medium); margin:0}
.field-hint:empty{display:block}
.form-actions{display:flex; align-items:center; gap:var(--space-4)}
.form-status{padding:10px 12px; border-radius:var(--radius-md); font-weight:600}
.form-status.is-sending{background:#eff6ff; color:var(--color-primary)}
.form-status.is-success{background:#d1fae5; color:#065f46}
.form-status.is-error{background:#fee2e2; color:#991b1b}

/* Slogan Card */
.slogan-card{
  background:#fff;
  border:1px solid var(--color-gray);
  border-left:4px solid var(--color-secondary);
  border-radius:var(--radius-md);
  padding:var(--space-6);
  box-shadow:0 10px 24px rgba(0,0,0,0.08);
  text-align:center;
  max-width:900px;
  margin:0 auto;
}
.slogan-label{
  color:var(--color-secondary);
  margin-bottom:var(--space-3);
  font-style:normal;
}
.slogan-text{
  font-style:italic;
  font-weight:600;
  color:var(--color-secondary);
  font-size:20px;
  line-height:28px;
  margin:0;
}

/* Slogan Section in About Page */
.slogan-section{
  background:#fff;
  padding:var(--space-6);
  border-radius:var(--radius-md);
  margin-top:var(--space-6);
}
.slogan-section p{
  font-style:italic;
  font-weight:600;
  color:var(--color-secondary);
  font-size:20px;
  line-height:28px;
  margin:0;
}
.slogan-section .h3{
  color:var(--color-secondary);
  font-style:normal;
  margin-bottom:0;
  display:inline;
}

@media (max-width: 900px){
  .contact-grid{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
  /* Mobile: 900px and below - stack footer columns */
  .footer-secondary-inner{grid-template-columns:1fr}
  .footer-secondary-hours{text-align:left; margin-top:var(--space-4)}
}
