


*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}


html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI',
    'Helvetica Neue', Arial, sans-serif;
  background-color: #fff;
  color: rgba(0, 0, 0, 0.84);
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
}

a {
  text-decoration: none;
}

@media (max-width: 736px) {
  .m-hide {
    display: none !important;
  }
}

@media (width > 736px) {
  .m-show {
    display: none !important;
  }
}


.h1 {
  font-size: clamp(26px, 2.67vw + 16px, 48px);
  font-weight: 700;
  line-height: 1.22;
  color: rgba(0, 0, 0, 0.84);
}

.h2 {
  font-size: clamp(18px, 2.2vw, 30px);
  font-weight: 500;
  line-height: 1.3;
  color: rgba(0, 0, 0, 0.72);
}

.h3 {
  font-size: clamp(17px, 0.85vw + 13.82px, 24px);
  font-weight: 400;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.72);
}

.h3-medium {
  font-size: clamp(17px, 0.85vw + 13.82px, 24px);
  font-weight: 500;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.72);
}

.body1 {
  font-size: clamp(14px, 0.48vw + 12.18px, 18px);
  font-weight: 400;
  line-height: 1.55;
  color: rgba(0, 0, 0, 0.64);
}

.body1-light {
  font-size: clamp(14px, 0.48vw + 12.18px, 18px);
  font-weight: 300;
  line-height: 1.55;
  color: rgba(0, 0, 0, 0.64);
  margin-top: clamp(12px, 1.5vw, 18px);
}

.body1-bold {
  font-size: clamp(14px, 0.48vw + 12.18px, 18px);
  font-weight: 700;
  line-height: 1.55;
  color: rgba(0, 0, 0, 0.84);
}

.body2 {
  font-size: clamp(13px, 0.36vw + 11.64px, 16px);
  font-weight: 400;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.64);
  margin-top: 8px;
}

.text-link {
  color: #155cc7;
  font-size: clamp(14px, 0.48vw + 12.18px, 18px);
  font-weight: 300;
  transition: opacity 0.2s;
}

.text-link:hover {
  opacity: 0.75;
}


.bg-white  { background-color: #ffffff; }
.bg-warm   { background-color: #faf9f4; }

.sp-card--athens-gray { background-color: #f5f5f7; }
.sp-card--warm-sand   { background-color: #e8e3d9; }
.sp-card--taupe       { background-color: #d7d3d4; }
.sp-card--cream       { background-color: #f4f1e8; }
.sp-card--mint        { background-color: #eaf3f3; }


.section {
  padding: clamp(40px, 9.5vw, 180px) 0;
  overflow: hidden;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
}

.container-wifi {
  max-width: 1300px;
  margin: 0 auto;
}

.text-center {
  text-align: center;
}

.text-center .body1-light {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}


.hero {
  width: 100%;
  aspect-ratio: 2 / 1;
  max-height: 960px;
  overflow: hidden;
  background-color: #f5f5f7;
  position: relative;
}

.hero picture {
  display: contents;
}

.hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.hero__overlay {
  position: absolute;
  inset: 0;
}


.hero__content {
  position: absolute;
  top: 48%;
  transform: translateY(calc(-50% - 5.2%));  
  left: 18.75%;                               
  width: min(34%, 750px);                               
  display: flex;
  flex-direction: column;
  gap: 2vw;                                
}


.hero__product-name {
  padding-left: 8.5%;                         
}

.hero__product-name img {
  width: clamp(95px, 12vw, 229px);  
  height: auto;
}


.hero__typography {
  display: flex;
  flex-direction: column;
  gap: 1vw;                                 
  padding-left: 8.5%;
  max-width: clamp(100px, 33.25vw, 638px);
}

.hero__h1 {
  font-size: clamp(20px, 2.5vw, 45px);        
  font-weight: 700;
  line-height: 1.25;
  color: rgba(0, 0, 0, 0.84);
}

.hero__body1 {
  font-size: clamp(12px, 1.25vw, 18px);     
  font-weight: 400;
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.64);
}

.hero__h3 {
  font-size: clamp(14px, 1.5vw, 24px);       
  font-weight: 700;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.72);
}


.hero__icons {
  display: flex;
  align-items: center;
  gap: min(2vw, 36px);                                 
  padding-left: 8.5%;
}

.hero__icons img {
  width: clamp(50px, 3.9vw, 75px);            
  height: clamp(50px, 3.9vw, 75px);
  object-fit: contain;
  flex-shrink: 0;
}


.hero__badges {
  position: absolute;
  bottom: 11%;                               
  right: 9%;                                
  display: flex;
  align-items: center;
  gap: 1.5vw;                                 
  pointer-events: auto;
}

.hero__badge {
  height: clamp(36px, 2.08vw, 40px);          
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.hero__badge img {
  height: 100%;
  width: auto;
  max-width: 130px;
  object-fit: contain;
}


.hero__mobile-overlay {
  display: none;
}


.sp-grid {
  padding-top: 180px;
  padding-bottom: 0;
  background: #fff;
}


.sp-mosaic {
  position: relative;
  margin-bottom: 20px;
}

.sp-mosaic picture {
  display: block;
}

.sp-mosaic__img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 28px;
}


.sp-mosaic__labels {
  position: absolute;
  inset: 0;
  pointer-events: none;
}



.sp-mosaic__label {
  position: absolute;
  padding: clamp(16px, 2.67vw, 32px);
  pointer-events: auto;
}


.sp-mosaic__label--1 {
  top: 0;
  left: 0;
}


.sp-mosaic__label--2 {
  top: 0;
  left: 57.5%;
}


.sp-mosaic__label--3 {
  top: 50.5%;
  left: 0;
}


.sp-mosaic__label--4 {
  top: 50.5%;
  left: 33.8%;
}


.sp-mosaic__label--5 {
  top: 50.5%;
  left: 67.5%;
}


.sp-strip {
  border-radius: 28px;
  padding: 40px 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-around;
  gap: 16px;
  min-height: 200px;
}

.sp-strip__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  width: 160px;
  text-align: center;
}

.sp-strip__item img {
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.sp-strip__item p {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.64);
}


.sp-wifi-never {
  position: relative;
 
 
  min-height: 750px;
  overflow: hidden;
  background: #fff;
}


.sp-wifi-never__img-wrap {
  position: absolute;
  top: 23%;      
  width: min(1300px,100%); 
  pointer-events: none;
}

.sp-wifi-never__img-wrap img {
  width: 100%;
  height: auto;
  display: block;
}


.sp-wifi-never .container {
  position: relative;
  z-index: 2;
  height: 100%;
}


.sp-wifi-never__text {
  position: relative;
 
  padding-top: clamp(16px, 1.46vw, 28px);
 
  max-width: clamp(400px, 30vw, 700px);
}

.sp-wifi-never__text .h1 {
  margin-bottom: 0;
}

.sp-wifi-never__text .body1-light {
 
  margin-top: clamp(10px, 2.5vw, 24px);
}

.sp-wifi-never__text .link-row {
  margin-top: clamp(12px, 2vw, 24px);
  display: flex;
  gap: clamp(16px, 2.5vw, 48px);
}

@media (max-width: 1000px) {
.sp-wifi-never {
  min-height: 500px;
}
}

.sp-interference .h1 {
  margin-bottom: 16px;
}

.sp-interference__card {
  border-radius: 28px;
  overflow: hidden;
  margin-top: 80px;
  position: relative;
}

.sp-interference__img-wrap {
  position: relative;
  width: 100%;
}

.sp-interference__img-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

.keep-up .text p {
    max-width: 48rem;
    margin: 16px auto 0;
  }

  .keep-up .keep-up-swiper {
    border-radius: 32px;
  }

  .swiper-controls {
    display: flex;
    align-items: center;
    margin-top: 1.5rem;
  }
  .swiper-controls .swiper-pagination {
    position: static;
    bottom: auto;
    width: auto;
    flex: 1;
    text-align: center;
  }
  .swiper-controls .swiper-nav-spacer {
    flex-shrink: 0;
    width: calc(2 * 50px + 8px);
  }
  .swiper-controls .swiper-nav-group {
    display: flex;
    gap: 20px;
    flex-shrink: 0;
  }
  .swiper-controls .swiper-nav-btn {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: none;
    background: #f8f8f8;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;

    &:hover {
      background: #f0f0f0;
    }

    &:active {
      background: #d8d8d8;
    }
  }
  .swiper-controls .swiper-nav-btn img {
    width: 24px;
    height: 24px;
    display: block;
  }
  .keep-up .swiper-slide img {
    width: 100%;
    object-fit: cover;
  }
  .swiper-controls .swiper-pagination-bullet {
    display: inline-block;
    background: #d9d9d9;
    opacity: 1;
    width: 8px;
    height: 8px;
    margin: 0 20px;
  }
  .swiper-controls .swiper-pagination-bullet-active {
    background: #155cc7;
  }

  @media (max-width: 736px) {
    .section { 
      padding: 86.6px 0;
    }
    .keep-up .w-container {
      width: auto;
    }
    .keep-up .text {
      text-align: left;
      margin-bottom: 1.5rem;
    }
    .keep-up .text p {
      max-width: none;
      margin: 0.75rem 0 0;
    }

    .sp-mosaic {
      margin-bottom: 10px;
    }
  }



.sp-performance .h1 {
  margin-bottom: 16px;
}


.speed-bars {
  margin: 80px 0;
  display: flex;
  flex-direction: column;
  gap: 22px;
  --bar-max: min(900px, 70vw);          
}

.speed-bar {
  display: flex;
  align-items: center;
  gap: 16px;
}

.speed-bar__label {
  font-size: 18px;
  font-weight: 700;
  width: 90px;
  flex-shrink: 0;
  color: rgba(0, 0, 0, 0.84);
}

.speed-bar__track {
  height: 11px;
  border-radius: 11px;
  overflow: hidden;
  flex-shrink: 0;
}

.speed-bar__fill {
  height: 100%;
  border-radius: 11px;
}

.speed-bar__fill--6ghz {
  width: 100%;
  background: linear-gradient(90deg, #156ae0, #0087ff 55%, #47ceff);
}

.speed-bar__fill--5ghz {
  width: 100%;
  background: linear-gradient(90deg, #15a3e0, #1acbde);
}

.speed-bar__fill--24ghz {
  width: 100%;
  background: linear-gradient(90deg, #a5a5a5, #ababab);
}


.speed-bar:nth-child(1) .speed-bar__track { width: min(100%, var(--bar-max)); }
.speed-bar:nth-child(2) .speed-bar__track { width: min(45%, calc(var(--bar-max) * 0.45)); }
.speed-bar:nth-child(3) .speed-bar__track { width: min(8%, calc(var(--bar-max) * 0.08)); }

.speed-bar__value {
  font-size: 18px;
  font-weight: 700;
  flex-shrink: 0;
  white-space: nowrap;
  color: rgba(0, 0, 0, 0.84);
}



.keep-up {
  --c1: 28px;
  --H1-Size: 48px;
  --H1-Bold: 500;
  --H1-Line-Height: 60px;
  --H3-Size: 24px;
  --H3-Bold: 500;
  --H3-Line-Height: 33.6px;
  --Body1-Size: 18px;
  --Body1-Regular: 400;
  --Body1-Line-Height: 27px;
  --font-weight-light: 300;
  --h-margin: 23.3px;

  margin-top: 0;
  width: min(calc(100% - 2 * var(--h-margin)), 1920px);
  margin-inline: auto;
}

.keep-up *,
.keep-up {
  box-sizing: border-box;
}

.keep-up img,
.keep-up video {
  max-width: 100%;
  height: auto;
  display: block;
}

.keep-up .w-container {
  max-width: 1200px;
  margin: 0 auto;
}

.keep-up .tp-h1 {
  font-size: var(--H1-Size);
  font-weight: var(--H1-Bold);
  line-height: var(--H1-Line-Height);
  margin-bottom: 16px;
  color: rgb(0 0 0 / 84%);
}

.keep-up .tp-body1 {
  font-size: var(--Body1-Size);
  font-weight: var(--Body1-Regular);
  line-height: var(--Body1-Line-Height);
  color: rgb(0 0 0 / 64%);
}

.keep-up .tp-light {
  font-weight: var(--font-weight-light);
}

.keep-up .tp-my-64 {
  margin-block: 64px;
}

.keep-up .tp-space-y-16 > :not([hidden]) ~ :not([hidden]) {
  margin-top: 16px;
}

.keep-up .keep-up-swiper {
  margin-top: 1.5rem;
  border-radius: 32px;
}

.keep-up .swiper-slide img {
  width: 100%;
  object-fit: cover;
}

.keep-up .swiper-controls {
  display: flex;
  align-items: center;
  margin-top: 1.5rem;
}

.keep-up .swiper-controls .swiper-pagination {
  position: static;
  bottom: auto;
  width: auto;
  flex: 1;
  text-align: center;
}

.keep-up .swiper-controls .swiper-nav-spacer {
  flex-shrink: 0;
  width: calc(2 * 50px + 8px);
}

.keep-up .swiper-controls .swiper-nav-group {
  display: flex;
  gap: 20px;
  flex-shrink: 0;
}

.keep-up .swiper-controls .swiper-nav-btn {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: none;
  background: #f8f8f8;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.keep-up .swiper-controls .swiper-nav-btn:hover {
  background: #f0f0f0;
}

.keep-up .swiper-controls .swiper-nav-btn:active {
  background: #d8d8d8;
}

.keep-up .swiper-controls .swiper-nav-btn img {
  width: 24px;
  height: 24px;
  display: block;
}

.keep-up .swiper-controls .swiper-pagination-bullet {
  display: inline-block;
  background: #d9d9d9;
  opacity: 1;
  width: 8px;
  height: 8px;
  margin: 0 20px;
}

.keep-up .swiper-controls .swiper-pagination-bullet-active {
  background: #155cc7;
}

@media (max-width: 736px) {
  .keep-up {
    --H1-Size: 30px;
    --H1-Line-Height: normal;
    --Body1-Size: 16px;
    --Body1-Line-Height: 24px;
    max-width: 375px;
  }

  .keep-up .m-hide {
    display: none !important;
  }

  .keep-up .w-container {
    width: auto;
  }

  .keep-up .text {
    text-align: left;
    margin-bottom: 1.5rem;
  }

  .keep-up .text p {
    max-width: none;
    margin: 0.75rem 0 0;
  }
  .speed-bar__track {
    height: 1.5vw;
  }
  .speed-bar:nth-child(1) .speed-bar__track { width: 48%; }
.speed-bar:nth-child(2) .speed-bar__track { width: 35%; }
.speed-bar:nth-child(3) .speed-bar__track { width: 15%; }

.sp-connections {
  padding: 86.6px 0 !important; 
}
}

@media (width > 736px) {
  .keep-up .m-show {
    display: none !important;
  }

  .keep-up .text p {
    max-width: 48rem;
    margin: 16px auto 0;
  }
}

.sp-multigig {
  padding: 0;
}
.sp-multigig__layout {
  display: grid;
  grid-template-columns: 41.7fr 56.7fr;
  gap: 1.7%;
  align-items: stretch;
}

.sp-multigig__left {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.sp-multigig__text .h1 {
  margin-bottom: 0;
}

.sp-multigig__lifestyle {
  border-radius: 28px;
  overflow: hidden;
  flex: 1;
  min-height: 260px;
  max-height: 400px;
}

.sp-multigig__lifestyle img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.sp-multigig__right {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  aspect-ratio: 675 / 692;
}

.sp-multigig__product-img-wrap {
  position: absolute;
  left: -5.8%;
  top: -66%;
  width: 150%;
  height: 146%;
  pointer-events: none;
}

.sp-multigig__product-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sp-multigig__port-label {
  position: absolute;
  left: 6%;
  top: 33.5%;
}

.port-speed {
  font-size: 24px;
  font-weight: 700;
  color: rgba(0, 0, 0, 0.84);
  line-height: 1.4;
}

.port-subtitle {
  font-size: 18px;
  font-weight: 400;
  color: rgba(0, 0, 0, 0.64);
  line-height: 1.5;
}

.sp-multigig__divider {
  position: absolute;
  left: 30%;
  top: 39%;
  height: 1px;
  width: clamp(60px, 12vw, 160px);
  background: rgba(0, 0, 0, 0.4);
}

.sp-multigig__use-cases {
  position: absolute;
  left: 0;
  right: 0;
  top: 71.2%;
  display: flex;
  justify-content: center;
  gap: 40px;
}

.use-case {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
  width: 120px;
}

.use-case img {
  width: 100px;
  height: 100px;
  object-fit: contain;
}

.use-case p {
  font-size: 18px;
  font-weight: 400;
  color: rgba(0, 0, 0, 0.84);
  line-height: 1.4;
}


.sp-connections {
  padding: 50px 0;
}
.sp-connections__video-wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.sp-connections__video {
  width: 100%;
  height: auto;
  display: block;
}

.sp-connections__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 4.5vw 0;
  gap: clamp(8px, 1.2vw, 16px);
  max-width: 800px;
  margin: 0 auto;
}

.sp-connections__overlay .body1-light {
  margin-top: 0;
}

.sp-connections__header {
  margin: 0 auto;
  margin-bottom: 24px;
  max-width: 800px;
}


.sp-simple__card {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
 
  aspect-ratio: 2400 / 1180;
}

.sp-simple__card-img {
  position: absolute;
 
  left: 4%;
  top: 6.6%;
  width: 67.7%;
  height: auto;
}

.sp-simple__card-img img {
  width: 100%;
  height: auto;
  display: block;
}

.sp-simple__card-text {
  position: absolute;
  left: 55%;
  top: 27.2%;
  width: 38.5%;
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 1.5vw, 24px);
}

.sp-simple__card-text .h1 {
  margin-bottom: 0;
}

.sp-simple__card-text .body1-light {
  margin-top: 0;
}

.setup-steps {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: clamp(24px, 3vw, 48px);
}

.setup-step {
  flex: 1;
  max-width: 320px;
}

.setup-step .body1 {
  font-weight: normal;
}

.setup-step .body2 {
  margin-top: 4px;
  margin-left: 24px;
   font-weight: normal;

}



.sp-homeshield {
  padding: 0;
}

.sp-homeshield__header {
  max-width: 70%;
  margin-bottom: 80px;
}

.sp-homeshield__logo {
  width: auto;
  max-height: clamp(32px, 3.5vw, 59px);
  display: block;
  margin-bottom: clamp(16px, 2vw, 24px);
}

.sp-homeshield__header .h1 {
  margin-bottom: 0;
}

.sp-homeshield__header .text-link {
  display: inline-block;
  margin-top: 16px;
}


.sp-hs-slider {
  width: 100%;
  overflow: hidden;
  cursor: grab;
  user-select: none;
}

.sp-hs-slider:active {
  cursor: grabbing;
}

.sp-hs-track {
  display: flex;
  gap: clamp(12px, 1.25vw, 20px);
 
  transition: transform 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  will-change: transform;
}


.sp-hs-card {
  flex: 0 0 min(1200px, calc(100vw - 80px));
  display: grid;
  grid-template-columns: 1423fr 977fr;
  aspect-ratio: 2 / 1;
  border-radius: clamp(16px, 1.67vw, 24px);
  overflow: hidden;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.sp-hs-card:not(.is-active) {
  opacity: 0.65;
}

.sp-hs-card__img {
  overflow: hidden;
}

.sp-hs-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sp-hs-card__desc {
  background: var(--hs-bg);
  padding: clamp(20px, 3vw, 48px) clamp(16px, 2.5vw, 40px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}

.sp-hs-card__desc .h3,
.sp-hs-card__desc .body1-light {
  margin: 0;
}

.hs-progress {
  position: relative;
  height: 4px;
  background: #d9d9d9;
  border-radius: 2px;
  margin-top: clamp(16px, 2vw, 28px);
}

.hs-progress__thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 33.33%;
  height: 100%;
  background: #155cc7;
  border-radius: 2px;
  transition: left 0.35s ease;
  pointer-events: none;
}

.sp-hs-mobile {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.sp-hs-mobile__card img {
  width: 100%;
  border-radius: 16px;
  display: block;
}

.sp-hs-mobile__card .h3 {
  margin-top: 16px;
  margin-bottom: 0;
}

.sp-hs-mobile__card .body1-light {
  margin-top: 8px;
}



.sp-iot .h1 {
  margin-bottom: 0;
}

.tp-mt-32 {
  margin-top: 32px;
}

.private-home-wrap {
  position: relative;
  line-height: 0;
  max-width: 1400px;
  margin-inline: auto;
  margin-top: 144px;
}

.private-home-wrap > img:first-child {
  width: 100%;
  display: block;
}

.pulse-ring {
  position: absolute;
  width: 4%;
  aspect-ratio: 1;
  background: url("https://static-product.tp-link.com/deco_be13000_v1/img/wifi-signal.webp") center / contain no-repeat;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0);
  opacity: 1;
  animation: 1.5s ease-out infinite pulse-expand;
}

.pulse-ring--delay {
  animation-delay: 0.5s;
}

@media (prefers-reduced-motion: reduce) {
  .pulse-ring {
    animation: none;
    transform: translate(-50%, -50%) scale(7);
    opacity: 0.4;
  }
  .pulse-ring--delay {
    display: none;
  }
}

@keyframes pulse-expand {
  0%  { transform: translate(-50%, -50%) scale(0);  opacity: 1; }
  to  { transform: translate(-50%, -50%) scale(10); opacity: 0; }
}


.sp-smart__heading {
  margin-bottom: 60px;
}

.sp-smart__heading .h1 {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.smart-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.smart-feature {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.smart-feature__img-wrap {
  border-radius: 56px;
  overflow: hidden;
  aspect-ratio: 3 / 2;
  position: relative;
  background: #F5F5F7;
}

.smart-feature__img-wrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
}


.smart-feature__bubble-wrap {
  position: absolute;
  bottom: clamp(16px, 4%, 50px);
  right: clamp(16px, 5%, 50px);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  z-index: 2;
}

.smart-feature__bubble {
  background: #fff;
  border-radius: 100px;
  padding: clamp(10px, 1.8%, 30px) clamp(16px, 3%, 45px);
  max-width: 70vw;
}

.smart-feature__bubble p {
  font-size: clamp(13px, 1.2vw, 18px);
  font-weight: 400;
  color: rgba(0,0,0,0.64);
  white-space: nowrap;
  line-height: 1.5;
}


.smart-feature__bubble-dot {
  display: block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
}

.smart-feature__text .h3 {
  margin-bottom: 12px;
}



@media (max-width: 640px) {

 

 

 
  .hero {
    position: relative;
    aspect-ratio: unset;
    height: auto;
    background-color: #f5f5f7;
  }

  .hero picture,
  .hero picture source { display: block; }

  .hero__img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 1125 / 1538;
    object-fit: cover;
    object-position: center top;
  }

 
  .hero__overlay {
    display: none;
  }

 
  .hero__mobile-overlay {
    display: block;
    position: absolute;
    inset: 0;
  }

  .sp-hs-mobile__card img { 
    margin-bottom: 3vw;
  }

 

 
  .hero__mobile-overlay::before {
    content: '';
    position: absolute;
    top: -7.02%;         
    left: -18.58vw;      
    width: 136.18vw;     
    height: 58%;         
    background: linear-gradient(to bottom, #dddace 0%, rgba(221, 218, 206, 0) 100%);
  }

 
  .hero__m-product-name {
    position: absolute;
    top: 10.67vw;        
    left: 6.22vw;        
  }

  .hero__m-product-name img {
    width: 20vw;      
    height: auto;
  }

 
  .hero__m-typography {
    position: absolute;
    top: 22.4vw;         
    left: 6.22vw;        
    right: 6.22vw;
    display: flex;
    flex-direction: column;
    gap: 2.84vw;         
  }

  .hero__m-h1 {
    font-size: 8vw;      
    font-weight: 700;
    line-height: 1.25;
    color: rgba(0, 0, 0, 0.84);
  }

  .hero__m-body1 {
    font-size: 4.27vw;   
    font-weight: 400;
    line-height: 1.5;
    color: rgba(0, 0, 0, 0.64);
  }

  .hero__m-h3 {
    font-size: 4.53vw;   
    font-weight: 700;
    line-height: 1.4;
    color: rgba(0, 0, 0, 0.72);
  }

 
  .hero__m-icons {
    position: absolute;
    top: 57.6%;          
    left: 6.22vw;        
    display: flex;
    align-items: center;
    gap: 2.22vw;         
  }

  .hero__m-icons img {
    width: 8.89vw;       
    height: 8.89vw;
    object-fit: contain;
    flex-shrink: 0;
  }

 
  .hero__m-badges {
    position: absolute;
    bottom: 10.67vw;     
    left: 6.22vw;        
    display: flex;
    flex-direction: column;
    gap: 2.84vw;         
    pointer-events: auto;
  }

 
  .hero__m-badge {
    height: 6.22vw;      
    display: flex;
    align-items: flex-start;
    justify-content: left;
    overflow: hidden;
    flex-shrink: 0;
  }

 
  .hero__m-badge:nth-child(1) { width: 19.91vw; }
  .hero__m-badge:nth-child(2) { width: 22.13vw; }
  .hero__m-badge:nth-child(3) { width: 22.13vw; }
  .hero__m-badge:nth-child(4) { width: 17.42vw; }

  .hero__m-badge img {
    height: 100%;
    width: auto;
    max-width: 100%;
    object-fit: contain;
  }

 
 
  .container {
    padding-inline: 6.22vw;
  }

 

  .sp-grid {
    padding-top: 86.6px;
  }

  .sp-mosaic__img {
    border-radius: 4vw;     
  }

 
  .sp-mosaic__label {
    padding: 5.33vw 6.25vw;  
  }

  .sp-mosaic__label--1 { top: 0;     left: 0; }
  .sp-mosaic__label--2 { top: 24.8%; left: 0; }
  .sp-mosaic__label--3 { top: 49.5%; left: 0; }
  .sp-mosaic__label--4 { top: 74.3%; left: 0;   width: 50%; }
  .sp-mosaic__label--5 { top: 74.3%; left: 50%;  width: 50%; }

  .sp-strip--grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6.4vw 6.4vw;
    padding: 6.25vw;
    min-height: auto;
    border-radius: 4.98vw;
  }

  .sp-strip--grid .sp-strip__item {
    width: auto;
    gap: 2.08vw;
  }

  .sp-strip--grid .sp-strip__item img {
    width: 11.07vw;
    height: 11.07vw;
  }

  .sp-strip--grid .sp-strip__item p {
    font-size: 4.27vw;
  }

 
  .sp-wifi-never {
    aspect-ratio: unset;
    min-height: unset;
    padding: 0;
  }

 
  .container-wifi {
    display: flex;
    flex-direction: column;
  }

  .sp-wifi-never .container {
    order: 1;
    height: auto;
  }

  .sp-wifi-never__img-wrap {
    order: 2;
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    margin-top: 28px;
  }

  .sp-wifi-never__text {
    max-width: 100%;
    padding-top: 0;
   
  }

  .sp-wifi-never__text .body1-light {
    margin-top: 12px;
  }

  .sp-wifi-never__text .link-row {
    flex-direction: column;
    gap: 12px;
    margin-top: 20px;
  }

 
  .sp-interference .text-center {
    text-align: left;
  }

  .sp-interference .text-center .body1-light {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }

  .sp-interference__card {
    margin-top: 28px;
    border-radius: 22px;
    overflow: hidden;
  }

 
 
  .speed-bars {
    --bar-max: 38vw;
    margin-top: 28px;
    margin-bottom: 40px;
  }
  .speed-bar__label{
    font-weight: 400;
  }
  .speed-bar__value {
    font-weight: 400;
    margin-left: 3vw;
  }
  .speed-bar { 
    gap: 3vw;
  }

  .speed-bar__label { width: 17vw; font-size: 16px; }
  .speed-bar__value { font-size: 13px; width: auto; }

 
  .keep-up {
    --h-margin: 6.22vw;
    max-width: 100%;
  }

  .keep-up .m-show.tp-space-y-16 img {
    border-radius: 16px;
  }

 
  .sp-multigig__layout {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .sp-multigig__lifestyle {
    min-height: unset;
    aspect-ratio: 984 / 667;
    border-radius: 22px;
  }

  .sp-multigig__right {
    aspect-ratio: auto;
    min-height: 100vw;
    border-radius: 22px;
    overflow: hidden;
  }

 
  .sp-multigig__product-img-wrap {
    position: absolute;
    left: -25%;
    top: -99%;
    width: 200%;
    height: auto;
  }

  .sp-multigig__port-label {
    position: absolute;
    left: 16px;
    top: 22%;
  }

  .sp-multigig__divider {
    position: absolute;
    left: 30%;
    top: 25%;
    width: 35%;
  }

  .sp-multigig__use-cases {
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 20px;
    padding: 0 8px;
    gap: 16px;
    justify-content: center;
  }

  .port-speed  { font-size: 5vw; }
  .port-subtitle { font-size: 4vw; }
  .use-case    { width: 72px; }
  .use-case img { width: 48px; height: 48px; }
  .use-case p  { font-size: 12px; }

 
  .sp-connections__header { text-align: left; }
  .sp-connections__header .body1-light { max-width: none; margin-left: 0; margin-right: 0; }

  .sp-connections__mobile-video-wrap {
    margin-top: 24px;
    margin-inline: -6.22vw;
    border-radius: 0;
    overflow: hidden;
  }

  .sp-connections__mobile-video-wrap video {
    width: 100%;
    height: auto;
    display: block;
    vertical-align: bottom;
    margin-bottom: -1px;
  }

 
 
  .sp-simple .container {
    display: flex;
    flex-direction: column;
  }

 
  .sp-simple__mobile-head {
    order: 1;
  }

  .sp-simple__mobile-head .body1-light {
    margin-top: 12px;
  }

 
  .setup-steps {
    order: 2;
    flex-direction: column;
    gap: 0;
    margin-top: 28px;
  }

  .setup-step {
    max-width: none;
    padding: 1.5vw 0;
  }

  .setup-step .body2 {
    margin-left: 18px;
    margin-top: 0;
  }

 
  .sp-simple__card {
    order: 3;
    aspect-ratio: 985 / 808;
    min-height: unset;
    border-radius: 22px;
    overflow: hidden;
    margin-top: 40px;
  }

  .sp-simple__card-img {
    position: absolute;
    left: 13%;
    top: 0;
    width: 107%;
    height: 100%;
  }

  .sp-simple__card-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: right bottom;
  }

 
  .sp-simple__card-text {
    display: none;
  }

 
  .sp-homeshield__header {
    max-width: 100%;
    margin-bottom: 40px;
  }

 
  .private-home-wrap {
    margin-top: 28px;
    transform: none;  
  }

 
  .pulse-ring {
    display: none;
  }

 
  .sp-smart__heading {
    text-align: left;
    margin-bottom: 32px;
  }

  .sp-smart__heading .h1 {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }

  .smart-features {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .smart-feature__img-wrap { border-radius: 28px; }

  .smart-feature__bubble-wrap {
    bottom: 4vw;
    right: 4vw;
  }

  .smart-feature__bubble {
    padding: 10px 20px;
    max-width: 88vw;
  }

  .smart-feature__bubble p {
    font-size: clamp(12px, 3.5vw, 16px);
    white-space: normal;
  }

  .smart-feature__bubble-dot {
    width: 2.5vw;
    height: 2.5vw;
  }
}
