/* =====================================================
   VBS iPhone RWD Final Fix
   Must be loaded AFTER vbs.css / huborbit.css
===================================================== */

@media screen and (max-width: 768px) {

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden ;
  }

  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  main,
  section,
  .page-shell,
  .vbsx-spec-section,
  .vbsx-spec-wrap {
    width: 100% ;
    max-width: 100vw ;
    min-width: 0 ;
    overflow-x: hidden ;
  }

  .vbsx-spec-section {
    padding: 64px 0 80px ;
  }

  .vbsx-spec-wrap {
    display: block ;
    grid-template-columns: 1fr ;
    padding: 0 16px ;
    margin: 0 auto ;
  }

  .vbsx-spec-list {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 28px !important;
  }

  .vbsx-spec-title {
    font-size: 24px !important;
    line-height: 1.3 !important;
    margin-bottom: 22px !important;
  }

  .vbsx-spec-row {
    display: block !important;
    grid-template-columns: 1fr !important;
    padding: 16px 0 !important;
  }

  .vbsx-spec-row .label,
  .vbsx-spec-row .value {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .vbsx-spec-row .value {
    margin-top: 6px !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    letter-spacing: .03em !important;
  }

  .vbsx-failover-card {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding: 28px 20px 32px !important;
    border-radius: 28px !important;
    overflow: hidden !important;
  }

  .vbsx-failover-head {
    display: block !important;
    width: 100% !important;
    margin-bottom: 16px !important;
  }

  .vbsx-failover-title {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 22px !important;
    line-height: 1.35 !important;
    letter-spacing: .02em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    margin-bottom: 8px !important;
  }

  .vbsx-failover-title span {
    display: block !important;
    margin-top: 6px !important;
    font-size: 13px !important;
  }

  .vbsx-failover-status {
    display: inline-flex !important;
    margin-top: 8px !important;
    font-size: 11px !important;
    padding: 6px 12px !important;
  }

  .vbsx-failover-desc {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 14px !important;
    line-height: 1.75 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    margin-bottom: 22px !important;
  }

  .vbsx-failover-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    margin-bottom: 24px !important;
  }

  .vbsx-failover-tags .tag,
  .vbsx-failover-tags button {
    flex: 0 1 auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    padding: 9px 14px !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
    text-align: center !important;
  }

  .vbsx-fg {
    position: relative !important;
    right: auto !important;
    left: auto !important;
    top: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: 148px !important;
    height: 148px !important;
    margin: 30px auto 0 !important;
  }

  .vbsx-fg-needle {
    height: 62px !important;
  }

  .vbsx-fg-status {
    font-size: 11px !important;
  }

  .vbsx-fg-ms {
    font-size: 17px !important;
  }

  .vbsx-failover-gauge {
    display: none !important;
  }
}

@media screen and (max-width: 430px) {

  .vbsx-spec-wrap {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .vbsx-failover-card {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  .vbsx-failover-title {
    font-size: 21px !important;
  }
}

@media screen and (max-width: 375px) {

  .vbsx-spec-wrap {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .vbsx-failover-card {
    padding: 24px 18px 30px !important;
    border-radius: 24px !important;
  }

  .vbsx-fg {
    width: 132px !important;
    height: 132px !important;
  }
}


/* =====================================================
   VBS Hero iPhone RWD Fix
   Fix: title/text/tags overflow on 390–430px screens
===================================================== */

@media screen and (max-width: 768px) {

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden ;
  }

  main {
    width: 100% ;
    max-width: 100vw ;
    padding-left: 0 ;
    padding-right: 0 ;
    overflow-x: hidden ;
  }

  .page-shell,
  .its-hero,
  .its-hero-inner {
    width: 100% !important;
    max-width: 100vw !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
  }

  .its-hero {
    padding: 28px 0 56px !important;
  }

  .its-hero-inner {
    display: block !important;
    padding: 28px 18px 36px !important;
    border-radius: 28px !important;
    margin: 0 auto !important;
  }

  .its-hero-copy {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 42px 22px 28px !important;
    margin: 0 auto !important;
    overflow: hidden !important;
  }

  .its-eyebrow {
    font-size: 13px !important;
    line-height: 1.55 !important;
    letter-spacing: .14em !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
  }

  .its-title {
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(30px, 9vw, 42px) !important;
    line-height: 1.22 !important;
    letter-spacing: -0.03em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance;
  }

  .its-subtitle {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 18px !important;
    line-height: 1.45 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .its-lead {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  .hero-tags {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    overflow: visible !important;
  }

  .hero-tag,
  .hero-tags .tag {
    max-width: 100% ;
    min-width: 0 ;
    white-space: normal ;
    overflow-wrap: anywhere ;
    word-break: break-word ;
    font-size: 13px ;
    line-height: 1.3 ;
    padding: 8px 13px ;
  }
}

/* iPhone 14 Pro Max / 430px  */
@media screen and (min-width: 390px) and (max-width: 430px) {

  .its-hero-inner {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .its-hero-copy {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .its-title {
    font-size: 42px !important;
    text-wrap: balance;
  }
}


/* iPhone 12 / 390px 以下 */
@media screen and (max-width: 390px) {

  .its-hero-inner {
    padding-left: 14px ;
    padding-right: 14px ;
  }

  .its-hero-copy {
    padding-left: 20px ;
    padding-right: 20px ;
  }

  .its-title {
    font-size: 34px;
    text-wrap: balance;
  }
}

/* =====================================================
   HX Hardware Access iPhone RWD Fix
   Fix: title overflow / card width / image section
===================================================== */

@media screen and (max-width: 768px) {

  .hx-hardware-access {
    width: 100% !important;
    max-width: 100vw !important;
    padding: 72px 0 80px !important;
    overflow-x: hidden !important;
  }

  .hx-shell {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
    margin: 0 auto !important;
    overflow-x: hidden !important;
  }

  .hx-head {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto 42px !important;
    padding: 0 !important;
    text-align: center !important;
  }

  .hx-kicker {
    max-width: 100% !important;
    padding: 8px 14px !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    letter-spacing: .12em !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .hx-title {
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(34px, 9vw, 42px) !important;
    line-height: 1.24 !important;
    letter-spacing: -0.035em !important;
    text-align: center !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  .hx-title span {
    display: inline !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .hx-desc {
    width: 100% !important;
    max-width: 100% !important;
    margin: 18px auto 42px !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
    text-align: center !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
  }

  .hx-desc::after {
    height: 36px !important;
  }

  .hx-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .hx-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 20px !important;
    border-radius: 26px !important;
    overflow: hidden !important;
  }

  .hx-media,
  .hx-media-img {
    width: 100% !important;
    height: auto !important;
    min-height: 180px !important;
    aspect-ratio: 16 / 10 !important;
    border-radius: 18px !important;
  }

  .hx-media-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  .hx-card h3 {
    font-size: 18px !important;
    line-height: 1.35 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .hx-card p {
    font-size: 14px !important;
    line-height: 1.65 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
  }

  .hx-tags {
    width: 100% !important;
    max-width: 100% !important;
    flex-wrap: wrap !important;
  }

  .hx-tags span {
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }
}

/* iPhone 14 Pro Max / 430px */
@media screen and (min-width: 391px) and (max-width: 430px) {

  .hx-shell {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .hx-title {
    font-size: 42px !important;
  }
}


/* iPhone 12 / 390px 以下 */
@media screen and (max-width: 390px) {

  .hx-shell {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .hx-title {
    font-size: 34px !important;
  }

  .hx-card {
    padding: 18px !important;
  }
}

/* =====================================================
   DFS AI Case Videos iPhone RWD Fix
   Fix: title overflow / filter pills / slider card width
===================================================== */

@media screen and (max-width: 768px) {

  .dfs-video-glass,
  .dfs-case-glass {
    width: 100% !important;
    max-width: 100vw !important;
    padding: 72px 0 76px !important;
    overflow-x: hidden !important;
  }

  .dfs-video-header,
  .dfs-case-header {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 18px !important;
    margin: 0 auto 34px !important;
    text-align: center !important;
    overflow: hidden !important;
  }

  .dfs-chip {
    max-width: 100% !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  /* 標題改成直向排版，不再左右硬擠 */
  .dfs-video-title,
  .dfs-title {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    text-align: center !important;
    font-size: clamp(36px, 10vw, 44px) !important;
    line-height: 1.18 !important;
    letter-spacing: -0.035em !important;
    margin: 28px auto 20px !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  .dfs-video-title .t-dark,
  .dfs-video-title .t-accent,
  .dfs-title .t-dark,
  .dfs-title .t-accent {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .dfs-video-title i {
    display: block !important;
    margin: 12px auto 0 !important;
  }

  .dfs-video-desc {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 4px !important;
    font-size: 15px !important;
    line-height: 1.65 !important;
    text-align: center !important;
    color: #5d6685 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
  }

  .dfs-video-desc i {
    display: block !important;
    margin: 0 auto 12px !important;
  }

  /* Filter pills */
  .dfs-video-filters {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 18px !important;
    margin-top: 26px !important;
    display: flex !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
  }

  .dfs-video-filters button {
    max-width: 100% !important;
    padding: 9px 16px !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  /* Slider */
  .dfs-video-slider {
    width: 100% !important;
    max-width: 100vw !important;
    margin-top: 34px !important;
    overflow-x: hidden !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .dfs-video-track {
    width: 100% !important;
    max-width: 100% !important;
    gap: 16px !important;
    overflow-x: auto !important;
    padding-bottom: 14px !important;
    scroll-snap-type: x mandatory !important;
  }

  .dfs-video-card {
    flex: 0 0 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 24px !important;
    padding: 14px !important;
    scroll-snap-align: center !important;
  }

  .dfs-video-thumb {
    width: 100% !important;
    border-radius: 18px !important;
    aspect-ratio: 16 / 9 !important;
  }

  .dfs-video-card h4 {
    font-size: 15px !important;
    line-height: 1.4 !important;
    overflow-wrap: anywhere !important;
  }

  .dfs-video-card p,
  .dfs-video-card li {
    font-size: 13.5px !important;
    line-height: 1.6 !important;
    overflow-wrap: break-word !important;
  }
}


/* iPhone 14 Pro Max / 430px */
@media screen and (min-width: 391px) and (max-width: 430px) {

  .dfs-video-title,
  .dfs-title {
    font-size: 42px !important;
  }

  .dfs-video-header,
  .dfs-case-header {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}


/* iPhone 12 / 390px 以下 */
@media screen and (max-width: 390px) {

  .dfs-video-title,
  .dfs-title {
    font-size: 36px ;
  }

  .dfs-video-header,
  .dfs-case-header,
  .dfs-video-slider,
  .dfs-video-filters {
    padding-left: 14px ;
    padding-right: 14px ;
  }
}