/* =========================================================
   RESPONSIVE.CSS — CLEAN RESPONSIVE
   Yleiset breakpointit, mobiilivalikko ja section-taustat.
   Ei home-hero- eikä guide-profiilimäärityksiä.
   Intro, tours ja retkikirja poistettu.
   ========================================================= */



/* =========================================================
   1. PERUSTA JA TAUSTALOGIIKKA
   ========================================================= */

html,
body {
  margin: 0 !important;
  padding: 0 !important;
  background-color: #050608 !important;
}

/* Desktop-tausta, jos section ei piirrä omaa taustaa. */
body {
  background-color: #050608 !important;
  background-image: url("../images/ekuva3.png") !important;
  background-position: center center !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
}

/* Älä tee base/body-pseudoelementeillä erillisiä taustakerroksia. */
body::before,
body::after {
  content: none !important;
  display: none !important;
}

/* Oletuksena sectionit eivät peitä body-taustaa. */
.snap-section,
.home-section,
.virtual-trail-section,
.contact-section {
  background: transparent !important;
  background-image: none !important;
}

@media (max-width: 900px) {
  body {
    background-image: none !important;
    background-attachment: scroll !important;
  }
}



/* =========================================================
   2. SECTION-TAUSTAT
   ========================================================= */

/* Desktop: nuotiotausta virtuaaliretkelle */
#virtual-trail {
  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/nuotiolla.png") !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
}

/* Contact = puolukka */
#contact,
#yhteys,
.contact-section {
  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;
}

#contact::before,
#contact::after,
#yhteys::before,
#yhteys::after {
  content: none !important;
  display: none !important;
}



/* =========================================================
   3. DESKTOP / LAPTOP
   ========================================================= */

@media (min-width: 901px) {
  .mobile-menu,
  .mobile-menu-panel {
    display: none !important;
  }
}

@media (max-width: 1360px) {
  .trezor-nav {
    gap: 18px !important;
  }

  .banner-nav .nav-link {
    gap: 6px !important;
    font-size: 12px !important;
    letter-spacing: 0.03em !important;
  }
}

@media (min-width: 901px) and (max-width: 1399px) and (max-height: 650px) {
  .fixed-gold-scroll {
    bottom: 8px !important;
  }
}

@media (min-width: 1200px) and (max-width: 1400px) {
  .section-header h2 {
    font-size: 32px !important;
  }

  .section-title-icon {
    width: 36px !important;
  }

  .virtual-bear-icon {
    width: clamp(96px, 9.5vw, 142px) !important;
  }

  .virtual-text {
    font-size: 30px !important;
    line-height: 1.35 !important;
  }
}



/* =========================================================
   4. TABLET + MOBIILI: SKROLLIN VAKAUS
   ========================================================= */

@media (max-width: 1024px) {
  *,
  *::before,
  *::after {
    scroll-snap-align: none !important;
    scroll-snap-stop: normal !important;
  }

  html,
  body {
    height: auto !important;
    min-height: 100% !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    scroll-snap-type: none !important;
    overscroll-behavior-y: auto !important;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch !important;
  }

  main,
  .page-container {
    height: auto !important;
    min-height: 100% !important;
    overflow: visible !important;
    overflow-y: visible !important;
    scroll-snap-type: none !important;
  }

  .snap-section,
  .home-section,
  .virtual-trail-section,
  .contact-section {
    height: auto !important;
    min-height: 100svh !important;
    overflow: visible !important;
    scroll-snap-align: none !important;
    scroll-snap-stop: normal !important;
  }

  #virtual-trail .virtual-stage {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 100svh !important;
    overflow: visible !important;
    transform: none !important;
  }

  #virtual-trail .section-inner,
  #contact .section-inner,
  #yhteys .section-inner {
    height: auto !important;
    min-height: 100svh !important;
    overflow: visible !important;
  }
}



/* =========================================================
   5. MOBIILI: YLEISET SÄÄNNÖT
   ========================================================= */

@media (max-width: 900px) {
  :root {
    --banner-visual-side-gap: 10px;
    --mobile-banner-top: 22px;
    --mobile-banner-height: 58px;
  }

  html,
  body {
    background-color: #050608 !important;
    background-image: none !important;
    background-attachment: scroll !important;
  }

  .trezor-nav,
  .banner-nav,
  .products-mega,
  .guide-mega,
  .journal-mega {
    display: none !important;
  }

  .section-inner {
    width: 100% !important;
    max-width: none !important;
    gap: 14px !important;
    padding:
      calc(var(--banner-top) + var(--banner-height) + 20px)
      18px
      86px !important;
  }

  .virtual-text {
    font-size: clamp(22px, 6vw, 30px) !important;
    line-height: 1.26 !important;
  }

  .section-header h2 {
    font-size: clamp(24px, 6vw, 34px) !important;
  }

  .section-title-icon {
    width: 34px !important;
  }

  .virtual-image {
    width: min(88vw, 450px) !important;
    max-height: 28vh !important;
  }

  .virtual-bear-icon {
    width: clamp(82px, 20vw, 118px) !important;
  }

  #virtual-trail,
  #contact,
  #yhteys,
  .virtual-trail-section,
  .contact-section {
    height: auto !important;
    min-height: 100svh !important;
    background-attachment: scroll !important;
  }

  #virtual-trail .virtual-stage {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 100svh !important;
    transform: none !important;
  }

  #virtual-trail .section-inner,
  #contact .section-inner,
  #yhteys .section-inner {
    height: auto !important;
    min-height: 100svh !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }
}



/* =========================================================
   6. MOBIILIBANNERI JA MOBIILIVALIKKO
   ========================================================= */

@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-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;
  }

  .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,
  .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(100svh - 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 !important;
    flex-direction: column !important;
    gap: 22px !important;
  }

  .mobile-menu-block {
    padding-bottom: 18px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
  }

  .mobile-menu-block:last-child {
    padding-bottom: 0 !important;
    border-bottom: 0 !important;
  }

  .mobile-menu-heading {
    margin: 0 0 10px !important;
    color: #faba00 !important;
    font-family: Inter, sans-serif !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
  }

  .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;
  }
}



/* =========================================================
   7. MOBIILI: OSIOT JA SECTION-TAUSTAT
   ========================================================= */

@media (max-width: 900px) {
  #virtual-trail {
    display: block !important;
    position: relative !important;
    overflow: hidden !important;
    background-attachment: scroll !important;
  }

  #virtual-trail .section-inner {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  #contact,
  #yhteys,
  .contact-section {
    display: block !important;
    position: relative !important;
    overflow: hidden !important;

    background-image:
      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 .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;
  }
}



/* =========================================================
   8. MODAALIT / OVERLAYT MOBIILISSA
   ========================================================= */

@media (max-width: 900px) {
  .guide-article {
    width: calc(100vw - 16px) !important;
    height: calc(100vh - 16px) !important;
    margin: 8px auto !important;
    border-radius: 18px !important;
  }

  .guide-shell {
    padding: 24px 16px 22px !important;
  }

  .guide-hero,
  .guide-mega-inner--info-grid,
  .guide-mega-panel--combined {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .guide-photo-wrap {
    max-width: 420px !important;
    margin: 0 auto !important;
  }

  .guide-intro h2 {
    font-size: 24px !important;
  }

  .guide-lead,
  .guide-body-text,
  .guide-quote p {
    font-size: 21px !important;
  }

  .guide-mega-panel--combined,
  .guide-mega-panel--history {
    min-height: 0 !important;
  }

  .guide-mega-panel--history {
    grid-template-rows: 120px 1fr !important;
  }
}



/* =========================================================
   9. PIENET NÄYTÖT
   ========================================================= */

@media (min-width: 701px) and (max-width: 950px) and (max-height: 600px) {
  .hero-eyebrow {
    margin-bottom: 6px !important;
    font-size: 22px !important;
    letter-spacing: 0.22em !important;
  }

  .virtual-text {
    font-size: 25px !important;
    line-height: 1.35 !important;
  }

  .hero-image {
    max-height: 42vh !important;
  }
}

@media (max-width: 420px) {
  .site-banner,
  .site-banner.trezor-banner {
    left: 10px !important;
    right: 10px !important;
  }
}

@media (max-width: 400px) {
  .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;
  }
}
