/* ============================================================
   Font Settings - Noto Sans TC & Poppins
   ============================================================ */
/* Route Latin characters to Poppins, CJK to Noto Sans TC */

@font-face {
  font-family: 'JuboFont';
  font-weight: 300;
  src: local('Poppins Light'), local('Poppins-Light');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'JuboFont';
  font-weight: 400;
  src: local('Poppins'), local('Poppins-Regular');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'JuboFont';
  font-weight: 500;
  src: local('Poppins Medium'), local('Poppins-Medium');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'JuboFont';
  font-weight: 600;
  src: local('Poppins SemiBold'), local('Poppins-SemiBold');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'JuboFont';
  font-weight: 700;
  src: local('Poppins Bold'), local('Poppins-Bold');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
    U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122,
    U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Apply globally */
body,
body * {
  font-family: 'JuboFont', 'Noto Sans TC', sans-serif !important;
}

/* ============================================================
   CTA BUTTON — character stagger
   ============================================================ */
.cta-button [data-button-animate-chars] {
  overflow: hidden;
  position: relative;
  display: inline-block;
}

.cta-button [data-button-animate-chars] span {
  display: inline-block;
  position: relative;
  text-shadow: 0px 1.5em currentColor;
  transform: translateY(0em) rotate(0.001deg);
  transition: transform 0.5s cubic-bezier(0.625, 0.05, 0, 1);
}

.cta-button:hover [data-button-animate-chars] span {
  transform: translateY(-1.5em) rotate(0.001deg);
}

/* ============================================================
   ATTRIBUTE STAGGER — switcher items
   ============================================================ */
[data-stagger-text] {
  overflow: hidden;
}

[data-stagger-text]>span {
  display: inline-block;
  vertical-align: top;
  position: relative;
  text-shadow: 0 1.5em currentColor;
  transform: translateY(0) rotate(0.001deg);
  transition: transform 0.5s cubic-bezier(0.625, 0.05, 0, 1);
}

[data-stagger-button]:hover [data-stagger-text]>span {
  transform: translateY(-1.5em) rotate(0.001deg);
}

/* ============================================================
   CTA BUTTON — background
   ============================================================ */
.cta-button_bg {
  inset: 0;
  transition: inset 0.5s cubic-bezier(0.625, 0.05, 0, 1);
}

/* ============================================================
   GLASS BUTTON — gradient icons
   ============================================================ */

.gradient-icon.is-1 {
  transform: translateX(0%) scale(1) !important;
  transition: transform 0.35s cubic-bezier(0.25, 0.1, 0.25, 1) !important;
}

.glass-button:hover .gradient-icon.is-1,
.cascading-slider_content-wrap:hover .gradient-icon.is-1 {
  transform: translateX(150%) scale(0.5) !important;
}

.gradient-icon.is-2 {
  transform: translateX(-150%) scale(0.5) !important;
  transition: transform 0.35s cubic-bezier(0.25, 0.1, 0.25, 1) !important;
  opacity: 1 !important;
}

.glass-button:hover .gradient-icon.is-2,
.cascading-slider_content-wrap:hover .gradient-icon.is-2 {
  transform: translateX(0%) scale(1) !important;
  opacity: 1 !important;
}

/* ============================================================
   GLASS BUTTON — character stagger
   ============================================================ */
.glass-button [data-button-animate-chars] {
  overflow: hidden;
  position: relative;
  display: inline-block;
}

.glass-button [data-button-animate-chars] span {
  display: inline-block;
  position: relative;
  text-shadow: 0px 1.5em currentColor;
  transform: translateY(0em) rotate(0.001deg);
  transition: transform 0.5s cubic-bezier(0.625, 0.05, 0, 1);
}

.glass-button:hover [data-button-animate-chars] span {
  transform: translateY(-1.5em) rotate(0.001deg);
}

/* ============================================================
   NAV LINK — character stagger
   JS-driven only. No :hover rule here — the mega menu
   sits inside the <a> tag and causes false hover triggers.
   ============================================================ */
.nav-link [data-button-animate-chars] {
  overflow: hidden;
  position: relative;
  display: inline-block;
}

.nav-link [data-button-animate-chars] span {
  display: inline-block;
  position: relative;
  text-shadow: 0px 1.5em currentColor;
  transform: translateY(0em) rotate(0.001deg);
  transition: transform 0.5s cubic-bezier(0.625, 0.05, 0, 1);
}

/* NO .nav-link:hover rule — handled entirely by JS below */

/* nav-icon animation*/
.nav-link .nav-icon {
  transition: transform 0.5s cubic-bezier(0.625, 0.05, 0, 1);
}

.nav-link.mm-is-open .nav-icon {
  transform: rotate(180deg);
}

.mega-menu_wrapper.mm-is-open {
  display: block !important;
}

/* Home Platform Tab Styling */
/* Fade the links that are not active */
.tab-content__bottom:has(.tab-content__item.active) .tab-content__item:not(.active) {
  opacity: 0.5;
}

@media (hover:hover) and (pointer:fine) {
  .tab-content__item:not(.active):hover .tab-content__item-bottom {
    background-color: rgba(0, 0, 0, 0.75);
  }

  .tab-content__item:not(.active):hover .content-item__nr {
    transform: translate(25%, 0px);
  }
}

/* Home Platform Section Tab Hover Effect*/
.top-switcher_item:not(.is-active):hover {
  background-color: rgba(0, 178, 192, 0.2);
}

.top-switcher_item {
  transition: background-color 0.15s ease;
}

/* Tab Visual — hide inactive, show active */
.tab-visual__item {
  visibility: hidden;
}

.tab-visual__item.active {
  visibility: visible;
}

/* Home Cascading Slider */
@media screen and (min-width: 992px) {

  /* Home Cascading Slider */
  [data-cascading-viewport] {
    --gap: 1rem;
    position: relative;
    overflow: hidden;
  }

  [data-cascading-slide] {
    --radius: 2rem;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    border-radius: var(--radius);
    overflow: hidden;
    will-change: transform, width;
  }

  [data-cascading-slide] .cascading-slider__item-inner,
  [data-cascading-slide] .cascading-slider__item-bg {
    width: 100%;
    height: 100%;
    position: relative;
  }

  [data-cascading-slide] .cascading-slider__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 0;
  }

  [data-cascading-slide] .cascading-slider__item-content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
  }

  [data-cascading-slide][data-status="active"] {
    cursor: default;
  }

  .cascading-slider__list {
    -webkit-mask-image: none;
    mask-image: none;
  }

  [data-cascading-slide] .cascading-slider_content-wrapper {
    transition: none;
  }

  [data-cascading-slide] .cascading-slider_content-wrap {
    display: none;
    border-radius: 2rem;
    opacity: 0;
  }

  [data-cascading-slide][data-status="active"] .cascading-slider_content-wrap {
    display: block;
  }

  [data-cascading-slide] .cascading-slider_content-wrap.is-inactive {
    display: none;
    align-items: center;
    justify-content: center;
    border-radius: 3rem;
    width: 100%;
  }

  [data-cascading-slide][data-status="inactive"] .cascading-slider_content-wrap.is-inactive {
    display: flex;
  }

  [data-cascading-slide][data-status="active"] .cascading-slider_content-wrap.is-inactive {
    display: none;
  }

  [data-cascading-slide] .cascading-slider_text-wrap {
    visibility: hidden;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s;
  }

  [data-cascading-slide][data-status="active"] .cascading-slider_text-wrap {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.35s ease 0.25s, transform 0.35s ease 0.25s, visibility 0s;
  }
}

/* ── News icon hover — exact match to Glass Btn ─────────── */

.news_icon-wrap {
  overflow: hidden;
}

.gradient-icon.is-news-1 {
  transform: translateX(0%) scale(1) !important;
  transition: transform 0.35s cubic-bezier(0.25, 0.1, 0.25, 1) !important;
}

.gradient-icon.is-news-2 {
  transform: translateX(-150%) scale(0.5) !important;
  transition: transform 0.35s cubic-bezier(0.25, 0.1, 0.25, 1) !important;
  opacity: 1 !important;
}

.single-home-news_wrap:hover .gradient-icon.is-news-1 {
  transform: translateX(150%) scale(0.5) !important;
}

.single-home-news_wrap:hover .gradient-icon.is-news-2 {
  transform: translateX(0%) scale(1) !important;
  opacity: 1 !important;
}

/* Link Text Underline Animation */
[data-underline-link] {
  text-decoration: none;
  position: relative;
}

[data-underline-link]::before,
[data-underline-link="alt"]::before,
[data-underline-link="alt"]::after {
  content: "";
  position: absolute;
  bottom: -0.0625em;
  left: 0;
  width: 100%;
  height: 0.0625em;
  background-color: currentColor;
  transition: transform 0.6s cubic-bezier(0.625, 0.05, 0, 1);
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
}

[data-underline-link="alt"]::before {
  transform-origin: left;
  transform: scaleX(1) rotate(0.001deg);
  transition-delay: 0.2s;
}

[data-underline-link="alt"]::after {
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
  transition-delay: 0s;
}

@media (hover: hover) and (pointer: fine) {

  [data-hover]:hover [data-underline-link]::before,
  [data-underline-link]:hover::before {
    transform-origin: left;
    transform: scaleX(1) rotate(0.001deg);
  }

  [data-hover]:hover [data-underline-link="alt"]::before,
  [data-underline-link="alt"]:hover::before {
    transform-origin: right;
    transform: scaleX(0) rotate(0.001deg);
    transition-delay: 0s;
  }

  [data-hover]:hover [data-underline-link="alt"]::after,
  [data-underline-link="alt"]:hover::after {
    transform-origin: left;
    transform: scaleX(1) rotate(0.001deg);
    transition-delay: 0.2s;
  }
}

/* Comapny Page Vertical Marquee */
.track-vertical {
  position: absolute !important;
  will-change: transform;
  animation: marquee-vertical 12s linear infinite;
}

@keyframes marquee-vertical {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-50%);
  }
}

.track-vertical-alt {
  position: absolute !important;
  will-change: transform;
  animation: marquee-vertical-alt 12s linear infinite;
}

@keyframes marquee-vertical-alt {
  from {
    transform: translateY(-50%);
  }

  to {
    transform: translateY(0);
  }
}

/* Home News & Company Certification List Hide Visual & Opacity Control */
.preview-follower__inner {
  transition: opacity 0.1s ease, transform 0.65s cubic-bezier(0.65, 0.1, 0, 1);
}

/* html:not(.wf-design-mode) */
.preview-follower__inner {
  opacity: 0;
  transform: scale(0);
}

.preview-follower [data-follower-visual] {
  display: block;
  width: 100%;
  height: 100%;
  z-index: 0;
}

@media (hover: hover) and (min-width: 992px) {
  body:has([data-follower-collection]:hover) .preview-follower__inner {
    opacity: 1;
    transform: scale(1);
  }

  body:has([data-follower-collection]:hover) .preview-follower__label {
    opacity: 1;
    transform: translate(0px, 0%);
  }

  body:has(.single-home-news_wrap:hover) .single-home-news_wrap:not(:hover) {
    opacity: 0.5;
  }
}

[data-follower-cursor-inner] [data-follower-visual] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
}

· [data-follower-cursor-inner] [data-follower-visual] img {
  object-fit: cover;
}

/* ============================================================
   BG Flicking Issue
   ============================================================ */
.home-gradient-bg {
  will-change: transform;
}

/* ============================================================
   Long-Term Care Resources Process GSAP Slider 
   ============================================================ */
[data-gsap-slider-init] {
  --slider-status: on;
  /* Turn slider on/off */
  --slider-spv: 3;
  /* Slides per view */
  --slider-gap: 1.5em;
  /* Slides Gap */
}

@media screen and (max-width: 991px) {
  [data-gsap-slider-init] {
    --slider-status: on;
    /* Turn slider on/off */
    --slider-spv: 2.25;
    /* Slides per view */
    --slider-gap: 1.5em;
    /* Slides Gap */
  }
}

@media screen and (max-width: 767px) {
  [data-gsap-slider-init] {
    --slider-status: on;
    /* Turn slider on/off */
    --slider-spv: 1.15;
    /* Slides per view */
    --slider-gap: 1em;
    /* Gap */
  }
}

[data-gsap-slider-item]:last-child {
  margin-right: 0;
}

/* Controls */
[data-gsap-slider-status="not-active"] [data-gsap-slider-controls] {
  display: none;
}

[data-gsap-slider-control-status="not-active"] {
  opacity: 0.2;
  pointer-events: none;
}

/* Customization */

.gsap-slider__control {
  transition: opacity 0.3s ease;
}

.demo-card {
  transition: all 0.3s ease;
}

[data-gsap-slider-item-status="not-active"] .demo-card {
  background-color: #131313;
}

.demo-card__tag {
  transition: all 0.3s ease;
}

[data-gsap-slider-item-status="not-active"] .demo-card__tag {
  opacity: 0;
}

/* ============================================================
   CMS Richtext Image Full Width
   ============================================================ */
.richtext figure:not([style*="max-width"]),
.richtext figure:not([style*="max-width"]) div,
.richtext figure:not([style*="max-width"]) img {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto;
  overflow: clip;
}

/* ============================================================
   Customer Story Load All
   ============================================================ */
body.customer-story-loaded-all .customer-story_pagination {
  display: none !important;
}

/* ============================================================
   Customer Story Hover In & Out
   ============================================================ */
.single-customer-story_wrap .customer-story_image-wrap {
  transform: scale(1);
  transition: transform 0.3s ease;
  transform-origin: center;
}

.single-customer-story_wrap .customer-story_headline-wrap {
  opacity: 1;
  transition: opacity 0.3s ease;
}

.single-customer-story_wrap:hover .customer-story_image-wrap {
  transform: scale(1.03);
}

.single-customer-story_wrap:hover .customer-story_headline-wrap {
  opacity: 0.7;
}

/* ============================================================
   Mobile Drawer
   ============================================================ */
html.mobile-menu-is-open,
body.mobile-menu-is-open {
  overflow: hidden !important;
  overscroll-behavior: none !important;
}

body.mobile-menu-is-open {
  position: fixed !important;
  width: 100% !important;
  left: 0 !important;
  right: 0 !important;
}

.mobile-menu_wrap {
  width: 100vw;
  max-width: 100%;
  overflow: hidden !important;
  overscroll-behavior: none !important;
  box-sizing: border-box;
}

.mobile-menu_inner-wrap {
  max-width: 100%;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch;
  box-sizing: border-box;
}

.mobile-accordion .accordion-answer.is-mobile-drawer {
  overflow: hidden;
  height: 0;
}

.mobile-accordion .nav-icon.is-mobile {
  transition: transform 220ms ease;
  transform: rotate(0deg);
}

.mobile-accordion.is-open .nav-icon.is-mobile {
  transform: rotate(180deg);
}

/* ------------------------------------------------------------
   News Filter Dropdown - tablet/mobile
   ------------------------------------------------------------ */
.news-filter_dropdown-highlight {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 0;
  border-radius: 0.5rem;
  background-color: rgba(0, 178, 192, 0.12);
  pointer-events: none;
}

/* Anchor point for absolute dropdown on mobile */
@media screen and (max-width: 991px) {
  .news-filter_form>.cta-button.is-filter {
    display: none !important;
    pointer-events: none !important;
  }
}

.news-category_list>.news-category_item:last-child .cta-button.is-filter,
.news-category_list>.news-category_item:last-child .cta-button.is-filter::before,
.news-category_list>.news-category_item:last-child .cta-button.is-filter::after,
.news-category_list>.news-category_item:last-child .cta-button.is-filter *,
.news-category_list>.news-category_item:last-child .cta-button.is-filter *::before,
.news-category_list>.news-category_item:last-child .cta-button.is-filter *::after {
  border-bottom: 0 !important;
}

.news-category_list>.news-category_item:last-child,
.news-category_list>.news-category_item:last-child::before,
.news-category_list>.news-category_item:last-child::after {
  border-bottom: 0 !important;
}

/* ------------------------------------------------------------
  Mobile IOT List Bottom Border
   ------------------------------------------------------------ */
@media screen and (max-width: 991px) {
  .iot_cms-item:has(.single-iot_wrap.is-last-visible) .mobile_list-header {
    border-bottom: 0 !important;
  }
}
