/* B2 Energy — design system
   Faithful to the B2 brand blue, brought into 2026 with gradient headers,
   soft depth and generous whitespace. */

/* Self-hosted Libre Franklin (the original WordPress theme font) — no external
   CDN, so it always loads even where Google Fonts is blocked. */
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 400;
  font-display: swap; src: url('/assets/fonts/libre-franklin-400.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 600;
  font-display: swap; src: url('/assets/fonts/libre-franklin-600.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 700;
  font-display: swap; src: url('/assets/fonts/libre-franklin-700.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 800;
  font-display: swap; src: url('/assets/fonts/libre-franklin-800.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
/* latin-ext (accented European characters) */
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 400;
  font-display: swap; src: url('/assets/fonts/libre-franklin-400-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 600;
  font-display: swap; src: url('/assets/fonts/libre-franklin-600-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 700;
  font-display: swap; src: url('/assets/fonts/libre-franklin-700-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: 'Libre Franklin'; font-style: normal; font-weight: 800;
  font-display: swap; src: url('/assets/fonts/libre-franklin-800-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* Nexa — the B2 brand font (same as the logo), extracted from the original
   WordPress theme. Used for the logo wordmark and all display headings. */
@font-face {
  font-family: 'Nexa'; font-style: normal; font-weight: 300;
  font-display: swap;
  src: url('/assets/fonts/nexa-light.woff2') format('woff2'),
       url('/assets/fonts/nexa-light.woff') format('woff');
}
@font-face {
  font-family: 'Nexa'; font-style: normal; font-weight: 700;
  font-display: swap;
  src: url('/assets/fonts/nexa-bold.woff2') format('woff2');
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --brand:      #17a5df;   /* B2 energy blue */
  --brand-2:    #0b74b0;   /* deeper blue */
  --brand-deep: #063a5c;
  --navy:       #0a2233;   /* dark sections */
  --ink:        #12222e;
  --text:       #35454f;
  --muted:      #667884;
  --line:       #e2edf3;
  --pale:       #eff8fd;
  --pale-2:     #f6fbfe;
  --white:      #ffffff;
  --radius:     14px;
  --radius-sm:  10px;
  --shadow:     0 1px 2px rgba(10,34,51,.04), 0 12px 32px -12px rgba(11,116,176,.22);
  --shadow-sm:  0 1px 2px rgba(10,34,51,.05), 0 6px 18px -10px rgba(11,116,176,.18);
  --grad:       linear-gradient(115deg, #0b74b0 0%, #17a5df 55%, #63d2f5 100%);
  --grad-soft:  linear-gradient(160deg, #f2fbff 0%, #eaf5fc 100%);
  --font:       'Libre Franklin', system-ui, -apple-system, 'Segoe UI', Helvetica, Arial, sans-serif;
  --display:    'Nexa', 'Libre Franklin', system-ui, sans-serif;
  --maxw:       1120px;
}

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font);
  background: var(--white);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: var(--brand-2); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* ── Top utility bar ── */
.topbar { background: var(--navy); color: #b9cbd7; font-size: .82rem; }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; min-height: 40px; }
.topbar__note { color: #8ba1b2; }
.topbar__links { display: flex; align-items: center; gap: 22px; }
.topbar__links a { color: #c6d6e2; text-decoration: none; display: inline-flex; align-items: center; gap: 7px; }
.topbar__links a:hover { color: #fff; }
.topbar__phone { font-weight: 600; }
.topbar__phone svg { width: 15px; height: 15px; }
@media (max-width: 720px) {
  .topbar__note { display: none; }
  .topbar__inner { justify-content: center; }
}
.skip {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--navy); color: #fff; padding: 12px 20px; border-radius: 0 0 8px 0;
}
.skip:focus { left: 0; }

/* ── Header ── */
.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.82);
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.header__bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px; min-height: 74px;
}
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; min-width: 0; }
/* Fixed width + auto height + no flex-shrink = logo keeps its aspect ratio, never squashed. */
.brand img { width: 46px; height: auto; flex: none; object-fit: contain; }
.brand__text { display: flex; flex-direction: column; line-height: 1.05; }
.brand__text strong {
  font-family: var(--display); font-weight: 700; font-size: 1.12rem;
  letter-spacing: -.01em; color: var(--navy);
}
.brand__text em {
  font-style: normal; font-size: .66rem; font-weight: 600; letter-spacing: .16em;
  text-transform: uppercase; color: var(--brand);
}
.nav { display: flex; align-items: center; gap: 4px; }
.nav a {
  padding: 9px 14px; border-radius: 8px;
  color: var(--ink); text-decoration: none;
  font-size: .93rem; font-weight: 600;
  transition: background .18s, color .18s;
}
.nav a:hover { background: var(--pale); color: var(--brand-2); }
.nav a[aria-current] { color: var(--brand-2); }
.nav__cta {
  margin-left: 8px; background: var(--grad); color: #fff !important;
  box-shadow: var(--shadow-sm);
}
.nav__cta:hover { filter: brightness(1.05); background: var(--grad); }
.navtoggle, .burger { display: none; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 13px 26px; border-radius: 7px;
  font-family: var(--font); font-size: .98rem; font-weight: 600;
  text-decoration: none; cursor: pointer; border: 1.5px solid transparent;
  transition: transform .15s, box-shadow .2s, background .2s, color .2s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary { background: var(--grad); color: #fff; box-shadow: var(--shadow-sm); }
.btn--primary:hover { box-shadow: var(--shadow); }
.btn--outline { background: transparent; color: var(--brand-2); border-color: #cfe6f4; }
.btn--outline:hover { background: var(--pale); }
.btn--light { background: #fff; color: var(--brand-2); }
.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.5); }
.btn--ghost:hover { background: rgba(255,255,255,.12); }

/* ── Hero ── */
.hero { position: relative; text-align: left; padding: 84px 24px 72px; isolation: isolate; }
.hero__inner { max-width: 720px; }
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: -2; background: var(--grad-soft);
}
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1; opacity: .5;
  background:
    radial-gradient(42rem 30rem at 15% -10%, rgba(23,165,223,.18), transparent 60%),
    radial-gradient(38rem 26rem at 100% 0%, rgba(99,210,245,.20), transparent 55%);
}
.hero--home { padding: 116px 24px 96px; }
.hero--inner { padding: 78px 24px 60px; }
.hero__kicker {
  font-size: .82rem; font-weight: 600; letter-spacing: .01em; color: var(--brand-2);
  margin-bottom: 16px;
}
.hero__kicker a { color: inherit; text-decoration: none; }
.hero__kicker a:hover { text-decoration: underline; }
.hero__sep { color: var(--muted); opacity: .55; margin: 0 3px; font-weight: 400; }
.hero__title {
  font-family: var(--display); font-weight: 700; letter-spacing: -.02em;
  font-size: clamp(2.4rem, 6vw, 4.4rem); line-height: 1.04; color: var(--navy);
}
/* Brand gradient headline on the light-background heroes (about, services,
   accreditations, contact, privacy). Falls back to solid brand blue where
   background-clip:text isn't supported. */
.hero:not(.hero--photo) .hero__title {
  background: linear-gradient(115deg, var(--brand-deep) 0%, var(--brand-2) 42%, var(--brand) 78%, #4fc6f2 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: var(--brand-2);
  padding-bottom: .08em;
}
.hero--home .hero__title { font-size: clamp(2.8rem, 8vw, 5.2rem); }
.grad {
  background: var(--grad); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: var(--brand-2);
}
.hero__sub {
  max-width: 620px; margin: 24px 0 0; font-size: 1.14rem; color: var(--muted);
}
.hero__actions { margin-top: 34px; display: flex; justify-content: flex-start; gap: 14px; flex-wrap: wrap; }
.hero__note { margin-top: 22px; font-size: .95rem; color: var(--muted); }
.hero__note a { color: var(--brand-2); font-weight: 600; text-decoration: none; }
.hero__note a:hover { text-decoration: underline; }

/* ── Hero with photo background ── */
.hero--photo { color: #fff; }
.hero--photo::before { display: none; }
.hero--photo .hero__media {
  position: absolute; inset: 0; z-index: -2;
  background-size: cover; background-position: center;
}
.hero--photo::after {
  z-index: -1; opacity: 1;
  background: linear-gradient(118deg, rgba(6,40,64,.94) 0%, rgba(9,73,116,.86) 45%, rgba(23,165,223,.62) 100%);
}
.hero--photo .hero__title {
  background: linear-gradient(118deg, #ffffff 0%, #ffffff 40%, #a8e3ff 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: #fff;
}
.hero--photo .hero__sub { color: rgba(255,255,255,.9); }
.hero--photo .hero__kicker { color: rgba(255,255,255,.82); }
.hero--photo .hero__sep { color: rgba(255,255,255,.5); }
.hero--photo .hero__note { color: rgba(255,255,255,.85); }
.hero--photo .hero__note a { color: #fff; text-decoration: underline; }
.hero--home.hero--photo { padding: 120px 24px 104px; }
.hero--inner.hero--photo { padding: 92px 24px 76px; }

/* ── Split (text + image) ── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; }
.split__text .lead { font-size: 1.24rem; color: var(--ink); line-height: 1.55; margin-bottom: 16px; }
.split__text p { font-size: 1.04rem; }
.split__media img {
  width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius);
  box-shadow: var(--shadow); aspect-ratio: 3 / 2;
}

/* ── Sections ── */
.section { padding: 84px 24px; }
.section--pale { background: var(--pale); }
.section--accr { padding-bottom: 84px; }
.section__title {
  font-family: var(--display); font-weight: 700; letter-spacing: -.015em;
  font-size: clamp(1.6rem, 3.4vw, 2.35rem); color: var(--navy);
  text-align: left; max-width: 780px; margin: 0; padding-top: 20px; position: relative;
}
.section__title::before {
  content: ""; position: absolute; top: 0; left: 0;
  width: 40px; height: 4px; border-radius: 2px; background: var(--grad);
}
.section__sub { text-align: left; color: var(--muted); max-width: 640px; margin: 12px 0 0; font-size: 1.05rem; }
/* Centred variant kept for the trust strip */
.section--center .section__title { margin: 0 auto; text-align: center; }
.section--center .section__title::before { left: 50%; transform: translateX(-50%); }
.section--center .section__sub { margin: 12px auto 0; text-align: center; }
.section__title + .cards, .section__sub + .cards,
.section__title + .features, .section__sub + .features,
.section__title + .accr, .section__sub + .accr,
.section__title + .faq, .section__title + .prose { margin-top: 48px; }

/* ── Cards ── */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(288px, 1fr)); gap: 22px; }
.card {
  display: flex; flex-direction: column; align-items: flex-start;
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 30px 28px; text-decoration: none; color: inherit;
  transition: transform .18s, box-shadow .2s, border-color .2s;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: #cfe6f4; }
.card__icon {
  width: 50px; height: 50px; border-radius: 12px; margin-bottom: 18px;
  display: grid; place-items: center; color: #fff; background: var(--grad);
  box-shadow: 0 8px 18px -8px rgba(11,116,176,.6);
}
.card__icon svg { width: 26px; height: 26px; }
.card h3 { font-family: var(--display); font-size: 1.16rem; color: var(--navy); margin-bottom: 8px; }
.card p { font-size: .95rem; color: var(--muted); }
.card__more { margin-top: 16px; font-weight: 600; font-size: .9rem; color: var(--brand-2); }

/* ── Photo cards ── */
.card--photo { padding: 0; overflow: hidden; }
.card--photo .card__media { display: block; width: 100%; aspect-ratio: 3 / 2; overflow: hidden; background: var(--pale); }
.card--photo .card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card--photo:hover .card__media img { transform: scale(1.05); }
.card--photo .card__icon { margin: -30px 0 0 26px; position: relative; z-index: 1; border: 3px solid #fff; }
.card--photo h3 { padding: 0 26px; margin-top: 14px; }
.card--photo p { padding: 0 26px; }
.card--photo .card__more { padding: 0 26px 28px; margin-top: 14px; }

/* ── Feature grid ── */
.features { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; }
.feature { display: flex; gap: 16px; align-items: flex-start; }
.feature__icon {
  flex: none; width: 44px; height: 44px; border-radius: 11px; display: grid; place-items: center;
  background: var(--pale); color: var(--brand-2); border: 1px solid #d7ecf7;
}
.feature__icon svg { width: 23px; height: 23px; }
.feature h3 { font-family: var(--display); font-size: 1.06rem; color: var(--navy); margin-bottom: 4px; }
.feature p { font-size: .93rem; color: var(--muted); }

/* ── Checklist columns ── */
.cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 30px; margin-top: 46px; }
.col h3 { font-family: var(--display); font-size: 1.1rem; color: var(--navy); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid var(--line); }
.ticks { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.ticks li { position: relative; padding-left: 30px; font-size: .96rem; color: var(--text); }
.ticks li::before {
  content: ""; position: absolute; left: 0; top: 2px; width: 19px; height: 19px; border-radius: 50%;
  background: var(--pale);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230b74b0' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m20 6-11 11-5-5'/%3E%3C/svg%3E");
  background-size: 13px; background-repeat: no-repeat; background-position: center;
}

/* ── Prose ── */
.prose { max-width: 760px; margin: 0 auto; }
.prose.center { text-align: center; }
.prose .lead { font-size: 1.24rem; color: var(--ink); line-height: 1.55; }
.prose p { margin-bottom: 16px; font-size: 1.04rem; }
.prose h2 { font-family: var(--display); color: var(--navy); font-size: 1.4rem; margin: 30px 0 10px; }
.prose--legal { text-align: left; }
.prose + .features { margin-top: 44px; }

/* ── CTA band ── */
.cta { position: relative; overflow: hidden; background: var(--navy); color: #fff; }
.cta::before {
  content: ""; position: absolute; inset: 0; opacity: .9;
  background:
    radial-gradient(40rem 30rem at 8% 120%, rgba(23,165,223,.5), transparent 55%),
    radial-gradient(36rem 24rem at 100% -20%, rgba(11,116,176,.55), transparent 55%);
}
.cta__inner {
  position: relative; padding: 66px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.cta h2 { font-family: var(--display); font-size: clamp(1.6rem, 3.4vw, 2.3rem); margin-bottom: 8px; letter-spacing: -.015em; }
.cta p { color: rgba(255,255,255,.82); max-width: 520px; }
.cta__actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* ── FAQ ── */
.faq { max-width: 800px; margin: 46px auto 0; display: flex; flex-direction: column; gap: 12px; }
.faq details {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 4px 22px; transition: border-color .2s;
}
.faq details[open] { border-color: #cfe6f4; box-shadow: var(--shadow-sm); }
.faq summary {
  cursor: pointer; list-style: none; padding: 16px 0; font-weight: 650; color: var(--navy);
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 1.4rem; color: var(--brand); transition: transform .2s; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p { padding: 0 0 18px; color: var(--muted); }

/* ── Accreditations ── */
.accr { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 26px; }
.accr__item {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 20px 26px; display: grid; place-items: center; min-height: 108px; min-width: 150px;
  box-shadow: var(--shadow-sm);
}
.accr__item img { max-height: 68px; width: auto; }

/* ── Contact ── */
.contact { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: start; }
.form { display: flex; flex-direction: column; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: .86rem; font-weight: 600; color: var(--navy); }
.field input, .field textarea {
  font-family: var(--font); font-size: 1rem; color: var(--ink);
  padding: 13px 15px; border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  background: var(--pale-2); transition: border-color .18s, background .18s, box-shadow .18s;
}
.field input:focus, .field textarea:focus {
  outline: none; border-color: var(--brand); background: #fff;
  box-shadow: 0 0 0 4px rgba(23,165,223,.14);
}
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.form .btn { align-self: flex-start; margin-top: 4px; }
.form__status { font-size: .95rem; font-weight: 600; min-height: 1.2em; }
.form__status.ok { color: #12805c; }
.form__status.err { color: #c0392b; }
.contact__aside {
  background: var(--grad-soft); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 30px 28px;
}
.contact__aside h2 { font-family: var(--display); color: var(--navy); font-size: 1.3rem; margin-bottom: 18px; }
.contact__line { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; color: var(--text); }
.contact__line svg { width: 20px; height: 20px; color: var(--brand-2); flex: none; }
.contact__line a { color: var(--ink); text-decoration: none; font-weight: 600; }
.contact__line a:hover { color: var(--brand-2); }
.contact__reg { margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--line); font-size: .86rem; color: var(--muted); }

/* ── Footer ── */
.footer { background: var(--navy); color: #b9cbd7; padding: 64px 24px 34px; }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 36px; }
.footer__brand img { width: 76px; height: auto; flex: none; object-fit: contain; margin-bottom: 16px; filter: brightness(0) invert(1); opacity: .95; }
.footer__brand p { font-size: .92rem; line-height: 1.6; color: #9fb3c1; }
.footer__accr { margin-top: 14px; font-size: .8rem; letter-spacing: .04em; color: #6f8798 !important; }
.footer__col h4 {
  font-family: var(--display); color: #fff; font-size: .82rem; letter-spacing: .12em;
  text-transform: uppercase; margin-bottom: 16px;
}
.footer__col a { display: block; color: #a9bccb; text-decoration: none; font-size: .93rem; padding: 5px 0; }
.footer__col a:hover { color: #fff; }
.footer__meta { font-size: .86rem; color: #7f95a6; margin-top: 10px; line-height: 1.6; }
.footer__legal { margin-top: 44px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1); }
.footer__legal p { font-size: .82rem; color: #6f8798; }

/* ── Responsive ── */
@media (max-width: 860px) {
  .contact { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .cta__inner { flex-direction: column; align-items: flex-start; }
  .split { grid-template-columns: 1fr; gap: 28px; }
  .split__media { order: -1; }
}
@media (max-width: 720px) {
  .burger {
    display: flex; flex-direction: column; gap: 5px; cursor: pointer;
    padding: 10px; margin: -10px; z-index: 60;
  }
  .burger span { width: 24px; height: 2px; background: var(--navy); border-radius: 2px; transition: .25s; }
  .nav {
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; align-items: stretch;
    gap: 4px; padding: 14px 24px 22px; background: rgba(255,255,255,.98);
    backdrop-filter: blur(12px); border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow);
    /* visibility:hidden guarantees the collapsed menu is fully hidden — no item peeks out */
    transform: translateY(-8px); opacity: 0; visibility: hidden;
    transition: transform .22s ease, opacity .22s ease, visibility .22s;
  }
  .navtoggle:checked ~ .nav { transform: translateY(0); opacity: 1; visibility: visible; }
  .navtoggle:checked ~ .burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .navtoggle:checked ~ .burger span:nth-child(2) { opacity: 0; }
  .navtoggle:checked ~ .burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .nav a { padding: 13px 12px; font-size: 1rem; }
  .nav__cta { margin: 8px 0 0; text-align: center; }
}
@media (max-width: 500px) {
  .footer__grid { grid-template-columns: 1fr; }
  .brand__text em { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; transition: none !important; }
}
