/* ==========================================================================
   Homewind – Components & Layout
   ========================================================================== */

/* --- Keyframes --- */
@keyframes slide-in-bottom {
  from { transform: translateY(200px); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}
@keyframes slide-in-right {
  from { transform: translateX(200px); opacity: 0; }
  to   { transform: translateX(0);     opacity: 1; }
}

/* --- Page --- */
.page {
  width: 100%;
  min-width: 60rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-xs);
  text-align: center;
}

/* --- Navigation (mobile-first) --- */
.page-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: var(--space-12) var(--space-24);
  font-size: var(--text-base);
  color: var(--color-darkslategray-300);
}
.page-header__inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.nav { position: relative; }

/* Hamburger toggle */
.nav__toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.625rem;
  width: 5rem;
  height: 5rem;
  padding: 1rem;
  background: none;
  border: 0;
  cursor: pointer;
}
.nav__toggle-bar {
  display: block;
  width: 100%;
  height: 0.25rem;
  background: var(--color-text-muted);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.nav--open .nav__toggle-bar:nth-child(1) {
  transform: translateY(0.875rem) rotate(45deg);
}
.nav--open .nav__toggle-bar:nth-child(2) { opacity: 0; }
.nav--open .nav__toggle-bar:nth-child(3) {
  transform: translateY(-0.875rem) rotate(-45deg);
}

/* Dropdown list (mobile) */
.nav__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: absolute;
  top: calc(100% + var(--space-8));
  right: 0;
  min-width: 32rem;
  padding: var(--space-12);
  border-radius: var(--radius-lg);
  background: var(--color-bg-muted);
  box-shadow: var(--shadow-card);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-1rem);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
}
.nav--open .nav__list {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Nav links */
.nav__link {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-12) var(--space-24);
  border-radius: var(--radius-full);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text-muted);
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
}
.nav__link--active {
  background: var(--color-primary);
  color: var(--color-white);
}

/* --- Hero --- */
.hero {
  width: 100%;
  max-width: var(--content-max-width);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--nav-height) var(--space-16) var(--space-48);
  font-size: var(--text-hero);
  color: var(--color-white);
  text-align: left;
}
.hero__wrap {
  width: 100%;
  height: 87.5rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  overflow: visible;
  padding: var(--space-8);
}
.hero__card {
  flex: 1;
  align-self: stretch;
  min-height: 0;
  display: flex;
  flex-direction: column;
  padding: var(--space-64) var(--space-64) 6.75rem;
  border-radius: var(--radius-xl);
  box-shadow: 0 4px 24px -2px rgba(81, 102, 130, 0.35);
  background: url(./src/images/Container@3x.png) top / cover no-repeat;
}
.hero__content {
  width: 33%;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-12);
}
.hero__title {
  margin: 0;
  align-self: stretch;
  font-size: inherit;
  line-height: 101%;
  font-weight: 800;
  color: inherit;
}
.hero__subtitle {
  margin: 0;
  align-self: stretch;
  font-size: var(--text-2xl);
  line-height: 110%;
  font-weight: 400;
  color: inherit;
}

/* --- Section (shared base) --- */
.section {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-16) var(--space-16) var(--space-48);
  color: var(--color-white);
  text-align: left;
  overflow: hidden;
}
.section--light {
  background: var(--color-bg);
  color: var(--color-text);
}
.section--accent {
  background: var(--color-accent-section);
  scroll-margin-top: var(--nav-height);
  padding: var(--space-64) var(--space-64) 0;
}
.section--accent-soft { background: var(--color-primary-darker); }
.section--accent-mid  { background: var(--color-primary-dark); }
.section--dark {
  background: var(--color-bg-dark);
  scroll-margin-top: var(--nav-height);
}
.section--fans {
  position: relative;
  padding: var(--space-80) var(--space-64) 17.5rem;
  gap: 1.25rem;
  scroll-margin-top: var(--nav-height);
}

.section--fans h2{
  color: var(--color-gray-300);
}
.section--fans p{
  color: var(--color-darkslategray-400);
}

.section--fans .section__block{
  padding-bottom: var(--space-24);
}
/* Section sub-elements */
.section__block {
  display: flex;
  flex-direction: column;
  align-items: center;
  align-self: stretch;
  text-align: center;
}
.section__block--overlay { position: relative; z-index: 1; }

.section__title {
  margin: 0;
  font-size: var(--text-3xl);
  line-height: var(--lh-54);
  font-weight: 800;
}
.section__title--light { color: var(--color-white); }

.section__lead {
  margin: 0;
  font-size: var(--text-xl);
  line-height: 125%;
  font-weight: 500;
  max-width: var(--max-w-768);
}
.section__lead--light { color: var(--color-text-light); }

.section__grid {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 8.124rem;
  max-width: 144rem;
  flex: 1;
  width: 100%;
}
.section__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4.25rem;
  flex: 1;
  min-width: 52rem;
  max-width: 80rem;
  font-size: 4rem;
  color: var(--color-white);
}
.section__content > .section__title,
.section__content > .section__lead {
  align-self: center;
  text-align: center;
}
.section__content > .section__title { padding-bottom: var(--space-24); }

.section__figure {
  width: 22.75rem;
  max-height: 100%;
  object-fit: cover;
  mix-blend-mode: luminosity;
}
.section__bg {
  position: absolute;
  top: -0.038rem;
  right: 12.912rem;
  left: 12.9rem;
  width: calc(100% - 206.5px);
  max-width: 100%;
  max-height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* --- About (#about) --- */
#about.section {
  padding: var(--space-40) var(--space-64) var(--space-80);
  gap: 1.25rem;
}
#about .section__block { 
  padding: 0 var(--space-48); 
}
#about .section__title { color: var(--color-gray-300); }
#about .section__lead  { color: var(--color-darkslategray-400); }

/* --- Feature Cards --- */
.feature-grid {
  align-self: stretch;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: flex-start;
  padding-top: var(--space-40);
  gap: var(--space-16);
  font-size: var(--text-lg);
  color: var(--color-gray-300);
  text-align: center;
}
.feature-card {
  flex: 1 1 100%;
  min-width: 0;
  max-width: 80rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-top: 16rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  background: top / cover no-repeat;
  opacity: 0;
}



.feature-card:nth-child(1) { background-image: url(./src/images/FeatureCard@3x.png); }
.feature-card:nth-child(2) { background-image: url(./src/images/FeatureCard1@3x.png); }
.feature-card:nth-child(3) { background-image: url(./src/images/FeatureCard2@3x.png); }




.feature-card__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  padding: var(--space-16) var(--space-12);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  background: var(--color-white);
  backdrop-filter: blur(23px);
  overflow: hidden;
}
.feature-card__icon-wrap {
  display: flex;
  justify-content: center;
  padding-bottom: var(--space-8);
}
.feature-card__icon {
  width: 7.5rem;
  height: 7.5rem;
  border-radius: 33px;
}
.feature-card__title {
  margin: 1rem 0 0.5rem;
  align-self: stretch;
  line-height: var(--lh-21);
  font-weight: 700;
  text-align: center;
}
.feature-card__text {
  margin: 0;
  align-self: stretch;
  font-size: var(--text-base);
  line-height: 125%;
  color: var(--color-darkslategray-300);
  text-align: center;
}

/* --- Product Cards --- */
.product-cards {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5rem;
  font-size: var(--text-2xl);
}
.product-card {
  align-self: stretch;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: var(--space-12);
}
.product-card__title {
  margin: 0;
  font-size: inherit;
  line-height: var(--lh-21);
  font-weight: 700;
  text-align: center;
  width: 100%;
}
.product-card__desc {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 125%;
  color: var(--color-border);
  text-align: center;
}

/* --- Buttons --- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  width: fit-content;
  height: 5rem;
  padding: var(--space-6) var(--space-24);
  border: 0;
  border-radius: var(--radius-md);
  font: inherit;
  font-size: var(--text-base);
  line-height: var(--lh-24);
  cursor: pointer;
}
.btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
}
.btn--secondary {
  background: var(--color-white);
  color: var(--color-primary);
  line-height: 135%;
  text-align: center;
}
.btn__icon {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
}

/* --- Device Showcase (iPhone Mockup) --- */
.device-showcase {
  height: 78.412rem;
  width: 78.226rem;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 3.5rem;
  overflow: hidden;
  flex-shrink: 0;
  opacity: 0;
  font-size: 1.812rem;
  color: var(--color-white);
}
.device-showcase__frame {
  height: 65.5rem;
  width: 28.5rem;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.device-showcase__img {
  position: absolute;
  left: 13.75rem;
  top: 6.5rem;
  height: 100%;
  width: 100%;
  object-fit: contain;
  transform: scale(1.197);
}
.iphone-mockup {
  height: var(--mockup-phone-h);
  width: 45rem;
  display: flex;
  align-items: flex-start;
  flex-shrink: 0;
}
.phone {
  height: 117.55rem;
  width: 71.212rem;
  position: relative;
  flex-shrink: 0;
}
.shadows-icon {
  position: absolute;
  top: 1.626rem;
  left: 2.1rem;
  width: 69.126rem;
  height: 115.938rem;
}
.frame {
  position: absolute;
  top: 0.288rem;
  left: 0.576rem;
  width: var(--mockup-phone-w);
  height: var(--mockup-phone-h);
  border-radius: 45.8px;
  border: 2.3px solid transparent;
  box-shadow:
    15.3px 15.3px 38.1px rgba(0, 0, 0, 0.35),
    61px 61px 114.4px rgba(0, 0, 0, 0.25);
  background:
    var(--color-black) padding-box,
    linear-gradient(156.79deg, rgba(255, 255, 255, 0.75), #010101) border-box;
}
.put-screen-in-here,
.home-indicator {
  position: absolute;
  left: 2.1rem;
  width: var(--mockup-screen-w);
}
.put-screen-in-here {
  top: 1.812rem;
  height: 88.288rem;
  border-radius: 38.1px;
  object-fit: cover;
}
.home-indicator {
  top: 86.85rem;
  height: 3.238rem;
  display: flex;
  align-items: flex-start;
  padding: 1.924rem 13.986rem 0.836rem;
}
.notch-shape {
  height: 0.476rem;
  width: 12.776rem;
  border-radius: 76.3px;
  background: var(--color-white);
}
.screen-shine,
.status-bar {
  position: absolute;
  top: 1.812rem;
  left: 2.1rem;
  width: var(--mockup-screen-w);
}
.screen-shine {
  height: 88.288rem;
  border-radius: 38.1px;
  background: linear-gradient(155.14deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0) 64.58%);
}
.status-bar {
  height: 6.676rem;
  display: flex;
  align-items: flex-start;
  padding: 2.286rem 2.586rem 2.386rem 4.386rem;
  gap: 21.3rem;
  overflow: hidden;
}
.left-side,
.statusbar-time {
  height: 2rem;
  width: 5.15rem;
  display: flex;
  align-items: flex-start;
}
.statusbar-time {
  align-self: center;
  border-radius: 18.3px;
  padding: 0.1rem 0;
}
.time {
  height: 1.912rem;
  width: 5.15rem;
  line-height: 2.1rem;
  font-weight: 600;
  letter-spacing: -0.31px;
}
.right-side-wrapper {
  width: 7.376rem;
  height: 1.612rem;
  display: flex;
  flex-direction: column;
  padding: 0.374rem 0;
}
.right-side {
  width: 7.376rem;
  height: 1.238rem;
  display: flex;
  align-items: flex-end;
  gap: 0.712rem;
}
.icon-mobile-signal { height: var(--mockup-split-h); width: 1.712rem; z-index: 3; }
.wifi-icon { height: 1.126rem; width: 1.626rem; }
.statusbar-battery {
  height: 1.238rem;
  width: 2.612rem;
  position: relative;
  z-index: 1;
}
.outline-icon {
  position: absolute;
  top: calc(50% - 5.25px);
  left: calc(50% - 11.15px);
  width: 2.388rem;
  height: 1.238rem;
  border-radius: 3.1px;
}
.battery-end-icon,
.fill-icon {
  position: absolute;
  top: calc(50% - 1.45px);
  left: calc(50% + 8.75px);
  width: 0.138rem;
  height: 0.4rem;
}
.fill-icon {
  top: calc(50% - 3.75px);
  left: calc(50% - 9.65px);
  width: 1.426rem;
  height: 0.862rem;
  border-radius: 1.5px;
}
.hardware {
  position: absolute;
  top: 0;
  left: 0;
  width: 45rem;
  height: var(--mockup-phone-h);
  display: flex;
  align-items: flex-end;
  padding: 1.812rem 0 54.536rem;
  gap: 1.812rem;
  isolation: isolate;
}
.switch-parent {
  height: 22.688rem;
  width: var(--mockup-btn-w);
  display: flex;
  flex-direction: column;
  gap: 3.224rem;
  z-index: 3;
  flex-shrink: 0;
}
.switch {
  width: var(--mockup-btn-w);
  height: 3.438rem;
  border-radius: 0 var(--radius-1_14) var(--radius-1_14) 0;
  background: var(--color-gray-1000);
  transform: rotate(180deg);
}
.volume-buttons {
  width: var(--mockup-btn-w);
  height: 16.024rem;
  display: flex;
  flex-direction: column;
  gap: 2.3rem;
}
.volume-up-button {
  width: var(--mockup-btn-w);
  height: 6.862rem;
  border-radius: 0 var(--radius-1_14) var(--radius-1_14) 0;
  background: var(--color-gray-1000);
  transform: rotate(180deg);
}
.notch-wrapper {
  width: var(--mockup-screen-w);
  height: 35.562rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: 28.886rem;
  z-index: 5;
  flex-shrink: 0;
}
.notch {
  width: var(--mockup-screen-w);
  height: 6.676rem;
  display: flex;
  padding: 1.462rem 14.174rem 1.4rem;
}
.dynamic-island {
  height: 3.812rem;
  width: 12.4rem;
  border-radius: 76.3px;
  background: var(--color-black);
}
.speaker-parent {
  position: absolute;
  top: 0;
  left: 0.288rem;
  height: var(--mockup-phone-h);
  width: var(--mockup-phone-w);
  display: flex;
  align-items: flex-start;
  isolation: isolate;
  z-index: 2;
  flex-shrink: 0;
  margin: 0;
}
.speaker {
  position: absolute;
  top: 0.288rem;
  right: 19.262rem;
  height: 0.662rem;
  width: 5.812rem;
  border-radius: 76.3px;
  background: var(--color-gray-900);
  z-index: 0;
}
.frame-splits {
  width: var(--mockup-phone-w);
  height: var(--mockup-phone-h);
  display: flex;
  flex-direction: column;
  gap: 71.886rem;
  z-index: 1;
}
.frame-parent {
  width: var(--mockup-phone-w);
  height: 10.012rem;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8.574rem;
  flex-shrink: 0;
}
.split-wrapper {
  width: 10.012rem;
  height: var(--mockup-btn-h);
  display: flex;
  justify-content: flex-end;
  padding-right: 8.862rem;
}
.split {
  width: 1.15rem;
  height: var(--mockup-btn-h);
  position: relative;
  flex-shrink: 0;
}
.split-child,
.split-inner,
.split-item {
  position: absolute;
  top: 0;
  height: var(--mockup-btn-h);
}
.split-child { left: 0.2rem;   width: 0.762rem;              background: var(--color-gray-400); }
.split-item  { left: 0;        width: var(--mockup-split-w);  background: var(--color-gray-800); }
.split-inner { left: 0.962rem; width: var(--mockup-split-w);  background: var(--color-gray-800); }
.split-parent {
  width: var(--mockup-phone-w);
  height: var(--mockup-split-h);
  display: flex;
  gap: 43.85rem;
  flex-shrink: 0;
}
.split-icon,
.split-icon2 {
  height: var(--mockup-split-h);
  width: var(--mockup-btn-w);
  object-fit: contain;
  z-index: 2;
}
.split-icon2 { z-index: 1; }
.frame-group {
  width: var(--mockup-phone-w);
  height: 10.012rem;
  display: flex;
  flex-direction: column;
  gap: 8.574rem;
  flex-shrink: 0;
}
.split-group {
  width: var(--mockup-phone-w);
  height: var(--mockup-split-h);
  display: flex;
  gap: 43.85rem;
  z-index: 2;
}
.split2 {
  width: var(--mockup-btn-w);
  height: var(--mockup-split-h);
  position: relative;
}
.rectangle-div {
  position: absolute;
  top: 0.188rem;
  left: 0.288rem;
  width: 0.762rem;
  height: var(--mockup-btn-h);
  background: var(--color-gray-500);
  transform: rotate(90deg);
  transform-origin: 0 0;
}
.split-child2,
.split-child3,
.split-child4 {
  position: absolute;
  left: 0.288rem;
  height: var(--mockup-btn-h);
  transform: rotate(90deg);
  transform-origin: 0 0;
}
.split-child2 { top: 0;        width: var(--mockup-split-w); background: var(--color-gray-700); }
.split-child3 { top: 0.95rem;  width: var(--mockup-split-w); background: var(--color-gray-700); }
.split-child4 { top: 0.188rem; width: 0.762rem;              background: var(--color-black); }
.split-container {
  width: 10.012rem;
  height: var(--mockup-btn-h);
  display: flex;
  padding-left: 8.862rem;
  z-index: 1;
}
.split-icon3 {
  height: var(--mockup-btn-h);
  width: 1.15rem;
  object-fit: contain;
}
.power-button-wrapper {
  height: 13.726rem;
  width: var(--mockup-btn-w);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: 2.286rem;
  z-index: 2;
  flex-shrink: 0;
}
.power-button {
  width: var(--mockup-btn-w);
  height: 11.438rem;
  border-radius: 0 var(--radius-1_14) var(--radius-1_14) 0;
  background: var(--color-gray-1000);
}

/* --- Version & Software Cards --- */
.section--accent-soft,
.section--accent-mid {
  gap: var(--space-24);
  padding: var(--space-40) var(--space-64) 4.5rem;
  text-align: center;
}
.section--accent-mid { padding-bottom: var(--space-80); }

.version-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  padding: var(--space-24) var(--space-14) 2.25rem;
  gap: var(--space-12);
  border-radius: var(--radius-lg);
  font-size: var(--text-xs);
  color: var(--color-white);
  text-align: left;
}
.version-card--single { padding: 0 var(--space-14); flex-shrink: 0; }
.btn--disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}
.version-card__hint {
  margin: 0;
  padding-top: 3.75rem;
  line-height: var(--lh-18);
  text-align: center;
}
.version-card__requirements {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding-top: 3.75rem;
}
.version-card__req {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  font-weight: 500;
  line-height: var(--lh-18);
}
.version-card__req img { flex-shrink: 0; }

/* --- Fan Cards --- */
.fan-grid {
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  gap: var(--space-24);
  align-self: stretch;
  flex: 1;
  min-width: var(--min-w-393);
  font-size: var(--text-lg);
  color: var(--color-darkslategray-100);
  z-index: 1;
}

.article-wrapper{
  display: flex;
  gap: var(--space-24);
  align-content: center;
  justify-content: center;
}



.fan-card {
  flex: 1;
  max-width: 36rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  isolation: isolate;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-card-alt);
  background: var(--color-gray-100);
  overflow: hidden;
  opacity: 0;
}
.fan-card__img-wrap {
  width: 26rem;
  height: 32.5rem;
  position: relative;
  background: var(--color-white);
  z-index: 0;
}
.fan-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.fan-card__name {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 0;
  padding: var(--space-16) 0 var(--space-20);
  backdrop-filter: blur(8px);
  background: var(--color-gray-600);
  z-index: 1;
  font-size: var(--text-base);
  line-height: var(--lh-24);
  font-weight: 800;
  text-align: center;
}

/* --- Support, Disclaimer, Footer --- */
.support__text {
  width: 100%;
  max-width: var(--content-narrow);
  padding: 0 var(--space-64);
  font-size: var(--text-base);
  line-height: 125%;
  text-align: center;
}
.disclaimer {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 9.25rem var(--space-64);
  background: var(--color-darkslategray-100);
}
.disclaimer__text {
  width: 100%;
  max-width: var(--content-narrow);
  margin: 0;
  font-size: var(--text-base);
  line-height: 125%;
  color: var(--color-white);
}
.page-footer {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  height: 15.126rem;
  padding: 6.124rem var(--space-32) 0;
  background: var(--color-bg);
  border-top: 1px solid var(--color-border);
  font-size: var(--text-sm);
  color: var(--color-slategray);
  text-align: left;
}
.page-footer__inner {
  width: 100%;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.5rem;
}
.page-footer__copy {
  margin: 0;
  width: 35.626rem;
  line-height: 2.188rem;
}
.page-footer__links {
  display: flex;
  align-items: flex-start;
  gap: var(--space-24);
  height: 3rem;
  font-size: var(--text-base);
  color: var(--color-darkslategray-400);
}
.page-footer__link {
  display: inline-flex;
  align-items: flex-start;
  gap: var(--space-8);
  color: inherit;
  text-decoration: none;
  line-height: var(--lh-24);
}
.page-footer__link img { flex-shrink: 0; }

/* --- Scroll Animations --- */
.feature-card.animate,
.fan-card.animate { animation: 1s ease-out forwards slide-in-bottom; }
.device-showcase.animate { animation: 1s ease forwards slide-in-right; }
.feature-card:nth-child(2).animate,
.fan-card:nth-child(2).animate { animation-delay: 0.2s; }
.feature-card:nth-child(3).animate,
.fan-card:nth-child(3).animate { animation-delay: 0.4s; }
.fan-card:nth-child(4).animate { animation-delay: 0.6s; }

/* --- Media Queries --- */

/* Mobile nav-height override */
@media (max-width: 767px) {
  :root { --nav-height: 8rem; }
}

@media (min-width: 450px) {
  .section--accent { gap: var(--space-16); }

  .hero,
  .section {
    padding-left: var(--space-24);
    padding-right: var(--space-24);
  }

}
@media (min-width: 750px) {
  .section--accent {
    gap: var(--space-32);
    padding: 5.25rem var(--space-32) 0;
  }
  .section--fans { padding: 6.5rem var(--space-32) 11.376rem; }
  .section--dark { padding: var(--space-48) var(--space-32); }
}

/* Tablet+ (768px): Desktop nav + 2-column cards */
@media (min-width: 768px) {
  /* Navigation: horizontal pill bar */
  .hero,
  .section {
    padding-left: var(--space-48);
    padding-right: var(--space-48);
  }
 

  .page-header {
    padding: var(--space-40) var(--space-32) var(--space-20);
    text-align: center;
  }
  .page-header__inner {
    height: 8rem;
    justify-content: center;
    align-items: flex-start;
  }
  .nav__toggle { display: none; }
  .nav__list {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--space-16);
    padding: var(--space-8);
    min-width: auto;
    border-radius: var(--radius-xl);
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    transition: none;
  }
  .nav__link { width: fit-content; }

  /* Feature cards: 2 per row */
  .feature-grid { gap: var(--space-24); }
  .feature-card {
    flex-basis: calc(50% - var(--space-12));
    padding-top: 20rem;
  }
  .feature-card__content {
    padding: var(--space-20) var(--space-16);
  }

  .product-card__title,
  .product-card__desc{
    text-align: left;
  }


  #get-homewind .section__block,
  #get-homewind .product-card{
    text-align: left;
    align-items: flex-start;
  }

}

/* Desktop: 3 cards per row, full proportions */
@media (min-width: 1200px) {
  .hero,
  .section {
    padding-left: var(--space-64);
    padding-right: var(--space-64);
  }
  .feature-card {
    flex-basis: calc(33.333% - var(--space-16));
    padding-top: 23rem;
  }
  .feature-card__content {
    padding: var(--space-24) var(--space-16);
  }
}
