/*
Theme Name: Topa Shop
Theme URI: https://topanabolen.com/
Author: Topanabolen
Author URI: https://topanabolen.com/
Description: Clean, clinical-pharmaceutical WooCommerce theme for Topanabolen. Deep medical-blue brand band, generous white space and cool neutral grays — a trustworthy, premium look for a sports-supplement catalog. Classic (no build step) — upload and activate.
Version: 1.1.0
Requires at least: 6.4
Tested up to: 6.5
Requires PHP: 7.4
WC requires at least: 8.0
WC tested up to: 9.9
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: getvital
Tags: woocommerce, e-commerce, custom-colors, custom-logo, accessibility-ready
*/

/* =========================================================================
   1. Design tokens — clinical pharmaceutical palette
   ========================================================================= */
:root {
  /* Brand blues (the constant header band) */
  --brand-blue-deep: #064877; /* hover / active / footer */
  --brand-blue:      #085C9D; /* primary: headers, buttons, links, accents */
  --brand-blue-light:#5292C5; /* secondary sky: highlights, badges, icons */
  --accent-red:      #C0392B; /* RARE accent: sale tags, alerts only */

  /* Surfaces & text */
  --paper:   #FFFFFF; /* page background, cards */
  --surface: #F2F4F6; /* alternating sections, inputs, panels */
  --border:  #E1E3E5; /* card borders, table lines, separators */
  --ink:     #2A2E35; /* body text */
  --heading: #1A2733; /* near-navy headings, high contrast */
  --muted:   #9CA2AE; /* captions, placeholders, disabled */
  --white:   #ffffff;

  /* Per-page accent. May be overridden inline on product cards / single-product
     roots, but defaults to the primary blue so the brand reads consistently. */
  --accent:     var(--brand-blue);
  --accent-ink: #ffffff; /* readable text color ON the accent */

  /* The constant header gradient */
  --brand-gradient: linear-gradient(105deg,
      var(--brand-blue-deep) 0%,
      var(--brand-blue) 55%,
      var(--brand-blue-light) 100%);

  --maxw: 1200px;
  --radius: 8px;
  --shadow-card: 0 1px 2px rgba(8,92,157,.06), 0 6px 20px rgba(8,92,157,.08);

  --font-head: 'Archivo', system-ui, 'Segoe UI', sans-serif;
  --font-body: 'Inter', system-ui, 'Segoe UI', sans-serif;
}

/* =========================================================================
   2. Base / reset
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--brand-blue-deep); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 {
  font-family: var(--font-head);
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin: 0 0 .5em;
  color: var(--heading);
}
.container { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

/* Visually-hidden but screen-reader accessible */
.screen-reader-text {
  border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
  height: 1px; width: 1px; margin: -1px; padding: 0; overflow: hidden;
  position: absolute !important; word-wrap: normal !important;
}
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--brand-blue-deep); color: #fff; padding: 10px 16px;
}
.skip-link:focus { left: 8px; top: 8px; }

:focus-visible { outline: 3px solid var(--brand-blue-deep); outline-offset: 2px; }

/* =========================================================================
   3. Compliance bars / disclaimers
   ========================================================================= */
.gv-utility-bar {
  background: var(--brand-blue-deep);
  color: #eaf3fb;
  font-size: 12.5px;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
  padding: 7px 12px;
  font-weight: 600;
}
.gv-disclaimer-block {
  border: 1px solid var(--muted);
  background: #fff;
  border-left: 4px solid var(--accent);
  padding: 14px 16px;
  font-size: 13.5px;
  color: #444;
  border-radius: var(--radius);
}
.gv-disclaimer-block strong { color: var(--ink); }

/* =========================================================================
   4. Header
   ========================================================================= */
.gv-header {
  background: var(--brand-gradient);
  color: #fff;
  position: sticky; top: 0; z-index: 50;
  transition: background .25s ease, box-shadow .25s ease, padding .25s ease;
}
.gv-header.is-stuck {
  background: var(--brand-blue-deep);
  box-shadow: 0 2px 16px rgba(0,0,0,.18);
}
.gv-header__inner {
  display: flex; align-items: center; gap: 24px;
  min-height: 116px; padding: 16px 20px;
  max-width: var(--maxw); margin: 0 auto;
  transition: min-height .25s ease, padding .25s ease;
}
.gv-header.is-stuck .gv-header__inner { min-height: 92px; padding: 10px 20px; }
.gv-logo { display: inline-flex; align-items: center; text-decoration: none; }
.gv-logo:hover { text-decoration: none; }
.gv-logo img, .gv-logo svg { height: 54px; width: auto; }
.gv-header.is-stuck .gv-logo img,
.gv-header.is-stuck .gv-logo svg { height: 44px; }

/* Brand lockup: medical-snake circular badge on the left, "TopAnabolen" wordmark on the right */
.gv-logo__lockup {
  display: inline-flex; flex-direction: row; align-items: center;
  text-align: left; line-height: 1; gap: 13px;
}
.gv-logo__mark { display: inline-flex; line-height: 0; flex: 0 0 auto; }
.gv-logo__text { display: inline-flex; flex-direction: column; gap: 4px; }
.gv-logo__name {
  font-family: var(--font-head); font-size: 1.6rem; letter-spacing: -0.01em;
  white-space: nowrap;
}
.gv-logo__name-get { font-weight: 400; }
.gv-logo__name-vital { font-weight: 800; }
.gv-logo__sub {
  font-family: var(--font-body); font-size: .62rem; font-weight: 600;
  letter-spacing: .34em; text-transform: uppercase; opacity: .9;
}
.gv-header.is-stuck .gv-logo__name { font-size: 1.32rem; }
.gv-header.is-stuck .gv-logo__sub { font-size: .56rem; }

.gv-nav { margin-left: auto; }
.gv-nav ul { list-style: none; display: flex; gap: 26px; margin: 0; padding: 0; }
.gv-nav a {
  color: #fff; font-weight: 600; font-size: 14.5px;
  letter-spacing: .03em; text-decoration: none; opacity: .92;
}
.gv-nav a:hover { opacity: 1; text-decoration: none; border-bottom: 2px solid #fff; }

.gv-header__actions { display: flex; align-items: center; gap: 18px; }

/* Language switcher (EN | NL) */
.gv-lang { display: inline-flex; align-items: center; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; overflow: hidden; }
.gv-lang__btn {
  color: #fff; opacity: .8; font-weight: 700; font-size: 12.5px; letter-spacing: .04em;
  padding: 5px 10px; line-height: 1; text-decoration: none; transition: background .15s ease, opacity .15s ease;
}
.gv-lang__btn:hover { opacity: 1; text-decoration: none; }
.gv-lang__btn.is-active { background: #fff; color: var(--brand-blue-deep); opacity: 1; }
/* Polylang fallback list, if that plugin is active */
.gv-lang--pll ul { list-style: none; display: flex; gap: 10px; margin: 0; padding: 0; }
.gv-lang--pll a { color: #fff; font-weight: 700; font-size: 12.5px; text-decoration: none; }
.gv-cart-link { color: #fff; display: inline-flex; align-items: center; gap: 7px; font-weight: 600; }
.gv-cart-link svg { stroke: #fff; }
.gv-cart-count {
  background: #fff; color: var(--brand-blue-deep);
  border-radius: 999px; font-size: 12px; font-weight: 800;
  min-width: 20px; height: 20px; padding: 0 6px;
  display: inline-flex; align-items: center; justify-content: center;
}
.gv-nav-toggle {
  display: none; background: transparent; border: 0; color: #fff;
  cursor: pointer; padding: 6px;
}

/* =========================================================================
   4b. Category bar — product categories shown as neat pills below the header
   (kept OUT of the main menu, which stays clean: Shop · Contact · etc.)
   ========================================================================= */
.gv-catbar { background: var(--surface); border-bottom: 1px solid var(--border); }
.gv-catbar__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 11px 20px;
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.gv-catbar__label {
  font-family: var(--font-head); font-weight: 700; font-size: 12px;
  letter-spacing: .09em; text-transform: uppercase; color: var(--muted); margin-right: 4px;
}
.gv-catbar__link {
  display: inline-flex; align-items: center; gap: 7px;
  background: #fff; border: 1px solid var(--border); border-radius: 999px;
  padding: 6px 14px; font-size: 13.5px; font-weight: 600;
  color: var(--brand-blue); text-decoration: none;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.gv-catbar__link:hover {
  background: var(--brand-blue); border-color: var(--brand-blue);
  color: #fff; text-decoration: none;
}
.gv-catbar__count {
  font-size: 11px; font-weight: 700; color: var(--muted);
  background: var(--surface); border-radius: 999px; padding: 1px 7px; line-height: 1.5;
}
.gv-catbar__link:hover .gv-catbar__count { color: #fff; background: rgba(255,255,255,.22); }
@media (max-width: 720px) {
  .gv-catbar__inner { padding: 9px 16px; gap: 7px; }
  .gv-catbar__label { display: none; }
}

/* =========================================================================
   5. Angular / chevron accent divider (the brand motif)
   ========================================================================= */
.gv-divider {
  position: relative; height: 14px; width: 100%;
  overflow: hidden; line-height: 0;
}
.gv-divider svg { width: 100%; height: 100%; display: block; }
.gv-divider .gv-divider__line { stroke: var(--accent); stroke-width: 2.5; fill: none; }

/* Thin inline version used inside cards */
.gv-divider--thin { height: 10px; }

/* =========================================================================
   6. Hero (gradient band + geometric watermark)
   ========================================================================= */
.gv-hero {
  position: relative;
  background: var(--brand-gradient);
  color: #fff;
  overflow: hidden;
  padding: 64px 20px 0;
}
.gv-hero__watermark {
  position: absolute; inset: 0; pointer-events: none;
  opacity: .14; mix-blend-mode: screen;
}
.gv-hero__watermark svg { width: 100%; height: 100%; }
.gv-hero__inner { position: relative; max-width: var(--maxw); margin: 0 auto; padding-bottom: 56px; }
.gv-hero h1 {
  color: #fff; font-size: clamp(2rem, 5vw, 3.4rem);
  text-transform: uppercase; max-width: 16ch;
}
.gv-hero p { font-size: 1.05rem; max-width: 56ch; color: #eaf3fb; }
.gv-hero__lead { font-size: clamp(1.15rem, 2.4vw, 1.5rem); max-width: 46ch; font-weight: 500; color: #fff; }
.gv-hero .gv-eyebrow {
  display: inline-block; text-transform: uppercase; letter-spacing: .18em;
  font-weight: 700; font-size: 12.5px; color: #d6ebf7; margin-bottom: 14px;
}

/* =========================================================================
   6b. Trust badges (Lab Tested · 99%+ Purity · Research Grade)
   ========================================================================= */
.gv-trust {
  list-style: none; margin: 28px 0 8px; padding: 18px 16px;
  display: flex; flex-wrap: wrap; gap: 14px 40px;
  align-items: center; justify-content: center;
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius);
  box-shadow: var(--shadow-card);
}
.gv-trust__item {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-head); font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; font-size: 14.5px; color: var(--ink);
}
.gv-trust__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; flex: 0 0 44px;
  border-radius: 50%;
  background: rgba(46,124,184,.10);
  color: var(--brand-blue-deep);
}
.gv-trust__icon svg { width: 24px; height: 24px; }

@media (max-width: 600px) {
  .gv-trust { flex-direction: column; align-items: flex-start; gap: 16px; }
}

/* =========================================================================
   7. Dosage badge (accent parallelogram chip)
   ========================================================================= */
.gv-dosage-badge {
  display: inline-block;
  background: var(--accent);
  color: var(--accent-ink);
  font-family: var(--font-head);
  font-weight: 800; font-size: 13px; letter-spacing: .02em;
  text-transform: uppercase;
  padding: 5px 14px 5px 12px;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
  line-height: 1.3;
}
.gv-dosage-badge--lg { font-size: 16px; padding: 8px 20px 8px 16px; }

/* Sub-label "LYOPHILIZED PEPTIDE" in accent color */
.gv-sublabel {
  text-transform: uppercase; letter-spacing: .16em;
  font-weight: 700; font-size: 12px; color: var(--accent);
}

/* =========================================================================
   8. Product card (echoes the box design)
   ========================================================================= */
.gv-grid {
  display: grid; gap: 26px;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  margin: 36px 0;
  padding: 0; list-style: none;
}
.gv-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease;
}
.gv-card:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(26,82,144,.16); }
.gv-card__band {
  background: var(--brand-gradient);
  color: #fff; padding: 16px 16px 14px; position: relative;
}
.gv-card__name {
  font-family: var(--font-head); font-weight: 800; text-transform: uppercase;
  font-size: 1.05rem; letter-spacing: -0.01em; margin: 0; color: #fff; line-height: 1.15;
}
.gv-card__name a { color: #fff; text-decoration: none; }
.gv-card__body { padding: 14px 16px 18px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.gv-card__vial { display: flex; align-items: center; justify-content: center; padding: 14px 0 6px; }
.gv-card__vial svg { height: 64px; width: auto; stroke: var(--brand-blue); }
.gv-card__meta { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.gv-card__purity { font-weight: 700; color: var(--ink); font-size: .95rem; }
.gv-card__vialsize { color: #666; font-size: .85rem; }
.gv-card__foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: auto; }
.gv-card__price { font-family: var(--font-head); font-weight: 800; font-size: 1.15rem; color: var(--ink); }
.gv-card__price .woocommerce-Price-amount { color: var(--ink); }
.gv-card__price del { color: var(--muted); font-weight: 500; font-size: .9rem; }

/* =========================================================================
   9. Buttons
   ========================================================================= */
.gv-btn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .button,
.woocommerce #respond input#submit,
.woocommerce input.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--accent); color: var(--accent-ink) !important;
  font-family: var(--font-head); font-weight: 700; letter-spacing: .02em;
  text-transform: uppercase; font-size: 14px;
  border: 0; border-radius: var(--radius); cursor: pointer;
  padding: 12px 22px; line-height: 1; text-decoration: none;
  transition: filter .15s ease, transform .05s ease;
}
.gv-btn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .button:hover,
.woocommerce input.button:hover { filter: brightness(.92); text-decoration: none; }
.gv-btn:active,
.woocommerce .button:active { transform: translateY(1px); }
.gv-btn--lg { padding: 15px 30px; font-size: 16px; }
.gv-btn--ghost {
  background: transparent; color: var(--brand-blue-deep) !important;
  border: 2px solid currentColor;
}

/* WooCommerce "alt" buttons (Proceed to checkout, Place order, single Add to
   cart) ship purple by default — force them to the brand blue like the rest. */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce .single_add_to_cart_button,
.woocommerce .checkout-button,
.woocommerce #place_order {
  background: var(--accent) !important;
  color: var(--accent-ink) !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce .single_add_to_cart_button:hover,
.woocommerce .checkout-button:hover,
.woocommerce #place_order:hover {
  background: var(--brand-blue-deep) !important;
}

/* =========================================================================
   10. Single product
   ========================================================================= */
.gv-single { padding: 30px 0 60px; }
.gv-single__layout { display: grid; grid-template-columns: 1.05fr 1fr; gap: 48px; align-items: start; }
.gv-single__gallery { position: relative; }
.gv-single__gallery .gv-band {
  background: var(--brand-gradient); border-radius: var(--radius) var(--radius) 0 0;
  padding: 18px 20px; color: #fff;
}
.gv-single__gallery-media {
  background: #fff; border: 1px solid var(--border); border-top: 0;
  border-radius: 0 0 var(--radius) var(--radius); padding: 28px;
  display: flex; align-items: center; justify-content: center; min-height: 320px;
}
.gv-single__main-img { max-width: 100%; height: auto; display: block; }
.gv-single__thumbs {
  list-style: none; margin: 14px 0 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 10px;
}
.gv-single__thumb { margin: 0; }
.gv-single__thumb-btn {
  display: block; padding: 0; cursor: pointer;
  border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden; background: #fff; line-height: 0;
  transition: border-color .15s ease;
}
.gv-single__thumb-btn:hover { border-color: var(--accent); }
.gv-single__thumb-btn.is-active { border-color: var(--accent); border-width: 2px; }
.gv-single__thumb-btn img { width: 72px; height: 72px; object-fit: cover; display: block; }
.gv-single__title { font-size: clamp(1.8rem, 4vw, 2.6rem); text-transform: uppercase; margin: 4px 0 6px; }
.gv-single__price { font-family: var(--font-head); font-weight: 800; font-size: 1.7rem; margin: 14px 0; }
.gv-single__price .woocommerce-Price-amount { color: var(--ink); }

.gv-spec {
  list-style: none; margin: 18px 0; padding: 0;
  border: 1px solid var(--border); border-radius: var(--radius); background: #fff; overflow: hidden;
}
.gv-spec__row { display: flex; justify-content: space-between; gap: 16px; padding: 12px 16px; border-top: 1px solid var(--border); }
.gv-spec__row:first-child { border-top: 0; }
.gv-spec__k { color: #6b6b6b; font-size: .85rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
.gv-spec__v { color: var(--ink); font-weight: 700; text-align: right; }

.gv-buybox {
  background: #fff; border: 1px solid var(--border); border-top: 3px solid var(--accent);
  border-radius: var(--radius); padding: 20px; margin: 22px 0;
}
.gv-buybox .quantity input {
  width: 72px; padding: 11px; border: 1px solid var(--muted);
  border-radius: var(--radius); font-size: 15px; text-align: center;
}
.gv-single .cart { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 8px 0 0; }
.gv-tag {
  display: inline-block; font-size: 11.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--accent); border: 1px solid var(--accent);
  border-radius: 999px; padding: 3px 11px;
}

/* WooCommerce tabs / related restyle */
.woocommerce-tabs { margin-top: 40px; }
.woocommerce-tabs ul.tabs { list-style: none; padding: 0; display: flex; gap: 6px; border-bottom: 2px solid var(--border); }
.woocommerce-tabs ul.tabs li a { display: inline-block; padding: 10px 16px; font-weight: 700; color: #666; }
.woocommerce-tabs ul.tabs li.active a { color: var(--brand-blue-deep); border-bottom: 3px solid var(--accent); }

/* =========================================================================
   11. WooCommerce notices / messages
   ========================================================================= */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-top-color: var(--accent) !important; border-radius: var(--radius);
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--accent) !important; }

/* WooCommerce default loop columns -> our grid */
.woocommerce ul.products { display: grid !important; gap: 26px; grid-template-columns: repeat(auto-fill, minmax(250px,1fr)); margin: 0; }
/* WooCommerce adds ::before/::after clearfix to ul.products; on a grid container
   they become grid items and leave an empty cell before the first product. */
.woocommerce ul.products::before, .woocommerce ul.products::after { content: none; display: none; }
.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; }
.woocommerce .woocommerce-result-count, .woocommerce .woocommerce-ordering { margin-bottom: 18px; }

/* =========================================================================
   11a. Static pages
   ========================================================================= */
.gv-page__title { font-size: clamp(1.8rem, 4vw, 2.6rem); text-transform: uppercase; margin: 0 0 14px; }
.gv-page__content { margin-top: 24px; }
.gv-page__content > * + * { margin-top: 1em; }

/* =========================================================================
   11b. Contact form
   ========================================================================= */
.gv-contact { max-width: 640px; margin: 0 auto; }
.gv-contact__form {
  background: #fff; border: 1px solid var(--border); border-top: 3px solid var(--brand-blue);
  border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow-card);
}
.gv-field { margin: 0 0 16px; display: flex; flex-direction: column; gap: 6px; }
.gv-field label { font-weight: 600; font-size: 14px; color: var(--ink); }
.gv-field input[type="text"],
.gv-field input[type="email"],
.gv-field textarea {
  width: 100%; padding: 11px 13px; font-size: 15px; font-family: var(--font-body);
  border: 1px solid var(--muted); border-radius: var(--radius); background: #fff; color: var(--ink);
}
.gv-field input:focus, .gv-field textarea:focus {
  outline: none; border-color: var(--brand-blue); box-shadow: 0 0 0 3px rgba(46,124,184,.18);
}
.gv-field textarea { resize: vertical; min-height: 130px; }
.gv-req { color: #c4453d; }
.gv-field__err { color: #c4453d; font-size: 13px; font-weight: 600; }
.gv-field--consent label { flex-direction: row; align-items: flex-start; gap: 10px; display: flex; font-weight: 400; }
.gv-field--consent input { margin-top: 3px; flex: 0 0 auto; }
.gv-field--consent span { font-size: 13.5px; color: #555; }

.gv-contact__notice { padding: 14px 16px; border-radius: var(--radius); margin-bottom: 18px; font-weight: 600; }
.gv-contact__notice--ok  { background: #e8f5ee; border: 1px solid #b7e0c6; color: #1f6b3c; }
.gv-contact__notice--err { background: #fdecea; border: 1px solid #f3c3bd; color: #9b2c22; }

/* Honeypot — keep in the DOM for bots, hidden from humans & screen readers */
.gv-hp { position: absolute !important; left: -9999px !important; top: auto; width: 1px; height: 1px; overflow: hidden; }

/* =========================================================================
   12. Footer
   ========================================================================= */
.gv-footer { background: var(--brand-blue-deep); color: #dce9f5; margin-top: 60px; }
.gv-footer__inner { max-width: var(--maxw); margin: 0 auto; padding: 48px 20px 30px;
  display: grid; gap: 32px; grid-template-columns: 1.4fr 1fr 1fr; }
.gv-footer h4 { color: #fff; text-transform: uppercase; letter-spacing: .06em; font-size: 14px; }
.gv-footer a { color: #cfe2f3; }
.gv-footer a:hover { color: #fff; }
.gv-footer__logo { margin-bottom: 14px; }
.gv-footer__logo svg, .gv-footer__logo img { height: 48px; }
.gv-footer__logo .gv-logo__lockup { align-items: center; }
.gv-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.gv-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.15); padding: 18px 20px;
  text-align: center; font-size: 12.5px; color: #b9d2ea;
}
.gv-footer__disclaimer {
  background: #15406f; color: #e8f1fa; text-align: center;
  padding: 14px 16px; font-size: 13px; font-weight: 600; letter-spacing: .02em;
}

/* =========================================================================
   13. Responsive
   ========================================================================= */
@media (max-width: 900px) {
  .gv-single__layout { grid-template-columns: 1fr; gap: 28px; }
  .gv-footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .gv-nav { display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--brand-blue-deep); padding: 10px 20px; }
  .gv-nav.is-open { display: block; }
  .gv-nav ul { flex-direction: column; gap: 14px; }
  .gv-nav-toggle { display: inline-flex; margin-left: auto; }
  .gv-header__actions { margin-left: 0; }
  .gv-footer__inner { grid-template-columns: 1fr; }
}

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