/* ==================================================
   Mobile Hamburger → X Animation & Menu Styling
   ================================================== */
@media (max-width: 768px) {

  /* Hamburger container */
  .menu-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    order: 2;
    gap: 4px;
    background-color: var(--nf-menu-bg, #fff);
    padding: 4px;
    cursor: pointer;
    transition: background-color .3s ease;
    z-index: 1001;
  }

  /* Bars */
  .hamburger-bar {
    width: 30px;
    height: 4px;
    background-color: var(--nf-menu-text, #333);
    transition: transform 0.5s ease, opacity 0.5s ease, background-color .3s ease;
    transform-origin: center;
  }
	
  /* Active X state */
  .menu-toggle.active,
  .menu-toggle:active {
    background-color: #111;
    opacity: 0.75;
  }
  .menu-toggle.active .hamburger-bar {
    background-color: #fff;
  }
  .menu-toggle.active .hamburger-bar:nth-child(1) {
    transform: translateY(8px) rotate(225deg);
  }
  .menu-toggle.active .hamburger-bar:nth-child(2) {
    opacity: 0;
	transform: rotate(720deg);
  }
  .menu-toggle.active .hamburger-bar:nth-child(3) {
    transform: translateY(-8px) rotate(135deg);
  }

  /* Drop nav under header, match body gutters */
  .main-navigation {
    display: none;
    order: 3;
    width: 100%;
    padding: 0 10px;
    box-sizing: border-box;
    background: var(--nf-menu-bg, #fff);
  }
  .main-navigation.toggled {
    display: block;
  }
	
  /* Flex header so nav drops below toggle */
  #site-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .site-branding {
    order: 1;
    flex: 1 1 auto;
  }
  .menu-toggle {
    order: 2;
    margin-left: auto;
  }

  /* Vertical full-width links with dividers */
  .main-navigation ul {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
  }
  .main-navigation li {
    width: 100%;
    background: var(--nf-menu-bg, #fff);
    border-bottom: 1px solid #ddd;
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .main-navigation li:last-child {
    border-bottom: none;
  }
  .main-navigation a {
    display: block;
    width: 100%;             /* full-row click/highlight area */
    box-sizing: border-box;  /* include that padding inside the width */
    padding: 1rem;
    text-align: center;
    color: var(--nf-menu-text, #333);
    font-family: var(--nf-menu-font-family, "Open Sans Condensed", Helvetica, Arial, sans-serif);
    font-size: 18px;
    font-weight: 700;
    text-decoration: none;
    transition: background-color .3s ease, color .3s ease;
  }
  .main-navigation a:hover,
  .main-navigation a:focus {
    background-color: color-mix(in srgb, var(--nf-menu-bg, #fff) 85%, #ffffff 15%);
    color: var(--nf-menu-text, #0066cc);
  }
}

/* ==================================================
   Header / Top Navigation (moved from style.css)
   ================================================== */

/* 02 HEADER — white & compact */
#site-header {
  background: var(--nf-menu-bg, #fff);
  height: 50px;
  padding: 0 0rem;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 100;
  transition: transform .24s ease;
}

/* Top Menu behavior modes */
body.nf-top-menu-slight #site-header {
  top: calc(-1 * var(--nf-top-menu-offset, 8px));
  transform: none;
}

body.nf-top-menu-slide #site-header {
  transform: translateY(calc(-1 * var(--nf-top-menu-offset, 8px)));
}

body.nf-top-menu-slide.nf-top-menu-hidden #site-header {
  transform: translateY(calc(-100% - var(--nf-top-menu-offset, 8px)));
}

body.nf-top-menu-static #site-header {
  transform: translateY(0);
}

body.nf-top-menu-moves #site-header {
  position: relative;
  top: auto;
  transform: none;
}

/* FLOATING LOGO — top-left corner */
.site-logo {
  position: fixed;
  top: 0px;
  left: 2px;
  z-index: 200;
}
.site-logo img {
  display: block;
  max-height: 60px;
  width: auto;
  transition: transform .5s ease;
}
.site-logo img:hover {
  transform: rotate(5deg) scale(0.98);
}

/* MENU TOGGLE (mobile) — header hamburger */
.menu-toggle {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  order: 2;     /* sits to the right in the header flex */
  display: none;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 50px;
  height: 50px;
    background-color: var(--nf-menu-bg, #fff);
  padding: 4px;             /* breathing room */
  border-radius: 0;
  transition: background-color .3s ease;
  gap: 4px;                 /* tight spacing between bars */
  z-index: 1001;
}
.hamburger-bar {
  width: 30px;
  height: 4px;
  background-color: var(--nf-menu-text, #333);
  transition: transform 0.5s ease, opacity 0.5s ease, background-color .3s ease;
  transform-origin: center;
}

/* PRIMARY MENU — horizontal, right-aligned */
.main-navigation ul {
  display: flex;
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0 1rem;
}
.main-navigation li {
  margin-left: 1.5rem;
}
.main-navigation a {
  display: block;
  font-family: var(--nf-menu-font-family, "Open Sans Condensed", Helvetica, Arial, sans-serif);
  font-size: 20px;
  font-weight: 700;
  line-height: 30px;
  text-align: right;
  color: var(--nf-menu-text, #333);
  text-decoration: none;
  transition: color .3s ease;
}
.main-navigation a:hover,
.main-navigation a:focus,
.main-navigation .current-menu-item > a {
  color: var(--nf-menu-text, #0066cc);
}

/* Global link affordance + click feedback for top navigation links */
.main-navigation a,
.secondary-navigation a {
  position: relative;
  transition: color .26s ease, transform .14s ease, text-shadow .22s ease, box-shadow .22s ease, letter-spacing .22s ease;
}

.main-navigation a:active,
.secondary-navigation a:active {
  transform: scale(0.96);
}

.main-navigation a::after,
.main-navigation a::before,
.secondary-navigation a::after,
.secondary-navigation a::before {
  pointer-events: none;
}

/* 4) Text underline */
body.nf-menu-hover-text-underline .main-navigation a::after,
body.nf-menu-hover-text-underline .secondary-navigation a::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: 6px;
  height: 2px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .24s ease;
}
body.nf-menu-hover-text-underline .main-navigation a:hover::after,
body.nf-menu-hover-text-underline .main-navigation a:focus-visible::after,
body.nf-menu-hover-text-underline .secondary-navigation a:hover::after,
body.nf-menu-hover-text-underline .secondary-navigation a:focus-visible::after {
  transform: scaleX(1);
}

/* 21) Creative menu hover effect */
body.nf-menu-hover-creative .main-navigation a:hover,
body.nf-menu-hover-creative .main-navigation a:focus-visible,
body.nf-menu-hover-creative .secondary-navigation a:hover,
body.nf-menu-hover-creative .secondary-navigation a:focus-visible {
  letter-spacing: 0.03em;
  text-shadow: 0 0 12px color-mix(in srgb, var(--nf-menu-creative-color, #81ceff) 72%, transparent);
}
body.nf-menu-hover-creative .main-navigation a::after,
body.nf-menu-hover-creative .secondary-navigation a::after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 4px;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, currentColor 50%, transparent 100%);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .24s ease, transform .24s ease;
}
body.nf-menu-hover-creative .main-navigation a:hover::after,
body.nf-menu-hover-creative .main-navigation a:focus-visible::after,
body.nf-menu-hover-creative .secondary-navigation a:hover::after,
body.nf-menu-hover-creative .secondary-navigation a:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}

/* 24) Wavy menu line */
body.nf-menu-hover-wavy .main-navigation a::after,
body.nf-menu-hover-wavy .secondary-navigation a::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: 4px;
  height: 6px;
  opacity: 0;
  background-image:
    radial-gradient(circle at 4px -1px, currentColor 4px, transparent 4px),
    radial-gradient(circle at 12px 7px, currentColor 4px, transparent 4px);
  background-size: 16px 8px;
  background-repeat: repeat-x;
  transition: opacity .22s ease;
}
body.nf-menu-hover-wavy .main-navigation a:hover::after,
body.nf-menu-hover-wavy .main-navigation a:focus-visible::after,
body.nf-menu-hover-wavy .secondary-navigation a:hover::after,
body.nf-menu-hover-wavy .secondary-navigation a:focus-visible::after {
  opacity: .9;
}

/* Hover.css-inspired shadow/glow transitions */
body.nf-menu-hover-glow .main-navigation a:hover,
body.nf-menu-hover-glow .main-navigation a:focus-visible,
body.nf-menu-hover-glow .secondary-navigation a:hover,
body.nf-menu-hover-glow .secondary-navigation a:focus-visible {
  text-shadow:
    0 0 8px color-mix(in srgb, var(--nf-menu-glow-color, #8cdcff) 86%, transparent),
    0 0 18px color-mix(in srgb, var(--nf-menu-glow-color, #8cdcff) 48%, transparent);
  color: color-mix(in srgb, var(--nf-menu-glow-color, #8cdcff) 68%, #ffffff 32%);
}

body.nf-menu-hover-shadow .main-navigation a:hover,
body.nf-menu-hover-shadow .main-navigation a:focus-visible,
body.nf-menu-hover-shadow .secondary-navigation a:hover,
body.nf-menu-hover-shadow .secondary-navigation a:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.24);
}

/* Prismic-inspired City Nights text effect (primary menu only) */
@keyframes nf-menu-lights {
  0% {
    color: hsl(230, 40%, 80%);
    text-shadow:
      0 0 1em hsla(320, 100%, 50%, 0.2),
      0 0 0.125em hsla(320, 100%, 60%, 0.3),
      -1em -0.125em 0.5em hsla(40, 100%, 60%, 0),
      1em 0.125em 0.5em hsla(200, 100%, 60%, 0);
  }
  30% {
    color: hsl(230, 80%, 90%);
    text-shadow:
      0 0 1em hsla(320, 100%, 50%, 0.5),
      0 0 0.125em hsla(320, 100%, 60%, 0.5),
      -0.5em -0.125em 0.25em hsla(40, 100%, 60%, 0.2),
      0.5em 0.125em 0.25em hsla(200, 100%, 60%, 0.4);
  }
  40% {
    color: hsl(230, 100%, 95%);
    text-shadow:
      0 0 1em hsla(320, 100%, 50%, 0.5),
      0 0 0.125em hsla(320, 100%, 90%, 0.5),
      -0.25em -0.125em 0.125em hsla(40, 100%, 60%, 0.2),
      0.25em 0.125em 0.125em hsla(200, 100%, 60%, 0.4);
  }
  70% {
    color: hsl(230, 80%, 90%);
    text-shadow:
      0 0 1em hsla(320, 100%, 50%, 0.5),
      0 0 0.125em hsla(320, 100%, 60%, 0.5),
      0.5em -0.125em 0.25em hsla(40, 100%, 60%, 0.2),
      -0.5em 0.125em 0.25em hsla(200, 100%, 60%, 0.4);
  }
  100% {
    color: hsl(230, 40%, 80%);
    text-shadow:
      0 0 1em hsla(320, 100%, 50%, 0.2),
      0 0 0.125em hsla(320, 100%, 60%, 0.3),
      1em -0.125em 0.5em hsla(40, 100%, 60%, 0),
      -1em 0.125em 0.5em hsla(200, 100%, 60%, 0);
  }
}

body.nf-menu-hover-city-nights .main-navigation a:hover,
body.nf-menu-hover-city-nights .main-navigation a:focus-visible {
  animation: nf-menu-lights 5s 750ms linear infinite;
  transform: translateY(-1px) scale(1.03);
}

body.nf-menu-hover-city-nights .main-navigation a:active {
  transform: scale(0.95);
}

/* Hover.css-inspired 2D transitions */
body.nf-menu-hover-twod .main-navigation a:hover,
body.nf-menu-hover-twod .main-navigation a:focus-visible,
body.nf-menu-hover-twod .secondary-navigation a:hover,
body.nf-menu-hover-twod .secondary-navigation a:focus-visible {
  transform: translateY(-2px) scale(1.05);
}

body.nf-menu-hover-twod .main-navigation a:active,
body.nf-menu-hover-twod .secondary-navigation a:active {
  transform: translateY(0) scale(0.94) rotate(-1deg);
}

/* 26) Animated text hover */
body.nf-menu-hover-animated-text .main-navigation a,
body.nf-menu-hover-animated-text .secondary-navigation a {
  transition: letter-spacing .24s ease, transform .24s ease, color .24s ease;
}
body.nf-menu-hover-animated-text .main-navigation a:hover,
body.nf-menu-hover-animated-text .main-navigation a:focus-visible,
body.nf-menu-hover-animated-text .secondary-navigation a:hover,
body.nf-menu-hover-animated-text .secondary-navigation a:focus-visible {
  letter-spacing: .06em;
  transform: translateY(-1px);
  color: color-mix(in srgb, var(--nf-menu-text, #0066cc) 74%, #ffffff 26%);
}

/* 20) CSS menu transition */
body.nf-menu-hover-menu-transition .main-navigation a::before,
body.nf-menu-hover-menu-transition .secondary-navigation a::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 3px;
  height: 2px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(.25);
  transition: transform .22s ease, opacity .22s ease;
}
body.nf-menu-hover-menu-transition .main-navigation a:hover::before,
body.nf-menu-hover-menu-transition .main-navigation a:focus-visible::before,
body.nf-menu-hover-menu-transition .secondary-navigation a:hover::before,
body.nf-menu-hover-menu-transition .secondary-navigation a:focus-visible::before {
  opacity: 1;
  transform: scaleX(1);
}

/* RSS ICON next to Podcast menu item */
.menu-rss-icon {
  margin-left: 0.3em;
  font-size: 0.9em;
  color: inherit;
  text-decoration: none;
}
.menu-rss-icon:hover,
.menu-rss-icon:focus {
  color: var(--nf-menu-text, #0066cc);
}

/* Animated RSS Icon */
.rss-icon {
  display: inline-block;
  width: 36px;
  height: 36px;
  background-color: #333;
  border-radius: 4px;
  transition: background-color .5s ease, transform .5s ease;
  vertical-align: middle;
  overflow: hidden;
}
.rss-icon .rss-svg {
  width: 100%;
  height: 100%;
  display: block;
}
.rss-icon:hover { background-color: #FF6600; }
@keyframes rss-spin { to { transform: rotate(360deg); } }
.rss-icon.spin { animation: rss-spin 3s linear infinite; }

/* SECONDARY MENU — below header */
.secondary-navigation {
  background: #f9f9f9;
  width: 100%;
  text-align: right;
  padding: 0.5rem 1rem;
}
.secondary-navigation ul {
  display: flex;
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0;
}
.secondary-navigation li { margin-left: 1rem; }
.secondary-navigation a {
  display: block;
  font-family: var(--nf-menu-font-family, "Open Sans Condensed", Helvetica, Arial, sans-serif);
  font-size: 16px;
  font-weight: 600;
  color: #555;
  text-decoration: none;
  transition: color .3s ease;
}
.secondary-navigation a:hover,
.secondary-navigation a:focus { color: #333; }

/* Mobile Hamburger → X Animation & Menu Styling (≤768px) */
@media (max-width: 768px) {
  /* Hamburger container */
  .menu-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    order: 2;
    gap: 4px;
  background-color: var(--nf-menu-bg, #fff);
    padding: 4px;
    cursor: pointer;
    transition: background-color .3s ease;
    z-index: 1001;
  }

  /* Bars */
  .hamburger-bar {
    width: 30px;
    height: 4px;
    background-color: var(--nf-menu-text, #333);
    transition: transform 0.5s ease, opacity 0.5s ease, background-color .3s ease;
    transform-origin: center;
  }

  /* Active X state */
  .menu-toggle.active,
  .menu-toggle:active { background-color: #111; opacity: 0.75; }
  .menu-toggle.active .hamburger-bar { background-color: #fff; }
  .menu-toggle.active .hamburger-bar:nth-child(1) {
    transform: translateY(8px) rotate(225deg);
  }
  .menu-toggle.active .hamburger-bar:nth-child(2) {
    opacity: 0;
    transform: rotate(720deg);
  }
  .menu-toggle.active .hamburger-bar:nth-child(3) {
    transform: translateY(-8px) rotate(135deg);
  }

  /* Drop nav under header, match body gutters */
  .main-navigation {
    display: none;
    order: 3;
    width: 100%;
    padding: 0 10px;
    box-sizing: border-box;
    background: var(--nf-menu-bg, #fff);
  }
  .main-navigation.toggled { display: block; }

  /* Flex header so nav drops below toggle */
  #site-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .site-branding { order: 1; flex: 1 1 auto; }
  .menu-toggle { order: 2; margin-left: auto; }

  /* Vertical full-width links with dividers */
  .main-navigation ul {
    display: flex; flex-direction: column; margin: 0; padding: 0;
  }
  .main-navigation li {
    width: 100%;
    background: var(--nf-menu-bg, #fff);
    border-bottom: 1px solid #ddd;
    list-style: none; margin: 0; padding: 0;
  }
  .main-navigation li:last-child { border-bottom: none; }
  .main-navigation a {
    display: block; width: 100%; box-sizing: border-box; padding: 1rem;
    text-align: center; color: var(--nf-menu-text, #333);
    font-family: var(--nf-menu-font-family, "Open Sans Condensed", Helvetica, Arial, sans-serif);
    font-size: 18px; font-weight: 700; text-decoration: none;
    transition: background-color .3s ease, color .3s ease;
  }
  .main-navigation a:hover,
  .main-navigation a:focus { background-color: color-mix(in srgb, var(--nf-menu-bg, #fff) 85%, #ffffff 15%); color: var(--nf-menu-text, #0066cc); }
}

/* Helpful focus styles */
.site-header .menu-toggle:focus-visible,
.main-navigation a:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

/* ==================================================
   Mobile Nav Style Variants
   ================================================== */
@media (max-width: 768px) {
  body.nf-mobile-nav-style-liquid .menu-toggle {
    border-radius: 999px;
    width: 46px;
    height: 46px;
    margin-right: 8px;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  }

  body.nf-mobile-nav-style-liquid #site-navigation {
    display: block;
    position: fixed;
    top: 52px;
    left: 10px;
    right: 10px;
    transform: translateY(-12px) scale(0.98);
    opacity: 0;
    pointer-events: none;
    border-radius: 14px;
    background: color-mix(in srgb, var(--nf-menu-bg, #fff) 92%, #000 8%);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.28);
    transition: transform .28s ease, opacity .28s ease;
  }
  body.nf-mobile-nav-style-liquid #site-navigation.toggled {
    transform: translateY(0) scale(1);
    opacity: 1;
    pointer-events: auto;
  }

  body.nf-mobile-nav-style-morph #site-navigation,
  body.nf-mobile-nav-style-push #site-navigation {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    width: min(86vw, 360px);
    height: 100vh;
    padding: 62px 12px 12px;
    transform: translateX(102%);
    opacity: 1;
    pointer-events: none;
    background: color-mix(in srgb, var(--nf-menu-bg, #fff) 88%, #000 12%);
    box-shadow: -12px 0 30px rgba(0, 0, 0, 0.35);
    transition: transform .32s cubic-bezier(.2,.7,.15,1);
    z-index: 1200;
  }

  body.nf-mobile-nav-style-morph #site-navigation.toggled,
  body.nf-mobile-nav-style-push #site-navigation.toggled {
    transform: translateX(0);
    pointer-events: auto;
  }

  body.nf-mobile-nav-style-morph #site-navigation ul,
  body.nf-mobile-nav-style-push #site-navigation ul {
    background: transparent;
  }

  body.nf-mobile-nav-style-morph #site-navigation li,
  body.nf-mobile-nav-style-push #site-navigation li {
    border-bottom-color: rgba(255, 255, 255, 0.12);
    background: transparent;
  }

  body.nf-mobile-nav-style-push.nf-mobile-nav-open::before,
  body.nf-mobile-nav-style-morph.nf-mobile-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    z-index: 1100;
  }

  body.nf-mobile-nav-style-push.nf-mobile-nav-open .site-main,
  body.nf-mobile-nav-style-push.nf-mobile-nav-open #page-content,
  body.nf-mobile-nav-style-push.nf-mobile-nav-open #site-footer {
    transform: translateX(-22px);
    opacity: .92;
    transition: transform .26s ease, opacity .26s ease;
  }
}
