:root{
  --hk-blue:#00387D;
  --text:#F2F4F7;
  --muted:rgba(242,244,247,.78);
  --muted2:rgba(242,244,247,.86);
}
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", Helvetica, sans-serif;
  background:#000;
  color:var(--text);
}
.hero{
  position:relative;
  min-height:100vh;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(1100px 780px at 72% 48%, rgba(0,56,125,.20), transparent 60%),
    radial-gradient(900px 620px at 86% 68%, rgba(255,0,90,.08), transparent 62%),
    radial-gradient(900px 620px at 70% 78%, rgba(255,210,0,.06), transparent 62%),
    radial-gradient(900px 620px at 58% 78%, rgba(0,255,160,.06), transparent 62%),
    radial-gradient(1200px 900px at 50% 50%, rgba(0,0,0,0), rgba(0,0,0,.92));
  transform:scale(1.02);
}
.hero__fx{ position:absolute; inset:0; pointer-events:none; }
.hero__fx--streaks{
  opacity:.95;
  mix-blend-mode:screen;
  filter: blur(1.4px);
  background:
    linear-gradient(120deg,
      transparent 30%,
      rgba(0,56,125,0) 42%,
      rgba(0,56,125,.78) 50%,
      rgba(0,56,125,0) 58%,
      transparent 70%
    ),
    linear-gradient(120deg,
      transparent 46%,
      rgba(255,45,85,0) 52%,
      rgba(255,45,85,.58) 58%,
      transparent 72%
    ),
    linear-gradient(120deg,
      transparent 54%,
      rgba(255,210,0,0) 61%,
      rgba(255,210,0,.48) 66%,
      transparent 78%
    ),
    linear-gradient(120deg,
      transparent 58%,
      rgba(0,255,160,0) 66%,
      rgba(0,255,160,.32) 72%,
      transparent 82%
    );
  animation: streakDrift 7.5s ease-in-out infinite alternate;
}
@keyframes streakDrift{
  from{ transform:translateX(-1.2%) translateY(-1%); }
  to{ transform:translateX(1.2%) translateY(1%); }
}
.hero__fx--glow{
  mix-blend-mode:screen;
  opacity:.95;
  background:
    radial-gradient(740px 440px at 18% 58%, rgba(0,56,125,.25), transparent 62%),
    radial-gradient(740px 440px at 35% 82%, rgba(0,56,125,.16), transparent 64%),
    radial-gradient(860px 560px at 82% 48%, rgba(0,56,125,.18), transparent 62%);
}
.hero__fx--grain{
  opacity:.14;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}
.hero__top{
  position:relative;
  z-index:3;
  padding:18px 20px 8px;
}
.hero__brand{
  display:flex;
  align-items:baseline;
  gap:10px;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:21px;
}
.hero__brandName--ef{
  font-style:italic;
  text-transform:uppercase;
  letter-spacing:.02em;
  font-weight:800;
  opacity:.95;
}
.hero__x{ opacity:.55; }
.hero__presents{
  margin-top:14px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:15px;
  opacity:.75;
}
.hero__wrap{
  position:relative;
  z-index:3;
  max-width:1180px;
  margin:0 auto;
  padding: 26px 20px 44px;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:28px;
  align-items:center;
}
.hero__copy{ max-width:560px; }
.hero__h1{
  margin:0 0 14px;
  font-size:clamp(52px, 6.6vw, 92px);
  line-height:.9;
  letter-spacing:-.04em;
  text-transform:uppercase;
  text-shadow:0 18px 60px rgba(0,0,0,.45);
}
.hero__sub{
  margin:0 0 18px;
  font-size:20px;
  color:var(--muted2);
  text-shadow: 0 10px 28px rgba(0,0,0,.55);
  max-width:44ch;
}
.hero__line{
  margin:0 0 26px;
  font-size:16px;
  color:var(--muted2);
  max-width:58ch;
}
.hero__capsule{
  font-weight:1000;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:#dbe9ff;
  text-shadow:0 0 26px rgba(0,56,125,.35);
}
.hero__note{
  margin-top:16px;
  color: rgba(242,244,247,.55);
  font-size:12px;
  letter-spacing:.02em;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 18px;
  border-radius:14px;
  font-weight:1000;
  text-decoration:none;
  letter-spacing:.01em;
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
}

/* Alias button styles used across later sections */
.hk-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 18px;
  border-radius:14px;
  font-weight:1000;
  text-decoration:none;
  letter-spacing:.01em;
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
}
.btn--primary{
  background: #ffffff;
  color: #000000;
  border-color: rgba(255,255,255,.85);
  box-shadow:
    0 0 0 6px rgba(0,56,125,.22),
    0 18px 70px rgba(0,0,0,.55),
    0 0 60px rgba(0,56,125,.35);
}

.hk-btn--primary{
  background: #ffffff;
  color: #000000;
  border-color: rgba(255,255,255,.85);
  box-shadow:
    0 0 0 6px rgba(0,56,125,.22),
    0 18px 70px rgba(0,0,0,.55),
    0 0 60px rgba(0,56,125,.35);
}

.hk-btn--primary:hover{ background: #f4f7fb; }

.hk-btn--ghost{
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
  border-color: rgba(255,255,255,0.14);
}

.hk-btn--ghost:hover{ background: rgba(255,255,255,0.10); }

.btn--primary:hover{
  background: #f4f7fb;
}
.hero__product{
  position:relative;
  height:min(560px, 64vh);
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero__shoeStage{
  position:absolute;
  width:min(560px, 92%);
  height:min(440px, 70%);
  border-radius:44px;
  background:
    radial-gradient(closest-side, rgba(0,56,125,.22), transparent 68%),
    radial-gradient(closest-side, rgba(255,45,85,.10), transparent 70%),
    radial-gradient(closest-side, rgba(255,210,0,.08), transparent 72%),
    radial-gradient(closest-side, rgba(0,255,160,.08), transparent 72%);
  filter: blur(18px);
  opacity:.9;
  transform: translateY(18px);
}
.hero__shoe{
  width:min(620px, 96%);
  height:auto;
  filter: drop-shadow(0 28px 60px rgba(0,0,0,.58));
  transform: translateY(-8px);
  will-change: transform;
}
.hero__scroll{
  position:absolute;
  z-index:3;
  bottom:16px;
  left:50%;
  transform:translateX(-50%);
  opacity:.55;
}
.hero__scroll span{
  display:block;
  width:2px;
  height:34px;
  background: linear-gradient(180deg, rgba(0,56,125,.0), rgba(0,56,125,.9), rgba(0,56,125,.0));
  border-radius:999px;
  animation: scrollPulse 1.7s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{ transform:translateY(0); opacity:.55; }
  50%{ transform:translateY(6px); opacity:.9; }
}
@media (max-width: 860px){
  .hero__wrap{
    grid-template-columns: 1fr;
    padding: 18px 16px 44px;
    gap:18px;
  }
  .hero__brand{ font-size:18px; }
  .hero__presents{ font-size:13px; }
  .hero__sub{ font-size:18px; }
  .hero__product{
    height:auto;
    padding-top:6px;
  }
  .hero__shoe{
    width:min(720px, 106%);
    transform: translateY(-2px);
  }
}


/* =========================
   SECTIONS 2 + 3 (Story)
   ========================= */

.hk-sections{
  position:relative;
  padding: 56px 0 88px;
  overflow:hidden;
}

/* On desktop, pull section 2 slightly upward so the handoff from the hero
   feels tighter (reduces “dead air” under the hero). */
@media (min-width: 861px){
  .hk-sections{
    margin-top: -48px;
    padding-top: 64px; /* keeps content breathing room after overlap */
  }
}

.hk-sections::before{
  content:"";
  position:absolute; inset:0;
  background:
    /* subtle continuation of hero motion streaks */
    linear-gradient(120deg,
      transparent 18%,
      rgba(0,56,125,0) 34%,
      rgba(0,56,125,.18) 46%,
      rgba(0,56,125,0) 58%,
      transparent 72%
    ),
    linear-gradient(120deg,
      transparent 34%,
      rgba(255,45,85,0) 44%,
      rgba(255,45,85,.10) 54%,
      rgba(255,45,85,0) 64%,
      transparent 78%
    ),
    linear-gradient(120deg,
      transparent 42%,
      rgba(255,210,0,0) 52%,
      rgba(255,210,0,.08) 60%,
      rgba(255,210,0,0) 70%,
      transparent 84%
    ),
    linear-gradient(120deg,
      transparent 48%,
      rgba(0,255,160,0) 58%,
      rgba(0,255,160,.06) 66%,
      rgba(0,255,160,0) 76%,
      transparent 90%
    ),
    radial-gradient(900px 520px at 20% 25%, rgba(0,56,125,.16), transparent 62%),
    radial-gradient(900px 520px at 85% 70%, rgba(0,56,125,.10), transparent 64%),
    radial-gradient(1200px 900px at 50% 50%, rgba(0,0,0,0), rgba(0,0,0,.88));
  pointer-events:none;
  z-index:0;
}

.hk-sections::after{
  content:"";
  position:absolute; inset:-2px;
  opacity:.10;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:0;
}

.hk-block{
  position:relative;
  z-index:1;
  max-width:1180px;
  margin:0 auto;
  padding: 0 20px;
}

.hk-block + .hk-block{ margin-top: 64px; }

.hk-grid{
  display:grid;
  gap:28px;
  align-items:center;
}

.hk-grid--what{
  grid-template-columns: 1fr 1.05fr;
}

.hk-grid--whyTop{
  grid-template-columns: 1fr;
  margin-bottom: 26px;
}

.hk-grid--why{
  grid-template-columns: 1.05fr .95fr 1fr;
  align-items:stretch;
}

.hk-media{
  position:relative;
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  background: rgba(0,0,0,.35);
}

.hk-media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}

.hk-media::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(0,56,125,.14), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.55));
  pointer-events:none;
}

/* Slightly different crops/heights per tile */
.hk-media--portrait{ min-height: 420px; }
.hk-media--craft{ min-height: 520px; }
.hk-media--detail{ min-height: 520px; }

.hk-copy{
  max-width: 620px;
}

.hk-copy p{
  margin: 0 0 14px;
  color: var(--muted2);
  line-height: 1.55;
  font-size: 16px;
}

.hk-h2{
  margin:0 0 14px;
  text-transform:uppercase;
  letter-spacing:.02em;
  font-weight: 950;
  font-size: clamp(36px, 4.4vw, 64px);
  line-height: .95;
  color: #dbe9ff;
  text-shadow: 0 0 26px rgba(0,56,125,.25);
}

.hk-h2--small{
  font-size: clamp(34px, 3.4vw, 52px);
}

.hk-lead{
  margin: 0 0 8px;
  font-size: 16px;
  color: rgba(242,244,247,.88);
}

.hk-lead2{
  margin: 0;
  font-size: 16px;
  color: rgba(242,244,247,.78);
}

/* Bullet block */
.hk-bullets{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.30);
  box-shadow: 0 22px 70px rgba(0,0,0,.42);
  padding: 22px 22px;
  position:relative;
  overflow:hidden;
}

.hk-bullets::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(800px 380px at 40% 20%, rgba(0,56,125,.16), transparent 60%);
  pointer-events:none;
}

.hk-bullets ul{
  position:relative;
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.hk-bullets li{
  position:relative;
  padding-left: 28px;
  color: rgba(242,244,247,.86);
  line-height: 1.45;
  font-size: 16px;
}

.hk-bullets li::before{
  content:"";
  position:absolute;
  left:0;
  top: .35em;
  width: 16px;
  height: 16px;
  background:
    radial-gradient(closest-side, rgba(0,56,125,.35), rgba(0,56,125,0)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M16.5 5.7 8.3 14l-4-4' stroke='%2300387D' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/16px 16px no-repeat;
  filter: drop-shadow(0 0 10px rgba(0,56,125,.35));
}

/* Responsive */
@media (max-width: 980px){
  .hk-grid--why{
    grid-template-columns: 1fr 1fr;
  }
  .hk-media--detail{ grid-column: 1 / -1; min-height: 420px; }
}

@media (max-width: 860px){
  .hk-sections{ padding: 54px 0 70px; }
  .hk-block + .hk-block{ margin-top: 56px; }

  .hk-grid--what{
    grid-template-columns: 1fr;
  }
  .hk-media--portrait{ min-height: 360px; }

  .hk-grid--why{
    grid-template-columns: 1fr;
  }
  .hk-media--craft{ min-height: 420px; }
  .hk-media--detail{ min-height: 360px; }

  .hk-bullets{ padding: 18px 18px; }
  .hk-bullets li{ font-size: 15px; }
  .hk-copy p{ font-size: 15px; }
}

/* =====================================
   SECTION 5: Season + Gallery
===================================== */
/*
  SECTION 5: Season hero banner + product gallery
  Goal: show MOST of the banner, keep colors punchy, and make the gallery feel premium.
*/

.hk-season{
  position: relative;
  padding: 0;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(3,4,6,1), rgba(3,4,6,1));
  border-top: 1px solid rgba(255,255,255,.08);
}

.hk-seasonHero{
  position: relative;
  min-height: 62vh;
  max-height: 760px;
  display: grid;
  align-items: end;
}

.hk-seasonHero__img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 58% 36%;
  filter: saturate(1.08) contrast(1.06);
}

.hk-seasonHero::after{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 520px at 18% 22%, rgba(0,187,255,.22), transparent 62%),
    radial-gradient(820px 520px at 78% 22%, rgba(255,213,0,.18), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.22), rgba(0,0,0,.64) 72%, rgba(0,0,0,.86));
  pointer-events: none;
}

.hk-seasonHero__content{
  position: relative;
  z-index: 1;
  padding: 56px 0 44px;
}

.hk-seasonHero__grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: end;
}

.hk-seasonHero__copy{
  max-width: 680px;
}

.hk-seasonHero__meta{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.hk-seasonHero__ctaRow{
  margin-top: 18px;
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.hk-pill{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.25);
  color: rgba(255,255,255,.88);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
}

/* Gallery */
.hk-gallery{
  padding: 56px 0 94px;
  background:
    radial-gradient(1000px 560px at 18% 8%, rgba(255,0,96,.12), transparent 55%),
    radial-gradient(900px 520px at 76% 14%, rgba(0,187,255,.14), transparent 58%),
    radial-gradient(900px 520px at 66% 84%, rgba(255,213,0,.10), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,.92), rgba(3,4,6,1));
}

.hk-gallery__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
}

/* When we only show the CTA (no headline/body copy) */
.hk-gallery__head--ctaOnly{
  justify-content: flex-end;
  align-items: center;
}

.hk-gallery__headCta{ flex: 0 0 auto; }


.hk-galleryShell{
  margin-top: 14px;
  padding: 20px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(900px 420px at 18% 22%, rgba(0,187,255,.10), transparent 62%),
    radial-gradient(780px 420px at 78% 70%, rgba(255,0,96,.09), transparent 62%),
    rgba(255,255,255,.035);
  box-shadow: 0 22px 80px rgba(0,0,0,.46);
}

.hk-galleryGrid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items: stretch;
}


/* Gallery layout fixes (Stage + Rail) */
.hk-galleryStage{
  position: relative;
  display: grid;
  place-items: center;
}

.hk-navBtn--prev,
.hk-navBtn--next{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
}

.hk-navBtn--prev{ left: 14px; }
.hk-navBtn--next{ right: 14px; }

.hk-navBtn--prev:hover,
.hk-navBtn--next:hover{ transform: translateY(calc(-50% - 1px)); }

.hk-navBtn--prev:active,
.hk-navBtn--next:active{ transform: translateY(-50%) scale(.98); }

.hk-galleryRail{
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  padding: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-content: start;
  max-height: 520px;
  overflow: auto;
}

.hk-galleryRail::-webkit-scrollbar{ height: 10px; width: 10px; }
.hk-galleryRail::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.10); border-radius: 999px; }

.hk-galleryRail .hk-thumb{
  width: 100%;
  height: 86px;
  border-radius: 16px;
  overflow: hidden;
  display: grid;
  place-items: center;
}

.hk-galleryRail .hk-thumb img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 10px;
  box-sizing: border-box;
}

/* Color hints behind the shoe (Nike x Jordan vibe) */
.hk-galleryBackdrop{
  position: absolute;
  inset: -22%;
  background:
    radial-gradient(520px 360px at 16% 30%, rgba(0,187,255,.26), transparent 62%),
    radial-gradient(560px 380px at 70% 22%, rgba(255,213,0,.22), transparent 64%),
    radial-gradient(620px 420px at 72% 78%, rgba(255,0,96,.18), transparent 66%),
    radial-gradient(520px 360px at 20% 82%, rgba(120,255,0,.10), transparent 66%);
  filter: blur(26px) saturate(1.18);
  opacity: .95;
  transform: rotate(7deg);
  pointer-events: none;
}

.hk-galleryMain img{
  position: relative;
  z-index: 2;
}

@media (max-width: 860px){
  .hk-galleryRail{
    max-height: none;
    grid-template-columns: repeat(6, minmax(72px, 1fr));
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    padding: 10px 8px;
  }
  .hk-galleryRail .hk-thumb{
    scroll-snap-align: start;
    width: 74px;
    height: 74px;
    border-radius: 14px;
  }
  .hk-galleryRail .hk-thumb img{ width: 56px; }
  .hk-navBtn--prev{ left: 10px; }
  .hk-navBtn--next{ right: 10px; }
}

.hk-galleryMain{
  position: relative;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.12);
  min-height: 520px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(0,0,0,.18)),
    radial-gradient(820px 420px at 20% 18%, rgba(255,213,0,.10), transparent 62%),
    radial-gradient(820px 420px at 78% 72%, rgba(0,187,255,.12), transparent 62%);
}

.hk-galleryMain img{
  width: min(560px, 92%);
  height: auto;
  transform: translateY(6px);
  filter: drop-shadow(0 44px 90px rgba(0,0,0,.62));
}

.hk-galleryGlow{ display:none; }

.hk-galleryControls{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 10px;
  pointer-events: none;
}

.hk-navBtn{
  pointer-events: auto;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.38);
  color: rgba(255,255,255,.92);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
  backdrop-filter: blur(10px);
}

.hk-navBtn:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.28); background: rgba(0,0,0,.48); }
.hk-navBtn:active{ transform: translateY(0px) scale(.98); }
.hk-navBtn:focus-visible{ outline: none; box-shadow: 0 0 0 3px rgba(255,255,255,.10), 0 0 0 6px rgba(0,187,255,.22); }


.hk-galleryAside{
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.hk-featureList{
  margin: 0;
  padding-left: 16px;
  color: rgba(255,255,255,.78);
  line-height: 1.55;
}

.hk-galleryThumbs{
  margin-top: 10px;
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 8px 2px 10px;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
}

.hk-thumb{
  flex: 0 0 auto;
  width: 74px;
  height: 74px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.02);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
  scroll-snap-align: start;
}

.hk-thumb img{
  width: 62px;
  height: auto;
  filter: drop-shadow(0 18px 22px rgba(0,0,0,.35));
}

.hk-thumb[aria-selected="true"],
.hk-thumb.is-active{
  border-color: rgba(255,255,255,.40);
  box-shadow: 0 0 0 4px rgba(0,187,255,.12);
  transform: translateY(-1px);
}

.hk-thumb:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(255,255,255,.10), 0 0 0 6px rgba(0,187,255,.25);
}

.hk-galleryHint{
  margin: 10px 2px 0;
  font-size: 13px;
  color: rgba(255,255,255,.62);
}

@media (max-width: 860px){
  .hk-seasonHero{ min-height: 54vh; max-height: 640px; }
  .hk-seasonHero__img{ object-position: 58% 30%; }
  .hk-seasonHero__grid{ grid-template-columns: 1fr; gap: 18px; }
  .hk-seasonHero__meta{ justify-content: flex-start; }
  .hk-gallery{ padding: 52px 0 74px; }
  .hk-gallery__head{ flex-direction: column; align-items: flex-start; }
  .hk-galleryGrid{ grid-template-columns: 1fr; }
  .hk-galleryMain{ min-height: 420px; }
  .hk-thumb{ width: 66px; height: 66px; border-radius: 13px; }
  .hk-thumb img{ width: 56px; }
}

@media (max-width: 520px){
  .hk-seasonHero__content{ padding: 46px 0 36px; }
  .hk-galleryShell{ padding: 14px; border-radius: 22px; }
  .hk-galleryMain{ min-height: 360px; }
  .hk-galleryMain img{ width: min(420px, 92%); }
}


/* SECTION 6: divider banner + "How they're made" (edgy drop vibe) */
.hk-divider{
  position: relative;
  width: 100%;
  height: clamp(180px, 26vw, 380px);
  overflow: hidden;
  background: #05070b;
}
.hk-divider__img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 70%;
  transform: scale(1.02);
  filter: saturate(1.08) contrast(1.05);
}
.hk-divider__fade{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(5,7,11,1) 0%, rgba(5,7,11,0) 26%, rgba(5,7,11,0) 70%, rgba(5,7,11,1) 100%);
}
.hk-divider__grain{
  position: absolute;
  inset: -35%;
  opacity: .14;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  animation: hkGrain 8s steps(8) infinite;
}

.hk-made{
  position: relative;
  /* tighter transition from the color burst banner above */
  padding: 56px 0 92px;
  background: radial-gradient(1200px 620px at 20% 10%, rgba(0, 220, 255, .10), transparent 55%),
              radial-gradient(900px 520px at 85% 35%, rgba(255, 0, 120, .10), transparent 60%),
              radial-gradient(760px 520px at 35% 80%, rgba(255, 210, 0, .10), transparent 60%),
              #05070b;
  overflow: hidden;
}
.hk-made__grid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 34px;
  align-items: center;
}
.hk-made__copy{
  /* center the text block within the left column so it doesn't hug the page edge */
  max-width: 56ch;
  justify-self: center;
}
.hk-made__copy .hk-h2{ margin: 10px 0 12px; }
.hk-made__tagline{
  margin-top: 18px;
  color: rgba(255,255,255,.78);
  font-size: 15px;
  line-height: 1.5;
  max-width: 46ch;
}

.hk-madeList{
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  display: grid;
  gap: 12px;
  max-width: 52ch;
}
.hk-madeList li{
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 10px;
  align-items: start;
  color: rgba(255,255,255,.86);
  font-size: 15px;
  line-height: 1.45;
}
.hk-icon{
  width: 22px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: rgba(255,255,255,.86);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset;
}
.hk-icon svg{ width: 16px; height: 16px; }

.hk-made__media{
  position: relative;
  margin: 0;
  min-height: 420px;
  display: grid;
  place-items: center;
  transform-style: preserve-3d;
  --hk-tilt-x: 0deg;
  --hk-tilt-y: 0deg;
}
.hk-made__frame{
  position: absolute;
  inset: 0;
  border-radius: 28px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow:
    0 26px 80px rgba(0,0,0,.55),
    0 0 0 1px rgba(0,0,0,.35) inset;
}
.hk-made__img{
  position: relative;
  width: min(560px, 92%);
  height: auto;
  /* transparent PNG: let the shoe float on the black stage */
  transform: rotate(-2.2deg) translateY(-6px);
  filter:
    drop-shadow(0 30px 44px rgba(0,0,0,.62))
    drop-shadow(0 0 48px rgba(0, 220, 255, .10))
    drop-shadow(0 0 56px rgba(255, 0, 120, .08));
}

/* Subtle parallax tilt (desktop only) */
@media (hover:hover) and (pointer:fine){
  .hk-made__media{
    transform: perspective(900px) rotateX(var(--hk-tilt-x)) rotateY(var(--hk-tilt-y));
    transition: transform .12s ease-out;
    will-change: transform;
  }
  .hk-made__frame{
    transform: translateZ(0);
    transition: box-shadow .18s ease-out;
  }
  .hk-made__img{
    transform: rotate(-2.2deg) translateY(-6px) translateZ(18px);
  }
}

@media (prefers-reduced-motion: reduce){
  .hk-made__media{
    transform: none !important;
    transition: none !important;
  }
}

.hk-made__fx{
  position: absolute;
  inset: -20%;
  pointer-events: none;
}
.hk-made__fx--grain{
  opacity: .12;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  animation: hkGrain 7s steps(7) infinite;
}
.hk-made__fx--glow{
  opacity: .22;
  background:
    radial-gradient(520px 320px at 30% 30%, rgba(0,220,255,.35), transparent 60%),
    radial-gradient(420px 300px at 75% 60%, rgba(255,0,120,.30), transparent 62%),
    radial-gradient(520px 380px at 45% 85%, rgba(255,210,0,.22), transparent 62%);
  filter: blur(10px);
  animation: hkGlowFloat 9s ease-in-out infinite;
}
.hk-made__fx--sweep{
  opacity: .18;
  background:
    linear-gradient(110deg,
      transparent 0%,
      rgba(255,255,255,.10) 18%,
      transparent 36%,
      rgba(255,255,255,.08) 54%,
      transparent 72%,
      rgba(255,255,255,.06) 90%,
      transparent 100%);
  transform: translateX(-22%) rotate(-6deg);
  filter: blur(14px);
  animation: hkSweep 6.5s ease-in-out infinite;
  mix-blend-mode: soft-light;
}

@keyframes hkSweep{
  0%{ transform: translateX(-28%) rotate(-6deg); }
  50%{ transform: translateX(10%) rotate(-6deg); }
  100%{ transform: translateX(-28%) rotate(-6deg); }
}
@keyframes hkGlowFloat{
  0%{ transform: translate3d(0,0,0) scale(1); }
  50%{ transform: translate3d(0,-12px,0) scale(1.02); }
  100%{ transform: translate3d(0,0,0) scale(1); }
}
@keyframes hkGrain{
  0%{ transform: translate3d(0,0,0); }
  10%{ transform: translate3d(-3%, -2%, 0); }
  20%{ transform: translate3d(-6%, 1%, 0); }
  30%{ transform: translate3d(4%, -4%, 0); }
  40%{ transform: translate3d(-2%, 5%, 0); }
  50%{ transform: translate3d(6%, 2%, 0); }
  60%{ transform: translate3d(1%, -6%, 0); }
  70%{ transform: translate3d(-5%, 3%, 0); }
  80%{ transform: translate3d(4%, 6%, 0); }
  90%{ transform: translate3d(-4%, -6%, 0); }
  100%{ transform: translate3d(0,0,0); }
}

@media (max-width: 900px){
  .hk-made{ padding: 46px 0 78px; }
  .hk-made__grid{ grid-template-columns: 1fr; gap: 22px; }
  .hk-made__media{ min-height: 360px; }
  .hk-made__copy{ max-width: 60ch; }
  .hk-made__img{ transform: rotate(-1.6deg) translateY(-4px); width: min(560px, 96%); }
}

@media (prefers-reduced-motion: reduce){
  .hk-divider__grain,
  .hk-made__fx--grain,
  .hk-made__fx--glow,
  .hk-made__fx--sweep{
    animation: none !important;
  }
}


/* SECTION 7: SOCIAL PROOF / HYPE */
.hk-hype{
  position: relative;
  padding: 120px 0 110px;
  background: #000;
  overflow: hidden;
}

.hk-hype__bg{
  position: absolute;
  inset: -20%;
  background: url("assets/season-banner-bottom.jpg") center/cover no-repeat;
  opacity: .075;
  filter: blur(14px) saturate(1.15) contrast(1.05);
  transform: scale(1.08);
}

.hk-hype__overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 520px at 50% 25%, rgba(0,0,0,.35), transparent 60%),
    linear-gradient(to bottom, rgba(0,0,0,.95), rgba(0,0,0,.65) 35%, rgba(0,0,0,.78) 70%, rgba(0,0,0,.95));
}

.hk-hype__grain{
  position: absolute;
  inset: -20%;
  pointer-events: none;
  opacity: .12;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  animation: hkHypeGrain 7.5s steps(7) infinite;
}

.hk-hype__glow{
  position: absolute;
  inset: -25%;
  pointer-events: none;
  opacity: .20;
  background:
    radial-gradient(520px 360px at 22% 40%, rgba(0,220,255,.32), transparent 62%),
    radial-gradient(520px 360px at 78% 55%, rgba(255,0,120,.26), transparent 62%),
    radial-gradient(520px 380px at 52% 82%, rgba(255,210,0,.20), transparent 62%);
  filter: blur(12px);
  animation: hkHypeGlow 10s ease-in-out infinite;
}

.hk-hype__inner{
  position: relative;
}

.hk-hype__title{
  text-align: center;
  margin: 0 auto 58px;
  max-width: 22ch;
}

.hk-hypeGrid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
  align-items: stretch;
}

.hk-hypeCard{
  grid-column: 2 / span 6;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 22px;
  padding: 26px 24px;
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
  position: relative;
  overflow: hidden;
  transform: translateY(22px) rotate(-1.2deg);
  opacity: 0;
  transition: transform .75s cubic-bezier(.2,.9,.2,1), opacity .75s ease;
}

.hk-hypeCard::before{
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(0,220,255,.22), rgba(255,0,120,.16), rgba(255,210,0,.12));
  opacity: .20;
  filter: blur(18px);
  pointer-events: none;
}

.hk-hypeCard:nth-child(2){
  grid-column: 6 / span 7;
  transform: translateY(22px) rotate(1.1deg);
}

.hk-hypeCard:nth-child(3){
  grid-column: 3 / span 5;
  transform: translateY(22px) rotate(.8deg);
}

.hk-hypeCard:nth-child(4){
  grid-column: 7 / span 5;
  transform: translateY(22px) rotate(-.9deg);
}

.hk-hypeCard--wide{
  padding: 30px 26px;
}

.hk-hypeCard--tall{
  padding: 34px 26px;
}

.hk-hypeQuote{
  position: relative;
  margin: 0;
  font-size: 22px;
  line-height: 1.25;
  letter-spacing: .01em;
}

.hk-hypeCard.is-visible{
  opacity: 1;
  transform: translateY(0) rotate(0deg);
}

.hk-hype__footer{
  text-align: center;
  margin: 52px auto 0;
  font-size: 14px;
  letter-spacing: .22em;
  text-transform: uppercase;
  opacity: .72;
}

@keyframes hkHypeGrain{
  0%{ transform: translate3d(0,0,0); }
  10%{ transform: translate3d(-3%, -2%, 0); }
  20%{ transform: translate3d(-6%, 1%, 0); }
  30%{ transform: translate3d(4%, -4%, 0); }
  40%{ transform: translate3d(-2%, 5%, 0); }
  50%{ transform: translate3d(6%, 2%, 0); }
  60%{ transform: translate3d(1%, -6%, 0); }
  70%{ transform: translate3d(-5%, 3%, 0); }
  80%{ transform: translate3d(4%, 6%, 0); }
  90%{ transform: translate3d(-4%, -6%, 0); }
  100%{ transform: translate3d(0,0,0); }
}

@keyframes hkHypeGlow{
  0%{ transform: translate3d(0,0,0) scale(1); }
  50%{ transform: translate3d(0,-10px,0) scale(1.02); }
  100%{ transform: translate3d(0,0,0) scale(1); }
}

@media (max-width: 900px){
  .hk-hype{ padding: 86px 0 84px; }
  .hk-hype__title{ margin-bottom: 38px; }
  .hk-hypeGrid{ grid-template-columns: 1fr; gap: 14px; }
  .hk-hypeCard,
  .hk-hypeCard:nth-child(2),
  .hk-hypeCard:nth-child(3),
  .hk-hypeCard:nth-child(4){
    grid-column: auto;
    transform: translateY(18px);
  }
  .hk-hypeQuote{ font-size: 20px; }
}

@media (prefers-reduced-motion: reduce){
  .hk-hype__grain,
  .hk-hype__glow{
    animation: none !important;
  }
  .hk-hypeCard{ transition: none !important; }
}

/* SECTION 8: FINAL WAITLIST CTA */
.hk-final{
  position: relative;
  padding: 140px 0 140px;
  background: #000;
  overflow: hidden;
}

.hk-final__bg{
  position: absolute;
  inset: 0;
  background: url("assets/track-night.jpg") center/cover no-repeat;
  transform: scale(1.05);
}

.hk-final__overlay{
  position: absolute;
  inset: 0;
  background: radial-gradient(1200px 700px at 50% 35%, rgba(0,0,0,0.18), rgba(0,0,0,0.82) 70%),
              linear-gradient(to bottom, rgba(0,0,0,0.6), rgba(0,0,0,0.92));
}

.hk-final__grain{
  position: absolute;
  inset: -30%;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  opacity: .12;
  mix-blend-mode: overlay;
  animation: hkFinalGrain 10s steps(6) infinite;
}

.hk-final__inner{
  position: relative;
  text-align: center;
  max-width: 780px;
}

.hk-final__title{
  margin: 0 auto 14px;
}

.hk-final__sub{
  margin: 0 auto 44px;
  font-size: 14px;
  letter-spacing: .22em;
  text-transform: uppercase;
  opacity: .82;
}

.hk-finalForm{
  width: min(520px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 16px;
  padding: 26px 22px;
  border-radius: 22px;
  background: rgba(0,0,0,0.46);
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(10px);
  box-shadow: 0 25px 70px rgba(0,0,0,0.55);
}

.hk-hidden{ display:none; }

.hk-fieldRow{
  display: grid;
  gap: 8px;
  text-align: left;
}

.hk-label{
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .85;
}

.hk-input{
  width: 100%;
  height: 46px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  color: #fff;
  outline: none;
}

.hk-input::placeholder{ opacity: .55; }

.hk-input:focus{
  border-color: rgba(255,255,255,0.28);
  box-shadow: 0 0 0 4px rgba(255,255,255,0.08);
}

.hk-stepper{
  display: grid;
  grid-template-columns: 44px 1fr 44px;
  align-items: center;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  overflow: hidden;
}

.hk-stepperBtn{
  height: 46px;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,0.9);
  font-size: 18px;
  cursor: pointer;
}

.hk-stepperBtn:hover{ background: rgba(255,255,255,0.06); }
.hk-stepperBtn:active{ background: rgba(255,255,255,0.1); }

.hk-stepperInput{
  height: 46px;
  width: 100%;
  border: 0;
  background: transparent;
  color: #fff;
  text-align: center;
  font-size: 16px;
  letter-spacing: .04em;
}

.hk-stepperInput::-webkit-outer-spin-button,
.hk-stepperInput::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; }

.hk-finalBtn{
  width: 100%;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  padding: 22px 26px;
  font-size: 18px;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: 22px;
  min-height: 72px;
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
}

.hk-final__note{
  margin: 6px 0 0;
  font-size: 12px;
  line-height: 1.35;
  opacity: .72;
  text-align: center;
}

/* Waitlist form status */
.hk-finalStatus{
  margin-top: 12px;
  min-height: 22px;
  font-size: 13px;
  letter-spacing: .02em;
  opacity: .92;
  text-align: center;
}
.hk-finalStatus.is-ok{ opacity: .9; }
.hk-finalStatus.is-err{ opacity: .9; }

/* Thank you page */
.hk-thanks{
  position: relative;
  min-height: 100vh;
  background: #000;
  overflow: hidden;
  display: grid;
  place-items: center;
  padding: 90px 20px;
}
.hk-thanks__bg{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 60% at 50% 35%, rgba(255,255,255,.08), transparent 60%),
    radial-gradient(40% 40% at 20% 70%, rgba(0,170,255,.10), transparent 65%),
    radial-gradient(45% 45% at 80% 75%, rgba(255,40,120,.10), transparent 65%);
}
.hk-thanks__overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.85), rgba(0,0,0,.55) 35%, rgba(0,0,0,.9));
}
.hk-thanks__inner{
  position: relative;
  text-align: center;
  max-width: 820px;
}
.hk-thanks__badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  letter-spacing: 2px;
  font-size: 12px;
  margin-bottom: 18px;
}
.hk-thanks__title{ margin: 0 0 10px; }
.hk-thanks__sub{ margin: 0 0 28px; opacity: .82; }
.hk-thanks__btn{
  display: inline-flex;
  min-height: 58px;
  padding: 0 26px;
  align-items: center;
  justify-content: center;
}
.hk-thanks__note{ margin-top: 18px; font-size: 13px; opacity: .65; }

@keyframes hkFinalGrain{
  0%{ transform: translate3d(0,0,0); }
  20%{ transform: translate3d(-2%, -3%, 0); }
  40%{ transform: translate3d(3%, 1%, 0); }
  60%{ transform: translate3d(-1%, 4%, 0); }
  80%{ transform: translate3d(4%, -2%, 0); }
  100%{ transform: translate3d(0,0,0); }
}

@media (max-width: 900px){
  .hk-final{ padding: 112px 0 112px; }
  .hk-finalForm{ padding: 22px 18px; }
}

@media (prefers-reduced-motion: reduce){
  .hk-final__grain{ animation: none !important; }
}

/* FOOTER */
.hk-footer{
  position: relative;
  background: #000;
  border-top: 1px solid rgba(255,255,255,0.10);
  padding: 56px 0 38px;
}

.hk-footer__wrap{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 32px;
  align-items: center;
}

.hk-footer__col{
  padding: 18px 18px 16px;
  border-radius: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(8px);
}

.hk-footer__brand{
  display: flex;
  align-items: center;
  gap: 14px;
}

.hk-footer__brand--right{ justify-content: center; }

.hk-footer__col--left,
.hk-footer__col--right{
  text-align: center;
}

.hk-footer__col--left .hk-footer__brand,
.hk-footer__col--right .hk-footer__brand{
  justify-content: center;
}

.hk-footer__logo{
  width: 64px;
  height: 64px;
  object-fit: contain;
  filter: drop-shadow(0 12px 28px rgba(0,0,0,0.6));
}

/* Slightly bigger HorseKicks mark */
.hk-footer__logo--hk{
  width: 74px;
  height: 74px;
}

/* New EF mark is circular and reads better slightly larger */
.hk-footer__logo--ef{ width: 74px; height: 74px; }

.hk-footer__brandText{ line-height: 1.05; }

.hk-footer__brandName{
  font-weight: 1000;
  letter-spacing: .02em;
  font-size: 14px;
}

.hk-footer__brandTag{
  margin-top: 4px;
  font-size: 12px;
  opacity: .72;
}

.hk-footer__socials{
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.hk-footer__socials{ justify-content: center; }

.hk-social{
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.hk-social svg{
  width: 20px;
  height: 20px;
  color: rgba(255,255,255,0.88);
}

.hk-social:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.20);
}

.hk-footer__mid{
  text-align: center;
  padding: 10px 6px;
}

.hk-footer__collab{
  font-weight: 1100;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
  opacity: .9;
}

.hk-footer__collabSub{
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
  opacity: .55;
}

.hk-footer__legalRow{
  margin-top: 22px;
}

.hk-footer__legal{
  margin: 0;
  font-size: 12px;
  opacity: .55;
  text-align: center;
}

@media (max-width: 900px){
  .hk-footer{ padding: 48px 0 34px; }
  .hk-footer__wrap{ grid-template-columns: 1fr; }
  .hk-footer__mid{ order: -1; }
  .hk-footer__col--right{ text-align: center; }
  .hk-footer__brand--right{ justify-content: center; }
  .hk-footer__col--right .hk-footer__socials{ justify-content: center; }
}


/* Disabled social icons (no link provided) */
.hk-social--disabled{opacity:.35;pointer-events:none;}
