:root {
  --ink: #111827; --muted: #5b6472; --paper: #f6f4ef; --white: #ffffff;
  --navy: #102a43; --accent: #7fd4f2; --green: #1f7a5c; --gold: #f5c84b;
  --line: rgba(17,24,39,.12); --shadow: 0 24px 70px rgba(17,24,39,.16);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "Inter", Arial, sans-serif; line-height: 1.65; }
img { max-width: 100%; height: auto; }
a { color: inherit; } a:hover { color: var(--accent); text-decoration: none; }
.site-header { padding: 14px 0; background: rgba(246,244,239,.86) !important; backdrop-filter: blur(18px); box-shadow: 0 16px 40px rgba(17,24,39,.08); }
.nav-shell { max-width: 1180px; } .site-header .navbar { padding: 0; } .navbar-brand img { height: 62px; width: auto; }
.site-header .nav-link { color: var(--ink) !important; font-weight: 800; font-size: 14px; letter-spacing: 0; padding: 12px 14px !important; position: relative; }
.site-header .nav-item.active .nav-link::after, .site-header .nav-link:hover::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: 5px; height: 3px; background: var(--accent); }
.nav-actions { display: flex; align-items: center; gap: 14px; margin-left: 18px; } .nav-phone { font-weight: 800; color: var(--navy); white-space: nowrap; }
.btn-style, .btn.btn-style { border-radius: 6px; padding: 13px 22px; font-weight: 800; border: 0; box-shadow: none; }
.btn-primary, .btn-primary:not(:disabled):not(.disabled):active { background: var(--accent); border-color: var(--accent); } .btn-primary:hover, .btn-primary:focus { background: var(--accent-strong); border-color: var(--accent-strong); }
.btn-outline-light { border: 1px solid rgba(255,255,255,.72) !important; color: var(--white) !important; background: rgba(255,255,255,.1); }
.hero-modern { min-height: 760px; position: relative; overflow: hidden; display: flex; align-items: center; color: var(--white); background: var(--navy); padding: 150px 0 76px; }
.hero-media { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(16,42,67,.96) 0%, rgba(16,42,67,.84) 42%, rgba(16,42,67,.28) 100%), url('assets/images/hero-home1.jpg') center/cover no-repeat; transform: scale(1.02); }
.hero-grid, .page-hero-grid { position: relative; display: grid; grid-template-columns: minmax(0,1.15fr) minmax(320px,.85fr); gap: 48px; align-items: end; }
.eyebrow { margin: 0 0 16px; color: var(--gold); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .12em; } .eyebrow.dark { color: var(--accent); }
.hero-copy h1, .page-hero h1 { font-family: "Inter", Arial, sans-serif; font-size: clamp(44px,7vw,92px); line-height: .95; letter-spacing: 0; margin: 0; max-width: 860px; }
.hero-lead, .page-hero p, .split-intro p { font-size: 20px; line-height: 1.55; color: rgba(255,255,255,.82); max-width: 660px; margin: 24px 0 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-panel { display: grid; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); backdrop-filter: blur(18px); }
.hero-panel div { padding: 26px; border-bottom: 1px solid rgba(255,255,255,.18); } .hero-panel div:last-child { border-bottom: 0; }
.hero-panel .metric { display: block; color: var(--gold); font-weight: 900; margin-bottom: 10px; } .hero-panel strong { display: block; font-size: 21px; line-height: 1.2; } .hero-panel p { color: rgba(255,255,255,.74); margin: 8px 0 0; }
.section-band { padding: 86px 0; } .intro-band, .values-band, .gallery-band { background: var(--white); } .process-band { background: #e9eef0; }
.split-intro { display: grid; grid-template-columns: .9fr 1.1fr; gap: 56px; align-items: start; } h2 { font-family: "Inter", Arial, sans-serif; font-size: clamp(34px,4vw,58px); line-height: 1.04; margin: 0; letter-spacing: 0; } .split-intro p { color: var(--muted); margin: 42px 0 0; }
.service-feature-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 18px; padding-top: 86px; padding-bottom: 86px; }
.feature-card, .services-suite article, .values-grid article, .contact-panel, .contact-details { background: var(--white); border: 1px solid var(--line); box-shadow: 0 14px 40px rgba(17,24,39,.08); }
.feature-card { min-height: 290px; padding: 30px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; transition: transform .18s ease, box-shadow .18s ease; }
.feature-card-tall { grid-row: span 2; background: var(--navy); color: var(--white); } .feature-card-dark { background: #202124; color: var(--white); } .accent-card { background: var(--green); color: var(--white); }
.image-card { color: var(--white); background-size: cover; background-position: center; position: relative; min-height: 360px; } .image-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(17,24,39,.05), rgba(17,24,39,.72)); } .image-card span { position: relative; font-size: 28px; line-height: 1.1; font-family: "Inter", Arial, sans-serif; font-weight: 800; }
.feature-card i, .services-suite i { font-size: 34px; color: var(--accent); margin-bottom: 20px; } .feature-card-dark i, .feature-card-tall i, .accent-card i { color: var(--gold); }
.feature-card h3, .services-suite h3, .values-grid h3, .contact-details h3 { font-family: "Inter", Arial, sans-serif; font-size: 25px; line-height: 1.12; margin: 0 0 12px; }
.feature-card p, .services-suite p, .values-grid p, .contact-details p, .about-copy p, .site-footer p { color: var(--muted); margin: 0; } .feature-card-tall p, .feature-card-dark p, .accent-card p { color: rgba(255,255,255,.78); }
.section-heading { max-width: 780px; margin-bottom: 42px; } .section-heading.compact { max-width: 680px; }
.process-row { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); border-top: 1px solid rgba(17,24,39,.18); border-left: 1px solid rgba(17,24,39,.18); }
.process-row div { min-height: 270px; padding: 26px; border-right: 1px solid rgba(17,24,39,.18); border-bottom: 1px solid rgba(17,24,39,.18); display: flex; flex-direction: column; justify-content: space-between; } .process-row span, .values-grid span { color: var(--accent); font-weight: 900; } .process-row h3 { font-family: "Inter", Arial, sans-serif; font-size: 25px; line-height: 1.18; margin: 0; }
.catalogue-section { padding-top: 78px; padding-bottom: 90px; } .catalogue-wrapper, .gallery-wrapper { display: grid; gap: 18px; } .catalogue-wrapper { grid-template-columns: repeat(4,minmax(0,1fr)); }
.catalogue-items { min-height: 150px; display: grid; place-items: center; background: var(--white); border: 1px solid var(--line); transition: transform .18s ease, box-shadow .18s ease; } .catalogue-items:hover, .services-suite article:hover, .feature-card:hover, .values-grid article:hover { transform: translateY(-4px); box-shadow: var(--shadow); } .catalogue-items img { max-width: 130px; max-height: 64px; object-fit: contain; }
.cta-modern { padding: 86px 0; color: var(--white); background: linear-gradient(90deg, rgba(16,42,67,.94), rgba(16,42,67,.58)), url('assets/images/home-slider2.jpg') center/cover no-repeat; } .cta-inner { display: flex; justify-content: space-between; align-items: center; gap: 28px; } .cta-inner h2 { max-width: 760px; }
.page-hero { min-height: 520px; display: flex; align-items: end; padding: 170px 0 84px; color: var(--white); background: var(--navy); position: relative; overflow: hidden; } .page-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(16,42,67,.94), rgba(16,42,67,.62)); } .about-hero { background: url('assets/images/IMG-20260516-WA0011.jpg') center/cover no-repeat; } .services-hero { background: url('assets/images/IMG-20260516-WA0035.jpg') center/cover no-repeat; } .contact-hero { background: url('assets/images/IMG-20260516-WA0015.jpg') center/cover no-repeat; }
.about-story { display: grid; grid-template-columns: .9fr 1.1fr; gap: 50px; align-items: center; padding-top: 90px; padding-bottom: 90px; } .about-image img { width: 100%; min-height: 520px; object-fit: cover; box-shadow: var(--shadow); } .about-copy p { margin-top: 20px; font-size: 18px; } .about-badges { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; } .about-badges span { border: 1px solid var(--line); padding: 10px 14px; background: var(--white); font-weight: 800; }
.values-grid, .services-suite { display: grid; gap: 18px; } .values-grid { grid-template-columns: repeat(3,minmax(0,1fr)); } .values-grid article, .services-suite article { padding: 30px; transition: transform .18s ease, box-shadow .18s ease; } .services-suite { grid-template-columns: repeat(3,minmax(0,1fr)); padding-top: 90px; padding-bottom: 90px; } .services-suite article { min-height: 255px; }
.gallery-wrapper { grid-template-columns: repeat(3,minmax(0,1fr)); } .gallery-items { margin: 0; background: var(--white); overflow: hidden; min-height: 260px; } .gallery-items img { width: 100%; height: 100%; min-height: 260px; object-fit: cover; transition: transform .24s ease; } .gallery-items:hover img { transform: scale(1.05); }
.contact-modern { display: grid; grid-template-columns: minmax(0,1.1fr) minmax(320px,.9fr); gap: 28px; padding-top: 90px; padding-bottom: 90px; } .contact-panel, .contact-details { padding: 34px; } .modern-form { display: grid; gap: 16px; margin-top: 26px; } .form-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; } .modern-form input, .modern-form textarea { width: 100%; border: 1px solid var(--line); background: #fbfaf7; padding: 16px 18px; min-height: 56px; color: var(--ink); font-weight: 700; } .modern-form textarea { min-height: 180px; resize: vertical; } .modern-form input:focus, .modern-form textarea:focus { outline: 2px solid rgba(229,57,53,.24); border-color: var(--accent); }
.contact-details { display: grid; gap: 20px; align-content: start; background: var(--navy); color: var(--white); } .contact-details div { padding-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,.18); } .contact-details div:last-child { border-bottom: 0; padding-bottom: 0; } .contact-details span { display: inline-grid; place-items: center; width: 42px; height: 42px; background: rgba(255,255,255,.12); color: var(--gold); margin-bottom: 16px; } .contact-details p, .contact-details a { color: rgba(255,255,255,.78); }
.site-footer { background: #111827; color: var(--white); } .footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3,minmax(0,.8fr)); gap: 36px; padding-top: 72px; padding-bottom: 56px; } .footer-brand img { max-width: 160px; background: var(--white); padding: 10px; margin-bottom: 20px; } .site-footer h3 { font-size: 15px; text-transform: uppercase; letter-spacing: .12em; color: var(--gold); margin: 0 0 18px; } .site-footer a { display: block; color: rgba(255,255,255,.78); margin-bottom: 10px; } .site-footer p { color: rgba(255,255,255,.68); } .footer-bottom { border-top: 1px solid rgba(255,255,255,.12); padding: 18px 0; } .footer-bottom p { margin: 0; font-size: 14px; }
#movetop { display: none; position: fixed; bottom: 24px; right: 24px; z-index: 99; width: 46px; height: 46px; border: 0; border-radius: 6px; color: var(--white); background: var(--accent); box-shadow: var(--shadow); } .alert { border-radius: 0; font-weight: 800; }
@media (max-width: 991px) { .site-header .navbar-collapse { padding: 18px 0 8px; } .nav-actions { margin: 12px 0 0; align-items: flex-start; flex-direction: column; } .hero-modern { min-height: auto; padding-top: 138px; } .hero-grid, .page-hero-grid, .split-intro, .about-story, .contact-modern { grid-template-columns: 1fr; } .service-feature-grid, .services-suite, .values-grid, .gallery-wrapper { grid-template-columns: repeat(2,minmax(0,1fr)); } .process-row, .catalogue-wrapper, .footer-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .cta-inner { display: grid; } }
@media (max-width: 640px) { .navbar-brand img { height: 52px; } .hero-modern, .page-hero { padding-top: 126px; } .hero-copy h1, .page-hero h1 { font-size: 43px; } .hero-lead, .page-hero p, .split-intro p { font-size: 17px; } .service-feature-grid, .services-suite, .values-grid, .gallery-wrapper, .process-row, .catalogue-wrapper, .footer-grid, .form-grid { grid-template-columns: 1fr; } .section-band, .catalogue-section, .about-story, .services-suite, .contact-modern, .cta-modern { padding-top: 58px; padding-bottom: 58px; } .feature-card, .process-row div, .services-suite article { min-height: auto; } }

/* Modern pass polish */
.hero-copy h1,
.page-hero h1,
.cta-inner h2 {
  color: var(--white) !important;
}
.hero-lead {
  color: rgba(255,255,255,.9) !important;
}
.page-hero p {
  color: rgba(255,255,255,.86) !important;
}
.site-header .navbar-toggler {
  border: 1px solid var(--line);
  padding: 10px 12px;
}
.site-header .navbar-toggler span {
  color: var(--ink);
}
@media (max-width: 640px) {
  .hero-panel div { padding: 20px; }
  .contact-panel, .contact-details { padding: 24px; }
}

/* Inner page hero scale */
.page-hero h1 {
  font-size: clamp(42px, 6vw, 76px) !important;
  max-width: 780px;
}
.page-hero {
  min-height: 500px;
}
@media (max-width: 640px) {
  .page-hero h1 { font-size: 40px !important; }
}

/* Header refinement: Inter, baby-blue brand accent, hardened mobile menu */
:root {
  --accent: #7fd4f2;
  --accent-strong: #40b9df;
  --accent-ink: #07283a;
}

body,
button,
input,
textarea,
select {
  font-family: "Inter", Arial, sans-serif !important;
}

.btn-primary,
.btn-primary:not(:disabled):not(.disabled):active,
#movetop {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--accent-ink) !important;
}

.btn-primary:hover,
.btn-primary:focus,
#movetop:hover {
  background: var(--accent-strong) !important;
  border-color: var(--accent-strong) !important;
  color: var(--accent-ink) !important;
}

.btn-outline-light {
  border-color: rgba(127,212,242,.78) !important;
}

.site-header {
  padding: 12px 0;
  border-bottom: 1px solid rgba(127,212,242,.34);
}

.navbar-brand img {
  height: 58px;
}

.site-header .nav-link {
  font-weight: 800;
  color: var(--ink) !important;
  border-radius: 6px;
}

.site-header .nav-item.active .nav-link::after,
.site-header .nav-link:hover::after {
  background: var(--accent);
  height: 4px;
  border-radius: 4px;
}

.nav-phone {
  color: var(--navy);
  font-size: 14px;
}

.nav-cta,
.hero-actions .btn,
.cta-modern .btn,
.modern-form .btn {
  border-radius: 6px !important;
}

.site-header .navbar-toggler {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(16,42,67,.18) !important;
  border-radius: 6px;
  background: #fff;
  padding: 0;
  outline: none !important;
}

.site-header .navbar-toggler:focus {
  box-shadow: 0 0 0 3px rgba(127,212,242,.36);
}

.site-header .navbar-toggler .icon-expand,
.site-header .navbar-toggler .icon-close {
  font-size: 21px;
  line-height: 1;
  color: var(--navy);
}

.feature-card,
.services-suite article,
.values-grid article,
.catalogue-items,
.contact-panel,
.contact-details,
.hero-panel,
.modern-form input,
.modern-form textarea,
.footer-brand img,
.about-badges span,
.alert,
.gallery-items,
.about-image img {
  border-radius: 6px !important;
}

.eyebrow,
.hero-panel .metric,
.process-row span,
.values-grid span,
.site-footer h3,
.contact-details span {
  color: var(--accent) !important;
}

.contact-details span {
  border-radius: 6px;
}

@media (max-width: 991px) {
  .site-header {
    padding: 10px 0;
  }

  .navbar-brand img {
    height: 50px;
  }

  .site-header .navbar-collapse {
    position: absolute;
    top: calc(100% + 10px);
    left: 15px;
    right: 15px;
    z-index: 1000;
    padding: 14px;
    background: #fff;
    border: 1px solid rgba(16,42,67,.14);
    border-radius: 6px;
    box-shadow: 0 24px 70px rgba(17,24,39,.2);
  }

  .site-header .navbar-nav {
    align-items: stretch !important;
  }

  .site-header .nav-item {
    width: 100%;
  }

  .site-header .nav-link {
    min-height: 48px;
    display: flex;
    align-items: center;
    padding: 12px 14px !important;
    border-bottom: 1px solid rgba(16,42,67,.08);
  }

  .site-header .nav-item:last-child .nav-link {
    border-bottom: 0;
  }

  .site-header .nav-item.active .nav-link,
  .site-header .nav-link:hover,
  .site-header .nav-link:focus {
    background: rgba(127,212,242,.16);
    color: var(--accent-ink) !important;
  }

  .site-header .nav-item.active .nav-link::after,
  .site-header .nav-link:hover::after {
    display: none;
  }

  .nav-actions {
    gap: 12px;
    margin-top: 16px;
  }

  .nav-phone,
  .nav-cta {
    width: 100%;
  }

  .nav-phone {
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  .nav-cta {
    text-align: center;
  }
}

/* Bootstrap breakpoint hardening for the custom header */
@media (min-width: 992px) {
  .site-header .navbar-toggler {
    display: none !important;
  }

  .site-header .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
    align-items: center;
  }
}


/* Typography and button sizing refinement */
.site-header .nav-link,
.nav-phone {
  font-weight: 600 !important;
}

.btn-style,
.btn.btn-style {
  padding: 9px 16px !important;
  font-weight: 600 !important;
  line-height: 1.25;
}

.nav-cta {
  padding: 9px 16px !important;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.hero-actions .btn,
.cta-modern .btn,
.modern-form .btn {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

@media (max-width: 991px) {
  .site-header .nav-link,
  .nav-phone {
    font-weight: 600 !important;
  }

  .nav-cta {
    min-height: 42px;
  }
}

/* Intentional 2-slide business hero */
.hero-slider {
  height: 80vh;
  min-height: 640px;
  max-height: 860px;
  padding: 0;
  align-items: stretch;
  isolation: isolate;
}

.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  padding: 116px 0 72px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: scale(1.012);
  transition: opacity 1100ms cubic-bezier(.22, .61, .36, 1), transform 1600ms cubic-bezier(.22, .61, .36, 1), visibility 0s linear 1100ms;
}

.hero-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: linear-gradient(90deg, rgba(16,42,67,.96) 0%, rgba(16,42,67,.84) 43%, rgba(16,42,67,.28) 100%), var(--hero-image);
  background-size: cover;
  background-position: center;
}

.hero-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(16,42,67,.1), rgba(16,42,67,.18));
}

.hero-slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: scale(1);
  transition-delay: 0s;
}

.hero-slider .hero-grid {
  width: 100%;
}

.hero-slider .hero-copy h1 {
  max-width: 760px;
  font-size: clamp(42px, 6vw, 82px);
  line-height: .98;
}

.hero-slider .hero-lead {
  max-width: 650px;
}

.hero-slider-controls {
  position: absolute;
  left: 50%;
  bottom: 28px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 12px;
  transform: translateX(-50%);
}

.hero-arrow,
.hero-dots button {
  border: 1px solid rgba(255,255,255,.4);
  background: rgba(255,255,255,.14);
  color: #fff;
  border-radius: 6px;
  backdrop-filter: blur(14px);
}

.hero-arrow {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
}

.hero-dots {
  display: flex;
  gap: 8px;
  padding: 7px;
  border-radius: 6px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  backdrop-filter: blur(14px);
}

.hero-dots button {
  width: 34px;
  height: 6px;
  padding: 0;
  opacity: .58;
}

.hero-dots button.is-active {
  background: var(--accent);
  border-color: var(--accent);
  opacity: 1;
}

.hero-arrow:focus,
.hero-dots button:focus {
  outline: 3px solid rgba(127,212,242,.45);
  outline-offset: 2px;
}

@media (max-width: 991px) {
  .hero-slider {
    height: auto;
    min-height: 80vh;
    max-height: none;
  }

  .hero-slide {
    min-height: 80vh;
    padding: 126px 0 86px;
    align-items: flex-start;
  }

  .hero-slide::before {
    background-image: linear-gradient(90deg, rgba(16,42,67,.96) 0%, rgba(16,42,67,.78) 58%, rgba(16,42,67,.42) 100%), var(--hero-image);
    background-position: center right;
  }

  .hero-slider .hero-grid {
    gap: 28px;
  }

  .hero-slider .hero-copy h1 {
    max-width: 560px;
    font-size: clamp(38px, 10vw, 58px);
    line-height: 1.02;
  }

  .hero-slider .hero-panel {
    max-width: 560px;
  }
}

@media (max-width: 640px) {
  .hero-slider {
    min-height: 80vh;
  }

  .hero-slide {
    min-height: 80vh;
    padding: 118px 0 78px;
  }

  .hero-slide::before {
    background-image: linear-gradient(90deg, rgba(16,42,67,.97) 0%, rgba(16,42,67,.8) 62%, rgba(16,42,67,.5) 100%), var(--hero-image);
    background-position: 62% center;
  }

  .hero-slider .hero-copy h1 {
    font-size: clamp(36px, 11vw, 45px) !important;
  }

  .hero-slider .hero-lead {
    font-size: 16px;
    line-height: 1.55;
  }

  .hero-slider .hero-actions {
    gap: 10px;
  }

  .hero-slider .hero-actions .btn {
    flex: 1 1 auto;
    min-width: 150px;
  }

  .hero-slider .hero-panel {
    display: none;
  }

  .hero-slider-controls {
    bottom: 18px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-slide {
    transition: none;
    transform: none;
  }
}

/* 80vh hero fit refinement */
.hero-slider {
  min-height: 600px;
}

.hero-slide {
  padding: 104px 0 64px;
}

.hero-slider .hero-grid {
  align-items: center;
}

.hero-slider .hero-copy h1 {
  font-size: clamp(40px, 5.2vw, 68px) !important;
  line-height: 1;
  max-width: 680px;
}

.hero-slider .hero-lead {
  font-size: 18px;
  line-height: 1.55;
  max-width: 640px;
  margin-top: 18px;
}

.hero-slider .hero-actions {
  margin-top: 24px;
}

.hero-slider .hero-panel div {
  padding: 20px 24px;
}

.hero-slider .hero-panel strong {
  font-size: 20px;
}

.hero-slider .hero-panel p {
  font-size: 15px;
  line-height: 1.45;
}

.hero-slider-controls {
  bottom: 20px;
}

@media (max-width: 991px) {
  .hero-slider {
    min-height: 80vh;
  }

  .hero-slide {
    padding: 116px 0 78px;
  }
}

/* Slider control and mobile composition refinement */
.hero-slider-controls {
  bottom: 26px;
}

.hero-arrow {
  width: 34px;
  height: 34px;
}

.hero-dots button {
  width: 30px;
}

@media (max-width: 991px) {
  .hero-slide {
    padding-bottom: 96px;
  }
}

@media (max-width: 640px) {
  .hero-slide {
    padding-top: 108px;
    padding-bottom: 92px;
  }

  .hero-slider .hero-copy h1 {
    font-size: clamp(32px, 9.4vw, 40px) !important;
    max-width: 350px;
  }

  .hero-slider .hero-lead {
    max-width: 350px;
  }

  .hero-slider-controls {
    bottom: 20px;
  }
}

/* True horizontal hero slide transition */
.hero-slider {
  display: block;
}

.hero-track {
  width: 100%;
  height: 100%;
  display: flex;
  transform: translate3d(0, 0, 0);
  transition: transform 1050ms cubic-bezier(.22, .61, .36, 1);
  will-change: transform;
}

.hero-slide {
  position: relative !important;
  inset: auto !important;
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
  transition: none !important;
}

.hero-slide[aria-hidden="true"] {
  pointer-events: none !important;
}

.hero-slide::before {
  transition: transform 1400ms cubic-bezier(.22, .61, .36, 1);
}

.hero-slide.is-active::before {
  transform: scale(1.015);
}

@media (prefers-reduced-motion: reduce) {
  .hero-track {
    transition: none;
  }

  .hero-slide::before {
    transition: none;
  }
}

/* Enforce the requested 80vh hero frame across responsive views */
@media (max-width: 991px) {
  .hero-slider {
    height: 80vh !important;
    min-height: 620px;
    max-height: 760px;
  }

  .hero-track,
  .hero-slide {
    height: 100%;
  }

  .hero-slide {
    align-items: center;
  }
}

@media (max-width: 640px) {
  .hero-slider {
    height: 80vh !important;
    min-height: 640px;
  }

  .hero-slide {
    padding-top: 96px;
    padding-bottom: 84px;
  }

  .hero-slider-controls {
    bottom: 18px;
  }
}

/* Remove hero top strip and refine outline button hover */
.site-header {
  border-bottom: 0 !important;
  box-shadow: none !important;
}

.hero-slider {
  margin-top: 0 !important;
}

.btn-outline-light:hover,
.btn-outline-light:focus,
.btn-outline-light:active {
  color: var(--accent) !important;
  border-color: var(--accent) !important;
  background: rgba(255,255,255,.94) !important;
}

.hero-actions .btn-outline-light:hover,
.hero-actions .btn-outline-light:focus,
.hero-actions .btn-outline-light:active {
  color: var(--accent) !important;
}

/* Hard containment for true slide carousel */
.hero-slider {
  width: 100%;
  overflow: hidden !important;
}

.hero-track {
  min-width: 100%;
  max-width: none;
}

.hero-slide {
  min-width: 100% !important;
  max-width: 100% !important;
  overflow: hidden;
}

.hero-slide > .container {
  flex: 0 0 auto;
}

/* Brand-correct outline button hover: Nifty navy text */
.btn-outline-light:hover,
.btn-outline-light:focus,
.btn-outline-light:active,
.hero-actions .btn-outline-light:hover,
.hero-actions .btn-outline-light:focus,
.hero-actions .btn-outline-light:active {
  color: var(--navy) !important;
  border-color: var(--accent) !important;
  background: rgba(255,255,255,.94) !important;
}

/* Business-ready fixed header rhythm */
@media (min-width: 992px) {
  .site-header {
    height: 100px !important;
    padding: 0 !important;
    display: flex;
    align-items: center;
  }

  .site-header .nav-shell,
  .site-header .navbar {
    height: 100%;
  }

  .site-header .navbar {
    align-items: center;
  }

  .navbar-brand img {
    height: 56px !important;
  }

  .site-header .nav-link {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  .nav-cta {
    min-height: 38px;
  }
}

@media (max-width: 991px) {
  .site-header {
    min-height: 86px;
    padding: 0 !important;
    display: flex;
    align-items: center;
  }

  .site-header .navbar {
    width: 100%;
    min-height: 86px;
    align-items: center;
  }

  .navbar-brand img {
    height: 48px !important;
  }
}

/* Intentional post-hero intro and header scroll hardening */
.w3l-top-header,
.top-header,
.header-top,
.main-top {
  display: none !important;
}

header.site-header,
header.site-header.fixed-top,
header.site-header.nav-fixed {
  top: 0 !important;
  right: 0 !important;
  left: 0 !important;
  width: 100% !important;
  max-height: 100px !important;
  background: rgba(246,244,239,.94) !important;
  transform: none !important;
}

.intro-band {
  background: #fff !important;
  padding: 74px 0 78px !important;
  border-bottom: 1px solid rgba(16,42,67,.08);
}

.intro-modern {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: start;
}

.intro-heading {
  max-width: 520px;
}

.intro-band .eyebrow.dark {
  margin-bottom: 14px;
  color: var(--navy);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
}

.intro-band h2 {
  max-width: 560px;
  font-size: clamp(32px, 3.4vw, 52px);
  line-height: 1.05;
  font-weight: 700;
  color: var(--ink);
}

.intro-content {
  padding-top: 36px;
}

.intro-content > p {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(17px, 1.45vw, 20px);
  line-height: 1.58;
  font-weight: 400;
}

.intro-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 34px;
  border: 1px solid rgba(16,42,67,.1);
  border-radius: 6px;
  overflow: hidden;
  background: #fbfaf7;
}

.intro-proof div {
  min-height: 148px;
  padding: 22px 20px;
  border-right: 1px solid rgba(16,42,67,.1);
}

.intro-proof div:last-child {
  border-right: 0;
}

.intro-proof span {
  display: block;
  margin-bottom: 18px;
  color: var(--accent-strong);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .08em;
}

.intro-proof strong {
  display: block;
  color: var(--navy);
  font-size: 17px;
  line-height: 1.2;
  font-weight: 700;
}

.intro-proof small {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
  font-weight: 400;
}

@media (min-width: 992px) {
  header.site-header,
  header.site-header.fixed-top,
  header.site-header.nav-fixed {
    height: 100px !important;
    min-height: 100px !important;
    padding: 0 !important;
  }
}

@media (max-width: 991px) {
  header.site-header,
  header.site-header.fixed-top,
  header.site-header.nav-fixed {
    max-height: none !important;
  }

  .intro-band {
    padding: 62px 0 66px !important;
  }

  .intro-modern {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .intro-content {
    padding-top: 0;
  }
}

@media (max-width: 640px) {
  .intro-band {
    padding: 50px 0 54px !important;
  }

  .intro-band h2 {
    font-size: clamp(29px, 8vw, 36px);
  }

  .intro-proof {
    grid-template-columns: 1fr;
  }

  .intro-proof div {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(16,42,67,.1);
  }

  .intro-proof div:last-child {
    border-bottom: 0;
  }
}

/* Keep the header in normal document flow; remove old sticky/fixed top behavior */
header.site-header,
header.site-header.fixed-top,
header.site-header.nav-fixed {
  position: relative !important;
  z-index: 20;
}

@media (min-width: 992px) {
  header.site-header,
  header.site-header.fixed-top,
  header.site-header.nav-fixed {
    height: 100px !important;
    min-height: 100px !important;
    max-height: 100px !important;
  }
}

/* Portfolio-ready selected work gallery */
.portfolio-section {
  background: #f6f4ef;
  padding: 76px 0 86px;
}

.portfolio-heading {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  column-gap: clamp(34px, 5vw, 72px);
  row-gap: 18px;
  align-items: end;
  margin-bottom: 34px;
}

.portfolio-heading .eyebrow {
  grid-column: 1 / -1;
  margin-bottom: 0;
  color: var(--navy);
  font-weight: 800;
  letter-spacing: .1em;
}

.portfolio-heading h2 {
  max-width: 620px;
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: 1.07;
  font-weight: 700;
  color: var(--ink);
}

.portfolio-heading p:not(.eyebrow) {
  max-width: 660px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.35vw, 18px);
  line-height: 1.58;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 220px;
  gap: 18px;
}

.portfolio-card {
  position: relative;
  min-height: 220px;
  overflow: hidden;
  border-radius: 6px;
  background: var(--navy);
  border: 1px solid rgba(16,42,67,.1);
  box-shadow: 0 14px 38px rgba(17,24,39,.08);
  isolation: isolate;
}

.portfolio-card-large {
  grid-column: span 2;
  grid-row: span 2;
}

.portfolio-card-wide {
  grid-column: span 2;
}

.portfolio-card img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform 700ms cubic-bezier(.22,.61,.36,1), filter 700ms cubic-bezier(.22,.61,.36,1);
}

.portfolio-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(16,42,67,.04) 0%, rgba(16,42,67,.28) 45%, rgba(16,42,67,.86) 100%);
}

.portfolio-card-dark::after {
  background: linear-gradient(180deg, rgba(17,24,39,.18) 0%, rgba(17,24,39,.44) 42%, rgba(17,24,39,.9) 100%);
}

.portfolio-card-copy {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: 24px;
  color: var(--white);
}

.portfolio-card-copy span {
  display: block;
  margin-bottom: 9px;
  color: var(--accent);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.portfolio-card-copy h3 {
  max-width: 360px;
  margin: 0;
  color: var(--white);
  font-size: clamp(21px, 2vw, 30px);
  line-height: 1.08;
  font-weight: 700;
}

.portfolio-card:hover img,
.portfolio-card:focus-within img {
  transform: scale(1.055);
  filter: saturate(1.04);
}

@media (max-width: 991px) {
  .portfolio-section {
    padding: 66px 0 72px;
  }

  .portfolio-heading {
    grid-template-columns: 1fr;
    margin-bottom: 28px;
  }

  .portfolio-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 230px;
  }

  .portfolio-card-large,
  .portfolio-card-wide {
    grid-column: span 2;
  }
}

@media (max-width: 640px) {
  .portfolio-section {
    padding: 54px 0 58px;
  }

  .portfolio-heading h2 {
    font-size: clamp(28px, 7.6vw, 34px);
  }

  .portfolio-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 260px;
    gap: 14px;
  }

  .portfolio-card,
  .portfolio-card-large,
  .portfolio-card-wide {
    grid-column: auto;
    grid-row: auto;
  }

  .portfolio-card-large {
    min-height: 330px;
  }

  .portfolio-card-copy {
    padding: 22px;
  }
}

.portfolio-card-large img {
  object-position: left center;
}

.portfolio-card-large img {
  transform: scale(1.22);
  transform-origin: left center;
}

.portfolio-card-large:hover img,
.portfolio-card-large:focus-within img {
  transform: scale(1.27);
}

/* Mobile portfolio card separation hardening */
@media (max-width: 640px) {
  .portfolio-grid {
    display: flex !important;
    flex-direction: column;
    gap: 18px !important;
  }

  .portfolio-card,
  .portfolio-card-large,
  .portfolio-card-wide {
    width: 100%;
    min-height: 300px;
    flex: 0 0 auto;
  }

  .portfolio-card-large {
    min-height: 380px;
  }

  .portfolio-card-copy {
    min-height: 112px;
    padding: 24px 22px 22px;
    background: linear-gradient(180deg, rgba(16,42,67,0), rgba(16,42,67,.88));
  }

  .portfolio-card-copy span {
    margin-bottom: 8px;
  }

  .portfolio-card-copy h3 {
    display: block;
    font-size: 24px;
    line-height: 1.12;
  }

  .portfolio-card-large img {
    transform: scale(1.14);
  }

  .portfolio-card-large:hover img,
  .portfolio-card-large:focus-within img {
    transform: scale(1.18);
  }
}

/* Modern back-to-top control */
#movetop.scroll-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 100;
  width: 54px;
  height: 54px;
  display: inline-grid !important;
  place-items: center;
  border: 1px solid rgba(127,212,242,.72) !important;
  border-radius: 6px !important;
  background: var(--navy) !important;
  color: var(--accent) !important;
  box-shadow: 0 18px 40px rgba(16,42,67,.24);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(12px);
  transition: opacity .22s ease, visibility .22s ease, transform .22s ease, background .18s ease, color .18s ease, border-color .18s ease;
}

#movetop.scroll-top.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

#movetop.scroll-top i {
  font-size: 21px;
  line-height: 1;
}

#movetop.scroll-top:hover,
#movetop.scroll-top:focus {
  background: var(--accent) !important;
  color: var(--navy) !important;
  border-color: var(--accent) !important;
  outline: none;
  transform: translateY(-3px);
}

#movetop.scroll-top:focus-visible {
  box-shadow: 0 0 0 4px rgba(127,212,242,.34), 0 18px 40px rgba(16,42,67,.24);
}

@media (max-width: 640px) {
  #movetop.scroll-top {
    right: 18px;
    bottom: 18px;
    width: 52px;
    height: 52px;
  }
}

/* Selected work consistency pass */
@media (min-width: 992px) {
  .portfolio-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-auto-rows: 220px;
    gap: 18px;
  }

  .portfolio-card {
    grid-column: span 3;
    grid-row: span 1;
  }

  .portfolio-card-large {
    grid-column: span 6;
    grid-row: span 2;
  }

  .portfolio-card-wide {
    grid-column: span 3;
  }

  .portfolio-card-copy {
    padding: 22px 24px;
  }

  .portfolio-card-copy h3 {
    font-size: clamp(22px, 1.8vw, 27px);
  }
}

@media (min-width: 641px) and (max-width: 991px) {
  .portfolio-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 230px;
    gap: 18px;
  }

  .portfolio-card {
    grid-column: span 1;
    grid-row: span 1;
    min-height: 230px;
  }

  .portfolio-card-large,
  .portfolio-card-wide {
    grid-column: span 2;
  }

  .portfolio-card-large {
    min-height: 430px;
  }

  .portfolio-card-large img {
    transform: scale(1.14);
    transform-origin: left center;
  }
}

@media (max-width: 640px) {
  .portfolio-card,
  .portfolio-card-large,
  .portfolio-card-wide {
    display: flex;
    flex-direction: column;
    min-height: 0;
    background: var(--navy);
  }

  .portfolio-card::after {
    display: none;
  }

  .portfolio-card img,
  .portfolio-card-large img,
  .portfolio-card-wide img {
    width: 100%;
    height: 224px;
    flex: 0 0 auto;
    object-fit: cover;
    object-position: center;
    transform: none !important;
    transition: transform 700ms cubic-bezier(.22,.61,.36,1), filter 700ms cubic-bezier(.22,.61,.36,1);
  }

  .portfolio-card-large img {
    height: 236px;
    object-position: left center;
  }

  .portfolio-card-copy {
    position: static;
    min-height: auto;
    padding: 22px;
    background: var(--navy);
  }

  .portfolio-card-copy h3 {
    font-size: 23px;
    line-height: 1.14;
  }

  .portfolio-card:hover img,
  .portfolio-card:focus-within img {
    transform: scale(1.035) !important;
  }
}

/* Selected work tablet overlap fix and lead crop refinement */
@media (min-width: 992px) {
  .portfolio-card-large img {
    transform: scale(1.32);
    transform-origin: left center;
  }

  .portfolio-card-large:hover img,
  .portfolio-card-large:focus-within img {
    transform: scale(1.37);
  }
}

@media (min-width: 641px) and (max-width: 991px) {
  .portfolio-card-large {
    grid-row: span 2;
  }

  .portfolio-card-large img {
    transform: scale(1.28);
    transform-origin: left center;
  }

  .portfolio-card-large:hover img,
  .portfolio-card-large:focus-within img {
    transform: scale(1.32);
  }
}

/* Lead portfolio image final crop */
.portfolio-card-large img {
  object-position: center;
}

@media (min-width: 641px) {
  .portfolio-card-large img,
  .portfolio-card-large:hover img,
  .portfolio-card-large:focus-within img {
    transform: scale(1.04);
  }
}

@media (max-width: 640px) {
  .portfolio-card-large img {
    object-position: center;
  }
}

/* Serious process section upgrade */
.process-band {
  position: relative;
  padding: 76px 0 82px !important;
  background: linear-gradient(180deg, #edf3f5 0%, #e8eef1 100%) !important;
  overflow: hidden;
}

.process-band::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, rgba(127,212,242,0), rgba(127,212,242,.9), rgba(127,212,242,0));
}

.process-modern {
  position: relative;
}

.process-heading {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  column-gap: clamp(34px, 5vw, 72px);
  row-gap: 16px;
  align-items: end;
  margin-bottom: 34px;
}

.process-heading .eyebrow {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--navy) !important;
  font-weight: 800;
  letter-spacing: .1em;
}

.process-heading h2 {
  max-width: 620px;
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: 1.07;
  font-weight: 700;
  color: var(--ink);
}

.process-heading p:not(.eyebrow) {
  max-width: 620px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.35vw, 18px);
  line-height: 1.58;
}

.process-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border: 1px solid rgba(16,42,67,.12) !important;
  border-radius: 6px;
  overflow: hidden;
  background: rgba(255,255,255,.58);
  box-shadow: 0 18px 44px rgba(16,42,67,.08);
}

.process-row div {
  min-height: 220px !important;
  padding: 24px !important;
  border: 0 !important;
  border-right: 1px solid rgba(16,42,67,.12) !important;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: rgba(255,255,255,.42);
}

.process-row div:last-child {
  border-right: 0 !important;
}

.process-row span {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: var(--navy);
  color: var(--accent) !important;
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .04em;
}

.process-row strong {
  display: block;
  margin-top: auto;
  margin-bottom: 12px;
  color: var(--accent-strong);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.process-row h3 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(20px, 1.7vw, 25px);
  line-height: 1.18;
  font-weight: 650;
}

@media (max-width: 991px) {
  .process-band {
    padding: 66px 0 70px !important;
  }

  .process-heading {
    grid-template-columns: 1fr;
    margin-bottom: 28px;
  }

  .process-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-row div {
    min-height: 200px !important;
  }

  .process-row div:nth-child(2) {
    border-right: 0 !important;
  }

  .process-row div:nth-child(-n+2) {
    border-bottom: 1px solid rgba(16,42,67,.12) !important;
  }
}

@media (max-width: 640px) {
  .process-band {
    padding: 54px 0 58px !important;
  }

  .process-heading h2 {
    font-size: clamp(28px, 7.6vw, 34px);
  }

  .process-row {
    grid-template-columns: 1fr;
  }

  .process-row div,
  .process-row div:nth-child(2),
  .process-row div:nth-child(-n+2) {
    min-height: 166px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(16,42,67,.12) !important;
  }

  .process-row div:last-child {
    border-bottom: 0 !important;
  }

  .process-row h3 {
    font-size: 21px;
  }
}

/* Protect mobile process copy from the fixed back-to-top control */
@media (max-width: 640px) {
  .process-row div {
    padding-right: 76px !important;
  }
}

/* Process cards: separated, calmer, intentional */
.process-row {
  gap: 16px !important;
  border: 0 !important;
  border-radius: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  box-shadow: none !important;
}

.process-row div,
.process-row div:nth-child(2),
.process-row div:nth-child(-n+2),
.process-row div:last-child {
  min-height: 188px !important;
  padding: 22px !important;
  border: 1px solid rgba(16,42,67,.1) !important;
  border-radius: 6px !important;
  background: rgba(255,255,255,.76) !important;
  box-shadow: 0 12px 30px rgba(16,42,67,.07);
  justify-content: flex-start !important;
}

.process-row span {
  width: 36px !important;
  height: 36px !important;
  margin-bottom: 24px;
  font-size: 12px !important;
}

.process-row strong {
  margin: 0 0 9px !important;
  font-size: 12px !important;
  letter-spacing: .09em;
}

.process-row h3 {
  max-width: 260px;
  font-size: clamp(17px, 1.25vw, 20px) !important;
  line-height: 1.24 !important;
  font-weight: 650;
}

@media (max-width: 991px) {
  .process-row {
    gap: 16px !important;
  }

  .process-row div,
  .process-row div:nth-child(2),
  .process-row div:nth-child(-n+2),
  .process-row div:last-child {
    min-height: 178px !important;
    padding: 21px !important;
  }

  .process-row h3 {
    max-width: 280px;
    font-size: 18px !important;
  }
}

@media (max-width: 640px) {
  .process-row {
    gap: 14px !important;
  }

  .process-row div,
  .process-row div:nth-child(2),
  .process-row div:nth-child(-n+2),
  .process-row div:last-child {
    min-height: auto !important;
    padding: 20px 70px 20px 20px !important;
  }

  .process-row span {
    margin-bottom: 20px;
  }

  .process-row h3 {
    max-width: 100%;
    font-size: 18px !important;
    line-height: 1.26 !important;
  }
}

/* Final process card type scale refinement */
.process-row div,
.process-row div:nth-child(2),
.process-row div:nth-child(-n+2),
.process-row div:last-child {
  min-height: 172px !important;
}

.process-row span {
  width: 34px !important;
  height: 34px !important;
  margin-bottom: 22px;
  font-size: 11px !important;
}

.process-row strong {
  margin-bottom: 8px !important;
  font-size: 11px !important;
}

.process-row h3 {
  font-size: clamp(16px, 1.05vw, 18px) !important;
  line-height: 1.28 !important;
  font-weight: 650;
}

@media (max-width: 991px) {
  .process-row div,
  .process-row div:nth-child(2),
  .process-row div:nth-child(-n+2),
  .process-row div:last-child {
    min-height: 162px !important;
  }

  .process-row h3 {
    font-size: 16.5px !important;
  }
}

@media (max-width: 640px) {
  .process-row div,
  .process-row div:nth-child(2),
  .process-row div:nth-child(-n+2),
  .process-row div:last-child {
    padding: 19px 68px 19px 19px !important;
  }

  .process-row h3 {
    font-size: 16px !important;
    line-height: 1.3 !important;
  }
}

/* Clean scoped catalogue section */
.catalogue-modern {
  padding: 72px 0 82px !important;
  background: #f6f4ef;
}

.catalogue-modern .catalogue-heading {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  column-gap: clamp(34px, 5vw, 72px);
  row-gap: 16px;
  align-items: end;
  margin-bottom: 30px;
}

.catalogue-modern .catalogue-heading .eyebrow {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--navy) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
}

.catalogue-modern .catalogue-heading h2 {
  max-width: 600px;
  color: var(--ink) !important;
  font-size: clamp(30px, 3.1vw, 46px);
  line-height: 1.08;
  font-weight: 700;
}

.catalogue-modern .catalogue-heading p:not(.eyebrow) {
  max-width: 620px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.3vw, 18px);
  line-height: 1.58;
}

.catalogue-modern .catalogue-wrapper {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px !important;
}

.catalogue-modern .catalogue-items {
  min-height: 156px !important;
  padding: 26px 22px 22px;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  border: 1px solid rgba(16,42,67,.1) !important;
  border-radius: 6px !important;
  background: rgba(255,255,255,.86) !important;
  box-shadow: 0 12px 30px rgba(16,42,67,.06) !important;
  color: var(--navy) !important;
  text-align: center;
  transform: none;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.catalogue-modern .catalogue-items img {
  width: auto;
  max-width: 138px !important;
  max-height: 54px !important;
  object-fit: contain;
  filter: saturate(.92) contrast(1.02);
}

.catalogue-modern .catalogue-items span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: .02em;
}

.catalogue-modern .catalogue-items:hover,
.catalogue-modern .catalogue-items:focus {
  background: var(--white) !important;
  border-color: rgba(127,212,242,.82) !important;
  box-shadow: 0 18px 42px rgba(16,42,67,.1) !important;
  transform: translateY(-3px);
  outline: none;
}

.catalogue-modern .catalogue-items:focus-visible {
  box-shadow: 0 0 0 4px rgba(127,212,242,.32), 0 18px 42px rgba(16,42,67,.1) !important;
}

@media (max-width: 991px) {
  .catalogue-modern {
    padding: 64px 0 70px !important;
  }

  .catalogue-modern .catalogue-heading {
    grid-template-columns: 1fr;
    margin-bottom: 26px;
  }

  .catalogue-modern .catalogue-wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  .catalogue-modern {
    padding: 52px 0 58px !important;
  }

  .catalogue-modern .catalogue-heading h2 {
    font-size: clamp(28px, 7.4vw, 34px);
  }

  .catalogue-modern .catalogue-wrapper {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .catalogue-modern .catalogue-items {
    min-height: 132px !important;
    padding: 22px 20px;
  }
}

/* Catalogue final mobile rhythm */
@media (max-width: 640px) {
  .catalogue-modern {
    padding-bottom: 64px !important;
  }

  .catalogue-modern .catalogue-items {
    min-height: 124px !important;
    gap: 14px;
  }

  .catalogue-modern .catalogue-items img {
    max-height: 48px !important;
  }
}

/* Scoped modern footer */
.footer-modern.site-footer {
  background: var(--navy) !important;
  color: var(--white) !important;
  border-top: 1px solid rgba(127,212,242,.24);
}

.footer-modern .footer-modern-grid {
  display: grid !important;
  grid-template-columns: minmax(260px, 1.25fr) minmax(150px, .7fr) minmax(190px, .85fr) minmax(230px, .95fr);
  gap: clamp(28px, 4vw, 56px) !important;
  padding-top: 58px !important;
  padding-bottom: 46px !important;
  align-items: start;
}

.footer-modern .footer-company {
  max-width: 420px;
}

.footer-modern .footer-brand {
  display: inline-flex !important;
  align-items: center;
  margin: 0 0 20px !important;
}

.footer-modern .footer-brand img {
  width: auto !important;
  height: 58px !important;
  max-width: 118px !important;
  padding: 8px !important;
  margin: 0 !important;
  border-radius: 6px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: none !important;
  object-fit: contain;
}

.footer-modern p,
.footer-modern a,
.footer-modern span {
  font-size: 14px;
  line-height: 1.58;
}

.footer-modern .footer-company p {
  max-width: 360px;
  margin: 0 !important;
  color: rgba(255,255,255,.72) !important;
}

.footer-modern .footer-column h3 {
  margin: 0 0 18px !important;
  color: var(--accent) !important;
  font-size: 12px !important;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.footer-modern .footer-column a {
  display: block !important;
  margin: 0 0 10px !important;
  color: rgba(255,255,255,.76) !important;
  font-weight: 500;
  text-decoration: none !important;
  transition: color .18s ease, transform .18s ease;
}

.footer-modern .footer-column a:hover,
.footer-modern .footer-column a:focus {
  color: var(--accent) !important;
  transform: translateX(2px);
  outline: none;
}

.footer-modern .footer-contact {
  display: grid;
  gap: 12px;
}

.footer-modern .footer-contact a {
  display: grid !important;
  grid-template-columns: 36px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  margin: 0 !important;
  color: rgba(255,255,255,.78) !important;
}

.footer-modern .footer-contact i {
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  border-radius: 6px;
  background: rgba(127,212,242,.12);
  color: var(--accent);
  font-size: 14px;
  line-height: 1;
}

.footer-modern .footer-contact span {
  min-width: 0;
  color: rgba(255,255,255,.78) !important;
  overflow-wrap: anywhere;
}

.footer-modern .footer-modern-bottom {
  border-top: 1px solid rgba(255,255,255,.12) !important;
}

.footer-modern .footer-modern-bottom .container {
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.footer-modern .footer-modern-bottom p,
.footer-modern .footer-modern-bottom a {
  margin: 0 !important;
  color: rgba(255,255,255,.62) !important;
  font-size: 13px;
  line-height: 1.4;
  text-decoration: none !important;
}

.footer-modern .footer-modern-bottom a:hover,
.footer-modern .footer-modern-bottom a:focus {
  color: var(--accent) !important;
  outline: none;
}

@media (max-width: 991px) {
  .footer-modern .footer-modern-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    padding-top: 48px !important;
    padding-bottom: 40px !important;
    gap: 30px !important;
  }

  .footer-modern .footer-company {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .footer-modern .footer-modern-grid {
    grid-template-columns: 1fr !important;
    padding-top: 42px !important;
    padding-bottom: 34px !important;
    gap: 28px !important;
  }

  .footer-modern .footer-brand img {
    height: 52px !important;
    max-width: 108px !important;
  }

  .footer-modern .footer-column h3 {
    margin-bottom: 14px !important;
  }

  .footer-modern .footer-modern-bottom .container {
    min-height: 68px;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
    padding-top: 16px;
    padding-bottom: 16px;
  }
}

/* Scoped final CTA before footer */
.cta-final.cta-modern {
  padding: 58px 0 !important;
  color: var(--white) !important;
  background: var(--navy) !important;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(127,212,242,.22);
  border-bottom: 1px solid rgba(127,212,242,.18);
}

.cta-final.cta-modern::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(127,212,242,.16), rgba(127,212,242,0) 48%, rgba(255,255,255,.06));
  pointer-events: none;
}

.cta-final .cta-final-inner {
  position: relative;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 32px;
  align-items: center;
}

.cta-final .cta-final-copy {
  max-width: 760px;
}

.cta-final .eyebrow {
  margin: 0 0 13px !important;
  color: var(--accent) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
}

.cta-final h2 {
  max-width: 720px !important;
  margin: 0 !important;
  color: var(--white) !important;
  font-size: clamp(30px, 3.4vw, 48px);
  line-height: 1.08;
  font-weight: 700;
}

.cta-final .cta-final-copy p:not(.eyebrow) {
  max-width: 620px;
  margin: 16px 0 0;
  color: rgba(255,255,255,.72) !important;
  font-size: 16px;
  line-height: 1.58;
}

.cta-final .btn {
  min-width: 156px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px !important;
  border-radius: 6px !important;
  background: var(--accent) !important;
  color: var(--navy) !important;
  font-size: 15px;
  font-weight: 700;
  white-space: nowrap;
  box-shadow: none !important;
}

.cta-final .btn:hover,
.cta-final .btn:focus {
  background: var(--white) !important;
  color: var(--navy) !important;
  outline: none;
}

@media (max-width: 991px) {
  .cta-final.cta-modern {
    padding: 52px 0 !important;
  }

  .cta-final .cta-final-inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .cta-final .btn {
    width: fit-content;
  }
}

@media (max-width: 640px) {
  .cta-final.cta-modern {
    padding: 44px 0 48px !important;
  }

  .cta-final h2 {
    font-size: clamp(28px, 7.6vw, 34px);
  }

  .cta-final .cta-final-copy p:not(.eyebrow) {
    font-size: 15px;
  }

  .cta-final .btn {
    width: 100%;
  }
}

/* CTA mobile fixed-control clearance */
@media (max-width: 640px) {
  .cta-final .btn {
    width: calc(100% - 72px) !important;
    max-width: 320px;
    justify-self: start;
  }
}

/* Intentional breathing room between CTA and footer */
.footer-modern.site-footer {
  margin-top: 22px !important;
}

@media (max-width: 640px) {
  .footer-modern.site-footer {
    margin-top: 18px !important;
  }
}

/* CTA final image background treatment */
.cta-final.cta-modern {
  background:
    linear-gradient(90deg, rgba(16,42,67,.94) 0%, rgba(16,42,67,.88) 48%, rgba(16,42,67,.7) 100%),
    url('assets/images/home-slider2.jpg') center/cover no-repeat !important;
}

.cta-final.cta-modern::before {
  background: linear-gradient(90deg, rgba(127,212,242,.16), rgba(127,212,242,0) 52%, rgba(255,255,255,.04));
}

@media (max-width: 640px) {
  .cta-final.cta-modern {
    background:
      linear-gradient(180deg, rgba(16,42,67,.94) 0%, rgba(16,42,67,.9) 100%),
      url('assets/images/home-slider2.jpg') center/cover no-repeat !important;
  }
}

/* Footer spacing adjustment */
.footer-modern.site-footer {
  margin-top: 30px !important;
}

@media (max-width: 640px) {
  .footer-modern.site-footer {
    margin-top: 30px !important;
  }
}

/* About page modern hero */
.about-hero-modern.page-hero {
  min-height: 60vh !important;
  height: 60vh;
  max-height: 680px;
  padding: 0 !important;
  display: flex;
  align-items: center;
  color: var(--white) !important;
  background:
    linear-gradient(90deg, rgba(16,42,67,.95) 0%, rgba(16,42,67,.84) 48%, rgba(16,42,67,.52) 100%),
    url('assets/images/IMG-20260516-WA0011.jpg') center/cover no-repeat !important;
  position: relative;
  overflow: hidden;
}

.about-hero-modern.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(127,212,242,.09), rgba(127,212,242,0) 42%);
  pointer-events: none;
}

.about-hero-modern .about-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .55fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: end;
  width: 100%;
  padding-top: 34px;
}

.about-hero-modern .eyebrow {
  margin: 0 0 14px !important;
  color: var(--accent) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
}

.about-hero-modern h1 {
  max-width: 800px !important;
  margin: 0 !important;
  color: var(--white) !important;
  font-size: clamp(40px, 5.4vw, 72px) !important;
  line-height: 1.02 !important;
  font-weight: 700;
  letter-spacing: 0;
}

.about-hero-modern .about-hero-note {
  max-width: 420px;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 6px;
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(14px);
}

.about-hero-modern .about-hero-note span {
  display: block;
  margin-bottom: 12px;
  color: var(--accent);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.about-hero-modern .about-hero-note p {
  margin: 0 !important;
  color: rgba(255,255,255,.82) !important;
  font-size: 17px !important;
  line-height: 1.55;
}

@media (max-width: 991px) {
  .about-hero-modern.page-hero {
    min-height: 60vh !important;
    height: auto;
    padding: 72px 0 !important;
  }

  .about-hero-modern .about-hero-inner {
    grid-template-columns: 1fr;
    gap: 28px;
    align-items: start;
    padding-top: 0;
  }

  .about-hero-modern .about-hero-note {
    max-width: 560px;
  }
}

@media (max-width: 640px) {
  .about-hero-modern.page-hero {
    min-height: 60vh !important;
    padding: 58px 0 !important;
    background:
      linear-gradient(180deg, rgba(16,42,67,.96) 0%, rgba(16,42,67,.86) 100%),
      url('assets/images/IMG-20260516-WA0011.jpg') center/cover no-repeat !important;
  }

  .about-hero-modern h1 {
    font-size: clamp(32px, 9vw, 40px) !important;
    line-height: 1.06 !important;
  }

  .about-hero-modern .about-hero-note {
    padding: 20px;
  }

  .about-hero-modern .about-hero-note p {
    font-size: 15px !important;
  }
}

/* About story clean upgrade */
.about-story-modern.about-story {
  padding: 78px 0 84px !important;
  background: #f6f4ef;
}

.about-story-modern .about-story-inner {
  display: grid;
  grid-template-columns: minmax(300px, .82fr) minmax(0, 1fr);
  gap: clamp(34px, 5vw, 70px);
  align-items: center;
}

.about-story-modern .about-image {
  position: relative;
}

.about-story-modern .about-image::after {
  content: "";
  position: absolute;
  right: -14px;
  bottom: -14px;
  width: 42%;
  height: 42%;
  border: 1px solid rgba(127,212,242,.55);
  border-radius: 6px;
  z-index: 0;
}

.about-story-modern .about-image img {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 440px !important;
  max-height: 520px;
  object-fit: cover;
  object-position: center;
  border-radius: 6px !important;
  box-shadow: 0 18px 48px rgba(16,42,67,.12) !important;
}

.about-story-modern .about-copy {
  max-width: 720px;
}

.about-story-modern .eyebrow.dark {
  margin: 0 0 14px !important;
  color: var(--navy) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
}

.about-story-modern h2 {
  max-width: 680px;
  color: var(--ink);
  font-size: clamp(32px, 3.4vw, 52px);
  line-height: 1.06;
  font-weight: 700;
}

.about-story-modern .about-copy-text {
  display: grid;
  gap: 14px;
  margin-top: 24px;
  max-width: 680px;
}

.about-story-modern .about-copy-text p {
  margin: 0 !important;
  color: var(--muted) !important;
  font-size: 17px !important;
  line-height: 1.62;
}

.about-story-modern .about-badges {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 28px !important;
}

.about-story-modern .about-badges span {
  min-height: 92px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  padding: 18px !important;
  border: 1px solid rgba(16,42,67,.1) !important;
  border-radius: 6px !important;
  background: rgba(255,255,255,.86) !important;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
  font-weight: 500 !important;
  box-shadow: 0 10px 28px rgba(16,42,67,.06);
}

.about-story-modern .about-badges strong {
  display: block;
  color: var(--navy);
  font-size: 18px;
  line-height: 1;
  font-weight: 750;
}

@media (max-width: 991px) {
  .about-story-modern.about-story {
    padding: 66px 0 72px !important;
  }

  .about-story-modern .about-story-inner {
    grid-template-columns: 1fr;
  }

  .about-story-modern .about-image img {
    min-height: 360px !important;
    max-height: 460px;
  }
}

@media (max-width: 640px) {
  .about-story-modern.about-story {
    padding: 54px 0 60px !important;
  }

  .about-story-modern .about-image::after {
    right: -8px;
    bottom: -8px;
  }

  .about-story-modern .about-image img {
    min-height: 300px !important;
  }

  .about-story-modern h2 {
    font-size: clamp(28px, 7.6vw, 36px);
  }

  .about-story-modern .about-copy-text p {
    font-size: 15.5px !important;
  }

  .about-story-modern .about-badges {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .about-story-modern .about-badges span {
    min-height: auto;
  }
}

/* About story layout ownership fix */
.about-story-modern.about-story {
  display: block !important;
  grid-template-columns: none !important;
  gap: 0 !important;
  align-items: initial !important;
}

.about-story-modern .about-story-inner {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 992px) {
  .about-story-modern .about-story-inner {
    grid-template-columns: minmax(360px, .9fr) minmax(0, 1.1fr);
  }
}

/* About values premium upgrade */
.values-modern.values-band {
  position: relative;
  overflow: hidden;
  padding: 76px 0 84px !important;
  background: linear-gradient(105deg, rgba(16, 42, 67, .96) 0%, rgba(16, 42, 67, .88) 48%, rgba(16, 42, 67, .58) 100%), url('assets/images/IMG-20260516-WA0035.jpg') center/cover no-repeat !important;
  color: var(--white);
  isolation: isolate;
}

.values-modern.values-band::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(139, 210, 236, .15) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, .06) 1px, transparent 1px);
  background-size: 74px 74px;
  mask-image: linear-gradient(90deg, rgba(0,0,0,.52), rgba(0,0,0,.12));
}

.values-modern .values-modern-inner {
  display: grid;
  grid-template-columns: minmax(280px, .78fr) minmax(0, 1.22fr);
  gap: clamp(34px, 5vw, 76px);
  align-items: start;
}

.values-modern .values-intro {
  max-width: 470px;
}

.values-modern .eyebrow.dark {
  margin: 0 0 14px !important;
  color: var(--accent) !important;
  font-size: 12px;
  letter-spacing: .18em;
}

.values-modern h2 {
  margin: 0;
  max-width: 520px;
  color: var(--white);
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.03;
  letter-spacing: 0;
}

.values-modern .values-intro > p {
  margin: 22px 0 0;
  color: rgba(255, 255, 255, .76);
  font-size: 17px;
  line-height: 1.72;
}

.values-modern .values-signal {
  margin-top: 30px;
  padding: 18px 20px;
  border: 1px solid rgba(139, 210, 236, .34);
  border-left: 4px solid var(--accent);
  border-radius: 6px;
  background: rgba(255, 255, 255, .075);
}

.values-modern .values-signal strong {
  display: block;
  color: var(--white);
  font-size: 15px;
  line-height: 1.2;
  margin-bottom: 7px;
}

.values-modern .values-signal span {
  display: block;
  color: rgba(255, 255, 255, .72) !important;
  font-size: 14px;
  line-height: 1.55;
  font-weight: 600 !important;
}

.values-modern .values-modern-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}

.values-modern .values-modern-grid article {
  min-height: 142px;
  display: grid;
  grid-template-columns: 48px 46px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding: 24px !important;
  border: 1px solid rgba(255, 255, 255, .14) !important;
  border-radius: 6px !important;
  background: rgba(255, 255, 255, .088) !important;
  box-shadow: none !important;
  backdrop-filter: blur(14px);
  transition: border-color .2s ease, background .2s ease, transform .2s ease !important;
}

.values-modern .values-modern-grid article:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(139, 210, 236, .56) !important;
  background: rgba(255, 255, 255, .12) !important;
  box-shadow: none !important;
}

.values-modern .values-modern-grid article > span {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  border-radius: 6px;
  background: var(--accent);
  color: var(--navy) !important;
  font-size: 14px;
  font-weight: 900 !important;
  line-height: 1;
}

.values-modern .values-modern-grid i {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  border-radius: 6px;
  background: rgba(255, 255, 255, .12);
  color: var(--accent);
  font-size: 18px;
}

.values-modern .values-modern-grid h3 {
  margin: 0 0 8px !important;
  color: var(--white);
  font-size: 22px !important;
  line-height: 1.18;
  letter-spacing: 0;
}

.values-modern .values-modern-grid p {
  max-width: 620px;
  margin: 0 !important;
  color: rgba(255, 255, 255, .72) !important;
  font-size: 15.5px !important;
  line-height: 1.65;
}

@media (max-width: 991px) {
  .values-modern.values-band {
    padding: 66px 0 72px !important;
  }

  .values-modern .values-modern-inner {
    grid-template-columns: 1fr;
  }

  .values-modern .values-intro {
    max-width: 720px;
  }
}

@media (max-width: 640px) {
  .values-modern.values-band {
    padding: 54px 0 60px !important;
  }

  .values-modern h2 {
    font-size: clamp(29px, 8vw, 38px);
  }

  .values-modern .values-intro > p {
    font-size: 15.5px;
    line-height: 1.65;
  }

  .values-modern .values-signal {
    margin-top: 24px;
    padding: 16px;
  }

  .values-modern .values-modern-grid article {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 14px;
    min-height: auto;
    padding: 18px !important;
  }

  .values-modern .values-modern-grid article > span,
  .values-modern .values-modern-grid i {
    width: 42px;
    height: 42px;
  }

  .values-modern .values-modern-grid i {
    grid-column: 1;
    grid-row: 2;
  }

  .values-modern .values-modern-grid article > div {
    grid-column: 2;
    grid-row: 1 / span 2;
  }

  .values-modern .values-modern-grid h3 {
    font-size: 20px !important;
  }

  .values-modern .values-modern-grid p {
    font-size: 14.5px !important;
  }
}
/* Services hero clean upgrade */
.services-hero-modern.page-hero {
  min-height: 60vh !important;
  height: 60vh;
  max-height: 680px;
  padding: 0 !important;
  display: flex;
  align-items: center;
  color: var(--white) !important;
  background:
    linear-gradient(100deg, rgba(16, 42, 67, .97) 0%, rgba(16, 42, 67, .88) 47%, rgba(16, 42, 67, .58) 100%),
    url('assets/images/IMG-20260516-WA0035.jpg') center/cover no-repeat !important;
  isolation: isolate;
}

.services-hero-modern.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(127, 212, 242, .1), rgba(127, 212, 242, 0) 46%);
  pointer-events: none;
}

.services-hero-modern .services-hero-inner {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(300px, .58fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: end;
  padding-top: 34px;
}

.services-hero-modern .services-hero-copy {
  max-width: 820px;
}

.services-hero-modern .eyebrow {
  margin: 0 0 14px !important;
  color: var(--accent) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
}

.services-hero-modern h1 {
  max-width: 780px !important;
  margin: 0 !important;
  color: var(--white) !important;
  font-size: clamp(40px, 5.2vw, 70px) !important;
  line-height: 1.02 !important;
  font-weight: 700;
  letter-spacing: 0;
}

.services-hero-modern .services-hero-copy > p:not(.eyebrow) {
  max-width: 650px;
  margin: 22px 0 0 !important;
  color: rgba(255, 255, 255, .84) !important;
  font-size: 18px !important;
  line-height: 1.62;
}

.services-hero-modern .services-hero-panel {
  max-width: 430px;
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 6px;
  background: rgba(255, 255, 255, .1);
  backdrop-filter: blur(16px);
}

.services-hero-modern .services-hero-panel > span {
  display: block;
  margin-bottom: 12px;
  color: var(--accent);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.services-hero-modern .services-hero-panel p {
  margin: 0 !important;
  color: rgba(255, 255, 255, .82) !important;
  font-size: 16.5px !important;
  line-height: 1.58;
}

.services-hero-modern .services-hero-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 20px;
}

.services-hero-modern .services-hero-points strong {
  min-height: 38px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(127, 212, 242, .32);
  border-radius: 6px;
  background: rgba(127, 212, 242, .12);
  color: var(--white);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
}

@media (max-width: 991px) {
  .services-hero-modern.page-hero {
    min-height: 60vh !important;
    height: auto;
    padding: 72px 0 !important;
  }

  .services-hero-modern .services-hero-inner {
    grid-template-columns: 1fr;
    gap: 28px;
    align-items: start;
    padding-top: 0;
  }

  .services-hero-modern .services-hero-panel {
    max-width: 560px;
  }
}

@media (max-width: 640px) {
  .services-hero-modern.page-hero {
    min-height: 60vh !important;
    padding: 58px 0 !important;
    background:
      linear-gradient(180deg, rgba(16, 42, 67, .96) 0%, rgba(16, 42, 67, .84) 100%),
      url('assets/images/IMG-20260516-WA0035.jpg') center/cover no-repeat !important;
  }

  .services-hero-modern h1 {
    font-size: clamp(31px, 8.6vw, 40px) !important;
    line-height: 1.07 !important;
  }

  .services-hero-modern .services-hero-copy > p:not(.eyebrow) {
    font-size: 15.5px !important;
    line-height: 1.62;
  }

  .services-hero-modern .services-hero-panel {
    padding: 20px;
  }

  .services-hero-modern .services-hero-panel p {
    font-size: 15px !important;
  }

  .services-hero-modern .services-hero-points {
    grid-template-columns: 1fr;
  }
}
/* Services image gallery upgrade */
.service-gallery-modern {
  padding: 78px 0 84px;
  background: #f6f4ef;
  overflow: hidden;
}

.service-gallery-modern .service-gallery-heading {
  max-width: 820px;
  margin-bottom: 34px;
}

.service-gallery-modern .eyebrow.dark {
  margin: 0 0 12px !important;
  color: var(--navy) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
}

.service-gallery-modern h2 {
  max-width: 780px;
  margin: 0;
  color: var(--ink);
  font-size: clamp(32px, 3.7vw, 54px);
  line-height: 1.04;
  letter-spacing: 0;
}

.service-gallery-modern .service-gallery-heading > p:not(.eyebrow) {
  max-width: 670px;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.68;
}

.service-gallery-modern .service-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.service-gallery-modern .service-gallery-card {
  min-height: 430px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(16, 42, 67, .1);
  border-radius: 6px;
  background: var(--white);
  box-shadow: 0 18px 46px rgba(16, 42, 67, .08);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.service-gallery-modern .service-gallery-card:hover {
  transform: translateY(-5px);
  border-color: rgba(127, 212, 242, .55);
  box-shadow: 0 24px 56px rgba(16, 42, 67, .14);
}

.service-gallery-modern .service-gallery-card-featured {
  grid-column: span 2;
}

.service-gallery-modern .service-gallery-card img {
  width: 100%;
  height: 250px;
  display: block;
  object-fit: cover;
  filter: saturate(.95) contrast(1.02);
  transition: transform .32s ease;
}

.service-gallery-modern .service-gallery-card:hover img {
  transform: scale(1.035);
}

.service-gallery-modern .service-gallery-copy {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 22px;
}

.service-gallery-modern .service-gallery-copy span {
  margin-bottom: 10px;
  color: var(--accent-ink);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.service-gallery-modern .service-gallery-copy h3 {
  margin: 0 0 10px;
  color: var(--ink);
  font-size: 23px;
  line-height: 1.16;
  font-weight: 700;
  letter-spacing: 0;
}

.service-gallery-modern .service-gallery-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.62;
}

@media (max-width: 991px) {
  .service-gallery-modern {
    padding: 66px 0 72px;
  }

  .service-gallery-modern .service-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-gallery-modern .service-gallery-card-featured {
    grid-column: span 2;
  }
}

@media (max-width: 640px) {
  .service-gallery-modern {
    padding: 54px 0 60px;
  }

  .service-gallery-modern h2 {
    font-size: clamp(28px, 7.6vw, 36px);
  }

  .service-gallery-modern .service-gallery-heading > p:not(.eyebrow) {
    font-size: 15.5px;
  }

  .service-gallery-modern .service-gallery-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .service-gallery-modern .service-gallery-card,
  .service-gallery-modern .service-gallery-card-featured {
    grid-column: auto;
    min-height: auto;
  }

  .service-gallery-modern .service-gallery-card img {
    height: 218px;
  }

  .service-gallery-modern .service-gallery-copy {
    padding: 18px;
  }

  .service-gallery-modern .service-gallery-copy h3 {
    font-size: 20px;
  }

  .service-gallery-modern .service-gallery-copy p {
    font-size: 14.5px;
  }
}
/* Services product-only gallery upgrade */
.product-gallery-modern.gallery-band {
  padding: 78px 0 86px !important;
  background: var(--white) !important;
  overflow: hidden;
}

.product-gallery-modern .product-gallery-heading {
  max-width: 760px;
  margin-bottom: 32px;
}

.product-gallery-modern .eyebrow.dark {
  margin: 0 0 12px !important;
  color: var(--navy) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
}

.product-gallery-modern h2 {
  margin: 0;
  max-width: 720px;
  color: var(--ink);
  font-size: clamp(32px, 3.4vw, 50px);
  line-height: 1.05;
  letter-spacing: 0;
}

.product-gallery-modern .product-gallery-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 190px;
  gap: 14px;
}

.product-gallery-modern .product-gallery-item {
  position: relative;
  min-height: 0 !important;
  margin: 0 !important;
  overflow: hidden;
  border-radius: 6px !important;
  background: #eef3f5;
  box-shadow: 0 16px 40px rgba(16, 42, 67, .08);
}

.product-gallery-modern .product-gallery-large {
  grid-column: span 2;
  grid-row: span 2;
}

.product-gallery-modern .product-gallery-wide {
  grid-column: span 2;
}

.product-gallery-modern .product-gallery-tall {
  grid-row: span 2;
}

.product-gallery-modern .product-gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(255, 255, 255, .42);
  border-radius: inherit;
  pointer-events: none;
}

.product-gallery-modern .product-gallery-item img {
  width: 100%;
  height: 100% !important;
  min-height: 0 !important;
  display: block;
  object-fit: cover;
  transition: transform .42s cubic-bezier(.16, 1, .3, 1), filter .42s ease;
}

.product-gallery-modern .product-gallery-item:hover img {
  transform: scale(1.055);
  filter: saturate(1.04) contrast(1.04);
}

@media (max-width: 991px) {
  .product-gallery-modern.gallery-band {
    padding: 66px 0 72px !important;
  }

  .product-gallery-modern .product-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 210px;
  }

  .product-gallery-modern .product-gallery-large,
  .product-gallery-modern .product-gallery-wide {
    grid-column: span 2;
  }
}

@media (max-width: 640px) {
  .product-gallery-modern.gallery-band {
    padding: 54px 0 60px !important;
  }

  .product-gallery-modern h2 {
    font-size: clamp(28px, 7.6vw, 36px);
  }

  .product-gallery-modern .product-gallery-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    gap: 12px;
  }

  .product-gallery-modern .product-gallery-item,
  .product-gallery-modern .product-gallery-large,
  .product-gallery-modern .product-gallery-wide,
  .product-gallery-modern .product-gallery-tall {
    grid-column: auto;
    grid-row: auto;
    aspect-ratio: 1 / .72;
  }
}
/* Contact hero clean upgrade */
.contact-hero-modern.page-hero {
  min-height: 60vh !important;
  height: 60vh;
  max-height: 680px;
  padding: 0 !important;
  display: flex;
  align-items: center;
  color: var(--white) !important;
  background:
    linear-gradient(100deg, rgba(16, 42, 67, .97) 0%, rgba(16, 42, 67, .86) 48%, rgba(16, 42, 67, .56) 100%),
    url('assets/images/IMG-20260516-WA0015.jpg') center/cover no-repeat !important;
  isolation: isolate;
}

.contact-hero-modern.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(127, 212, 242, .1), rgba(127, 212, 242, 0) 46%);
  pointer-events: none;
}

.contact-hero-modern .contact-hero-inner {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(300px, .56fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: end;
  padding-top: 34px;
}

.contact-hero-modern .contact-hero-copy {
  max-width: 820px;
}

.contact-hero-modern .eyebrow {
  margin: 0 0 14px !important;
  color: var(--accent) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
}

.contact-hero-modern h1 {
  max-width: 780px !important;
  margin: 0 !important;
  color: var(--white) !important;
  font-size: clamp(40px, 5.2vw, 70px) !important;
  line-height: 1.02 !important;
  font-weight: 700;
  letter-spacing: 0;
}

.contact-hero-modern .contact-hero-copy > p:not(.eyebrow) {
  max-width: 650px;
  margin: 22px 0 0 !important;
  color: rgba(255, 255, 255, .84) !important;
  font-size: 18px !important;
  line-height: 1.62;
}

.contact-hero-modern .contact-hero-panel {
  max-width: 430px;
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 6px;
  background: rgba(255, 255, 255, .1);
  backdrop-filter: blur(16px);
}

.contact-hero-modern .contact-hero-panel > span {
  display: block;
  margin-bottom: 12px;
  color: var(--accent);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.contact-hero-modern .contact-hero-panel p {
  margin: 0 !important;
  color: rgba(255, 255, 255, .82) !important;
  font-size: 16.5px !important;
  line-height: 1.58;
}

.contact-hero-modern .contact-hero-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 20px;
}

.contact-hero-modern .contact-hero-actions a {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid rgba(127, 212, 242, .36);
  border-radius: 6px;
  background: rgba(127, 212, 242, .13);
  color: var(--white);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}

.contact-hero-modern .contact-hero-actions a:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--navy);
}

.contact-hero-modern .contact-hero-actions i {
  color: inherit;
  font-size: 14px;
}

@media (max-width: 991px) {
  .contact-hero-modern.page-hero {
    min-height: 60vh !important;
    height: auto;
    padding: 72px 0 !important;
  }

  .contact-hero-modern .contact-hero-inner {
    grid-template-columns: 1fr;
    gap: 28px;
    align-items: start;
    padding-top: 0;
  }

  .contact-hero-modern .contact-hero-panel {
    max-width: 560px;
  }
}

@media (max-width: 640px) {
  .contact-hero-modern.page-hero {
    min-height: 60vh !important;
    padding: 58px 0 !important;
    background:
      linear-gradient(180deg, rgba(16, 42, 67, .96) 0%, rgba(16, 42, 67, .84) 100%),
      url('assets/images/IMG-20260516-WA0015.jpg') center/cover no-repeat !important;
  }

  .contact-hero-modern h1 {
    font-size: clamp(31px, 8.6vw, 40px) !important;
    line-height: 1.07 !important;
  }

  .contact-hero-modern .contact-hero-copy > p:not(.eyebrow) {
    font-size: 15.5px !important;
    line-height: 1.62;
  }

  .contact-hero-modern .contact-hero-panel {
    padding: 20px;
  }

  .contact-hero-modern .contact-hero-panel p {
    font-size: 15px !important;
  }

  .contact-hero-modern .contact-hero-actions {
    grid-template-columns: 1fr;
  }
}
/* Contact form modern upgrade */
.contact-form-modern.contact-modern {
  display: block !important;
  padding: 78px 0 86px !important;
  background: #f6f4ef;
}

.contact-form-modern .contact-form-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr);
  gap: 22px;
  align-items: stretch;
}

.contact-form-modern .contact-form-panel,
.contact-form-modern .contact-info-panel {
  border-radius: 6px !important;
  box-shadow: 0 22px 56px rgba(16, 42, 67, .1) !important;
}

.contact-form-modern .contact-form-panel {
  padding: 34px !important;
  border: 1px solid rgba(16, 42, 67, .1) !important;
  background: var(--white) !important;
}

.contact-form-modern .contact-form-heading {
  max-width: 650px;
  margin-bottom: 24px;
}

.contact-form-modern .eyebrow.dark {
  margin: 0 0 12px !important;
  color: var(--navy) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
}

.contact-form-modern h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(32px, 3.5vw, 50px);
  line-height: 1.05;
  letter-spacing: 0;
}

.contact-form-modern .contact-form-heading > p:not(.eyebrow) {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.65;
}

.contact-form-modern .contact-brief-form {
  display: grid !important;
  gap: 16px !important;
  margin-top: 0 !important;
}

.contact-form-modern .form-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px !important;
}

.contact-form-modern .contact-brief-form label {
  display: grid;
  gap: 8px;
  margin: 0;
}

.contact-form-modern .contact-brief-form label span {
  color: var(--ink);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
}

.contact-form-modern .contact-brief-form input,
.contact-form-modern .contact-brief-form textarea {
  width: 100%;
  min-height: 52px !important;
  padding: 14px 15px !important;
  border: 1px solid rgba(16, 42, 67, .14) !important;
  border-radius: 6px !important;
  background: #fbfaf7 !important;
  color: var(--ink) !important;
  font-size: 15px;
  font-weight: 600 !important;
  line-height: 1.4;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.contact-form-modern .contact-brief-form textarea {
  min-height: 170px !important;
  resize: vertical;
}

.contact-form-modern .contact-brief-form input::placeholder,
.contact-form-modern .contact-brief-form textarea::placeholder {
  color: rgba(17, 24, 39, .42);
}

.contact-form-modern .contact-brief-form input:focus,
.contact-form-modern .contact-brief-form textarea:focus {
  outline: 0 !important;
  border-color: var(--accent-strong) !important;
  background: var(--white) !important;
  box-shadow: 0 0 0 4px rgba(127, 212, 242, .22);
}

.contact-form-modern .contact-brief-form .btn {
  width: fit-content;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: 4px;
  padding: 12px 18px !important;
  border-radius: 6px !important;
  font-size: 15px !important;
}

.contact-form-modern .contact-info-panel {
  display: flex !important;
  flex-direction: column;
  gap: 24px !important;
  padding: 30px !important;
  border: 1px solid rgba(255, 255, 255, .12) !important;
  background:
    linear-gradient(150deg, rgba(16, 42, 67, .98), rgba(19, 54, 82, .94)),
    url('assets/images/home-slider2.jpg') center/cover no-repeat !important;
  color: var(--white) !important;
}

.contact-form-modern .contact-info-intro .eyebrow {
  margin: 0 0 12px !important;
  color: var(--accent) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
}

.contact-form-modern .contact-info-intro h3 {
  margin: 0 0 12px !important;
  color: var(--white) !important;
  font-size: 30px !important;
  line-height: 1.08;
  font-weight: 700;
}

.contact-form-modern .contact-info-intro p {
  margin: 0 !important;
  color: rgba(255, 255, 255, .74) !important;
  font-size: 15.5px;
  line-height: 1.65;
}

.contact-form-modern .contact-info-list {
  display: grid;
  gap: 12px;
}

.contact-form-modern .contact-info-list a {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 6px;
  background: rgba(255, 255, 255, .08);
  color: var(--white);
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}

.contact-form-modern .contact-info-list a:hover {
  transform: translateY(-2px);
  border-color: rgba(127, 212, 242, .46);
  background: rgba(255, 255, 255, .12);
  color: var(--white);
}

.contact-form-modern .contact-info-list span {
  width: 46px !important;
  height: 46px !important;
  display: inline-grid !important;
  place-items: center;
  margin: 0 !important;
  border-radius: 6px !important;
  background: var(--accent) !important;
  color: var(--navy) !important;
}

.contact-form-modern .contact-info-list strong {
  display: block;
  margin-bottom: 5px;
  color: var(--white);
  font-size: 15px;
  line-height: 1.15;
}

.contact-form-modern .contact-info-list p {
  margin: 0 !important;
  color: rgba(255, 255, 255, .74) !important;
  font-size: 14.5px;
  line-height: 1.5;
}

@media (max-width: 991px) {
  .contact-form-modern.contact-modern {
    padding: 66px 0 72px !important;
  }

  .contact-form-modern .contact-form-inner {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .contact-form-modern.contact-modern {
    padding: 54px 0 60px !important;
  }

  .contact-form-modern .contact-form-panel,
  .contact-form-modern .contact-info-panel {
    padding: 22px !important;
  }

  .contact-form-modern h2 {
    font-size: clamp(28px, 7.6vw, 36px);
  }

  .contact-form-modern .form-grid {
    grid-template-columns: 1fr;
  }

  .contact-form-modern .contact-brief-form .btn {
    width: 100%;
    justify-content: center;
  }

  .contact-form-modern .contact-info-intro h3 {
    font-size: 25px !important;
  }
}
/* Contact anti-spam field */
.contact-form-modern .form-hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Inner page hero CTA actions */
.inner-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.about-hero-modern .inner-hero-actions .btn,
.services-hero-modern .inner-hero-actions .btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 18px !important;
  border-radius: 6px !important;
  font-size: 15px !important;
  line-height: 1;
}

.about-hero-modern .inner-hero-actions .btn-outline-light,
.services-hero-modern .inner-hero-actions .btn-outline-light {
  border-color: rgba(255, 255, 255, .5) !important;
  color: var(--white) !important;
  background: rgba(255, 255, 255, .08) !important;
}

.about-hero-modern .inner-hero-actions .btn-outline-light:hover,
.services-hero-modern .inner-hero-actions .btn-outline-light:hover,
.about-hero-modern .inner-hero-actions .btn-outline-light:focus,
.services-hero-modern .inner-hero-actions .btn-outline-light:focus {
  background: var(--white) !important;
  border-color: var(--white) !important;
  color: var(--navy) !important;
}

.shared-page-cta.cta-final {
  margin-top: 30px;
}

@media (max-width: 640px) {
  .inner-hero-actions {
    gap: 10px;
    margin-top: 24px;
  }

  .about-hero-modern .inner-hero-actions .btn,
  .services-hero-modern .inner-hero-actions .btn {
    width: 100%;
  }
}
/* Intentional sticky navigation */
header.site-header,
header.site-header.fixed-top,
header.site-header.nav-fixed {
  position: sticky !important;
  top: 0 !important;
  right: auto !important;
  left: auto !important;
  z-index: 1040 !important;
  width: 100% !important;
  background: rgba(246, 244, 239, .92) !important;
  border-bottom: 1px solid rgba(127, 212, 242, .22) !important;
  box-shadow: 0 0 0 rgba(16, 42, 67, 0) !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transition: background-color .28s ease, box-shadow .28s ease, border-color .28s ease, min-height .28s ease, height .28s ease;
}

header.site-header.is-scrolled {
  background: rgba(246, 244, 239, .98) !important;
  border-bottom-color: rgba(127, 212, 242, .38) !important;
  box-shadow: 0 14px 34px rgba(16, 42, 67, .12) !important;
}

header.site-header .navbar-brand img,
header.site-header .nav-link,
header.site-header .nav-cta,
header.site-header .nav-phone,
header.site-header .navbar-toggler {
  transition: transform .28s ease, height .28s ease, padding .28s ease, background-color .28s ease, color .28s ease, box-shadow .28s ease;
}

@media (min-width: 992px) {
  header.site-header.is-scrolled,
  header.site-header.is-scrolled.fixed-top,
  header.site-header.is-scrolled.nav-fixed {
    height: 86px !important;
    min-height: 86px !important;
    max-height: 86px !important;
  }

  header.site-header.is-scrolled .navbar-brand img {
    height: 48px !important;
  }

  header.site-header.is-scrolled .nav-link {
    padding-top: 9px !important;
    padding-bottom: 9px !important;
  }

  header.site-header.is-scrolled .nav-cta {
    min-height: 42px;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
}

@media (max-width: 991px) {
  header.site-header,
  header.site-header.fixed-top,
  header.site-header.nav-fixed {
    min-height: 86px !important;
    max-height: none !important;
  }

  header.site-header.is-scrolled {
    box-shadow: 0 12px 28px rgba(16, 42, 67, .13) !important;
  }

  header.site-header .navbar-collapse {
    box-shadow: 0 22px 46px rgba(16, 42, 67, .16);
  }
}
/* Fixed sticky-top enforcement */
:root {
  --site-header-offset: 100px;
}

body {
  padding-top: var(--site-header-offset) !important;
}

header.site-header,
header.site-header.fixed-top,
header.site-header.nav-fixed {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  left: 0 !important;
  transform: translateY(0);
}

@media (max-width: 991px) {
  :root {
    --site-header-offset: 86px;
  }
}
/* AJAX contact form feedback */
.contact-form-modern .contact-form-status {
  display: none;
  margin: 0 0 18px !important;
  padding: 14px 16px !important;
  border: 1px solid transparent;
  border-radius: 6px !important;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 700;
}

.contact-form-modern .contact-form-status.is-visible {
  display: block;
}

.contact-form-modern .contact-form-status.is-success {
  color: var(--navy);
  border-color: rgba(127, 212, 242, .58);
  background: rgba(127, 212, 242, .18);
}

.contact-form-modern .contact-form-status.is-warning {
  color: #5d4210;
  border-color: rgba(219, 170, 72, .62);
  background: #fff8e6;
}

.contact-form-modern .field-error {
  display: none;
  margin-top: 7px;
  color: #6b4c10;
  font-size: 12.5px;
  line-height: 1.35;
  font-weight: 700;
}

.contact-form-modern [data-field-wrap].has-error .field-error {
  display: block;
}

.contact-form-modern [data-field-wrap].has-error input,
.contact-form-modern [data-field-wrap].has-error textarea {
  border-color: rgba(219, 170, 72, .95) !important;
  background: #fffbf0 !important;
  box-shadow: 0 0 0 4px rgba(219, 170, 72, .16) !important;
}

.contact-form-modern .contact-brief-form.is-submitting .btn,
.contact-form-modern .contact-brief-form .btn:disabled {
  opacity: .82;
  cursor: progress;
  pointer-events: none;
}

/* Dedicated portfolio page */
.portfolio-hero-modern.page-hero {
  min-height: 60vh !important;
  height: 60vh;
  max-height: 680px;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  background: linear-gradient(90deg, rgba(16, 42, 67, .96) 0%, rgba(16, 42, 67, .84) 50%, rgba(16, 42, 67, .62) 100%), url('assets/images/hero-home1.jpg') center/cover no-repeat !important;
}

.portfolio-hero-modern.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(127, 212, 242, .1), rgba(127, 212, 242, 0) 46%);
  pointer-events: none;
}

.portfolio-hero-modern .portfolio-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 410px);
  gap: 42px;
  align-items: center;
}

.portfolio-hero-modern .portfolio-hero-copy h1 {
  max-width: 760px;
  margin: 0;
  color: var(--white) !important;
  font-size: clamp(42px, 5.6vw, 76px) !important;
  line-height: .98;
  font-weight: 700;
}

.portfolio-hero-modern .portfolio-hero-copy > p:not(.eyebrow) {
  max-width: 620px;
  margin: 22px 0 0;
  color: rgba(255, 255, 255, .84) !important;
  font-size: 18px;
  line-height: 1.62;
}

.portfolio-hero-modern .portfolio-hero-panel {
  padding: 26px !important;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 6px !important;
  background: rgba(255, 255, 255, .13);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 22px 52px rgba(0, 0, 0, .18);
}

.portfolio-hero-modern .portfolio-hero-panel span {
  display: block;
  margin-bottom: 12px;
  color: var(--accent) !important;
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.portfolio-hero-modern .portfolio-hero-panel p {
  margin: 0;
  color: rgba(255, 255, 255, .78) !important;
  font-size: 15px;
  line-height: 1.65;
}

.portfolio-hero-modern .portfolio-hero-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 22px;
}

.portfolio-hero-modern .portfolio-hero-points strong {
  min-height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(127, 212, 242, .32);
  border-radius: 6px !important;
  color: var(--white);
  background: rgba(127, 212, 242, .1);
  font-size: 14px;
}

.portfolio-page-section {
  padding: 78px 0 88px;
  background: #f6f4ef;
  overflow: hidden;
}

.portfolio-page-heading {
  max-width: 820px;
  margin-bottom: 34px;
}

.portfolio-page-heading .eyebrow.dark,
.portfolio-proof-band .eyebrow.dark {
  margin: 0 0 12px !important;
  color: var(--navy) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.portfolio-page-heading h2,
.portfolio-proof-copy h2 {
  max-width: 780px;
  margin: 0;
  color: var(--ink);
  font-size: clamp(32px, 3.6vw, 54px);
  line-height: 1.06;
  font-weight: 700;
}

.portfolio-page-heading > p:not(.eyebrow) {
  max-width: 650px;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.62;
}

.portfolio-page-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-rows: 228px;
  gap: 18px;
}

.portfolio-work-card {
  position: relative;
  grid-column: span 4;
  overflow: hidden;
  border: 1px solid rgba(16, 42, 67, .12);
  border-radius: 6px !important;
  background: var(--white);
  box-shadow: 0 18px 42px rgba(16, 42, 67, .08);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.portfolio-work-card:hover {
  transform: translateY(-4px);
  border-color: rgba(127, 212, 242, .55);
  box-shadow: 0 24px 58px rgba(16, 42, 67, .14);
}

.portfolio-work-featured {
  grid-column: span 8;
  grid-row: span 2;
}

.portfolio-work-wide {
  grid-column: span 8;
}

.portfolio-work-card img {
  width: 100%;
  height: 100% !important;
  min-height: 0 !important;
  display: block;
  object-fit: cover;
  transition: transform .28s ease, filter .28s ease;
}

.portfolio-work-card:hover img {
  transform: scale(1.045);
  filter: saturate(1.04) contrast(1.03);
}

.portfolio-work-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(16, 42, 67, 0) 34%, rgba(16, 42, 67, .9) 100%);
  pointer-events: none;
}

.portfolio-work-dark::after {
  background: linear-gradient(180deg, rgba(16, 42, 67, .08) 16%, rgba(16, 42, 67, .94) 100%);
}

.portfolio-work-copy {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  padding: 22px;
}

.portfolio-work-copy span {
  display: block;
  margin-bottom: 8px;
  color: var(--accent) !important;
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.portfolio-work-copy h3 {
  margin: 0;
  color: var(--white) !important;
  font-size: 25px;
  line-height: 1.12;
  font-weight: 700;
}

.portfolio-work-copy p {
  max-width: 560px;
  margin: 10px 0 0;
  color: rgba(255, 255, 255, .76) !important;
  font-size: 14.5px;
  line-height: 1.5;
}

.portfolio-proof-band {
  padding: 72px 0 78px;
  background: var(--white);
}

.portfolio-proof-inner {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  gap: 34px;
  align-items: start;
}

.portfolio-proof-copy h2 {
  font-size: clamp(30px, 3.1vw, 46px);
}

.portfolio-proof-list {
  display: grid;
  gap: 14px;
}

.portfolio-proof-list article {
  padding: 22px;
  border: 1px solid rgba(16, 42, 67, .1);
  border-radius: 6px !important;
  background: #f6f4ef;
  box-shadow: 0 16px 36px rgba(16, 42, 67, .07);
}

.portfolio-proof-list span {
  display: inline-block;
  margin-bottom: 12px;
  color: var(--accent-ink);
  font-size: 13px;
  font-weight: 800;
}

.portfolio-proof-list h3 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 20px;
  line-height: 1.18;
  font-weight: 700;
}

.portfolio-proof-list p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6;
}

@media (max-width: 991px) {
  .portfolio-hero-modern.page-hero {
    height: auto;
    min-height: 60vh !important;
    padding: 72px 0 !important;
  }

  .portfolio-hero-modern .portfolio-hero-inner,
  .portfolio-proof-inner {
    grid-template-columns: 1fr;
  }

  .portfolio-page-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 250px;
  }

  .portfolio-work-card,
  .portfolio-work-featured,
  .portfolio-work-wide {
    grid-column: auto;
    grid-row: auto;
  }

  .portfolio-work-featured {
    grid-column: span 2;
  }
}

@media (max-width: 640px) {
  .portfolio-hero-modern.page-hero {
    padding: 58px 0 !important;
    background: linear-gradient(180deg, rgba(16, 42, 67, .96) 0%, rgba(16, 42, 67, .86) 100%), url('assets/images/hero-home1.jpg') center/cover no-repeat !important;
  }

  .portfolio-hero-modern .portfolio-hero-copy h1 {
    font-size: clamp(36px, 9vw, 43px) !important;
  }

  .portfolio-hero-modern .portfolio-hero-copy > p:not(.eyebrow) {
    font-size: 16px;
    line-height: 1.58;
  }

  .portfolio-hero-modern .portfolio-hero-panel {
    padding: 22px !important;
  }

  .portfolio-hero-modern .portfolio-hero-points {
    grid-template-columns: 1fr;
  }

  .portfolio-page-section,
  .portfolio-proof-band {
    padding: 54px 0 60px;
  }

  .portfolio-page-heading h2,
  .portfolio-proof-copy h2 {
    font-size: clamp(28px, 7.6vw, 36px);
  }

  .portfolio-page-heading > p:not(.eyebrow) {
    font-size: 15.5px;
  }

  .portfolio-page-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    gap: 14px;
  }

  .portfolio-work-card,
  .portfolio-work-featured,
  .portfolio-work-wide {
    min-height: 330px;
    grid-column: auto;
    grid-row: auto;
  }

  .portfolio-work-copy {
    padding: 18px;
  }

  .portfolio-work-copy h3 {
    font-size: 22px;
  }

  .portfolio-work-copy p {
    font-size: 14px;
  }

  .portfolio-proof-list article {
    padding: 19px;
  }
}
/* Portfolio nav fit after adding the dedicated page */
@media (min-width: 992px) and (max-width: 1199px) {
  .site-header .nav-link {
    padding-left: 9px !important;
    padding-right: 9px !important;
    font-size: 13.5px !important;
  }

  .site-header .nav-item.active .nav-link::after,
  .site-header .nav-link:hover::after {
    left: 9px;
    right: 9px;
  }

  .nav-actions {
    gap: 10px !important;
    margin-left: 12px !important;
  }

  .nav-phone {
    font-size: 13px !important;
  }

  .nav-cta {
    padding-left: 13px !important;
    padding-right: 13px !important;
  }
}
/* Intentional polish pass: portfolio filtering and interaction states */
.portfolio-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: end;
}

.portfolio-heading-link {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border: 1px solid rgba(16, 42, 67, .16);
  border-radius: 6px !important;
  color: var(--navy) !important;
  background: rgba(127, 212, 242, .16);
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}

.portfolio-heading-link:hover,
.portfolio-heading-link:focus {
  color: var(--navy) !important;
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-1px);
}

.portfolio-page-heading-row {
  max-width: none !important;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
}

.portfolio-filter-group {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  max-width: 440px;
}

.portfolio-filter-group button {
  min-height: 40px;
  padding: 9px 13px;
  border: 1px solid rgba(16, 42, 67, .14);
  border-radius: 6px !important;
  color: var(--navy);
  background: rgba(255, 255, 255, .72);
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}

.portfolio-filter-group button:hover,
.portfolio-filter-group button:focus,
.portfolio-filter-group button.is-active {
  color: var(--navy);
  border-color: var(--accent);
  background: var(--accent);
  outline: none;
}

.portfolio-filter-group button:hover,
.portfolio-filter-group button:focus {
  transform: translateY(-1px);
}

.portfolio-work-card.is-filtered-out {
  display: none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: 3px solid rgba(127, 212, 242, .55) !important;
  outline-offset: 3px;
}

.btn-style,
.nav-link,
.catalogue-items,
.service-gallery-card,
.portfolio-card,
.portfolio-work-card,
.contact-info-list a {
  -webkit-tap-highlight-color: rgba(127, 212, 242, .22);
}

@media (max-width: 991px) {
  .portfolio-heading,
  .portfolio-page-heading-row {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .portfolio-filter-group {
    justify-content: flex-start;
    max-width: none;
  }
}

@media (max-width: 640px) {
  .portfolio-heading-link {
    width: 100%;
  }

  .portfolio-filter-group {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .portfolio-filter-group button {
    width: 100%;
  }
}
/* New portfolio image placement refinements */
.portfolio-work-card[data-category="apparel"] img,
.portfolio-work-card[data-category="gifting"] img {
  object-position: center center;
}

.portfolio-work-card img[src*="IMG-20260516-WA0035"],
.portfolio-work-card img[src*="IMG-20260516-WA0036"],
.portfolio-work-card img[src*="IMG-20260516-WA0055"] {
  object-position: center top;
}

@media (max-width: 640px) {
  .portfolio-work-card,
  .portfolio-work-featured,
  .portfolio-work-wide {
    min-height: 360px;
  }
}
/* Site-wide new image placement polish */
.about-story-modern .about-image img {
  object-position: center center;
}

.service-gallery-modern .service-gallery-card img[src*="IMG-20260516-WA0031"],
.service-gallery-modern .service-gallery-card img[src*="IMG-20260516-WA0035"],
.service-gallery-modern .service-gallery-card img[src*="IMG-20260516-WA0036"],
.service-gallery-modern .service-gallery-card img[src*="IMG-20260516-WA0049"] {
  object-position: center top;
}

.service-gallery-modern .service-gallery-card img[src*="IMG-20260516-WA0024"],
.service-gallery-modern .service-gallery-card img[src*="IMG-20260516-WA0037"] {
  object-position: center center;
}