:root {
  --navy: #082b59;
  --navy-deep: #041d3e;
  --teal: #087e91;
  --teal-dark: #056275;
  --green: #55b642;
  --sky: #eaf5f7;
  --paper: #fbfcfd;
  --ink: #0d2b4f;
  --muted: #52657a;
  --line: #dce5eb;
  --white: #fff;
  --font-body: "DM Sans", sans-serif;
  --font-display: "Manrope", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--font-body); -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
.container { width: min(1180px, calc(100% - 48px)); margin: 0 auto; }
.section { padding: 112px 0; }

.site-header { position: fixed; z-index: 50; top: 0; left: 0; width: 100%; border-bottom: 1px solid transparent; transition: .3s; }
.site-header.scrolled { border-color: rgba(8,43,89,.08); background: rgba(255,255,255,.94); box-shadow: 0 8px 32px rgba(8,43,89,.08); backdrop-filter: blur(14px); }
.nav-wrap { display: flex; height: 86px; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; }
.brand img { width: 210px; height: 58px; object-fit: contain; object-position: left center; }
.main-nav { display: flex; align-items: center; gap: 30px; font-size: 13px; font-weight: 700; }
.main-nav a:not(.nav-cta):hover { color: var(--teal); }
.nav-cta { padding: 13px 19px; border-radius: 6px; color: white; background: var(--navy); transition: .2s; }
.nav-cta:hover { background: var(--teal-dark); transform: translateY(-1px); }
.menu-toggle { display: none; border: 0; background: none; }

.hero { position: relative; padding-top: 86px; overflow: hidden; background: radial-gradient(circle at 82% 35%, #e8f5f7 0, transparent 35%), linear-gradient(120deg, #fff 55%, #f1f7f9); }
.hero::before { content: ""; position: absolute; top: 130px; right: -100px; width: 550px; height: 550px; border: 1px solid rgba(8,126,145,.12); border-radius: 50%; box-shadow: 0 0 0 80px rgba(8,126,145,.025), 0 0 0 160px rgba(8,126,145,.018); }
.hero-layout { position: relative; display: grid; min-height: 690px; grid-template-columns: .92fr 1.08fr; align-items: center; gap: 60px; padding: 58px 0 45px; }
.eyebrow { display: flex; align-items: center; gap: 10px; color: var(--teal-dark); font-size: 11px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.eyebrow > span { width: 30px; height: 2px; background: var(--green); }
.eyebrow.light { color: #7ee1e5; }
.eyebrow.light > span { background: var(--green); }
h1, h2, h3 { margin-top: 0; font-family: var(--font-display); }
h1 { margin: 20px 0 25px; font-size: clamp(52px, 5.8vw, 80px); line-height: 1.02; letter-spacing: -.055em; }
h1 em, .fulfillment-copy h2 em { color: var(--teal); font-style: normal; }
.hero-subheadline { margin: -10px 0 18px; color: var(--teal); font-family: var(--font-display); font-size: clamp(22px, 2.4vw, 32px); font-weight: 700; letter-spacing: .01em; }
.hero-lead { max-width: 600px; margin: 0; color: var(--muted); font-size: 18px; line-height: 1.72; }
.hero-actions { display: flex; align-items: center; gap: 28px; margin-top: 34px; }
.button { display: inline-flex; min-height: 54px; align-items: center; justify-content: center; gap: 24px; padding: 0 24px; border: 0; border-radius: 6px; cursor: pointer; font-weight: 700; transition: .2s; }
.button:hover { transform: translateY(-2px); }
.button:disabled { cursor: wait; opacity: .68; transform: none; }
.button-primary { color: white; background: var(--navy); box-shadow: 0 13px 28px rgba(8,43,89,.18); }
.button-primary:hover { background: var(--teal-dark); }
.button-secondary { border: 1px solid var(--navy); color: var(--navy); background: white; }
.button-secondary:hover { color: white; background: var(--navy); }
.text-link { padding-bottom: 4px; border-bottom: 1px solid #9aabb7; font-size: 13px; font-weight: 700; }
.trust-row { display: flex; gap: 24px; margin-top: 43px; }
.trust-item { padding-right: 24px; border-right: 1px solid var(--line); }
.trust-item:last-child { border: 0; }
.trust-item strong, .trust-item span { display: block; }
.trust-item strong { margin-bottom: 4px; font-size: 13px; }
.trust-item span { color: #657689; font-size: 10px; }
.hero-photo { position: relative; overflow: hidden; border-radius: 0 0 90px 0; box-shadow: 0 30px 75px rgba(8,43,89,.16); }
.hero-photo img { width: 100%; min-height: 545px; object-fit: cover; object-position: center; }
.photo-badge { position: absolute; bottom: 22px; left: 22px; display: flex; align-items: center; gap: 12px; padding: 13px 17px; border: 1px solid rgba(255,255,255,.6); border-radius: 8px; background: rgba(255,255,255,.93); box-shadow: 0 12px 30px rgba(8,43,89,.13); backdrop-filter: blur(8px); }
.photo-badge > span { display: grid; width: 35px; height: 35px; place-items: center; border-radius: 50%; color: white; background: var(--teal); }
.photo-badge strong, .photo-badge small { display: block; }
.photo-badge strong { font-size: 12px; }
.photo-badge small { margin-top: 2px; color: var(--muted); font-size: 10px; }
.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 75px; margin-bottom: 60px; }
.section-heading h2, .story-copy h2, .fulfillment-copy h2, .contact-copy h2 { margin: 17px 0 0; font-size: clamp(40px, 4.8vw, 62px); line-height: 1.08; letter-spacing: -.045em; }
.section-heading > p { max-width: 490px; margin: 0 0 4px; color: var(--muted); font-size: 16px; line-height: 1.75; }
.about { background: white; }
.about-layout { display: grid; grid-template-columns: .82fr 1.18fr; gap: 100px; align-items: start; }
.about-heading h2 { margin: 17px 0 0; font-size: clamp(40px, 4.8vw, 62px); line-height: 1.08; letter-spacing: -.045em; }
.about-image { margin-top: 34px; overflow: hidden; border-radius: 8px 45px 8px 8px; box-shadow: 0 18px 42px rgba(8,43,89,.1); }
.about-image img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; }
.about-copy { padding-top: 28px; }
.about-brand-lockup { width: min(240px, 66%); height: auto; margin: 0 0 26px; }
.about-copy > p { color: var(--muted); font-size: 15px; line-height: 1.78; }
.about-copy .about-lead { margin-top: 0; color: var(--ink); font-family: var(--font-display); font-size: 21px; font-weight: 600; line-height: 1.55; }
.audience-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 35px; }
.audience-grid div { padding: 20px 17px; border: 1px solid var(--line); border-radius: 8px; background: #f8fbfc; }
.audience-grid strong, .audience-grid span { display: block; }
.audience-grid strong { margin-bottom: 8px; color: var(--teal-dark); font-size: 12px; }
.audience-grid span { color: var(--muted); font-size: 11px; line-height: 1.55; }
.value-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.trust-grid { grid-template-columns: repeat(5, 1fr); }
.value-card { min-height: 330px; padding: 28px; border: 1px solid var(--line); border-radius: 10px; background: white; box-shadow: 0 8px 25px rgba(8,43,89,.035); transition: .25s; }
.value-card:hover { transform: translateY(-7px); box-shadow: 0 22px 45px rgba(8,43,89,.09); }
.value-card.featured { color: white; border-color: var(--navy); background: linear-gradient(145deg, var(--navy), #064863); }
.card-number { color: #8996a5; font-size: 10px; font-weight: 700; }
.featured .card-number { color: #79d7df; }
.feature-icon { display: grid; width: 53px; height: 53px; margin: 58px 0 25px; place-items: center; border: 1px solid #abd0d7; border-radius: 50%; color: var(--teal); font-size: 23px; }
.featured .feature-icon { border-color: #4a8fa4; color: #7ee1e5; }
.value-card h3 { margin-bottom: 13px; font-size: 19px; }
.value-card p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.72; }
.featured p { color: #b6cfda; }

.image-story { background: #f0f6f8; }
.story-layout, .fulfillment-layout { display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 85px; }
.story-photo, .fulfillment-photo { overflow: hidden; border-radius: 0 70px 0 0; box-shadow: 0 24px 60px rgba(8,43,89,.13); }
.story-photo img, .fulfillment-photo img { width: 100%; min-height: 530px; object-fit: cover; }
.story-copy h2 { margin-bottom: 22px; }
.story-copy > p, .fulfillment-copy > p { color: var(--muted); font-size: 16px; line-height: 1.75; }
.check-list { margin: 35px 0 0; padding: 0; list-style: none; }
.check-list li { display: grid; grid-template-columns: 38px 1fr; gap: 14px; padding: 18px 0; border-top: 1px solid #d2e1e5; }
.check-list li > span { display: grid; width: 31px; height: 31px; place-items: center; border-radius: 50%; color: white; background: var(--teal); font-size: 12px; }
.check-list strong, .check-list small { display: block; }
.check-list strong { margin-bottom: 5px; font-size: 14px; }
.check-list small { color: var(--muted); line-height: 1.55; }

.capabilities { color: white; background: var(--navy-deep); }
.capability-heading { display: flex; align-items: end; justify-content: space-between; gap: 60px; margin-bottom: 60px; }
.capability-heading h2 { max-width: 850px; margin: 17px 0 0; font-size: clamp(39px, 4.7vw, 60px); line-height: 1.08; letter-spacing: -.045em; }
.capability-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(255,255,255,.14); border-left: 1px solid rgba(255,255,255,.14); }
.capability-item { min-height: 260px; padding: 32px; border-right: 1px solid rgba(255,255,255,.14); border-bottom: 1px solid rgba(255,255,255,.14); transition: background .2s; }
.capability-item:hover { background: rgba(8,126,145,.15); }
.capability-item > span { color: #63d5dc; font-size: 10px; font-weight: 700; }
.capability-item h3 { margin: 55px 0 13px; font-size: 20px; }
.capability-item p { margin: 0; color: #9db4c5; font-size: 13px; line-height: 1.72; }

.fulfillment-layout { grid-template-columns: .85fr 1.15fr; }
.fulfillment-photo { order: 2; border-radius: 70px 0 0 0; }
.fulfillment-copy h2 { margin-bottom: 22px; }
.mini-features { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 35px; }
.mini-features div { display: flex; align-items: center; gap: 11px; padding: 14px; border: 1px solid var(--line); border-radius: 7px; background: white; font-size: 12px; }
.mini-features span { display: grid; width: 28px; height: 28px; place-items: center; border-radius: 50%; color: var(--teal); background: var(--sky); }

.partners { color: white; background: var(--navy-deep); }
.partners-layout { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 85px; }
.partners-copy h2 { margin: 17px 0 22px; font-size: clamp(40px, 4.8vw, 62px); line-height: 1.08; letter-spacing: -.045em; }
.partners-copy p { max-width: 580px; margin: 0 0 32px; color: #aec2d0; font-size: 16px; line-height: 1.78; }
.partners-copy .partners-detail { margin-top: -16px; color: #a8becb; font-size: 13px; }
.button-light { color: var(--navy-deep); background: #75d9df; }
.button-light:hover { background: white; }
.partners-image { overflow: hidden; border-radius: 70px 0 0 0; box-shadow: 0 24px 65px rgba(0,0,0,.22); }
.partners-image img { width: 100%; min-height: 470px; object-fit: cover; }

.brand-gallery { overflow: hidden; padding-top: 30px; background: white; }
.gallery-heading { display: flex; align-items: end; justify-content: space-between; gap: 70px; margin-bottom: 42px; }
.gallery-heading h2 { margin: 17px 0 0; font-size: clamp(40px, 4.8vw, 60px); line-height: 1.08; letter-spacing: -.045em; }
.gallery-heading > p { max-width: 500px; margin: 0; color: var(--muted); font-size: 15px; line-height: 1.72; }
.gallery-track { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(310px, 35vw); gap: 18px; overflow-x: auto; padding: 5px 2px 22px; scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: #9eb8c2 #edf3f5; }
.gallery-card { position: relative; height: 310px; margin: 0; overflow: hidden; border-radius: 10px; background: #eaf1f4; box-shadow: 0 12px 28px rgba(8,43,89,.08); scroll-snap-align: start; }
.gallery-card.gallery-wide { grid-auto-columns: minmax(380px, 43vw); }
.gallery-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.gallery-card:hover img { transform: scale(1.025); }
.gallery-card::after { content: ""; position: absolute; inset: 45% 0 0; background: linear-gradient(transparent, rgba(4,29,62,.8)); pointer-events: none; }
.gallery-card figcaption { position: absolute; z-index: 2; right: 20px; bottom: 18px; left: 20px; color: white; font-family: var(--font-display); font-size: 14px; font-weight: 700; }
.gallery-hint { margin: 13px 0 0; color: #8494a3; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-align: right; text-transform: uppercase; }

.process { background: #f1f5f7; }
.section-heading.compact { margin-bottom: 70px; }
.process-grid { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); }
.process-grid::before { content: ""; position: absolute; top: 38px; right: 20px; left: 20px; height: 1px; background: #b9cbd3; }
.process-step { position: relative; padding-right: 38px; }
.process-step > span { display: block; margin-bottom: 20px; color: var(--teal); font-size: 10px; font-weight: 700; }
.process-step i { position: relative; z-index: 2; display: block; width: 13px; height: 13px; margin-bottom: 34px; border: 3px solid #f1f5f7; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 1px var(--green); }
.process-step h3 { margin-bottom: 11px; font-size: 19px; }
.process-step p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.7; }

.brand-banner { position: relative; min-height: 500px; overflow: hidden; color: white; background: linear-gradient(125deg, #041d3e 0%, #083a62 62%, #087e91 100%); }
.brand-banner::before { content: ""; position: absolute; top: -210px; right: -100px; width: 620px; height: 620px; border: 1px solid rgba(255,255,255,.13); border-radius: 50%; box-shadow: 0 0 0 85px rgba(255,255,255,.025), 0 0 0 170px rgba(255,255,255,.018); }
.brand-banner::after { content: ""; position: absolute; right: 11%; bottom: 19%; width: 90px; height: 4px; border-radius: 5px; background: var(--green); box-shadow: 115px 0 0 rgba(117,217,223,.65); }
.brand-banner-copy { position: relative; z-index: 2; display: flex; min-height: 500px; flex-direction: column; justify-content: center; }
.brand-banner-copy span { color: #70d5dc; font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.brand-banner-copy h2 { max-width: 620px; margin: 16px 0; font-size: clamp(42px, 5vw, 64px); line-height: 1.05; letter-spacing: -.05em; }
.brand-banner-copy p { max-width: 520px; margin: 0; color: #c0d2de; font-size: 17px; line-height: 1.7; }

.faq { background: #f1f5f7; }
.faq-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 90px; align-items: start; }
.faq-heading { position: sticky; top: 120px; }
.faq-heading h2 { margin: 17px 0 20px; font-size: clamp(40px, 4.8vw, 60px); line-height: 1.08; letter-spacing: -.045em; }
.faq-heading p { max-width: 400px; color: var(--muted); line-height: 1.7; }
.faq-list { border-top: 1px solid #cbd8df; }

.contact-layout { display: grid; grid-template-columns: .9fr 1.1fr; gap: 100px; }
.contact-copy h2 { margin-bottom: 22px; }
.contact-copy > p { color: var(--muted); font-size: 16px; line-height: 1.75; }
.contact-image { margin-top: 27px; overflow: hidden; border-radius: 8px 45px 8px 8px; box-shadow: 0 18px 42px rgba(8,43,89,.09); }
.contact-image img { width: 100%; height: auto; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; }
.contact-assurance { margin-top: 30px; padding: 20px; border-left: 3px solid var(--green); background: #eff7f6; }
.contact-assurance strong, .contact-assurance span { display: block; }
.contact-assurance strong { margin-bottom: 5px; font-size: 13px; }
.contact-assurance span { color: var(--muted); font-size: 12px; line-height: 1.55; }
.business-identity { margin: 26px 0 0; border-top: 1px solid var(--line); }
.business-identity div { display: grid; grid-template-columns: 130px 1fr; gap: 18px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.business-identity dt { color: #66778a; font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.business-identity dd { margin: 0; color: var(--ink); font-size: 13px; font-weight: 700; }
.contact-detail { margin-top: 36px; padding-top: 22px; border-top: 1px solid var(--line); }
.contact-detail span, .contact-detail a { display: block; }
.contact-detail span { margin-bottom: 7px; color: #66778a; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }
.contact-detail a { font-size: 17px; font-weight: 700; }
.contact-detail a + a { margin-top: 6px; }
.contact-form { padding: 38px; border: 1px solid var(--line); border-radius: 10px; background: white; box-shadow: 0 25px 65px rgba(8,43,89,.09); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact-form label { display: block; margin-bottom: 18px; color: #4d6077; font-size: 11px; font-weight: 700; }
.contact-form input, .contact-form textarea { width: 100%; margin-top: 7px; padding: 13px 0; border: 0; border-bottom: 1px solid #cbd7de; outline: 0; color: var(--ink); background: transparent; font-size: 13px; resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--teal); }
.contact-form input:focus-visible, .contact-form textarea:focus-visible, .button:focus-visible, a:focus-visible, button:focus-visible { outline: 3px solid rgba(8,126,145,.28); outline-offset: 3px; }
.contact-form .field-error { border-color: #b33a3a; }
.consent-field { display: flex !important; align-items: flex-start; gap: 10px; font-weight: 400 !important; line-height: 1.5; }
.consent-field input { flex: 0 0 auto; width: 15px; height: 15px; margin: 2px 0 0; accent-color: var(--teal); }
.consent-field a { color: var(--teal-dark); font-weight: 700; text-decoration: underline; }
.submit-button { width: 100%; }
.form-honeypot { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.form-note { margin: 13px 0 0; color: #5f7184; font-size: 10px; line-height: 1.55; text-align: center; }
.form-status { min-height: 18px; margin: 13px 0 0; color: var(--teal-dark); font-size: 12px; text-align: center; }
.form-status.error { color: #a12d2d; }

.legal-summary { padding: 32px 0; color: white; background: #082749; }
.legal-summary-layout { display: grid; grid-template-columns: 1fr 1fr auto; align-items: center; gap: 35px; }
.legal-summary-layout div { padding-left: 18px; border-left: 2px solid var(--teal); }
.legal-summary-layout strong, .legal-summary-layout span { display: block; }
.legal-summary-layout strong { margin-bottom: 4px; font-size: 13px; }
.legal-summary-layout span { color: #91a9ba; font-size: 11px; }
.legal-summary-layout > a { color: #77dae0; font-size: 12px; font-weight: 700; }

footer { padding: 58px 0 25px; color: #c1cfda; background: #03162f; }
.footer-top { display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: start; padding-bottom: 42px; }
.footer-brand img { width: 68px; height: 64px; filter: none; opacity: .96; }
.footer-top > p { margin: 5px 0; color: #a4b7c6; font-size: 13px; line-height: 1.6; }
.footer-links { display: flex; justify-content: flex-end; gap: 24px; font-size: 12px; }
.footer-links a:hover, .legal-links a:hover, .cookie-settings:hover { color: #70d5dc; }
.legal-links { display: flex; flex-wrap: wrap; gap: 12px 24px; padding: 21px 0; border-top: 1px solid rgba(255,255,255,.1); font-size: 11px; }
.legal-links a, .cookie-settings { color: #a4b7c6; }
.cookie-settings { border: 0; padding: 0; background: none; cursor: pointer; font: inherit; }
.footer-bottom { display: block; max-width: 980px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.1); color: #a4b7c6; font-size: 11.5px; line-height: 1.65; }

.cookie-banner { position: fixed; z-index: 100; right: 24px; bottom: 24px; left: 24px; display: flex; max-width: 850px; margin: auto; align-items: center; justify-content: space-between; gap: 30px; padding: 21px 23px; border: 1px solid rgba(255,255,255,.12); border-radius: 8px; color: white; background: #041d3e; box-shadow: 0 22px 60px rgba(4,29,62,.3); }
.cookie-banner[hidden] { display: none; }
.cookie-banner strong { display: block; margin-bottom: 5px; font-family: var(--font-display); }
.cookie-banner p { margin: 0; color: #aec0ce; font-size: 12px; line-height: 1.5; }
.cookie-actions { display: flex; flex: 0 0 auto; gap: 9px; }
.cookie-button { min-height: 39px; padding: 0 15px; border: 1px solid #71899a; border-radius: 4px; color: white; background: transparent; cursor: pointer; font-size: 11px; font-weight: 700; }
.cookie-accept { border-color: #63d5dc; color: var(--navy-deep); background: #63d5dc; }

.legal-page { background: var(--paper); }
.legal-header { position: static; border-bottom: 1px solid var(--line); background: white; }
.legal-header .nav-wrap { height: 78px; }
.back-link { color: var(--teal-dark); font-size: 12px; font-weight: 700; }
.legal-hero { padding: 85px 0 52px; background: linear-gradient(135deg, #f4f8fa, #eaf5f7); }
.legal-hero h1 { max-width: 850px; margin: 18px 0 16px; font-size: clamp(43px, 6vw, 70px); }
.legal-hero p { max-width: 720px; margin: 0; color: var(--muted); font-size: 16px; line-height: 1.7; }
.legal-updated { display: block; margin-top: 23px; color: #5f7184; font-size: 11px; }
.legal-content { display: grid; grid-template-columns: 250px 1fr; gap: 80px; padding: 72px 0 105px; }
.legal-nav { position: sticky; top: 30px; align-self: start; padding: 24px; border: 1px solid var(--line); border-radius: 7px; background: white; }
.legal-nav strong { display: block; margin-bottom: 14px; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.legal-nav a { display: block; padding: 8px 0; color: #52657a; font-size: 12px; }
.legal-nav a:hover { color: var(--teal); }
.legal-copy { max-width: 760px; }
.legal-copy section { scroll-margin-top: 30px; margin-bottom: 46px; }
.legal-copy h2 { margin-bottom: 14px; font-size: 26px; letter-spacing: -.025em; }
.legal-copy h3 { margin: 24px 0 10px; font-size: 16px; }
.legal-copy p, .legal-copy li { color: #4e6074; font-size: 14px; line-height: 1.8; }
.legal-copy ul { padding-left: 20px; }
.legal-copy a { color: var(--teal-dark); text-decoration: underline; text-underline-offset: 3px; }
.legal-note { padding: 19px 21px; border-left: 3px solid var(--teal); background: #edf6f7; }
.placeholder-note { padding: 17px 19px; border: 1px dashed #c19b48; color: #72571e !important; background: #fff9ea; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 1000px) {
  .main-nav { gap: 18px; }
  .hero-layout { grid-template-columns: 1fr; padding-top: 95px; }
  .hero-photo { max-width: 760px; }
  .value-grid, .trust-grid { grid-template-columns: 1fr 1fr; }
  .story-layout, .fulfillment-layout, .contact-layout, .partners-layout, .faq-layout { grid-template-columns: 1fr; gap: 65px; }
  .about-layout { grid-template-columns: 1fr; gap: 35px; }
  .story-photo, .fulfillment-photo { order: initial; }
  .capability-grid { grid-template-columns: 1fr 1fr; }
  .faq-heading { position: static; }
}

@media (max-width: 760px) {
  .container { width: min(100% - 32px, 1180px); }
  .section { padding: 80px 0; }
  .nav-wrap { height: 72px; }
  .brand img { width: 176px; height: 48px; }
  .menu-toggle { display: block; padding: 8px; }
  .menu-toggle span { display: block; width: 24px; height: 2px; margin: 6px 0; background: var(--navy); }
  .main-nav { position: absolute; top: 72px; right: 16px; left: 16px; display: none; align-items: stretch; flex-direction: column; gap: 0; padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: white; box-shadow: 0 20px 45px rgba(8,43,89,.14); }
  .main-nav.open { display: flex; }
  .main-nav a { padding: 13px; }
  .nav-cta { text-align: center; }
  .hero { padding-top: 72px; }
  .hero-layout { min-height: auto; padding: 80px 0 45px; }
  h1 { font-size: 50px; }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .trust-row { flex-wrap: wrap; }
  .trust-item { width: calc(50% - 12px); }
  .hero-photo img { min-height: 420px; }
  .section-heading, .capability-heading { align-items: flex-start; flex-direction: column; gap: 24px; margin-bottom: 42px; }
  .about-heading h2 { font-size: 40px; }
  .about-copy { padding-top: 0; }
  .audience-grid { grid-template-columns: 1fr; }
  .gallery-heading { align-items: flex-start; flex-direction: column; gap: 20px; }
  .section-heading h2, .story-copy h2, .fulfillment-copy h2, .contact-copy h2 { font-size: 40px; }
  .value-grid, .trust-grid, .capability-grid { grid-template-columns: 1fr; }
  .value-card { min-height: 285px; }
  .feature-icon { margin-top: 38px; }
  .story-photo img, .fulfillment-photo img { min-height: 380px; }
  .capability-item { min-height: 230px; }
  .capability-item h3 { margin-top: 40px; }
  .mini-features { grid-template-columns: 1fr; }
  .partners-image img { min-height: 360px; }
  .gallery-track { grid-auto-columns: 88%; }
  .gallery-card { height: 255px; }
  .process-grid { grid-template-columns: 1fr; gap: 38px; }
  .process-grid::before { top: 0; bottom: 0; left: 5px; width: 1px; height: auto; }
  .process-step { padding-left: 34px; }
  .process-step > span { margin-bottom: 8px; }
  .process-step i { position: absolute; top: 2px; left: 0; }
  .brand-banner, .brand-banner-copy { min-height: 450px; }
  .brand-banner::after { right: 20px; bottom: 40px; }
  .field-row { grid-template-columns: 1fr; gap: 0; }
  .business-identity div { grid-template-columns: 110px 1fr; }
  .contact-form { padding: 27px 21px; }
  .legal-summary-layout { grid-template-columns: 1fr; gap: 22px; }
  .footer-top { grid-template-columns: 1fr; gap: 30px; }
  .footer-links { justify-content: flex-start; }
  .footer-bottom { align-items: flex-start; flex-direction: column; gap: 9px; }
  .cookie-banner { right: 12px; bottom: 12px; left: 12px; align-items: stretch; flex-direction: column; gap: 17px; }
  .cookie-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .legal-content { grid-template-columns: 1fr; gap: 38px; padding-top: 48px; }
  .legal-nav { position: static; }
  .legal-hero { padding: 62px 0 43px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* Motion and interaction refinements */
html { scroll-padding-top: 105px; }
section[id] { scroll-margin-top: 105px; }

.site-header {
  transition: background-color .28s ease, border-color .28s ease, box-shadow .28s ease, backdrop-filter .28s ease;
}

.main-nav a:not(.nav-cta) {
  position: relative;
  padding: 8px 0;
  transition: color .2s ease;
}

.main-nav a:not(.nav-cta)::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 1px;
  left: 0;
  height: 2px;
  border-radius: 2px;
  background: var(--teal);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .22s ease;
}

.main-nav a:not(.nav-cta):hover,
.main-nav a:not(.nav-cta).active { color: var(--teal-dark); }

.main-nav a:not(.nav-cta):hover::after,
.main-nav a:not(.nav-cta).active::after {
  transform: scaleX(1);
  transform-origin: left;
}

.button {
  transition: color .2s ease, background-color .2s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.button > span { transition: transform .2s ease; }
.button:hover > span { transform: translateX(4px); }

.hero-photo img,
.about-image img,
.story-photo img,
.fulfillment-photo img,
.partners-image img,
.contact-image img {
  transition: transform .3s ease;
}

.hero-photo:hover img { transform: scale(1.015); }
.about-image:hover img,
.story-photo:hover img,
.fulfillment-photo:hover img,
.partners-image:hover img,
.contact-image:hover img { transform: scale(1.02); }

.audience-grid div,
.mini-features div {
  transition: border-color .25s ease, background-color .25s ease, box-shadow .25s ease, transform .25s ease;
}

.audience-grid div:hover,
.mini-features div:hover {
  border-color: #bfd9de;
  background: white;
  box-shadow: 0 14px 30px rgba(8,43,89,.07);
  transform: translateY(-5px);
}

.value-card {
  transition: border-color .25s ease, background-color .25s ease, box-shadow .25s ease, transform .25s ease;
}

.value-card:hover {
  border-color: #bfd9de;
  transform: translateY(-6px);
}

.capability-item {
  transition: border-color .25s ease, background-color .25s ease, box-shadow .25s ease, transform .25s ease;
}

.capability-item:hover {
  border-color: rgba(117,217,223,.25);
  box-shadow: inset 0 0 0 1px rgba(117,217,223,.08);
  transform: translateY(-5px);
}

.faq-item {
  border-bottom: 1px solid #cbd8df;
  transition: background-color .25s ease;
}

.faq-item h3 { margin: 0; }
.faq-item.is-open { background: rgba(255,255,255,.48); }

.faq-question {
  position: relative;
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  gap: 25px;
  padding: 24px 5px 24px 0;
  border: 0;
  color: var(--ink);
  background: transparent;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
}

.faq-question > span {
  position: relative;
  flex: 0 0 22px;
  width: 22px;
  height: 22px;
  transition: transform .28s ease;
}

.faq-question > span::before,
.faq-question > span::after {
  content: "";
  position: absolute;
  top: 10px;
  left: 3px;
  width: 16px;
  height: 2px;
  border-radius: 2px;
  background: var(--teal);
}

.faq-question > span::after { transform: rotate(90deg); }
.faq-question[aria-expanded="true"] > span { transform: rotate(45deg); }

.faq-answer {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transition: grid-template-rows .3s ease, opacity .25s ease;
}

.faq-answer > div { overflow: hidden; }

.faq-answer p {
  margin: -3px 45px 24px 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.75;
}

.faq-item.is-open .faq-answer {
  grid-template-rows: 1fr;
  opacity: 1;
}

.faq-question:focus-visible {
  outline: 3px solid rgba(8,126,145,.28);
  outline-offset: 4px;
}

.contact-form input,
.contact-form textarea {
  transition: border-color .2s ease, box-shadow .2s ease;
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--teal);
  box-shadow: 0 1px 0 var(--teal);
}

.contact-form .field-error {
  border-color: #b33a3a;
  box-shadow: 0 1px 0 #b33a3a;
}

.field-message {
  display: block;
  min-height: 15px;
  margin-top: 5px;
  color: #a12d2d;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.4;
}

.consent-message { margin: -12px 0 15px 25px; }

.submit-button.is-loading::before {
  content: "";
  width: 15px;
  height: 15px;
  border: 2px solid rgba(255,255,255,.42);
  border-top-color: white;
  border-radius: 50%;
  animation: button-spin .7s linear infinite;
}

.submit-button.is-success {
  background: #267a45;
  box-shadow: 0 12px 28px rgba(38,122,69,.2);
}

.submit-button.is-error {
  background: #9c3434;
  box-shadow: 0 12px 28px rgba(156,52,52,.18);
}

@keyframes button-spin { to { transform: rotate(360deg); } }

.form-status {
  transition: color .2s ease, opacity .2s ease, transform .2s ease;
}

.form-status:not(:empty) { animation: status-enter .3s ease both; }
@keyframes status-enter { from { opacity: 0; transform: translateY(5px); } }

.footer-links a,
.legal-links a,
.cookie-settings { transition: color .2s ease; }

.smooth-transition { transition: all .25s ease; }

.fade-up,
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .62s cubic-bezier(.22,.61,.36,1), transform .62s cubic-bezier(.22,.61,.36,1);
  transition-delay: var(--reveal-delay, 0ms);
}

.fade-in {
  opacity: 0;
  transition: opacity .6s ease;
  transition-delay: var(--reveal-delay, 0ms);
}

.scale-in {
  opacity: 0;
  transform: scale(.985);
  transition: opacity .65s ease, transform .65s cubic-bezier(.22,.61,.36,1);
  transition-delay: var(--reveal-delay, 0ms);
}

.fade-up.visible,
.fade-in.visible,
.scale-in.visible,
.reveal.visible {
  opacity: 1;
  transform: none;
}

.stagger-item { transition-delay: var(--reveal-delay, 0ms); }

.hover-lift {
  transition: border-color .25s ease, background-color .25s ease, box-shadow .25s ease, transform .25s ease;
}

.js .hero-entrance > *,
.js .hero-image-entrance {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .62s cubic-bezier(.22,.61,.36,1), transform .62s cubic-bezier(.22,.61,.36,1);
}

.js.page-ready .hero-entrance > *,
.js.page-ready .hero-image-entrance {
  opacity: 1;
  transform: none;
}

.js.page-ready .hero-entrance .eyebrow { transition-delay: 60ms; }
.js.page-ready .hero-entrance h1 { transition-delay: 130ms; }
.js.page-ready .hero-entrance .hero-subheadline { transition-delay: 190ms; }
.js.page-ready .hero-entrance .hero-lead { transition-delay: 250ms; }
.js.page-ready .hero-entrance .hero-actions { transition-delay: 340ms; }
.js.page-ready .hero-entrance .trust-row { transition-delay: 430ms; }
.js .hero-image-entrance { transform: scale(.985); }
.js.page-ready .hero-image-entrance { transition-delay: 210ms; }

@media (hover: none) {
  .hero-photo:hover img,
  .about-image:hover img,
  .story-photo:hover img,
  .fulfillment-photo:hover img,
  .partners-image:hover img,
  .contact-image:hover img,
  .audience-grid div:hover,
  .mini-features div:hover,
  .value-card:hover,
  .capability-item:hover {
    transform: none;
  }
}

/* Readability, contrast, and narrow-screen safeguards */
h1, h2, h3,
.contact-detail a,
.legal-copy a,
.footer-bottom,
.footer-links a,
.legal-links a {
  overflow-wrap: anywhere;
}

.button-primary,
.submit-button.is-loading,
.submit-button.is-success,
.submit-button.is-error {
  color: #fff;
}

.button-primary:hover { background: #045467; }
.button-secondary:hover { border-color: var(--navy); }
.button-light { color: #041d3e; background: #83e2e7; }
.button-light:hover { color: #041d3e; background: #fff; }

.footer-links a:hover,
.legal-links a:hover,
.cookie-settings:hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}

@media (max-width: 760px) {
  .hero-layout { gap: 42px; padding-top: 68px; }
  h1 { font-size: clamp(42px, 13vw, 50px); }
  .about-heading h2,
  .section-heading h2,
  .story-copy h2,
  .fulfillment-copy h2,
  .contact-copy h2,
  .capability-heading h2,
  .partners-copy h2,
  .faq-heading h2,
  .brand-banner-copy h2 {
    font-size: clamp(34px, 10vw, 40px);
    letter-spacing: -.035em;
  }
  .hero-lead,
  .section-heading > p,
  .story-copy > p,
  .fulfillment-copy > p,
  .partners-copy p,
  .contact-copy > p,
  .legal-hero p {
    font-size: 15px;
  }
  .hero-actions { width: 100%; gap: 14px; }
  .hero-actions .button { width: 100%; }
  .about-brand-lockup { width: min(205px, 58%); margin-bottom: 22px; }
  .hero-photo img { min-height: 340px; }
  .photo-badge { right: 14px; bottom: 14px; left: 14px; }
  .story-photo img,
  .fulfillment-photo img,
  .partners-image img { min-height: 320px; }
  .footer-links { flex-wrap: wrap; row-gap: 14px; }
  .legal-hero h1 { font-size: clamp(36px, 11vw, 46px); }
  .legal-copy h2 { font-size: 23px; }
}

@media (max-width: 420px) {
  .container { width: min(100% - 24px, 1180px); }
  .section { padding: 68px 0; }
  .brand img { width: 154px; height: 44px; }
  .main-nav { right: 12px; left: 12px; }
  .hero-layout { padding-top: 58px; }
  h1 { font-size: 40px; }
  .hero-subheadline { font-size: 21px; }
  .trust-item { width: 100%; padding: 0 0 13px; border-right: 0; border-bottom: 1px solid var(--line); }
  .trust-item:last-child { padding-bottom: 0; border-bottom: 0; }
  .hero-photo { border-radius: 0 0 48px 0; }
  .hero-photo img { min-height: 290px; }
  .photo-badge { padding: 11px 12px; }
  .photo-badge small { font-size: 9px; }
  .value-card { min-height: auto; }
  .capability-item { min-height: 215px; padding: 26px; }
  .story-photo img,
  .fulfillment-photo img,
  .partners-image img { min-height: 275px; }
  .business-identity div { grid-template-columns: 1fr; gap: 5px; }
  .contact-form { padding: 24px 17px; }
  .consent-message { margin-left: 0; }
  .faq-question { gap: 16px; font-size: 16px; }
  .faq-answer p { margin-right: 12px; }
  .footer-links { align-items: flex-start; flex-direction: column; gap: 13px; }
  .legal-links { gap: 12px 18px; }
  .cookie-actions { grid-template-columns: 1fr; }
  .legal-header .brand img { width: 145px; }
  .back-link { font-size: 11px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal,
  .fade-up,
  .fade-in,
  .scale-in,
  .js .hero-entrance > *,
  .js .hero-image-entrance {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .faq-answer { transition: none; }
  .submit-button.is-loading::before,
  .form-status:not(:empty) { animation: none; }
}
