/* =================================================================
   MATRANXHI CONSTRUCTION LIMITED — v2 Wireframe-Faithful Build
   Brand colours extracted from MCL logo assets
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800&family=Bebas+Neue&display=swap');

/* =================================================================
   DESIGN TOKENS
   ================================================================= */
:root {
  /* Brand palette — extracted from MCL logo */
  --brand-darkest:   #00020E;
  --brand-dark:      #00051B;
  --brand-navy:      #000B27;
  --brand-blue:      #004177;
  --brand-blue-lt:   #004B84;
  --brand-silver:    #A5A6A8;
  --brand-white:     #EFEFEF;

  /* Functional colours */
  --clr-bg:          #FFFFFF;
  --clr-bg-off:      #F5F5F5;
  --clr-bg-grey:     #F0F0F0;
  --clr-text:        #1A1A1A;
  --clr-text-muted:  #5A5A5A;
  --clr-text-light:  #8A8A8A;
  --clr-border:      #E0E0E0;
  --clr-white:       #FFFFFF;

  /* CTA / Accent — derived from blue highlight in logo */
  --clr-accent:      #004B84;
  --clr-accent-hover:#003A66;

  /* Typography */
  --ff-display: 'Bebas Neue', 'Impact', sans-serif;
  --ff-body:    'Plus Jakarta Sans', 'Segoe UI', sans-serif;

  --fs-hero:    clamp(2.8rem, 6vw, 5rem);
  --fs-h1:      clamp(2rem, 3.5vw, 3rem);
  --fs-h2:      clamp(1.4rem, 2.2vw, 1.8rem);
  --fs-h3:      clamp(1.1rem, 1.5vw, 1.25rem);
  --fs-body:    clamp(0.9rem, 1vw, 1rem);
  --fs-small:   0.85rem;
  --fs-xs:      0.75rem;

  --lh-tight: 1.1;
  --lh-snug:  1.3;
  --lh-body:  1.65;
  --lh-loose: 1.8;

  --ls-display: 0.03em;
  --ls-wide:    0.06em;

  /* Spacing */
  --sp-xs:  0.25rem;  --sp-sm:  0.5rem;
  --sp-md:  1rem;     --sp-lg:  1.5rem;
  --sp-xl:  2rem;     --sp-2xl: 3rem;
  --sp-3xl: 4rem;     --sp-4xl: 6rem;
  --sp-section: clamp(4rem, 8vw, 7rem);

  --max-w: 1140px;
  --max-narrow: 680px;

  /* Effects */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.1);
  --radius:    10px;
  --radius-sm: 6px;
  --radius-lg: 16px;
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --dur: 300ms;
}

/* =================================================================
   RESET
   ================================================================= */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);font-size:var(--fs-body);line-height:var(--lh-body);color:var(--clr-text);background:var(--clr-bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}
h1,h2,h3,h4{font-weight:700;line-height:var(--lh-tight)}
::selection{background:var(--brand-blue);color:#fff}
:focus-visible{outline:3px solid var(--brand-blue);outline-offset:3px}

/* =================================================================
   UTILITIES
   ================================================================= */
.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--sp-lg)}
.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}
.section-pad{padding-block:var(--sp-section)}

/* =================================================================
   BUTTONS — matching wireframe's rounded pill + outlined styles
   ================================================================= */
.btn{
  display:inline-flex;align-items:center;gap:var(--sp-sm);
  padding:0.7rem 1.8rem;font-size:var(--fs-small);font-weight:600;
  border-radius:50px;transition:all var(--dur) var(--ease);
  letter-spacing:var(--ls-wide);text-transform:uppercase;
}
.btn--filled{background:var(--brand-navy);color:#fff}
.btn--filled:hover{background:var(--brand-blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--outline{border:2px solid var(--clr-text);color:var(--clr-text);background:transparent}
.btn--outline:hover{background:var(--brand-navy);color:#fff;border-color:var(--brand-navy)}
.btn--outline-white{border:2px solid #fff;color:#fff;background:transparent}
.btn--outline-white:hover{background:#fff;color:var(--brand-navy)}
.btn--outline-dark{border:2px solid var(--brand-navy);color:var(--brand-navy);background:transparent}
.btn--outline-dark:hover{background:var(--brand-navy);color:#fff}
.btn svg{width:14px;height:14px;transition:transform var(--dur) var(--ease)}
.btn:hover svg{transform:translateX(3px)}

/* =================================================================
   HEADER — wireframe: logo left, nav right, clean line
   ================================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:300;
  background:var(--clr-white);
  border-bottom:1px solid var(--clr-border);
  padding:0.8rem 0;transition:box-shadow var(--dur) var(--ease);
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.site-logo{display:flex;align-items:center;gap:var(--sp-sm)}
.site-logo img{height:36px;width:auto}
.site-logo__text{
  font-family:var(--ff-display);font-size:1.1rem;color:var(--brand-navy);
  letter-spacing:var(--ls-display);text-transform:uppercase;line-height:1.1;
}
.site-logo__text small{
  display:block;font-family:var(--ff-body);font-size:0.55rem;
  font-weight:500;letter-spacing:var(--ls-wide);color:var(--brand-silver);
  text-transform:uppercase;margin-top:1px;
}

.nav-links{display:flex;gap:var(--sp-xl)}
.nav-links a{
  font-size:var(--fs-small);font-weight:500;color:var(--clr-text);
  transition:color 150ms var(--ease);position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;
  background:var(--brand-navy);transition:width var(--dur) var(--ease);
}
.nav-links a:hover,
.nav-links a.active{color:var(--brand-navy)}
.nav-links a:hover::after,
.nav-links a.active::after{width:100%}

/* Services dropdown indicator */
.nav-links .has-dropdown::after{content:none}
.nav-links .has-dropdown{display:flex;align-items:center;gap:4px}
.nav-links .has-dropdown svg{width:12px;height:12px}

/* Mobile toggle */
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:var(--sp-sm);z-index:301}
.menu-toggle span{width:24px;height:2px;background:var(--brand-navy);transition:all var(--dur) var(--ease);transform-origin:center}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-nav{
  display:none;position:fixed;inset:0;background:var(--clr-white);z-index:299;
  flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-xl);
}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--ff-display);font-size:2rem;color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase}
.mobile-nav a:hover{color:var(--brand-blue)}

/* =================================================================
   HERO — Option A: Split layout (wireframe) heading left, video right
   ================================================================= */
.hero--split{
  background:var(--brand-darkest);
  background-image:url('img/brand-bg.png');
  background-size:cover;background-position:center;
  padding:calc(var(--sp-4xl) + 60px) 0 var(--sp-4xl);
  min-height:90vh;display:flex;align-items:center;
}
.hero--split .hero-grid{
  max-width:1600px;margin-inline:auto;display:grid;grid-template-columns:1fr 2.2fr;gap:var(--sp-3xl);align-items:center;
}
.hero--split .hero__title{
  font-family:var(--ff-display);font-size:var(--fs-hero);
  color:var(--brand-white);letter-spacing:var(--ls-display);
  text-transform:uppercase;line-height:0.95;margin-bottom:var(--sp-lg);
}
.hero--split .hero__subtitle{
  color:var(--brand-silver);font-size:var(--fs-body);
  line-height:var(--lh-loose);margin-bottom:var(--sp-xl);max-width:460px;
}
.hero--split .hero__actions{display:flex;gap:var(--sp-md);flex-wrap:wrap}

/* Video frame — wireframe shows a rounded rect with play button */
.hero__video-frame{
  background:rgba(255,255,255,0.08);border-radius:var(--radius-lg);
  aspect-ratio:16/9;min-height:500px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;border:1px solid rgba(255,255,255,0.1);
}
.hero__video-frame video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  border-radius:var(--radius-lg);
}
.hero__play-btn{
  width:80px;height:80px;background:rgba(255,255,255,0.15);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  z-index:2;backdrop-filter:blur(4px);border:2px solid rgba(255,255,255,0.3);
  transition:all var(--dur) var(--ease);cursor:pointer;
}
.hero__play-btn:hover{background:rgba(255,255,255,0.25);transform:scale(1.08)}
.hero__play-btn svg{width:36px;height:36px;color:#fff;margin-left:3px}

/* =================================================================
   HERO — Option B: Full-width video background
   ================================================================= */
.hero--fullwidth{
  position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
}
.hero--fullwidth .hero__bg{position:absolute;inset:0;z-index:0}
.hero--fullwidth .hero__bg video{width:100%;height:100%;object-fit:cover}
.hero--fullwidth .hero__bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,2,14,0.85) 0%,rgba(0,11,39,0.6) 50%,rgba(0,65,119,0.4) 100%);
}
.hero--fullwidth .hero__content{position:relative;z-index:1;max-width:700px;padding-top:var(--sp-4xl)}
.hero--fullwidth .hero__title{
  font-family:var(--ff-display);font-size:var(--fs-hero);
  color:var(--brand-white);letter-spacing:var(--ls-display);
  text-transform:uppercase;line-height:0.95;margin-bottom:var(--sp-lg);
}
.hero--fullwidth .hero__subtitle{
  color:var(--brand-silver);font-size:clamp(1rem,1.3vw,1.15rem);
  line-height:var(--lh-loose);margin-bottom:var(--sp-xl);max-width:520px;
}
.hero--fullwidth .hero__actions{display:flex;gap:var(--sp-md);flex-wrap:wrap}

/* =================================================================
   SERVICES — wireframe: centred heading, 3 cards with icons
   ================================================================= */
.services{background:var(--clr-bg);text-align:center}
.services__title{font-family:var(--ff-display);font-size:var(--fs-h1);color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-3xl)}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-xl)}
.service-card{
  border:1px solid var(--clr-border);border-radius:var(--radius);
  padding:var(--sp-2xl) var(--sp-lg);text-align:center;
  transition:all var(--dur) var(--ease);
}
.service-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.service-card__icon{
  width:48px;height:48px;margin:0 auto var(--sp-lg);
  display:flex;align-items:center;justify-content:center;
}
.service-card__icon svg{width:36px;height:36px;color:var(--brand-navy)}
.service-card__title{font-weight:700;font-size:var(--fs-h3);margin-bottom:var(--sp-sm);color:var(--brand-navy)}
.service-card__desc{font-size:var(--fs-small);color:var(--clr-text-muted);line-height:var(--lh-body)}

/* =================================================================
   PROJECTS — wireframe: centred heading, horizontal carousel with dots
   ================================================================= */
.projects{background:var(--clr-bg-off)}
.projects__header{text-align:center;margin-bottom:var(--sp-2xl)}
.projects__title{font-family:var(--ff-display);font-size:var(--fs-h1);color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-sm)}
.projects__subtitle{color:var(--clr-text-muted);font-size:var(--fs-body)}

.projects__carousel{
  display:flex;gap:var(--sp-lg);overflow-x:auto;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  padding-bottom:var(--sp-md);scrollbar-width:none;
}
.projects__carousel::-webkit-scrollbar{display:none}

.project-slide{
  flex:0 0 calc(50% - var(--sp-lg)/2);scroll-snap-align:start;
  aspect-ratio:4/3;background:var(--clr-bg-grey);border-radius:var(--radius);
  overflow:hidden;position:relative;
}
.project-slide img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s var(--ease)}
.project-slide:hover img{transform:scale(1.05)}

.projects__dots{
  display:flex;justify-content:center;gap:var(--sp-sm);margin-top:var(--sp-xl);
}
.projects__dot{
  width:10px;height:10px;border-radius:50%;background:var(--clr-border);
  border:none;cursor:pointer;transition:all var(--dur) var(--ease);padding:0;
}
.projects__dot.active{background:var(--brand-navy);width:24px;border-radius:50px}

/* =================================================================
   ZIGZAG CONTENT BLOCKS — wireframe: alternating image + text
   ================================================================= */
.zigzag{background:var(--clr-bg)}
.zigzag__block{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3xl);
  align-items:center;padding-block:var(--sp-section);
}
.zigzag__block:not(:last-child){border-bottom:1px solid var(--clr-border)}
.zigzag__block--reverse .zigzag__image{order:2}
.zigzag__block--reverse .zigzag__text{order:1}

.zigzag__image{
  aspect-ratio:4/3;background:var(--clr-bg-grey);border-radius:var(--radius);overflow:hidden;
}
.zigzag__image img{width:100%;height:100%;object-fit:cover}
.zigzag__heading{font-family:var(--ff-display);font-size:var(--fs-h1);color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-lg)}
.zigzag__text p{color:var(--clr-text-muted);line-height:var(--lh-loose);margin-bottom:var(--sp-lg)}

/* =================================================================
   CTA STRIP — wireframe: grey bg, centred heading + text + button
   ================================================================= */
.cta-strip{
  background:var(--clr-bg-off);padding-block:var(--sp-4xl);text-align:center;
}
.cta-strip__title{
  font-family:var(--ff-display);font-size:var(--fs-h1);color:var(--brand-navy);
  letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-md);
}
.cta-strip__desc{color:var(--clr-text-muted);max-width:500px;margin-inline:auto;margin-bottom:var(--sp-xl);line-height:var(--lh-body)}

/* =================================================================
   FOOTER — wireframe: 4 columns (logo, links, services, social)
   ================================================================= */
.site-footer{background:var(--clr-bg);padding-top:var(--sp-4xl);border-top:1px solid var(--clr-border)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--sp-3xl);padding-bottom:var(--sp-2xl)}
.footer-logo{display:flex;align-items:center;gap:var(--sp-sm);margin-bottom:var(--sp-md)}
.footer-logo img{height:40px}
.footer-col__title{font-weight:700;font-size:var(--fs-body);margin-bottom:var(--sp-lg);color:var(--brand-navy)}
.footer-col__links{display:flex;flex-direction:column;gap:var(--sp-md)}
.footer-col__links a{font-size:var(--fs-small);color:var(--clr-text-muted);transition:color 150ms var(--ease)}
.footer-col__links a:hover{color:var(--brand-navy)}

.footer-social{display:flex;gap:var(--sp-lg);margin-top:var(--sp-sm)}
.footer-social a{color:var(--brand-navy);transition:color 150ms var(--ease)}
.footer-social a:hover{color:var(--brand-blue)}
.footer-social svg{width:24px;height:24px}

.footer-bottom{
  border-top:1px solid var(--clr-border);padding-block:var(--sp-lg);
  text-align:center;font-size:var(--fs-xs);color:var(--clr-text-light);
}

/* =================================================================
   PAGE HERO — wireframe: dark bg band with title
   ================================================================= */
.page-hero{
  background:var(--brand-darkest);
  background-image:url('img/brand-bg.png');
  background-size:cover;background-position:center;
  padding:calc(var(--sp-4xl) + 60px) 0 var(--sp-3xl);
}
.page-hero__title{
  font-family:var(--ff-display);font-size:var(--fs-hero);
  color:var(--brand-white);letter-spacing:var(--ls-display);text-transform:uppercase;
}

/* =================================================================
   ABOUT — Overlapping card layout (wireframe pages 2-3)
   ================================================================= */
.overlap-block{padding-block:var(--sp-section)}
.overlap-card{
  display:grid;grid-template-columns:1fr 1fr;
  border-radius:var(--radius);overflow:visible;
  max-width:750px;margin-inline:auto;position:relative;
}
.overlap-card--right{margin-left:auto;margin-right:0}
.overlap-card--left{margin-left:0;margin-right:auto}

.overlap-card__text{
  background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius);
  padding:var(--sp-2xl);z-index:2;position:relative;
}
.overlap-card__text h3{font-family:var(--ff-display);font-size:var(--fs-h2);color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-lg)}
.overlap-card__text p{color:var(--clr-text-muted);line-height:var(--lh-loose);font-size:var(--fs-small)}
.overlap-card__image{
  background:var(--clr-bg-grey);border-radius:var(--radius);min-height:280px;overflow:hidden;
}
.overlap-card__image img{width:100%;height:100%;object-fit:cover}

/* Reverse: image left, text right */
.overlap-card--reverse .overlap-card__image{order:1}
.overlap-card--reverse .overlap-card__text{order:2}

/* =================================================================
   TEAM — wireframe: 4 person cards with icons
   ================================================================= */
.team{text-align:center}
.team__title{font-family:var(--ff-display);font-size:var(--fs-h1);color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-3xl)}
.team__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-xl)}
.team-card{text-align:center}
.team-card__avatar{
  width:80px;height:80px;border-radius:50%;background:var(--clr-bg-off);
  display:flex;align-items:center;justify-content:center;margin:0 auto var(--sp-md);
  border:2px solid var(--clr-border);
}
.team-card__avatar svg{width:32px;height:32px;color:var(--brand-navy)}
.team-card__name{font-weight:700;margin-bottom:var(--sp-xs);color:var(--brand-navy)}
.team-card__role{font-size:var(--fs-small);color:var(--clr-text-muted)}

/* =================================================================
   CONTACT — wireframe: centred form, then office card below
   ================================================================= */
.contact-form-section{max-width:520px;margin-inline:auto;padding-block:var(--sp-section)}
.contact-form-section .form-group{margin-bottom:var(--sp-lg)}
.contact-form-section label{display:block;font-weight:600;font-size:var(--fs-small);margin-bottom:var(--sp-sm);color:var(--brand-navy)}
.contact-form-section input,
.contact-form-section select,
.contact-form-section textarea{
  width:100%;padding:0.75rem 1rem;border:1px solid var(--clr-border);
  border-radius:var(--radius-sm);font-family:var(--ff-body);font-size:var(--fs-body);
  color:var(--clr-text);background:var(--clr-bg-off);transition:border-color 150ms var(--ease);
}
.contact-form-section input:focus,
.contact-form-section select:focus,
.contact-form-section textarea:focus{border-color:var(--brand-blue);outline:none;box-shadow:0 0 0 3px rgba(0,75,132,0.1)}
.contact-form-section textarea{min-height:160px;resize:vertical}
.contact-form-section .btn{margin-top:var(--sp-md)}

/* Registered Office Card — wireframe: map left, details right */
.office-card{
  display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--clr-border);
  border-radius:var(--radius);overflow:hidden;max-width:700px;margin:0 auto var(--sp-section);
}
.office-card__map{background:var(--clr-bg-grey);min-height:220px;display:flex;align-items:center;justify-content:center}
.office-card__map svg{width:48px;height:48px;color:var(--clr-text-light);opacity:0.4}
.office-card__details{padding:var(--sp-2xl)}
.office-card__details h3{font-weight:700;margin-bottom:var(--sp-lg);color:var(--brand-navy)}
.office-card__details p{font-size:var(--fs-small);color:var(--clr-text-muted);line-height:var(--lh-loose);margin-bottom:var(--sp-md)}
.office-card__phone{display:flex;align-items:center;gap:var(--sp-sm);font-weight:600;color:var(--brand-navy);margin-top:var(--sp-lg)}
.office-card__phone svg{width:18px;height:18px}

/* =================================================================
   TERMS — simple prose page
   ================================================================= */
.terms-content{max-width:var(--max-narrow);margin-inline:auto;padding-block:var(--sp-section)}
.terms-content h2{font-family:var(--ff-display);font-size:var(--fs-h1);color:var(--brand-navy);letter-spacing:var(--ls-display);text-transform:uppercase;margin-bottom:var(--sp-xl)}
.terms-content p{color:var(--clr-text-muted);line-height:var(--lh-loose);margin-bottom:var(--sp-lg)}

/* =================================================================
   SCROLL REVEAL
   ================================================================= */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(24px);transition:opacity 0.7s var(--ease),transform 0.7s var(--ease)}
  .reveal.visible{opacity:1;transform:translateY(0)}
  .stagger>*{opacity:0;transform:translateY(16px);transition:opacity 0.5s var(--ease),transform 0.5s var(--ease)}
  .stagger.visible>*:nth-child(1){transition-delay:0s}
  .stagger.visible>*:nth-child(2){transition-delay:0.1s}
  .stagger.visible>*:nth-child(3){transition-delay:0.15s}
  .stagger.visible>*:nth-child(4){transition-delay:0.2s}
  .stagger.visible>*{opacity:1;transform:translateY(0)}
}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media(max-width:1024px){
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .team__grid{grid-template-columns:repeat(2,1fr);gap:var(--sp-2xl)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--sp-2xl)}
  .hero--split .hero-grid{gap:var(--sp-2xl)}
  .overlap-card{max-width:100%}
}

@media(max-width:768px){
  .nav-links{display:none}
  .menu-toggle{display:flex}
  .hero--split .hero-grid{grid-template-columns:1fr;display:flex;flex-direction:column-reverse}
  .hero--split .hero__video-frame{max-width:100%}
  .services__grid{grid-template-columns:1fr}
  .zigzag__block{grid-template-columns:1fr}
  .zigzag__block--reverse .zigzag__image{order:0}
  .zigzag__block--reverse .zigzag__text{order:0}
  .overlap-card{grid-template-columns:1fr}
  .overlap-card__image{min-height:200px}
  .team__grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr;gap:var(--sp-2xl)}
  .office-card{grid-template-columns:1fr}
  .project-slide{flex:0 0 85%}
}

@media(max-width:480px){
  .hero--split .hero__actions,.hero--fullwidth .hero__actions{flex-direction:column}
  .hero--split .hero__actions .btn,.hero--fullwidth .hero__actions .btn{width:100%;justify-content:center}
  .team__grid{grid-template-columns:1fr}
}
