/* ============================================================
   ShaggyGo — styles.css
   CSS prefix: gna5n-
   Fonts: Newsreader (editorial serif) + Manrope (clean grotesque)
   Layout: Flexbox throughout
   BEM methodology
   ============================================================ */

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

/* tokens */
:root {
  /* colours */
  --clr-forest:     #2D6A50;
  --clr-forest-dk:  #1E4D39;
  --clr-sage:       #4A8C6F;
  --clr-amber:      #E08C2A;
  --clr-amber-lt:   #F5B85A;
  --clr-cream:      #FAF6EF;
  --clr-cream-dk:   #F0EAE0;
  --clr-mint-bg:    #EAF4EE;
  --clr-ink:        #1A1A18;
  --clr-ink-soft:   #3D3D38;
  --clr-muted:      #7A7A72;
  --clr-border:     #DDD8CE;
  --clr-white:      #FFFFFF;
  --clr-error:      #C0392B;
  --clr-success:    #2D6A50;

  /* typography */
  --ff-serif:   'Newsreader', Georgia, serif;
  --ff-sans:    'Manrope', system-ui, sans-serif;
  --fs-xs:      0.75rem;
  --fs-sm:      0.875rem;
  --fs-base:    1rem;
  --fs-md:      1.125rem;
  --fs-lg:      1.25rem;
  --fs-xl:      1.5rem;
  --fs-2xl:     2rem;
  --fs-3xl:     2.75rem;
  --fs-4xl:     3.75rem;
  --fs-5xl:     5rem;
  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semi:    600;
  --fw-bold:    700;
  --lh-tight:   1.2;
  --lh-snug:    1.4;
  --lh-base:    1.6;
  --lh-loose:   1.8;

  /* spacing */
  --sp-1:  0.25rem;
  --sp-2:  0.5rem;
  --sp-3:  0.75rem;
  --sp-4:  1rem;
  --sp-5:  1.25rem;
  --sp-6:  1.5rem;
  --sp-8:  2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;

  /* layout */
  --container-max: 1160px;
  --container-pad: var(--sp-6);

  /* header */
  --header-h:    68px;
  --logo-w:      140px;
  --logo-h:       44px;

  /* radius */
  --r-sm:  4px;
  --r-md:  8px;
  --r-lg:  12px;
  --r-xl:  20px;
  --r-full: 9999px;

  /* shadows */
  --sh-sm:  0 1px 4px rgba(26,26,24,.08);
  --sh-md:  0 4px 16px rgba(26,26,24,.10);
  --sh-lg:  0 8px 32px rgba(26,26,24,.12);

  /* transitions */
  --tr-fast:   150ms ease;
  --tr-base:   250ms ease;
  --tr-slow:   400ms ease;

  /* z-index */
  --z-base:    1;
  --z-above:   10;
  --z-header:  100;
  --z-overlay: 200;
  --z-modal:   300;
  --z-toast:   400;
}

/* base */
html { scroll-behavior: smooth; }
body {
  font-family: var(--ff-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--clr-ink);
  background: var(--clr-cream);
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5 {
  font-family: var(--ff-serif);
  line-height: var(--lh-tight);
  font-weight: var(--fw-regular);
  color: var(--clr-ink);
}
h1 { font-size: clamp(2.25rem, 5vw, var(--fs-4xl)); }
h2 { font-size: clamp(1.6rem, 3.5vw, var(--fs-3xl)); }
h3 { font-size: clamp(1.2rem, 2.5vw, var(--fs-xl)); }
h4 { font-size: var(--fs-lg); }
p { line-height: var(--lh-base); color: var(--clr-ink-soft); }
strong { font-weight: var(--fw-semi); color: var(--clr-ink); }
a:hover { color: var(--clr-forest); }

/* layout */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
}
main { padding-top: var(--header-h); }
.section { padding: var(--sp-20) 0; }
.section--alt { background: var(--clr-mint-bg); }
.section--dark { background: var(--clr-forest-dk); color: var(--clr-white); }
.section--cream-dk { background: var(--clr-cream-dk); }

.section__header {
  text-align: center;
  max-width: 640px;
  margin: 0 auto var(--sp-12);
}
.section__label {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--clr-sage);
  margin-bottom: var(--sp-3);
}
.section__title { margin-bottom: var(--sp-4); }
.section__desc { color: var(--clr-muted); font-size: var(--fs-md); }

/* header */
#site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  background: var(--clr-cream);
  border-bottom: 1px solid var(--clr-border);
  z-index: var(--z-header);
  overflow: hidden;
  transition: box-shadow var(--tr-base);
}
#site-header.scrolled { box-shadow: var(--sh-md); }
#site-header .container { height: 100%; }
.nav-inner {
  display: flex;
  align-items: center;
  height: 100%;
  gap: var(--sp-6);
  overflow: hidden;
}
.gna5n-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.gna5n-logo img {
  max-width: var(--logo-w);
  max-height: var(--logo-h);
  width: auto;
  height: auto;
  display: block;
}
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  margin-left: auto;
}
.nav-links a {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-ink-soft);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  transition: color var(--tr-fast), background var(--tr-fast);
  white-space: nowrap;
}
.nav-links a:hover,
.nav-links a.active {
  color: var(--clr-forest);
  background: var(--clr-mint-bg);
}
.nav-actions {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.btn { display: inline-flex; align-items: center; gap: var(--sp-2); font-weight: var(--fw-semi); border-radius: var(--r-full); transition: background var(--tr-fast), color var(--tr-fast), transform var(--tr-fast), box-shadow var(--tr-fast); }
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--clr-forest); color: var(--clr-white); padding: var(--sp-3) var(--sp-6); font-size: var(--fs-sm); }
.btn--primary:hover { background: var(--clr-forest-dk); box-shadow: var(--sh-sm); color: var(--clr-white); }
.btn--secondary { background: transparent; color: var(--clr-forest); border: 1.5px solid var(--clr-forest); padding: var(--sp-3) var(--sp-6); font-size: var(--fs-sm); }
.btn--secondary:hover { background: var(--clr-mint-bg); color: var(--clr-forest); }
.btn--amber { background: var(--clr-amber); color: var(--clr-white); padding: var(--sp-3) var(--sp-6); font-size: var(--fs-sm); }
.btn--amber:hover { background: #c97d24; box-shadow: var(--sh-sm); color: var(--clr-white); }
.btn--lg { padding: var(--sp-4) var(--sp-8); font-size: var(--fs-base); }
.btn--sm { padding: var(--sp-2) var(--sp-4); font-size: var(--fs-xs); }

.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  margin-left: auto;
  flex-shrink: 0;
  border-radius: var(--r-sm);
  transition: background var(--tr-fast);
}
.hamburger:hover { background: var(--clr-mint-bg); }
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--clr-ink);
  border-radius: 2px;
  margin: 0 auto;
  transition: transform var(--tr-base), opacity var(--tr-base);
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* mobile menu */
.mobile-menu {
  position: fixed;
  top: var(--header-h);
  left: 0; right: 0;
  background: var(--clr-cream);
  border-bottom: 1px solid var(--clr-border);
  padding: var(--sp-6) var(--sp-6) var(--sp-8);
  display: none;
  flex-direction: column;
  gap: var(--sp-2);
  z-index: calc(var(--z-header) - 1);
  box-shadow: var(--sh-md);
}
.mobile-menu.open { display: flex; }
.mobile-menu a {
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  color: var(--clr-ink-soft);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  transition: background var(--tr-fast), color var(--tr-fast);
}
.mobile-menu a:hover,
.mobile-menu a.active { background: var(--clr-mint-bg); color: var(--clr-forest); }
.mobile-menu .btn--primary { margin-top: var(--sp-4); text-align: center; justify-content: center; }

/* breadcrumb */
.breadcrumb {
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-cream-dk);
}
.breadcrumb ol {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.breadcrumb li { display: flex; align-items: center; gap: var(--sp-2); }
.breadcrumb a { font-size: var(--fs-sm); color: var(--clr-muted); transition: color var(--tr-fast); }
.breadcrumb a:hover { color: var(--clr-forest); }
.breadcrumb li:not(:last-child)::after {
  content: '›';
  color: var(--clr-border);
  font-size: var(--fs-sm);
}
.breadcrumb li:last-child span { font-size: var(--fs-sm); color: var(--clr-ink-soft); font-weight: var(--fw-medium); }

/* pet selector — unique component for ShaggyGo */
.gna5n-selector {
  background: var(--clr-cream);
  padding: var(--sp-20) 0 var(--sp-16);
}
.gna5n-selector__intro {
  max-width: 600px;
  margin-bottom: var(--sp-12);
}
.gna5n-selector__headline {
  font-size: clamp(2.5rem, 6vw, var(--fs-5xl));
  font-family: var(--ff-serif);
  line-height: 1.1;
  margin-bottom: var(--sp-4);
  letter-spacing: -.02em;
}
.gna5n-selector__sub {
  font-size: var(--fs-md);
  color: var(--clr-muted);
  max-width: 480px;
}
.gna5n-selector__tabs {
  display: flex;
  gap: var(--sp-3);
  margin-bottom: var(--sp-10);
  flex-wrap: wrap;
}
.gna5n-tab-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-6);
  border-radius: var(--r-full);
  border: 2px solid var(--clr-border);
  background: var(--clr-white);
  font-weight: var(--fw-semi);
  font-size: var(--fs-base);
  color: var(--clr-ink-soft);
  transition: border-color var(--tr-fast), background var(--tr-fast), color var(--tr-fast), box-shadow var(--tr-fast);
  cursor: pointer;
}
.gna5n-tab-btn svg { flex-shrink: 0; transition: color var(--tr-fast); }
.gna5n-tab-btn:hover { border-color: var(--clr-sage); color: var(--clr-forest); }
.gna5n-tab-btn.active {
  border-color: var(--clr-forest);
  background: var(--clr-forest);
  color: var(--clr-white);
  box-shadow: var(--sh-sm);
}
.gna5n-panel { display: none; animation: panelIn var(--tr-base) both; }
.gna5n-panel.active { display: block; }
@keyframes panelIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.gna5n-panel__grid {
  display: flex;
  gap: var(--sp-5);
  flex-wrap: wrap;
}
.gna5n-service-card {
  flex: 1 1 260px;
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-8) var(--sp-6);
  cursor: pointer;
  transition: border-color var(--tr-fast), box-shadow var(--tr-fast), transform var(--tr-fast);
}
.gna5n-service-card:hover {
  border-color: var(--clr-sage);
  box-shadow: var(--sh-md);
  transform: translateY(-2px);
}
.gna5n-service-card__icon {
  width: 44px; height: 44px;
  background: var(--clr-mint-bg);
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-5);
  color: var(--clr-forest);
}
.gna5n-service-card__title {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  margin-bottom: var(--sp-3);
}
.gna5n-service-card__desc { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-5); }
.gna5n-service-card__link {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-forest);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

/* guides grid */
.gna5n-guides-grid {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.gna5n-guide-card {
  flex: 1 1 300px;
  background: var(--clr-white);
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1.5px solid var(--clr-border);
  transition: box-shadow var(--tr-base), transform var(--tr-base);
  cursor: pointer;
}
.gna5n-guide-card:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); }
.gna5n-guide-card__img {
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  background: var(--clr-cream-dk);
}
.gna5n-guide-card__body { padding: var(--sp-6); }
.gna5n-guide-card__tag {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--clr-sage);
  margin-bottom: var(--sp-3);
}
.gna5n-guide-card__title {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  margin-bottom: var(--sp-3);
  line-height: var(--lh-snug);
}
.gna5n-guide-card__excerpt { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-4); }
.gna5n-guide-card__meta {
  font-size: var(--fs-xs);
  color: var(--clr-muted);
  display: flex;
  gap: var(--sp-3);
  align-items: center;
}

/* trust strip */
.gna5n-trust {
  background: var(--clr-forest-dk);
  padding: var(--sp-12) 0;
  color: var(--clr-white);
}
.gna5n-trust__grid {
  display: flex;
  gap: var(--sp-8);
  flex-wrap: wrap;
  justify-content: center;
}
.gna5n-trust__item {
  flex: 1 1 180px;
  text-align: center;
}
.gna5n-trust__num {
  font-family: var(--ff-serif);
  font-size: var(--fs-4xl);
  line-height: 1;
  color: var(--clr-amber-lt);
  display: block;
  margin-bottom: var(--sp-2);
}
.gna5n-trust__label { font-size: var(--fs-sm); color: rgba(255,255,255,.7); }

/* quiz teaser */
.gna5n-quiz-teaser {
  background: var(--clr-amber);
  border-radius: var(--r-xl);
  padding: var(--sp-12) var(--sp-10);
  display: flex;
  align-items: center;
  gap: var(--sp-10);
  flex-wrap: wrap;
}
.gna5n-quiz-teaser__text { flex: 1 1 300px; }
.gna5n-quiz-teaser__label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.8);
  margin-bottom: var(--sp-3);
}
.gna5n-quiz-teaser__title {
  font-family: var(--ff-serif);
  font-size: clamp(1.5rem, 3vw, var(--fs-2xl));
  color: var(--clr-white);
  margin-bottom: var(--sp-4);
}
.gna5n-quiz-teaser__desc { font-size: var(--fs-sm); color: rgba(255,255,255,.85); }
.gna5n-quiz-teaser__cta { flex-shrink: 0; }
.btn--white { background: var(--clr-white); color: var(--clr-amber); padding: var(--sp-4) var(--sp-8); font-size: var(--fs-base); font-weight: var(--fw-semi); border-radius: var(--r-full); transition: box-shadow var(--tr-fast), transform var(--tr-fast); }
.btn--white:hover { box-shadow: var(--sh-md); transform: translateY(-2px); color: var(--clr-amber); }

/* quiz — unique interactive component */
.gna5n-quiz-wrap {
  max-width: 680px;
  margin: 0 auto;
}
.gna5n-quiz-progress {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-10);
}
.gna5n-quiz-progress__bar {
  flex: 1;
  height: 6px;
  background: var(--clr-border);
  border-radius: var(--r-full);
  overflow: hidden;
}
.gna5n-quiz-progress__fill {
  height: 100%;
  background: var(--clr-forest);
  border-radius: var(--r-full);
  transition: width var(--tr-slow);
}
.gna5n-quiz-progress__label { font-size: var(--fs-sm); color: var(--clr-muted); white-space: nowrap; }
.gna5n-quiz-step { display: none; }
.gna5n-quiz-step.active { display: block; animation: panelIn var(--tr-base) both; }
.gna5n-quiz-q {
  font-family: var(--ff-serif);
  font-size: clamp(1.5rem, 3vw, var(--fs-2xl));
  margin-bottom: var(--sp-8);
  line-height: var(--lh-snug);
}
.gna5n-quiz-opts {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.gna5n-quiz-opt {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-6);
  border: 2px solid var(--clr-border);
  border-radius: var(--r-lg);
  background: var(--clr-white);
  text-align: left;
  font-size: var(--fs-base);
  color: var(--clr-ink-soft);
  transition: border-color var(--tr-fast), background var(--tr-fast);
  cursor: pointer;
}
.gna5n-quiz-opt:hover { border-color: var(--clr-sage); background: var(--clr-mint-bg); }
.gna5n-quiz-opt.selected { border-color: var(--clr-forest); background: var(--clr-mint-bg); color: var(--clr-forest); font-weight: var(--fw-semi); }
.gna5n-quiz-opt__icon {
  width: 36px; height: 36px;
  border-radius: var(--r-md);
  background: var(--clr-mint-bg);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--clr-forest);
}
.gna5n-quiz-nav {
  display: flex;
  gap: var(--sp-4);
  margin-top: var(--sp-8);
  align-items: center;
}
.gna5n-quiz-result {
  display: none;
  text-align: center;
  padding: var(--sp-12) 0;
  animation: panelIn var(--tr-slow) both;
}
.gna5n-quiz-result.active { display: block; }
.gna5n-quiz-result__badge {
  width: 72px; height: 72px;
  background: var(--clr-forest);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-6);
  color: var(--clr-white);
}
.gna5n-quiz-result__title {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  margin-bottom: var(--sp-4);
}
.gna5n-quiz-result__desc { font-size: var(--fs-md); color: var(--clr-muted); max-width: 480px; margin: 0 auto var(--sp-8); }
.gna5n-quiz-lead {
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-8);
  max-width: 440px;
  margin: 0 auto;
  text-align: left;
}
.gna5n-quiz-lead__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); margin-bottom: var(--sp-2); }
.gna5n-quiz-lead__desc { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-6); }

/* form elements */
.form-group { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.form-group label { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--clr-ink); }
.form-control {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-white);
  font-size: var(--fs-base);
  color: var(--clr-ink);
  transition: border-color var(--tr-fast), box-shadow var(--tr-fast);
}
.form-control:focus {
  outline: none;
  border-color: var(--clr-forest);
  box-shadow: 0 0 0 3px rgba(45,106,80,.15);
}
.form-control.error { border-color: var(--clr-error); }
textarea.form-control { resize: vertical; min-height: 120px; }
.form-hint { font-size: var(--fs-xs); color: var(--clr-muted); }
.form-error { font-size: var(--fs-xs); color: var(--clr-error); display: none; }
.form-error.visible { display: block; }
.form-success {
  background: var(--clr-mint-bg);
  border: 1.5px solid var(--clr-forest);
  border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-6);
  font-size: var(--fs-sm);
  color: var(--clr-forest);
  display: none;
}
.form-success.visible { display: block; }

/* services page */
.gna5n-services-grid {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.gna5n-svc-card {
  flex: 1 1 320px;
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-8);
}
.gna5n-svc-card__icon {
  width: 52px; height: 52px;
  background: var(--clr-mint-bg);
  border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-forest);
  margin-bottom: var(--sp-5);
}
.gna5n-svc-card__name { font-family: var(--ff-serif); font-size: var(--fs-2xl); margin-bottom: var(--sp-2); }
.gna5n-svc-card__audience { font-size: var(--fs-sm); color: var(--clr-sage); font-weight: var(--fw-medium); margin-bottom: var(--sp-4); }
.gna5n-svc-card__desc { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-5); }
.gna5n-svc-card__list { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-5); }
.gna5n-svc-card__list li {
  font-size: var(--fs-sm);
  color: var(--clr-ink-soft);
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
}
.gna5n-svc-card__list li::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--clr-sage);
  flex-shrink: 0;
  margin-top: 6px;
}
.gna5n-svc-card__note {
  font-size: var(--fs-xs);
  color: var(--clr-muted);
  background: var(--clr-cream-dk);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  border-left: 3px solid var(--clr-border);
}

/* article / guide pages */
.gna5n-article {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--sp-16) var(--sp-6);
}
.gna5n-article__header { margin-bottom: var(--sp-10); }
.gna5n-article__tag {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--clr-sage);
  margin-bottom: var(--sp-4);
}
.gna5n-article__title {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: var(--sp-5);
  letter-spacing: -.02em;
}
.gna5n-article__meta {
  display: flex;
  gap: var(--sp-5);
  align-items: center;
  flex-wrap: wrap;
  font-size: var(--fs-sm);
  color: var(--clr-muted);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
}
.gna5n-article__hero {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: var(--r-xl);
  margin-bottom: var(--sp-10);
  background: var(--clr-cream-dk);
}
.gna5n-article__body h2 { font-size: var(--fs-2xl); margin: var(--sp-10) 0 var(--sp-4); }
.gna5n-article__body h3 { font-size: var(--fs-xl); margin: var(--sp-8) 0 var(--sp-3); }
.gna5n-article__body p { margin-bottom: var(--sp-5); }
.gna5n-article__body ul, .gna5n-article__body ol { margin-bottom: var(--sp-5); padding-left: var(--sp-6); }
.gna5n-article__body ul { list-style: disc; }
.gna5n-article__body ol { list-style: decimal; }
.gna5n-article__body li { margin-bottom: var(--sp-2); color: var(--clr-ink-soft); }
.gna5n-article__body strong { color: var(--clr-ink); }
.gna5n-article__body a { color: var(--clr-forest); text-decoration: underline; text-underline-offset: 3px; }

/* reading progress */
#reading-progress {
  position: fixed;
  top: var(--header-h);
  left: 0; right: 0;
  height: 3px;
  background: var(--clr-border);
  z-index: var(--z-header);
}
#reading-progress .bar {
  height: 100%;
  background: var(--clr-forest);
  width: 0%;
  transition: width 100ms linear;
}

/* TOC */
.gna5n-toc {
  background: var(--clr-mint-bg);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  margin-bottom: var(--sp-8);
}
.gna5n-toc__title { font-size: var(--fs-sm); font-weight: var(--fw-bold); margin-bottom: var(--sp-4); letter-spacing: .05em; text-transform: uppercase; color: var(--clr-muted); }
.gna5n-toc ol { padding-left: var(--sp-4); list-style: decimal; }
.gna5n-toc li { margin-bottom: var(--sp-2); }
.gna5n-toc a { font-size: var(--fs-sm); color: var(--clr-ink-soft); transition: color var(--tr-fast); text-decoration: none; }
.gna5n-toc a:hover { color: var(--clr-forest); }

/* quiz hub */
.gna5n-quiz-hub-grid {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.gna5n-quiz-hub-card {
  flex: 1 1 340px;
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-10) var(--sp-8);
  text-align: center;
  transition: box-shadow var(--tr-base), transform var(--tr-base);
  cursor: pointer;
}
.gna5n-quiz-hub-card:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); }
.gna5n-quiz-hub-card__icon {
  width: 60px; height: 60px;
  background: var(--clr-mint-bg);
  border-radius: var(--r-xl);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-5);
  color: var(--clr-forest);
}
.gna5n-quiz-hub-card__title { font-family: var(--ff-serif); font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.gna5n-quiz-hub-card__desc { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-6); }
.gna5n-quiz-hub-card__meta { font-size: var(--fs-xs); color: var(--clr-muted); margin-bottom: var(--sp-6); }

/* contact */
.gna5n-contact-grid {
  display: flex;
  gap: var(--sp-12);
  flex-wrap: wrap;
  align-items: flex-start;
}
.gna5n-contact-info { flex: 1 1 260px; }
.gna5n-contact-form { flex: 2 1 400px; }
.gna5n-contact-detail {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.gna5n-contact-detail__icon {
  width: 40px; height: 40px;
  background: var(--clr-mint-bg);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-forest);
  flex-shrink: 0;
}
.gna5n-contact-detail__label { font-size: var(--fs-xs); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: .08em; color: var(--clr-muted); margin-bottom: var(--sp-1); }
.gna5n-contact-detail__value { font-size: var(--fs-sm); color: var(--clr-ink-soft); }

/* about */
.gna5n-about-hero {
  display: flex;
  gap: var(--sp-12);
  align-items: center;
  flex-wrap: wrap;
  padding: var(--sp-20) 0 var(--sp-16);
}
.gna5n-about-hero__text { flex: 1 1 400px; }
.gna5n-about-hero__img { flex: 1 1 340px; }
.gna5n-about-hero__img img {
  width: 100%;
  border-radius: var(--r-xl);
  aspect-ratio: 4/3;
  object-fit: cover;
  background: var(--clr-cream-dk);
}
.gna5n-values-grid {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.gna5n-value {
  flex: 1 1 240px;
  padding: var(--sp-6);
}
.gna5n-value__icon {
  width: 40px; height: 40px;
  background: var(--clr-forest);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-white);
  margin-bottom: var(--sp-4);
}
.gna5n-value__title { font-weight: var(--fw-semi); margin-bottom: var(--sp-2); }
.gna5n-value__desc { font-size: var(--fs-sm); color: var(--clr-muted); }

/* legal pages */
.gna5n-legal-body {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--sp-16) var(--sp-6);
}
.gna5n-legal-body h1 { font-size: var(--fs-3xl); margin-bottom: var(--sp-3); }
.gna5n-legal-body .updated { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-12); }
.gna5n-legal-body h2 { font-size: var(--fs-xl); margin: var(--sp-10) 0 var(--sp-4); }
.gna5n-legal-body h3 { font-size: var(--fs-lg); margin: var(--sp-6) 0 var(--sp-3); }
.gna5n-legal-body p { margin-bottom: var(--sp-4); }
.gna5n-legal-body ul { list-style: disc; padding-left: var(--sp-6); margin-bottom: var(--sp-5); }
.gna5n-legal-body li { margin-bottom: var(--sp-2); color: var(--clr-ink-soft); }
.gna5n-legal-body a { color: var(--clr-forest); text-decoration: underline; }

/* thank-you */
.gna5n-thankyou {
  text-align: center;
  padding: var(--sp-24) var(--sp-6);
  max-width: 560px;
  margin: 0 auto;
}
.gna5n-thankyou__icon {
  width: 80px; height: 80px;
  background: var(--clr-forest);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-8);
  color: var(--clr-white);
}
.gna5n-thankyou__title { font-size: var(--fs-3xl); margin-bottom: var(--sp-4); }
.gna5n-thankyou__desc { font-size: var(--fs-md); color: var(--clr-muted); margin-bottom: var(--sp-10); }
.gna5n-thankyou__links { display: flex; gap: var(--sp-4); justify-content: center; flex-wrap: wrap; }

/* guides hub */
.gna5n-guides-hub {
  padding: var(--sp-20) 0;
}

/* map section */
.gna5n-map-wrap {
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1.5px solid var(--clr-border);
  margin-top: var(--sp-8);
}
.gna5n-map-placeholder {
  background: var(--clr-cream-dk);
  aspect-ratio: 16/6;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-muted);
  font-size: var(--fs-sm);
}

/* CTA newsletter (article pages) */
.gna5n-cta-block {
  background: var(--clr-mint-bg);
  border: 1.5px solid var(--clr-forest);
  border-radius: var(--r-xl);
  padding: var(--sp-10) var(--sp-8);
  margin: var(--sp-12) 0;
  text-align: center;
}
.gna5n-cta-block__title { font-family: var(--ff-serif); font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.gna5n-cta-block__desc { font-size: var(--fs-sm); color: var(--clr-muted); margin-bottom: var(--sp-6); }
.gna5n-cta-block__form { display: flex; gap: var(--sp-3); max-width: 420px; margin: 0 auto; }
.gna5n-cta-block__form input { flex: 1; }

/* related reading */
.gna5n-related { margin-top: var(--sp-12); padding-top: var(--sp-10); border-top: 1px solid var(--clr-border); }
.gna5n-related__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); margin-bottom: var(--sp-6); }
.gna5n-related__grid { display: flex; gap: var(--sp-4); flex-wrap: wrap; }
.gna5n-related-link {
  flex: 1 1 220px;
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  transition: border-color var(--tr-fast), box-shadow var(--tr-fast);
  cursor: pointer;
}
.gna5n-related-link:hover { border-color: var(--clr-sage); box-shadow: var(--sh-sm); }
.gna5n-related-link__tag { font-size: var(--fs-xs); color: var(--clr-sage); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: .08em; margin-bottom: var(--sp-2); }
.gna5n-related-link__title { font-family: var(--ff-serif); font-size: var(--fs-base); line-height: var(--lh-snug); }

/* footer */
footer {
  background: var(--clr-ink);
  color: rgba(255,255,255,.8);
  padding: var(--sp-16) 0 var(--sp-8);
}
.footer-inner {
  display: flex;
  gap: var(--sp-10);
  flex-wrap: wrap;
  margin-bottom: var(--sp-12);
}
.footer-brand { flex: 2 1 300px; }
.footer-brand .gna5n-logo img { filter: brightness(0) invert(1); }
.footer-slogan {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  color: var(--clr-white);
  line-height: 1.15;
  margin-top: var(--sp-5);
  max-width: 360px;
}
.footer-slogan em { color: var(--clr-amber-lt); font-style: normal; }
.footer-col { flex: 1 1 140px; }
.footer-col h4 { font-size: var(--fs-xs); font-weight: var(--fw-bold); letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: var(--sp-4); }
.footer-col ul { display: flex; flex-direction: column; gap: var(--sp-3); }
.footer-col a { font-size: var(--fs-sm); color: rgba(255,255,255,.7); transition: color var(--tr-fast); }
.footer-col a:hover { color: var(--clr-white); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: var(--sp-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-4);
}
.footer-bottom p { font-size: var(--fs-xs); color: rgba(255,255,255,.4); }
.footer-legal { display: flex; gap: var(--sp-5); }
.footer-legal a { font-size: var(--fs-xs); color: rgba(255,255,255,.4); transition: color var(--tr-fast); }
.footer-legal a:hover { color: rgba(255,255,255,.8); }

/* cookie */
#cookie-banner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--clr-ink);
  color: var(--clr-white);
  padding: var(--sp-5) var(--sp-6);
  z-index: var(--z-toast);
  transform: translateY(100%);
  transition: transform var(--tr-slow);
  border-top: 3px solid var(--clr-forest);
}
#cookie-banner.visible { transform: translateY(0); }
.cookie-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.cookie-text { flex: 1 1 300px; font-size: var(--fs-sm); color: rgba(255,255,255,.8); }
.cookie-text a { color: var(--clr-amber-lt); text-decoration: underline; }
.cookie-btns { display: flex; gap: var(--sp-3); flex-shrink: 0; }
#cookie-accept { background: var(--clr-forest); color: var(--clr-white); padding: var(--sp-2) var(--sp-5); border-radius: var(--r-full); font-size: var(--fs-sm); font-weight: var(--fw-semi); transition: background var(--tr-fast); }
#cookie-accept:hover { background: var(--clr-sage); }
#cookie-decline { background: transparent; color: rgba(255,255,255,.6); padding: var(--sp-2) var(--sp-4); border-radius: var(--r-full); font-size: var(--fs-sm); border: 1px solid rgba(255,255,255,.2); transition: background var(--tr-fast), color var(--tr-fast); }
#cookie-decline:hover { background: rgba(255,255,255,.1); color: var(--clr-white); }

/* back to top */
#back-to-top {
  position: fixed;
  bottom: var(--sp-8);
  right: var(--sp-6);
  width: 44px; height: 44px;
  background: var(--clr-forest);
  color: var(--clr-white);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  z-index: var(--z-above);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity var(--tr-base), transform var(--tr-base), box-shadow var(--tr-fast);
  box-shadow: var(--sh-sm);
}
#back-to-top.visible { opacity: 1; pointer-events: all; transform: translateY(0); }
#back-to-top:hover { box-shadow: var(--sh-md); }

/* animations */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--tr-slow), transform var(--tr-slow);
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* responsive */
@media (min-width: 1025px) {
  .nav-links { display: flex; }
  .nav-actions { display: flex; }
  .hamburger { display: none; }
}
@media (max-width: 1024px) and (min-width: 769px) {
  .nav-actions { display: none; }
  .nav-links { display: flex; }
  .hamburger { display: none; }
}
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-actions { display: none; }
  .hamburger { display: flex; }
  .gna5n-selector__headline { font-size: 2.25rem; }
  .gna5n-quiz-teaser { padding: var(--sp-8) var(--sp-6); }
  .footer-slogan { font-size: var(--fs-2xl); }
  .gna5n-cta-block__form { flex-direction: column; }
  .gna5n-about-hero { gap: var(--sp-8); }
  .gna5n-contact-grid { flex-direction: column; }
  .section { padding: var(--sp-12) 0; }
}
@media (max-width: 480px) {
  :root { --container-pad: var(--sp-4); }
  .gna5n-quiz-teaser__cta { width: 100%; }
  .btn--white { width: 100%; justify-content: center; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
