/* ============================================================
   FLEET SERVICES — Global Stylesheet
   Font: Segoe UI (system font, Windows rendered)
   Sizes: exact Tailwind values from source CSS
   ============================================================ */

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;background:none;border:none;font:inherit}
ol,ul{list-style:none}

/* DESIGN TOKENS */
:root{
  /* Colors — exact from source oklch */
  --navy:oklch(22% .11 262);
  --steel:oklch(42% .16 252);
  --teal:oklch(64% .21 246);
  --mist:oklch(86% .09 240);
  --surface:oklch(98.5% .006 240);
  --background:#fff;
  --card:#fff;
  --muted-foreground:oklch(45% .03 240);
  --border:oklch(90% .01 220);

  /* Fonts — Segoe UI as rendered by browser on Windows */
  --font-display:'Segoe UI',system-ui,-apple-system,sans-serif;
  --font-sans:'Segoe UI',system-ui,-apple-system,sans-serif;
  --font-light:'Segoe UI Light','Segoe UI',system-ui,-apple-system,sans-serif;

  /* Font sizes — exact Tailwind values */
  --text-xs:.75rem;       /* 12px */
  --text-sm:.875rem;      /* 14px */
  --text-base:1rem;       /* 16px */
  --text-lg:1.125rem;     /* 18px */
  --text-xl:1.25rem;      /* 20px */
  --text-2xl:1.5rem;      /* 24px */
  --text-3xl:1.875rem;    /* 30px */
  --text-4xl:2.25rem;     /* 36px */
  --text-5xl:3rem;        /* 48px */
  --text-6xl:3.75rem;     /* 60px */
  --text-7xl:4.5rem;      /* 72px */

  /* Spacing — 1 unit = 0.25rem */
  --radius:.625rem;
}

/* BASE */
html{scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  font-size:var(--text-base);
  line-height:1.5;
  background:var(--background);
  color:var(--navy);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-0.02em;
}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklch,var(--surface) 95%,transparent);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.hdr-in{
  max-width:80rem;margin:0 auto;
  padding:0 1.5rem;
  display:flex;height:8rem;align-items:center;justify-content:space-between;gap:1.5rem;
}
@media(min-width:64rem){.hdr-in{padding:0 2.5rem}}

.logo img{height:6rem;width:auto;object-fit:contain}

/* Desktop nav */
.dnav{display:none;align-items:center;gap:.25rem}
@media(min-width:64rem){.dnav{display:flex}}

.dnav a{
  padding:.5rem .75rem;
  font-size:var(--text-sm);
  font-family:var(--font-sans);
  font-weight:400;
  color:color-mix(in oklch,var(--navy) 70%,transparent);
  transition:color .2s;
}
.dnav a:hover{color:var(--navy)}
.dnav a.act{color:var(--teal);font-weight:500}

.ddrop{position:relative}
.ddtog{
  display:inline-flex;align-items:center;gap:.25rem;
  padding:.5rem .75rem;
  font-size:var(--text-sm);
  font-family:var(--font-sans);
  font-weight:400;
  color:color-mix(in oklch,var(--navy) 70%,transparent);
  transition:color .2s;
}
.ddtog:hover{color:var(--navy)}
.ddtog svg{width:14px;height:14px;transition:transform .2s}
.ddrop:hover .ddtog svg{transform:rotate(180deg)}

.ddmenu{
  position:absolute;left:0;top:100%;padding-top:.5rem;
  opacity:0;visibility:hidden;transition:all .2s;min-width:200px;
}
.ddrop:hover .ddmenu{opacity:1;visibility:visible}
.ddmenu-in{
  background:var(--surface);
  border:1px solid var(--border);
  box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);
  padding:.5rem 0;
}
.ddmenu a{
  display:block;padding:.5rem 1rem;
  font-size:var(--text-sm);
  font-family:var(--font-sans);
  color:color-mix(in oklch,var(--navy) 80%,transparent);
  transition:all .15s;
}
.ddmenu a:hover{background:var(--background);color:var(--teal)}

/* Hamburger */
.hbg{
  display:flex;padding:.5rem;color:var(--navy);
}
@media(min-width:64rem){.hbg{display:none}}

/* Mobile nav */
.mnav{
  display:none;padding-bottom:1rem;
  max-width:80rem;margin:0 auto;
  padding-left:1.5rem;padding-right:1.5rem;
}
.mnav.open{display:grid;gap:.25rem}
.mnav a{
  display:block;padding:.5rem .75rem;
  font-size:var(--text-sm);
  font-family:var(--font-sans);
  color:color-mix(in oklch,var(--navy) 80%,transparent);
}
.mnav a:hover,.mnav a.act{color:var(--teal);font-weight:500}
.mstog{
  width:100%;text-align:left;
  padding:.5rem .75rem;
  font-size:var(--text-sm);
  font-family:var(--font-sans);
  color:color-mix(in oklch,var(--navy) 80%,transparent);
  display:flex;align-items:center;justify-content:space-between;
}
.mstog.act{color: var(--teal); font-weight: 500;}
.mstog svg{width:16px;height:16px;transition:transform .2s}
.mstog.open svg{transform:rotate(180deg)}
.msub{display:none;padding-left:1rem}
.msub.open{display:grid;gap:.25rem}

/* ============================================================
   HERO SLIDER
   ============================================================ */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(135deg,var(--navy) 0%,var(--steel) 55%,var(--teal) 100%);
}
.s-wrap{overflow:hidden}
.s-track{display:flex;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.slide{flex:0 0 100%;min-width:0;position:relative}
.s-bg{position:absolute;inset:0}
.s-bg img{width:100%;height:100%;object-fit:cover;opacity:.4;mix-blend-mode:luminosity}
.s-ov{
  position:absolute;inset:0;
  background:linear-gradient(to right,var(--navy),
    color-mix(in oklch,var(--navy) 80%,transparent),
    color-mix(in oklch,var(--navy) 20%,transparent));
}
.s-con{
  position:relative;
  max-width:80rem;margin:0 auto;
  padding:5rem 1.5rem 7rem;
}
@media(min-width:64rem){.s-con{padding:5rem 2.5rem 7rem}}
@media(min-width:768px){.s-con{padding-top:7rem;padding-bottom:9rem}}

.s-eye{
  font-size:var(--text-xs);
  text-transform:uppercase;
  letter-spacing:.3em;
  color:var(--mist);
  font-weight:500;
  font-family:var(--font-sans);
}

/* h1: text-5xl mobile, text-7xl md+ */
.s-h1{
  margin-top:1.5rem;
  font-family:var(--font-display);
  font-size:var(--text-5xl);   /* 3rem = 48px */
  font-weight:700;
  line-height:1.02;
  max-width:56rem;
}
@media(min-width:768px){.s-h1{font-size:var(--text-7xl)}} /* 4.5rem = 72px */
.s-h1 span{color:var(--mist)}

/* desc: text-lg mobile, text-xl md+ */
.s-p{
  margin-top:1.5rem;
  max-width:42rem;
  font-size:var(--text-lg);    /* 1.125rem = 18px */
  color:rgba(255,255,255,.75);
  line-height:1.625;           /* leading-relaxed */
  font-family:var(--font-sans);
}
@media(min-width:768px){.s-p{font-size:var(--text-xl)}} /* 1.25rem = 20px */

.s-cta{margin-top:2.5rem}

/* Slider buttons */
.s-pbtn{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:2.75rem;height:2.75rem;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(4px);
  color:#fff;
  transition:all .2s;
}
.s-pbtn:hover{background:var(--teal)}
.s-pbtn svg{width:20px;height:20px}
.s-prev{left:1rem}.s-next{right:1rem}

/* Slider dots */
.s-dots{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.5rem;z-index:10;
}
.s-dot{
  height:6px;border-radius:9999px;
  background:rgba(255,255,255,.3);
  transition:all .3s;
}
.s-dot.on{width:2rem;background:var(--mist)}
.s-dot:not(.on){width:1rem}
.s-dot:hover:not(.on){background:rgba(255,255,255,.5)}

/* ============================================================
   SHARED LAYOUT
   ============================================================ */
.wrap{max-width:80rem;margin:0 auto;padding:0 1.5rem}
@media(min-width:64rem){.wrap{padding:0 2.5rem}}

.sec{padding:6rem 0}
.sec-t{border-top:1px solid var(--border)}
.sec-bg{background:var(--surface)}

/* Eyebrow label */
.eye{
  font-size:var(--text-xs);
  text-transform:uppercase;
  letter-spacing:.25em;
  color:var(--teal);
  font-weight:500;
  font-family:var(--font-sans);
}

/* Section title: text-4xl mobile, text-5xl md+ */
.stitle{
  margin-top:.75rem;
  font-family:var(--font-display);
  font-size:var(--text-4xl);   /* 2.25rem = 36px */
  font-weight:700;
  color:var(--navy);
  line-height:1.1;
}
@media(min-width:768px){.stitle{font-size:var(--text-5xl)}} /* 3rem = 48px */

/* CTA button */
.btn{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--teal);color:#fff;
  padding:1rem 1.5rem;
  font-weight:600;font-size:var(--text-base);
  font-family:var(--font-sans);
  border-radius:.5rem;
  transition:all .2s;
  border:none;
}
.btn:hover{background:var(--navy);color:#fff}
.btn svg{width:20px;height:20px}

.btn-outline{
  display:inline-flex;align-items:center;gap:.75rem;
  border:1px solid var(--border);color:var(--navy);
  padding:1rem 1.5rem;
  font-weight:600;font-size:var(--text-base);
  font-family:var(--font-sans);
  border-radius:.5rem;
  transition:all .2s;
}
.btn-outline:hover{border-color:var(--teal)}

/* ============================================================
   SERVICES GRID (Home)
   ============================================================ */
.svc-sec{padding:6rem 0}
.svc-hdr{
  display:flex;flex-wrap:wrap;align-items:flex-end;
  justify-content:space-between;gap:1.5rem;margin-bottom:3rem;
}

/* Six divisions title: text-4xl mobile, text-5xl md+ */
.svc-title{
  margin-top:.75rem;
  font-family:var(--font-display);
  font-size:var(--text-4xl);
  font-weight:700;
  color:var(--navy);
  max-width:42rem;
  line-height:1.1;
}
@media(min-width:768px){.svc-title{font-size:var(--text-5xl)}}

.svc-grid{display:grid;gap:1.5rem}
@media(min-width:768px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:64rem){.svc-grid{grid-template-columns:repeat(4,1fr)}}

.card{
  display:block;
  border:1px solid var(--border);
  background:var(--card);
  overflow:hidden;
  transition:border-color .2s;
}
.card:hover{border-color:var(--teal)}
.card-img{aspect-ratio:4/3;overflow:hidden;background:var(--navy)}
.card-img img{
  width:100%;height:100%;object-fit:cover;
  opacity:.9;transition:all .5s;
}
.card:hover .card-img img{opacity:1;transform:scale(1.05)}
.card-logo{
  aspect-ratio:4/3;background:var(--navy);
  display:flex;align-items:center;justify-content:center;padding:2rem;
}
.card-logo img{
  max-height:100%;max-width:100%;
  object-fit:contain;filter:brightness(0) invert(1);
}
.card-body{padding:1.5rem}
.card-icons{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:.75rem;min-height:24px;
}
.card-icons svg{width:24px;height:24px}
.ic-t{color:var(--teal)}
.ic-m{color:var(--muted-foreground);transition:all .2s}
.card:hover .ic-arr{color:var(--teal);transform:translateX(4px)}

/* Card h3: text-xl = 1.25rem */
.card h3{
  font-family:var(--font-display);
  font-size:var(--text-xl);   /* 1.25rem = 20px */
  font-weight:700;
  color:var(--navy);
  letter-spacing:-0.02em;
}
/* Card p: text-sm = 0.875rem */
.card p{
  margin-top:.5rem;
  font-size:var(--text-sm);   /* 0.875rem = 14px */
  font-family:var(--font-sans);
  color:var(--muted-foreground);
  line-height:1.625;
}

/* ============================================================
   MAP SECTION
   ============================================================ */
.map-sec{background:var(--surface);padding:5rem 1.5rem}
@media(min-width:64rem){.map-sec{padding:5rem 2.5rem}}

.map-card{
  max-width:80rem;margin:0 auto;
  display:grid;
  background:var(--navy);
  border-radius:1rem;overflow:hidden;
  box-shadow:0 32px 64px -16px rgba(0,27,61,.3);
}
@media(min-width:64rem){.map-card{grid-template-columns:1fr 1fr}}

.map-vis{
  position:relative;min-height:400px;
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
@media(min-width:64rem){.map-vis{min-height:700px}}
.map-glow{
  position:absolute;inset:0;
  background:radial-gradient(circle at center,rgba(0,229,255,.18),transparent 70%);
}
.map-img{position:relative;width:80%;height:80%;display:flex;align-items:center;justify-content:center}
.map-img img{width:100%;height:100%;object-fit:contain;mix-blend-mode:screen}

.map-con{padding:2rem;border-left:1px solid rgba(255,255,255,.05)}
@media(min-width:768px){.map-con{padding:4rem}}
@media(min-width:64rem){.map-con{padding:5rem;display:flex;flex-direction:column;justify-content:center}}

.map-badge{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}
.map-badge svg{width:20px;height:20px;color:var(--teal);flex-shrink:0}
.map-badge span{
  font-size:var(--text-xs);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.3em;
  color:color-mix(in oklch,var(--teal) 80%,transparent);
  font-family:var(--font-sans);
}

/* Map h2: text-4xl → text-5xl md → text-6xl lg */
.map-h2{
  font-family:var(--font-display);
  font-size:var(--text-4xl);   /* 2.25rem = 36px */
  font-weight:700;color:#fff;
  margin-bottom:2rem;line-height:1.25;
}
@media(min-width:768px){.map-h2{font-size:var(--text-5xl)}}   /* 3rem = 48px */
@media(min-width:64rem){.map-h2{font-size:var(--text-6xl)}}   /* 3.75rem = 60px */
.map-h2 span{
  background:linear-gradient(to right,#fff,rgba(255,255,255,.4));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* Map body text: text-lg = 1.125rem, font-light, white/60 */
.map-txt p{
  font-size:var(--text-lg);    /* 1.125rem = 18px */
  font-family:var(--font-light);
  font-weight:300;
  color:rgba(255,255,255,.6);
  line-height:1.625;
  margin-bottom:1.5rem;
}

/* ============================================================
   REPAIRS SECTION
   ============================================================ */
.rep-sec{border-top:1px solid var(--border);background:var(--surface)}
.rep-in{
  max-width:80rem;margin:0 auto;
  padding:6rem 1.5rem;
  display:grid;gap:4rem;align-items:center;
}
@media(min-width:64rem){.rep-in{grid-template-columns:1fr 1fr;padding:6rem 2.5rem}}

.rep-eye{
  font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.25em;
  color:var(--teal);font-weight:500;
  font-family:var(--font-sans);
  display:flex;align-items:center;gap:.5rem;
}
.rep-eye svg{width:16px;height:16px}

/* Rep h2: text-4xl mobile, text-5xl md+ */
.rep-h2{
  margin-top:.75rem;
  font-family:var(--font-display);
  font-size:var(--text-4xl);   /* 2.25rem */
  font-weight:700;color:var(--navy);line-height:1.25;
}
@media(min-width:768px){.rep-h2{font-size:var(--text-5xl)}}
.rep-h2 span{color:var(--teal)}

/* Rep body: text-base = 1rem, muted-foreground, leading-relaxed */
.rep-p{
  margin-top:1.25rem;
  font-size:var(--text-base);  /* 1rem = 16px */
  font-family:var(--font-sans);
  color:var(--muted-foreground);
  line-height:1.625;
}
.rep-img{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--border)}
.rep-img img{width:100%;height:100%;object-fit:cover}

/* ============================================================
   TRUSTED SECTION
   ============================================================ */
.tru-sec{
  background:linear-gradient(135deg,var(--navy) 0%,var(--steel) 55%,var(--teal) 100%);
  color:#fff;position:relative;overflow:hidden;
}
.tru-in{
  max-width:80rem;margin:0 auto;
  padding:6rem 1.5rem;
  display:grid;gap:4rem;align-items:flex-start;
}
@media(min-width:64rem){.tru-in{grid-template-columns:1fr 1fr;padding:6rem 2.5rem}}

.tru-eye{
  font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.3em;
  color:var(--mist);font-weight:500;
  font-family:var(--font-sans);
}

/* Tru h2: text-4xl mobile, text-5xl md+ */
.tru-h2{
  margin-top:.75rem;
  font-family:var(--font-display);
  font-size:var(--text-4xl);
  font-weight:700;line-height:1.25;
}
@media(min-width:768px){.tru-h2{font-size:var(--text-5xl)}}
.tru-h2 span{color:var(--mist)}

.tru-list{margin-top:2rem;display:flex;flex-direction:column;gap:1rem;color:rgba(255,255,255,.8)}
.tru-list li{display:flex;gap:.75rem;align-items:flex-start}
.tru-list li svg{width:20px;height:20px;color:var(--mist);flex-shrink:0;margin-top:2px}
.tru-list li span{font-size:var(--text-base);font-family:var(--font-light)}

.tru-tel{
  margin-top:2rem;display:inline-flex;align-items:center;gap:.75rem;
  color:#fff;font-weight:600;font-family:var(--font-sans);
  font-size:var(--text-base);
  transition:color .2s;
}
.tru-tel:hover{color:var(--mist)}
.tru-tel svg{width:20px;height:20px}

.tru-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(8px);
  padding:2.5rem;border-radius:.5rem;
}
.tru-card-eye{
  font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.3em;
  color:var(--mist);font-weight:500;
  font-family:var(--font-sans);
}
/* Card h3: text-3xl = 1.875rem */
.tru-card-h3{
  margin-top:.75rem;
  font-family:var(--font-display);
  font-size:var(--text-3xl);   /* 1.875rem = 30px */
  font-weight:700;color:#fff;
  line-height:1.25;
}
.tru-card-p{
  margin-top:1rem;
  font-size:var(--text-base);
  font-family:var(--font-sans);
  color:rgba(255,255,255,.7);
  line-height:1.625;
}
.tru-card-a{
  margin-top:1.5rem;display:inline-flex;align-items:center;gap:.5rem;
  color:var(--mist);font-weight:600;font-family:var(--font-sans);
  font-size:var(--text-base);
  transition:all .2s;
}
.tru-card-a:hover{color:#fff;text-decoration:underline}
.tru-card-a svg{width:16px;height:16px}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{
  position:relative;
  background:linear-gradient(135deg,var(--navy) 0%,var(--steel) 55%,var(--teal) 100%);
  color:#fff;overflow:hidden;
}
.ph-bg{position:absolute;inset:0}
.ph-bg img{width:100%;height:100%;object-fit:cover;opacity:.25;mix-blend-mode:luminosity}
.ph-ov{
  position:absolute;inset:0;
  background:linear-gradient(to right,var(--navy),
    color-mix(in oklch,var(--navy) 80%,transparent),
    color-mix(in oklch,var(--navy) 30%,transparent));
}
.ph-con{
  position:relative;
  max-width:80rem;margin:0 auto;
  padding:6rem 1.5rem 6rem;
}
@media(min-width:64rem){.ph-con{padding:6rem 2.5rem 8rem}}
@media(min-width:768px){.ph-con{padding-top:8rem;padding-bottom:8rem}}

.ph-bc{
  font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.1em;
  /*color:rgba(255,255,255,.6);*/
  color: var(--mist);
  margin-bottom:1.5rem;
  display:flex;gap:.5rem;align-items:center;
  font-family:var(--font-sans);
}
.ph-bc a{transition:color .2s}
.ph-bc a:hover{color:#fff}
.ph-bc span{color:rgba(255,255,255,.3)}
.ph-eye{
  font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.3em;
  color:var(--mist);font-weight:500;
  font-family:var(--font-sans);
}
/* Page h1: text-4xl mobile, text-6xl md+ */
.ph-h1{
  margin-top:1rem;
  font-family:var(--font-display);
  font-size:var(--text-4xl);   /* 2.25rem = 36px */
  font-weight:700;
  max-width:48rem;line-height:1.05;
}
@media(min-width:768px){.ph-h1{font-size:var(--text-6xl)}} /* 3.75rem = 60px */

.ph-desc{
  margin-top:1.5rem;max-width:42rem;
  font-size:var(--text-lg);    /* 1.125rem = 18px */
  font-family:var(--font-sans);
  color:rgba(255,255,255,.7);line-height:1.7;
}

/* ============================================================
   SERVICE BLOCKS (inner pages)
   ============================================================ */
.svc-block{
  position:relative;background:#fff;
  border:1px solid var(--border);
  padding:2rem;transition:all .3s;overflow:hidden;
}
.svc-block::before{
  content:'';position:absolute;top:0;left:0;
  height:4px;width:3rem;background:var(--teal);transition:width .5s;
}
.svc-block:hover{border-color:var(--teal);box-shadow:0 10px 30px rgba(0,0,0,.08)}
.svc-block:hover::before{width:100%}
.svc-block h3{
  font-family:var(--font-display);
  font-size:var(--text-xl);
  font-weight:700;color:var(--navy);
  margin-bottom:1rem;margin-top:.5rem;
}
.svc-block ul{display:flex;flex-direction:column;gap:.5rem}
.svc-block li{
  display:flex;gap:.5rem;
  font-size:var(--text-sm);
  font-family:var(--font-sans);
  color:var(--muted-foreground);line-height:1.6;
}
.svc-block li span:first-child{color:var(--teal);margin-top:1px}

.svc-grid-3{display:grid;gap:1.5rem}
@media(min-width:768px){.svc-grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:64rem){.svc-grid-3{grid-template-columns:repeat(3,1fr)}}

/* ============================================================
   DARK CTA SECTION
   ============================================================ */
.dark-cta{
  background:linear-gradient(135deg,var(--navy) 0%,var(--steel) 55%,var(--teal) 100%);
  color:#fff;padding:5rem 0;
}
.dark-cta-in{
  max-width:80rem;margin:0 auto;padding:0 1.5rem;
  display:grid;gap:2.5rem;align-items:center;
}
@media(min-width:64rem){.dark-cta-in{grid-template-columns:1.4fr 1fr;padding:0 2.5rem}}

.dark-cta-eye{
  font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.3em;
  color:var(--mist);font-weight:500;
  font-family:var(--font-sans);
  display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;
}
.dark-cta h2{
  font-family:var(--font-display);
  font-size:var(--text-3xl);
  font-weight:700;line-height:1.1;
}
@media(min-width:768px){.dark-cta h2{font-size:var(--text-4xl)}}
.dark-cta h2 span{color:var(--mist)}

.dark-cta-btns{display:flex;flex-wrap:wrap;gap:1rem}
@media(min-width:64rem){.dark-cta-btns{justify-content:flex-end}}

.btn-inv{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--teal);color:#fff;
  padding:1rem 1.5rem;font-weight:600;
  font-family:var(--font-sans);
  border-radius:.5rem;transition:all .2s;
}
.btn-inv:hover{background:var(--mist);color:var(--navy)}
.btn-inv svg{width:20px;height:20px}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.75rem;
  border:1px solid rgba(255,255,255,.25);color:#fff;
  padding:1rem 1.5rem;font-weight:600;
  font-family:var(--font-sans);
  border-radius:.5rem;transition:all .2s;
}
.btn-ghost:hover{border-color:var(--mist)}

/* ============================================================
   IMAGE GRID
   ============================================================ */
.art-grid{display:grid;gap:1rem}
@media(min-width:768px){.art-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:64rem){.art-grid{grid-template-columns:repeat(3,1fr)}}

.art-grid-4{display:grid;gap:1rem}
@media(min-width:768px){.art-grid-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:64rem){.art-grid-4{grid-template-columns:repeat(4,1fr)}}

.img-box{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--border);background:var(--surface)}
.img-box img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.img-box:hover img{transform:scale(1.05)}

/* ============================================================
   FOOTER
   ============================================================ */
.ftr{background:var(--surface);border-top:1px solid var(--border);color:color-mix(in oklch,var(--navy) 75%,transparent)}
.ftr-in{max-width:80rem;margin:0 auto;padding:4rem 1.5rem}
@media(min-width:64rem){.ftr-in{padding:4rem 2.5rem}}

.ftr-grid{display:grid;gap:3rem}
@media(min-width:768px){.ftr-grid{grid-template-columns:repeat(3,1fr)}}

.ftr-logo img{height:7rem;width:auto;object-fit:contain}

.ftr-h{
  font-family:var(--font-display);
  font-weight:700;color:var(--navy);
  font-size:var(--text-sm);
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:1rem;
}
.ftr-links{display:flex;flex-direction:column;gap:.375rem;font-size:var(--text-sm);font-family:var(--font-sans);line-height:1.6}
.ftr-links a:hover{color:var(--teal)}

.ftr-ct{display:flex;flex-direction:column;gap:.5rem;font-size:var(--text-sm);font-family:var(--font-sans);line-height:1.6}
.ftr-ci{display:flex;gap:.5rem;align-items:flex-start}
.ftr-ci svg{width:16px;height:16px;color:var(--teal);flex-shrink:0;margin-top:2px}
.ftr-ci a:hover{color:var(--teal)}
.ftr-sep{padding-top:.5rem;margin-top:.25rem;border-top:1px solid color-mix(in oklch,var(--border) 60%,transparent)}

.ftr-bot{
  margin-top:3.5rem;padding-top:1.5rem;border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:1rem;
  font-size:var(--text-xs);
  color:color-mix(in oklch,var(--navy) 50%,transparent);
  font-family:var(--font-sans);
}
@media(min-width:768px){.ftr-bot{flex-direction:row;justify-content:space-between}}
.ftr-bl{display:flex;gap:1.5rem}
.ftr-bl a:hover{color:var(--teal)}
