/* =========================================================
   RESPONSIVE.CSS — CLEANED
   ========================================================= */


/* =========================================================
   GLOBAL BACKGROUND
   ========================================================= */

html,
body {
  background-color: #050608 !important;
}

body {
  background-image:
    url("../images/niskakoski.jpg") !important;

  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
}

/* Osioiden ei pidä peittää body-taustaa */
.snap-section,
.home-section,
.intro-section,
.virtual-trail-section,
.tours-section,
.journal-section,
.contact-section {
  background: transparent !important;
  background-image: none !important;
}


/* =========================================================
   DESKTOP / LAPTOP GENERAL
   ========================================================= */

@media (max-width: 1360px) {
  .trezor-nav {
    gap: 18px;
  }

  .banner-nav .nav-link {
    gap: 6px;
    font-size: 12px;
    letter-spacing: 0.03em;
  }
}

@media (min-width: 901px) and (max-width: 1399px) and (max-height: 650px) {
  .fixed-gold-scroll {
    bottom: 8px;
  }
}


/* =========================================================
   LAPTOP 1200–1400px
   ========================================================= */

@media (min-width: 1200px) and (max-width: 1400px) {
  .section-header h2 {
    font-size: 32px;
  }

  .section-title-icon {
    width: 36px;
  }

  .virtual-bear-icon {
    width: clamp(96px, 9.5vw, 142px);
  }

  .intro-text,
  .virtual-text,
  .journal-text {
    font-size: 30px;
    line-height: 1.35;
  }

  #home {
    position: relative !important;
    min-height: 100vh !important;
    overflow: hidden !important;
  }

  #home .hero-image-wrap.scroll-bear-layer {
    position: absolute !important;
    top: -74px !important;
    right: 217px !important;
    left: auto !important;
    width: 500px !important;
    max-width: none !important;
    margin: 0 !important;
    transform: none !important;
    z-index: 1 !important;
  }

  #home .hero-title-block {
    position: absolute !important;
    top: 194px !important;
    left: 54% !important;
    right: auto !important;
    width: max-content !important;
    max-width: 94vw !important;
    margin: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    z-index: 4 !important;
  }

  #home .hero-eyebrow {
    color: #faba00 !important;
    -webkit-text-fill-color: #faba00 !important;
    font-size: clamp(42px, 4.2vw, 58px) !important;
    line-height: 0.9 !important;
    letter-spacing: 0.14em !important;
  }

  #home .hero-kicker {
    font-size: clamp(11px, 0.85vw, 16px) !important;
    letter-spacing: 0.22em !important;
  }

  #home .home-quote-wrap {
    position: absolute !important;
    top: 332px !important;
    left: 50% !important;
    right: auto !important;
    display: block !important;
    margin: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 5 !important;
  }
}


/* =========================================================
   LAPTOP LOW HEIGHT
   ========================================================= */

@media (min-width: 1200px) and (max-width: 1400px) and (max-height: 650px) {
  #vieraskirja .section-inner {
    justify-content: center;
    gap: 10px;
    padding-top: 98px;
    padding-bottom: 32px;
  }

  #vieraskirja .section-title-icon {
    display: none;
  }

  #vieraskirja .section-header h2 {
    font-size: 30px;
  }

  #vieraskirja .journal-text {
    font-size: 28px;
    line-height: 1.15;
  }

  #vieraskirja .journal-image-wrap {
    width: min(54vw, 540px);
    margin-top: 2px;
  }

  .virtual-image,
  #vieraskirja .journal-image {
    -webkit-mask-image:
      linear-gradient(to right, transparent 0%, #000 24%, #000 76%, transparent 100%),
      linear-gradient(to bottom, transparent 0%, #000 14%, #000 84%, transparent 100%);
    -webkit-mask-composite: source-in;

    mask-image:
      linear-gradient(to right, transparent 0%, #000 24%, #000 76%, transparent 100%),
      linear-gradient(to bottom, transparent 0%, #000 14%, #000 84%, transparent 100%);
    mask-composite: intersect;
  }

  #vieraskirja .journal-image {
    max-height: 32vh;
  }

  #vieraskirja .journal-actions-below-image {
    gap: 8px;
    margin-top: 8px;
  }

  #vieraskirja .journal-actions-below-image .ui-btn {
    width: 190px;
    min-height: 34px;
    padding: 5px 14px;
    font-size: 6.4px;
  }
}


/* =========================================================
   DESKTOP 1401–1800px
   ========================================================= */

@media (min-width: 1401px) and (max-width: 1800px) {
  #home {
    position: relative !important;
    min-height: 100vh !important;
    overflow: hidden !important;
  }

  #home .hero-image-wrap.scroll-bear-layer {
    position: absolute !important;
    top: 14px !important;
    right: 312px !important;
    left: auto !important;
    width: 611px !important;
    max-width: none !important;
    margin: 0 !important;
    transform: none !important;
    z-index: 1 !important;
  }

  #home .hero-title-block {
    position: absolute !important;
    top: 332px !important;
    left: 47% !important;
    right: auto !important;
    width: max-content !important;
    max-width: 94vw !important;
    margin: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    z-index: 4 !important;
  }

  #home .hero-eyebrow {
    color: #faba00 !important;
    -webkit-text-fill-color: #faba00 !important;
    font-size: clamp(46px, 3.4vw, 62px) !important;
    line-height: 0.9 !important;
    letter-spacing: 0.15em !important;
  }

  #home .hero-kicker {
    font-size: clamp(11px, 0.85vw, 16px) !important;
    letter-spacing: 0.22em !important;
  }

  #home .home-quote-wrap {
    position: absolute !important;
    top: 590px !important;
    left: 50% !important;
    right: auto !important;
    display: block !important;
    margin: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 5 !important;
  }
}


/* =========================================================
   DESKTOP ONLY
   ========================================================= */

@media (min-width: 901px) {
  .mobile-menu,
  .mobile-menu-panel {
    display: none !important;
  }
}


/* =========================================================
   MOBILE GENERAL
   ========================================================= */

@media (max-width: 900px) {
  :root {
    --banner-visual-side-gap: 10px;
    --mobile-banner-top: 22px;
    --mobile-banner-height: 58px;
  }

  html,
  body {
    overflow-x: hidden;
    background-color: #050608 !important;
  }

  body {
    background-image:
      linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.35) 0%,
        rgba(0, 0, 0, 0.62) 48%,
        rgba(0, 0, 0, 0.88) 100%
      ),
      url("../images/niskakoski.jpg") !important;

    background-position: center center !important;
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-attachment: scroll !important;
  }

  body::before,
  body::after {
    display: none !important;
    content: none !important;
  }

  .snap-section,
  .home-section,
  .intro-section,
  .virtual-trail-section,
  .tours-section,
  .journal-section,
  .contact-section {
    background: transparent !important;
    background-image: none !important;
    background-attachment: scroll !important;
    overflow: hidden;
    isolation: isolate;
  }

  .trezor-nav,
  .banner-nav,
  .products-mega,
  .guide-mega,
  .journal-mega {
    display: none !important;
  }

  .section-inner {
    width: 100%;
    max-width: none;
    min-height: 100%;
    gap: 14px;
    padding:
      calc(var(--banner-top) + var(--banner-height) + 20px)
      18px
      86px;
  }

  .intro-text,
  .virtual-text,
  .journal-text {
    font-size: clamp(22px, 6vw, 30px);
    line-height: 1.26;
  }

  .section-header h2 {
    font-size: clamp(24px, 6vw, 34px);
  }

  .section-title-icon {
    width: 34px;
  }

  .virtual-image {
    width: min(88vw, 450px);
    max-height: 28vh;
  }

  .journal-image {
    width: min(86vw, 420px);
    max-height: 26vh;
  }

  .virtual-bear-icon {
    width: clamp(82px, 20vw, 118px);
  }
}


/* =========================================================
   MOBILE BANNER — LIGHT PILL
   ========================================================= */

@media (max-width: 900px) {
  .site-banner,
  .site-banner.trezor-banner {
    position: fixed !important;
    top: 12px !important;
    left: 12px !important;
    right: 12px !important;
    z-index: 100000 !important;

    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;

    height: 58px !important;
    min-height: 58px !important;
    padding: 8px 14px !important;

    border: 1px solid rgba(90, 76, 54, 0.12) !important;
    border-radius: 999px !important;

    background: rgba(245, 242, 236, 0.96) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.22) !important;

    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
  }

  .site-banner::before,
  .site-banner::after,
  .site-banner.trezor-banner::before,
  .site-banner.trezor-banner::after {
    content: none !important;
    display: none !important;
  }

  .banner-left {
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  .banner-left picture {
    display: block !important;
  }

  .banner-home-link {
    text-decoration: none !important;
  }

  .banner-logo {
    display: block !important;
    width: auto !important;
    height: 36px !important;
    max-width: 48vw !important;
    object-fit: contain !important;
    filter: none !important;
  }

  .banner-right {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 9px !important;
    flex: 0 0 auto !important;
    margin-left: 8px !important;
  }

  .lang-text-link {
    min-width: auto !important;
    height: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    color: #2f2a24 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    text-decoration: none !important;

    border-radius: 0 !important;
    text-shadow: none !important;
  }

  .lang-text-link:hover,
  .lang-text-link:focus-visible {
    color: #8a6415 !important;
    background: transparent !important;
  }

  .burger {
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;

    width: 34px !important;
    height: 34px !important;
    padding: 0 !important;

    border: none !important;
    border-radius: 50% !important;
    background: transparent !important;
    box-shadow: none !important;
    cursor: pointer !important;
  }

  .burger span {
    display: block !important;
    width: 20px !important;
    height: 2px !important;
    margin: 0 !important;
    border-radius: 999px !important;
    background: #2f2a24 !important;
    box-shadow: none !important;
    transition:
      transform 0.25s ease,
      opacity 0.2s ease,
      background 0.2s ease !important;
  }

  .burger[aria-expanded="true"] span:nth-child(1) {
    transform: translateY(6px) rotate(45deg) !important;
  }

  .burger[aria-expanded="true"] span:nth-child(2) {
    opacity: 0 !important;
  }

  .burger[aria-expanded="true"] span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg) !important;
  }
}


/* =========================================================
   MOBILE MENU
   ========================================================= */

@media (max-width: 900px) {
  .mobile-menu,
  .mobile-menu-panel {
    position: fixed !important;
    top: 84px !important;
    left: 12px !important;
    right: 12px !important;
    z-index: 99999 !important;

    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;

    width: auto !important;
    max-width: none !important;
    max-height: calc(100dvh - 108px) !important;

    padding: 18px !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    box-sizing: border-box !important;

    border: 1px solid rgba(250, 186, 0, 0.14) !important;
    border-radius: 28px !important;

    background:
      radial-gradient(circle at 50% 0%, rgba(250, 186, 0, 0.11), transparent 34%),
      linear-gradient(145deg, rgba(35, 36, 33, 0.92), rgba(8, 9, 8, 0.88)) !important;

    box-shadow:
      0 26px 70px rgba(0, 0, 0, 0.72),
      inset 0 1px 0 rgba(255, 255, 255, 0.13),
      inset 0 -1px 0 rgba(250, 186, 0, 0.08) !important;

    backdrop-filter: blur(22px) saturate(1.18) !important;
    -webkit-backdrop-filter: blur(22px) saturate(1.18) !important;

    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(-10px) scale(0.985) !important;

    transition:
      opacity 0.25s ease,
      transform 0.25s ease !important;
  }

  .mobile-menu.is-open,
  .mobile-menu-panel.is-open {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(0) scale(1) !important;
  }

  .mobile-menu-content {
    display: flex;
    flex-direction: column;
    gap: 22px;
  }

  .mobile-menu-block {
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  }

  .mobile-menu-block:last-child {
    padding-bottom: 0;
    border-bottom: 0;
  }

  .mobile-menu-heading {
    margin: 0 0 10px;
    color: #faba00;
    font-family: Inter, sans-serif;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.13em;
    text-transform: uppercase;
  }

  .mobile-menu-row {
    display: grid !important;
    grid-template-columns: 74px minmax(0, 1fr) !important;
    align-items: center !important;
    column-gap: 14px !important;

    width: 100% !important;
    min-height: 68px !important;
    margin-bottom: 8px !important;
    padding: 7px 10px 7px 7px !important;

    box-sizing: border-box !important;
    overflow: hidden !important;

    color: rgba(255, 255, 255, 0.92) !important;
    text-decoration: none !important;

    border: 1px solid rgba(255, 255, 255, 0.095) !important;
    border-radius: 11px !important;
    background: rgba(255, 255, 255, 0.035) !important;
  }

  .mobile-menu-row:last-child {
    margin-bottom: 0 !important;
  }

  .mobile-menu-row:hover,
  .mobile-menu-row:focus-visible {
    border-color: rgba(250, 186, 0, 0.42) !important;
    background: rgba(250, 186, 0, 0.055) !important;
    outline: none !important;
  }

  .mobile-menu-row::before,
  .mobile-menu-arrow {
    content: none !important;
    display: none !important;
  }

  .mobile-menu-thumb {
    display: block !important;
    width: 74px !important;
    height: 54px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: rgba(255, 255, 255, 0.05) !important;
  }

  .mobile-menu-thumb img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    filter: brightness(0.82) contrast(1.05) !important;
  }

  .mobile-menu-row-text {
    min-width: 0 !important;
  }

  .mobile-menu-row-text strong {
    display: block !important;
    color: rgba(255, 255, 255, 0.95) !important;
    font-family: "Cormorant Garamond", serif !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    line-height: 1.05 !important;
    letter-spacing: 0.01em !important;
  }
}


/* =========================================================
   MOBILE HOME HERO
   ========================================================= */

@media (max-width: 600px) {
  #home {
    position: relative !important;
    min-height: 100svh !important;
    min-height: 100dvh !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .home-stack {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    min-height: 100svh !important;
    min-height: 100dvh !important;
  }

  #home .hero-image-wrap.scroll-bear-layer {
    position: absolute !important;
    top: 95px !important;
    left: 50% !important;
    right: auto !important;
    display: block !important;
    width: 450px !important;
    max-width: 92vw !important;
    height: auto !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: none !important;
    z-index: 1 !important;
  }

  #home .hero-image-wrap.scroll-bear-layer img,
  #home .hero-image {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: center center !important;
    opacity: 1 !important;
    visibility: visible !important;
    filter: brightness(1.08) contrast(1.18) !important;
  }

  #home::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background:
      linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.16) 0%,
        rgba(0, 0, 0, 0.20) 36%,
        rgba(0, 0, 0, 0.56) 66%,
        rgba(0, 0, 0, 0.86) 100%
      );
  }

  #home .hero-title-block {
    --hero-heading-x: 0px !important;

    position: absolute !important;
    top: 365px !important;
    left: 50% !important;
    right: auto !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding: 0 10px !important;
    overflow: visible !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    z-index: 4 !important;
  }

  #home .hero-kicker {
    display: block !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: clamp(10px, 3vw, 13px) !important;
    letter-spacing: 0.18em !important;
    text-align: center !important;
    transform: none !important;
  }

  #home .hero-eyebrow {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    color: #faba00 !important;
    -webkit-text-fill-color: #faba00 !important;
    font-size: clamp(32px, 9.2vw, 39px) !important;
    line-height: 0.92 !important;
    letter-spacing: 0.08em !important;
    text-align: center !important;
    white-space: normal !important;
    transform: none !important;
    text-shadow:
      0 3px 8px rgba(0, 0, 0, 0.95),
      0 14px 28px rgba(0, 0, 0, 0.72) !important;
  }

  #home .home-quote-wrap {
    position: absolute !important;
    top: 475px !important;
    left: 50% !important;
    right: auto !important;
    display: block !important;
    width: 88vw !important;
    max-width: 88vw !important;
    margin: 0 !important;
    text-align: center !important;
    transform: translateX(-50%) !important;
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 5 !important;
  }
}


/* =========================================================
   INTRO + TOURS QUOTES
   ========================================================= */

#intro.intro-section {
  display: grid !important;
  place-items: center !important;
}

#intro .intro-stage {
  width: 100% !important;
  min-height: 100dvh !important;
  display: grid !important;
  place-items: center !important;
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
}

#intro .section-inner {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 auto !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
  box-sizing: border-box !important;
  text-align: center !important;
}

#intro .hero-quote-wrap.intro-quote-wrap,
#tours .hero-quote-wrap.intro-quote-wrap {
  width: min(88vw, 980px) !important;
  max-width: 980px !important;
  margin: 0 auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  text-align: center !important;
  box-sizing: border-box !important;
}

#intro blockquote.hero-forest-quote.intro-forest-quote,
#intro blockquote.hero-forest-quote.intro-forest-quote p,
#tours blockquote.hero-forest-quote.intro-forest-quote,
#tours blockquote.hero-forest-quote.intro-forest-quote p {
  width: 100% !important;
  max-width: 980px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  text-align: center !important;
  box-sizing: border-box !important;
}

#tours.tours-section {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-height: 100dvh !important;
  overflow: hidden !important;
}

#tours .tours-stage {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  max-width: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
  left: 0 !important;
  right: 0 !important;
  transform: none !important;
  box-sizing: border-box !important;
}

#tours .section-inner {
  width: 100% !important;
  max-width: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
  box-sizing: border-box !important;
  text-align: center !important;
}

#tours .tours-actions {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}


/* =========================================================
   QUOTE ORNAMENTS OFF
   ========================================================= */

.hero-quote-ornament,
.hero-quote-ornament-bottom,
.hero-quote-wrap::before,
.hero-quote-wrap::after,
.intro-quote-wrap::before,
.intro-quote-wrap::after,
.home-quote-wrap::before,
.home-quote-wrap::after {
  display: none !important;
  content: none !important;
}


/* =========================================================
   VIRTUAL TRAIL LINK
   ========================================================= */

.virtual-trail-entry {
  position: relative;
  display: inline-block;
  text-decoration: none;
}

.virtual-trail-entry .virtual-image {
  transition:
    transform 0.35s ease,
    filter 0.35s ease,
    box-shadow 0.35s ease;
}

.virtual-trail-entry:hover .virtual-image {
  transform: scale(1.035);
  filter: brightness(1.08);
}

.virtual-link-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 22px;
  padding: 12px 24px;
  color: #faba00;
  background: rgba(5, 6, 8, 0.45);
  border: 1px solid rgba(250, 186, 0, 0.65);
  border-radius: 999px;
  font-family: "Cinzel", serif;
  font-size: clamp(15px, 2vw, 20px);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: 0 0 22px rgba(250, 186, 0, 0.18);
  transition:
    transform 0.25s ease,
    background 0.25s ease,
    box-shadow 0.25s ease;
}

.virtual-trail-entry:hover .virtual-link-label {
  transform: translateY(-2px);
  background: rgba(250, 186, 0, 0.12);
  box-shadow: 0 0 32px rgba(250, 186, 0, 0.35);
}


/* =========================================================
   MODALS / OVERLAYS MOBILE
   ========================================================= */

@media (max-width: 900px) {
  .tours-window-article,
  .guide-article {
    width: calc(100vw - 16px);
    height: calc(100vh - 16px);
    margin: 8px auto;
    border-radius: 18px;
  }

  .tours-window-topbar {
    height: 56px;
    padding: 0 64px 0 16px;
  }

  .tours-window-topbar h2 {
    font-size: 15px;
  }

  .tours-window-frame {
    inset: 56px 0 0 0;
    height: calc(100% - 56px);
  }

  .guide-shell {
    padding: 24px 16px 22px;
  }

  .guide-hero,
  .guide-mega-inner--info-grid,
  .guide-mega-panel--combined {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .guide-photo-wrap {
    max-width: 420px;
    margin: 0 auto;
  }

  .guide-intro h2 {
    font-size: 24px;
  }

  .guide-lead,
  .guide-body-text,
  .guide-quote p {
    font-size: 21px;
  }

  .guide-mega-panel--combined,
  .guide-mega-panel--history {
    min-height: 0;
  }

  .guide-mega-panel--history {
    grid-template-rows: 120px 1fr;
  }
}


/* =========================================================
   VERY SMALL MOBILE
   ========================================================= */

@media (max-width: 420px) {
  .site-banner,
  .site-banner.trezor-banner {
    left: 10px !important;
    right: 10px !important;
  }
}

@media (max-width: 400px) {
  #home .hero-title-block {
    top: 355px !important;
  }

  .hero-eyebrow {
    font-size: 35px;
  }

  .mobile-menu-row {
    grid-template-columns: 66px minmax(0, 1fr) !important;
    column-gap: 12px !important;
  }

  .mobile-menu-thumb {
    width: 66px !important;
    height: 50px !important;
  }

  .mobile-menu-row-text strong {
    font-size: 18px !important;
  }
}

@media (max-width: 380px) {
  .hero-eyebrow {
    letter-spacing: 0.12em;
  }
}


/* =========================================================
   TABLET / LOW HEIGHT
   ========================================================= */

@media (min-width: 701px) and (max-width: 950px) and (max-height: 600px) {
  .hero-eyebrow {
    margin-bottom: 6px;
    font-size: 22px;
    letter-spacing: 0.22em;
  }

  .intro-text,
  .virtual-text,
  .journal-text {
    font-size: 25px;
    line-height: 1.35;
  }

  .hero-image {
    max-height: 42vh;
  }
}


/* Desktop: karhukuva vähän näkyvämmäksi */
@media (min-width: 901px) {
  #home .hero-image-wrap.scroll-bear-layer,
  #home .hero-image {
    opacity: 0.7 !important;
    filter: brightness(1.35) !important;
  }
}

/* =========================================================
   FINAL: SECTION BACKGROUNDS + MOBILE STABILITY
   ========================================================= */

/* INTRO = musta tunnelma */
#intro {
  background:
    radial-gradient(
      circle at 50% 42%,
      rgba(255, 255, 255, 0.045),
      transparent 36%
    ),
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.86) 0%,
      rgba(2, 3, 4, 0.98) 42%,
      rgba(2, 3, 4, 0.98) 72%,
      rgba(0, 0, 0, 0.90) 100%
    ) !important;
}

/* DESKTOP: polku-tausta */
#virtual-trail,
#tours,
#vieraskirja {
  background:
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.54) 0%,
      rgba(0, 0, 0, 0.34) 42%,
      rgba(0, 0, 0, 0.72) 100%
    ),
    url("../images/polku-vaaka-pieni.png") !important;

  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
}

/* DESKTOP: yhteys = puolukka */
#yhteys {
  position: relative !important;

  background:
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.18) 0%,
      rgba(0, 0, 0, 0.18) 32%,
      rgba(0, 0, 0, 0.34) 72%,
      rgba(0, 0, 0, 0.48) 100%
    ),
    url("../images/puolukka.png") !important;

  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
}

#yhteys::before,
#yhteys::after {
  display: none !important;
  content: none !important;
}

/* =========================================================
   MOBILE: BACKGROUNDS + JITTER FIX
   Säilyttää tärinän poistaneet rivit
   ========================================================= */

@media (max-width: 900px) {
  *,
  *::before,
  *::after {
    scroll-snap-align: none !important;
    scroll-snap-stop: normal !important;
  }

  html,
  body,
  main,
  .page-container {
    height: auto !important;
    min-height: 100% !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    scroll-snap-type: none !important;
    overscroll-behavior-y: none !important;
    scroll-behavior: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  body {
    background-attachment: scroll !important;
  }

  #home,
  .home-stack {
    min-height: 100svh !important;
    background-attachment: scroll !important;
  }

  #intro,
  #tours,
  #virtual-trail,
  #vieraskirja,
  #yhteys,
  .intro-section,
  .tours-section,
  .virtual-trail-section,
  .journal-section,
  .contact-section {
    height: auto !important;
    min-height: auto !important;
    background-attachment: scroll !important;
    scroll-snap-align: none !important;
    scroll-snap-stop: normal !important;
  }

  #intro .intro-stage,
  #tours .tours-stage,
  #virtual-trail .virtual-stage,
  #vieraskirja .journal-stage {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: auto !important;
    transform: none !important;
  }

  #tours,
  #virtual-trail,
  #vieraskirja,
  #yhteys {
    display: block !important;
    position: relative !important;
    overflow: hidden !important;
  }

  #intro .section-inner,
  #tours .section-inner,
  #virtual-trail .section-inner,
  #vieraskirja .section-inner,
  #yhteys .section-inner {
    min-height: auto !important;
    height: auto !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  /* Mobiilissa vain nämä käyttävät polku-kuvaa */
  #virtual-trail,
  #tours {
    background:
      linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.62) 0%,
        rgba(0, 0, 0, 0.40) 42%,
        rgba(0, 0, 0, 0.82) 100%
      ),
      url("../images/polku-vaaka-pieni.png") !important;

    background-position: center center !important;
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-attachment: scroll !important;
  }

  #tours .section-inner {
    padding-top: 110px !important;
    padding-bottom: 100px !important;
  }

  #virtual-trail .section-inner {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  /* Mobiilissa retkikirjan alta taustakuva pois */
  #vieraskirja {
    background: #000 !important;
    background-image: none !important;
    background-attachment: scroll !important;
  }

  #vieraskirja .section-inner {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  #vieraskirja .journal-image-wrap {
    width: min(86vw, 420px) !important;
    margin-top: 10px !important;
  }

  #vieraskirja .journal-image {
    display: block !important;
    width: 100% !important;
    max-height: 28vh !important;
    height: auto !important;
    object-fit: contain !important;
  }

  #vieraskirja .guestbook-actions,
  #vieraskirja .journal-actions-below-image {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    margin-top: 14px !important;
  }

  #vieraskirja .journal-actions-below-image .ui-btn {
    width: auto !important;
    min-width: 118px !important;
    min-height: 0 !important;
    height: auto !important;
    padding: 8px 14px !important;
    font-size: 7px !important;
    letter-spacing: 0.22em !important;
    white-space: nowrap !important;
  }

  /* Mobiilissa yhteys = puolukka, ilman fixed-taustaa */
  #yhteys {
    background:
      linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.16) 0%,
        rgba(0, 0, 0, 0.22) 42%,
        rgba(0, 0, 0, 0.44) 100%
      ),
      url("../images/puolukka.png") !important;

    background-position: center center !important;
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-attachment: scroll !important;
  }

  #yhteys::before,
  #yhteys::after {
    display: none !important;
    content: none !important;
  }

  #yhteys .contact-inner {
    width: min(94vw, 100%) !important;
    min-height: auto !important;
    margin: 0 auto !important;
    padding: 100px 20px 90px !important;

    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;

    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  .mobile-menu,
  .mobile-menu-panel {
    max-height: calc(100svh - 108px) !important;
  }
}