/*
Theme Name: WaterBeauty Static Website
Theme URI: https://waterbeauty.com.tw/
Author: Manus AI
Description: Custom WordPress theme converted from the Water Beauty/NanoPlus corporate image website. It serves the completed static pages through WordPress while preserving the approved design, product copy, images, CTA, and internal navigation.
Version: 1.4.2
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: waterbeauty-static-theme
*/

/* The visual CSS is embedded in each converted page to preserve the approved design exactly. */


/* v4 responsive hardening */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}
img, video, canvas, svg {
  max-width: 100%;
  height: auto;
}
.no-scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.no-scrollbar::-webkit-scrollbar {
  display: none;
}
@media (max-width: 1023px) {
  body.admin-bar nav.fixed {
    top: 32px;
  }
}
@media (max-width: 782px) {
  body.admin-bar nav.fixed {
    top: 46px;
  }
  h1, h2, h3 {
    overflow-wrap: anywhere;
  }
}
@media (max-width: 640px) {
  section {
    scroll-margin-top: 8rem;
  }
}


/* v4.1 mobile navigation refinement: prevent horizontal scrolling and keep the menu responsive. */
@media (max-width: 1023px) {
  nav .lg\:hidden {
    overflow-x: hidden !important;
  }
  nav .lg\:hidden > div {
    overflow-x: hidden !important;
  }
  nav .lg\:hidden .flex {
    min-width: 0 !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
}
@media (max-width: 480px) {
  nav .lg\:hidden a {
    font-size: 13px !important;
    line-height: 1.1 !important;
  }
}


/* v4.2 responsive hardening: make mobile nav fit without horizontal overflow. */
@media (max-width: 640px) {
  html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
  nav {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
  nav > div:first-child {
    height: 72px !important;
    padding-left: 16px !important;
    padding-right: 10px !important;
    gap: 8px !important;
  }
  nav > div:first-child img {
    height: 38px !important;
  }
  nav > div:first-child span:not(.material-symbols-outlined) {
    font-size: 16px !important;
  }
  nav .lg\:hidden,
  nav .lg\:hidden > div,
  nav .lg\:hidden .flex {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
  nav .lg\:hidden > div {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  nav .lg\:hidden .flex {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    column-gap: 8px !important;
    row-gap: 2px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }
  nav .lg\:hidden a {
    flex: 0 1 auto !important;
    min-width: 0 !important;
    max-width: 46vw !important;
    height: 28px !important;
    padding-left: 2px !important;
    padding-right: 2px !important;
    font-size: 12px !important;
    line-height: 1.15 !important;
    letter-spacing: -0.02em !important;
    white-space: nowrap !important;
  }
  main {
    padding-top: 128px !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
  section,
  section > div,
  .grid,
  [class*="max-w-7xl"] {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
  p, li, h1, h2, h3, h4, h5, h6, a, span {
    overflow-wrap: anywhere;
    word-break: normal;
  }
}
@media (max-width: 360px) {
  nav .lg\:hidden a {
    font-size: 11px !important;
    max-width: 48vw !important;
  }
  nav .lg\:hidden .flex {
    column-gap: 6px !important;
  }
}

/* v4.3 mobile navigation grid: keep every nav item inside the viewport. */
@media (max-width: 640px) {
  nav .lg\:hidden .flex {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    width: 100% !important;
    max-width: 100vw !important;
    gap: 4px 2px !important;
    padding: 6px 6px 8px !important;
    box-sizing: border-box !important;
  }
  nav .lg\:hidden a {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: 28px !important;
    padding: 0 1px !important;
    font-size: 12px !important;
    line-height: 1.05 !important;
    white-space: normal !important;
    word-break: keep-all !important;
    text-align: center !important;
    overflow: hidden !important;
  }
}
@media (max-width: 360px) {
  nav .lg\:hidden .flex {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  nav .lg\:hidden a {
    font-size: 11px !important;
  }
  main {
    padding-top: 156px !important;
  }
}

/* v4.6 mobile decorative icon hardening: prevent oversized Material Symbol backgrounds from expanding the viewport. */
@media (max-width: 640px) {
  .material-symbols-outlined.text-\[400px\] {
    font-size: min(72vw, 280px) !important;
    max-width: 100% !important;
    line-height: 1 !important;
  }
}

/* v4.5 mobile content hardening: prevent card/text clipping after nav overflow fix. */
*, *::before, *::after {
  box-sizing: border-box;
}
@media (max-width: 640px) {
  html,
  body,
  #page,
  main {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
  main {
    padding-top: 132px !important;
  }
  section {
    width: 100% !important;
    max-width: 100vw !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    overflow-x: hidden !important;
  }
  section.relative,
  section.overflow-hidden {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  section.relative > .relative,
  section.relative > div:not(.absolute),
  section.overflow-hidden > .relative,
  section.overflow-hidden > div:not(.absolute) {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  section > div,
  [class*="max-w-"],
  .container,
  .grid,
  .flex {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .grid {
    width: 100% !important;
    overflow: visible !important;
  }
  .grid > *,
  section [class*="rounded-"],
  section [class*="shadow"],
  section [class*="border"] {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  p,
  li,
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  a,
  span:not(.material-symbols-outlined) {
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }
  li.flex,
  li[class*="flex"] {
    align-items: flex-start !important;
    min-width: 0 !important;
  }
  li .material-symbols-outlined {
    flex: 0 0 auto !important;
  }
  .material-symbols-outlined {
    max-width: none !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }
  h1 {
    font-size: clamp(2rem, 10vw, 2.65rem) !important;
    line-height: 1.08 !important;
  }
  h2 {
    font-size: clamp(1.75rem, 8vw, 2.25rem) !important;
    line-height: 1.15 !important;
  }
  p.text-lg,
  .text-lg {
    font-size: 1rem !important;
    line-height: 1.75 !important;
  }
  img {
    max-width: 100% !important;
    height: auto !important;
  }
}
@media (max-width: 360px) {
  main {
    padding-top: 156px !important;
  }
  section {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}
