/* ============================================================
   HighFit Landing — design tokens
   ============================================================ */
:root {
  --color-accent: #FF6B1A;
  --color-accent-soft: #FFF1E6;
  --color-bg: #FFFFFF;
  --color-bg-muted: #FAFAFB;
  --color-bg-soft: #F6F6F7;
  --color-border: #E6E6E8;
  --color-border-strong: #D1D1D4;
  --color-primary: #0F0F10;
  --color-primary-soft: #1A1A1C;
  --color-text-primary: #0F0F10;
  --color-text-secondary: #62626A;
  --color-text-tertiary: #8E8E96;
  --color-text-on-dark: #FFFFFF;
  --color-text-on-dark-soft: #B5B5BB;

  --container-width: 1200px;
  --section-padding-x: 120px;
  --section-padding-y: 96px;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
}

/* ============================================================
   Reset / base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 84px; }

body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--color-text-primary);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

h1, h2, h3, h4, h5, p { margin: 0; }
a { text-decoration: none; color: inherit; }
ul { margin: 0; padding: 0; list-style: none; }
img { display: block; max-width: 100%; }

i[data-lucide] { width: 1em; height: 1em; }

/* Inline brand icons (Instagram, X, LinkedIn, Facebook, YouTube) */
.svg-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.brand-ico { width: 16px; height: 16px; fill: currentColor; display: block; }

.container {
  width: 100%;
  max-width: calc(var(--container-width) + var(--section-padding-x) * 2);
  margin: 0 auto;
  padding-left: var(--section-padding-x);
  padding-right: var(--section-padding-x);
}

.section { padding-top: var(--section-padding-y); padding-bottom: var(--section-padding-y); }
.section--soft { background: var(--color-bg-soft); }

/* ============================================================
   Shared bits — eyebrows / kickers / dividers
   ============================================================ */
.eyebrow {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 2px;
  color: var(--color-accent);
}
.eyebrow--dark { color: var(--color-text-on-dark-soft); letter-spacing: 2.5px; }

.kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 1.2px;
  color: var(--color-text-secondary);
}
.kicker .dot {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--color-accent);
}
.kicker--pill {
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--color-bg-soft);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.6px;
}
.kicker--outline { background: var(--color-bg); border: 1px solid var(--color-border); }

.divider {
  display: block;
  width: 64px; height: 1px;
  background: var(--color-border);
}

.section__head { margin-bottom: 56px; }
.section__head--center {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.section__head h2 {
  font-size: 48px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.5px;
}
.section__head h2.display {
  font-size: 56px;
  letter-spacing: -1.5px;
  line-height: 1.05;
}
.section__head p {
  font-size: 16px;
  color: var(--color-text-secondary);
  line-height: 1.6;
}
.section__head--center .kicker--pill { margin-bottom: 6px; }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.1px;
  cursor: pointer;
  border: 0;
  border-radius: var(--radius-md);
  padding: 16px 28px;
  transition: transform .15s ease, background .15s ease, opacity .15s ease;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn i[data-lucide] { width: 16px; height: 16px; }

.btn--pill { border-radius: 999px; }
.btn--block { width: 100%; padding: 16px 24px; }
.btn--sm { padding: 12px 20px; font-size: 14px; }

.btn--dark { background: var(--color-primary); color: var(--color-text-on-dark); }
.btn--dark:hover { background: var(--color-primary-soft); }
.btn--ghost { background: transparent; color: var(--color-primary); border: 1px solid var(--color-border-strong); }
.btn--ghost:hover { background: var(--color-bg-soft); }
.btn--outline { background: var(--color-bg); color: var(--color-primary); border: 1px solid var(--color-border-strong); }
.btn--outline:hover { background: var(--color-bg-soft); }
.btn--light { background: var(--color-bg); color: var(--color-primary); }
.btn--light:hover { opacity: .9; }
.btn--accent { background: var(--color-accent); color: #fff; }
.btn--accent:hover { filter: brightness(1.05); }

/* ============================================================
   Grids / cards
   ============================================================ */
.grid { display: grid; gap: 24px; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }

.card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 32px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.card:hover {
  border-color: var(--color-border-strong);
  box-shadow: 0 12px 30px rgba(15, 15, 16, .06);
  transform: translateY(-2px);
}
.card h3 { font-size: 20px; font-weight: 600; }
.card p { font-size: 14px; color: var(--color-text-secondary); line-height: 1.6; }

.icon-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: var(--color-bg-soft);
  color: var(--color-primary);
}
.icon-box i[data-lucide] { width: 22px; height: 22px; }

/* ============================================================
   01 Navbar
   ============================================================ */
.navbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}
.navbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 84px;
}
.navbar__logo img { height: 36px; width: auto; max-width: none; object-fit: contain; }
.navbar__links { display: flex; align-items: center; gap: 36px; }
.navbar__links a {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-secondary);
  transition: color .15s ease;
}
.navbar__links a:hover, .navbar__links a.is-active { color: var(--color-primary); }
.navbar__actions { display: flex; align-items: center; gap: 12px; }

/* Language switcher */
.lang { position: relative; }
.lang__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--color-primary);
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 9px 12px;
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease;
}
.lang__btn:hover { border-color: var(--color-border-strong); }
.lang__btn i[data-lucide] { width: 16px; height: 16px; }
.lang__btn i[data-lucide="chevron-down"] { width: 14px; height: 14px; color: var(--color-text-tertiary); transition: transform .15s ease; }
.lang.is-open .lang__btn i[data-lucide="chevron-down"] { transform: rotate(180deg); }
.lang__menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 160px;
  display: none;
  flex-direction: column;
  padding: 6px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 16px 40px rgba(15, 15, 16, .12);
  z-index: 60;
}
.lang.is-open .lang__menu { display: flex; }
.lang__menu button {
  text-align: left;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-secondary);
  background: transparent;
  border: 0;
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  cursor: pointer;
  transition: background .12s ease, color .12s ease;
}
.lang__menu button:hover { background: var(--color-bg-soft); color: var(--color-primary); }
.navbar__toggle {
  display: none;
  background: transparent;
  border: 0;
  color: var(--color-primary);
  cursor: pointer;
  padding: 6px;
}
.navbar__toggle i[data-lucide] { width: 24px; height: 24px; }

/* ============================================================
   02 Hero
   ============================================================ */
.hero { background: var(--color-bg); }
.hero__inner {
  display: grid;
  grid-template-columns: 1fr 520px;
  gap: 80px;
  align-items: stretch;
  padding-top: var(--section-padding-y);
  padding-bottom: var(--section-padding-y);
}
.hero__left { display: flex; flex-direction: column; gap: 32px; align-items: flex-start; }
.hero__heading { display: flex; flex-direction: column; gap: 24px; }
.hero__heading h1 {
  font-size: 80px;
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -3px;
}
.hero__heading p {
  max-width: 480px;
  font-size: 18px;
  color: var(--color-text-secondary);
  line-height: 1.5;
}
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero__stats { display: flex; gap: 40px; }
.stat { display: flex; flex-direction: column; gap: 4px; }
.stat__num { font-size: 24px; font-weight: 700; letter-spacing: -0.6px; }
.stat__lbl { font-size: 12px; color: var(--color-text-tertiary); letter-spacing: 0.2px; }
.hero__media {
  min-height: 528px;
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.hero__media img { width: 100%; height: 100%; object-fit: cover; }

/* ============================================================
   05 Plans
   ============================================================ */
.plan {
  display: flex;
  flex-direction: column;
  gap: 32px;
  padding: 40px;
  border-radius: 20px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}
.plan__head, .plan__price { display: flex; flex-direction: column; gap: 12px; }
.plan__price { gap: 4px; }
.plan__top { display: flex; align-items: center; justify-content: space-between; }
.plan h3 { font-size: 22px; font-weight: 600; }
.plan__head p, .plan__desc { font-size: 14px; color: var(--color-text-secondary); line-height: 1.5; }
.plan__price-main { font-size: 28px; font-weight: 700; letter-spacing: -0.5px; }
.plan__price-sub { font-size: 13px; color: var(--color-text-tertiary); }
.plan__divider { height: 1px; background: var(--color-border); }
.plan__feats { display: flex; flex-direction: column; gap: 14px; }
.plan__feats li { display: flex; align-items: center; gap: 12px; font-size: 14px; }
.plan__feats li i[data-lucide] { width: 18px; height: 18px; flex-shrink: 0; }
.plan .btn { margin-top: auto; }

.badge {
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--color-accent);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.4px;
}

.plan--featured {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-text-on-dark);
}
.plan--featured .plan__desc { color: var(--color-text-on-dark-soft); }
.plan--featured .plan__price-main { color: #fff; }
.plan--featured .plan__price-sub { color: var(--color-text-on-dark-soft); }
.plan--featured .plan__divider { background: rgba(255, 255, 255, .12); }

/* ============================================================
   06 Trainers
   ============================================================ */
.trainer {
  display: flex;
  flex-direction: column;
  border-radius: 20px;
  overflow: hidden;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}
.trainer__img {
  height: 360px;
  background-size: cover;
  background-position: center;
}
.trainer__body { display: flex; flex-direction: column; gap: 20px; padding: 32px; }
.trainer__info { display: flex; flex-direction: column; gap: 6px; }
.trainer__info h3 { font-size: 22px; font-weight: 600; letter-spacing: -0.4px; }
.trainer__info span { font-size: 14px; font-weight: 500; color: var(--color-text-tertiary); }
.trainer__body > p { font-size: 14px; color: var(--color-text-secondary); line-height: 1.55; }
.trainer__socials { display: flex; gap: 10px; }
.trainer__socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 1px solid var(--color-border);
  color: var(--color-primary);
  transition: background .15s ease, border-color .15s ease;
}
.trainer__socials a:hover { background: var(--color-bg-soft); border-color: var(--color-border-strong); }
.trainer__socials i[data-lucide] { width: 16px; height: 16px; }

/* ============================================================
   07 Why Choose
   ============================================================ */
.why__inner { display: grid; grid-template-columns: 380px 1fr; gap: 96px; }
.why__left { display: flex; flex-direction: column; gap: 24px; align-items: flex-start; }
.why__left h2 { font-size: 48px; font-weight: 600; line-height: 1.1; letter-spacing: -1px; }
.why__left p { font-size: 16px; color: var(--color-text-secondary); line-height: 1.6; }
.why__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 6px;
}
.why__link i[data-lucide] { width: 16px; height: 16px; }

.why__right { display: flex; flex-direction: column; }
.why__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  padding: 28px 0;
  border-bottom: 1px solid var(--color-border);
}
.why__row:first-child { padding-top: 0; }
.why__row:last-child { padding-bottom: 0; border-bottom: 0; }
.why__feat { display: flex; flex-direction: column; gap: 12px; }
.why__feat i[data-lucide] { width: 22px; height: 22px; color: var(--color-primary); }
.why__feat h4 { font-size: 16px; font-weight: 600; }
.why__feat p { font-size: 14px; color: var(--color-text-secondary); line-height: 1.5; }

/* ============================================================
   08 Gallery
   ============================================================ */
.gallery__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 48px;
  margin-bottom: 48px;
}
.gallery__head-left { display: flex; flex-direction: column; gap: 20px; max-width: 640px; }
.gallery__head-left h2 { font-size: 48px; font-weight: 600; line-height: 1.1; letter-spacing: -1px; }
.gallery__head-left p { font-size: 16px; color: var(--color-text-secondary); line-height: 1.6; }

.gallery__grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 16px;
  height: 560px;
}
.gallery__col { display: flex; flex-direction: column; gap: 16px; }
.gallery__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; height: 220px; }
.gallery__col--left .gallery__img--tall { flex: 1; }
.gallery__img {
  border-radius: var(--radius-lg);
  background-size: cover;
  background-position: center;
}
.gallery__img--short { height: 200px; }
.gallery__img--fill { flex: 1; }
.gallery__img--mini { height: 140px; }

/* ============================================================
   09 Contact CTA
   ============================================================ */
.contact { background: var(--color-primary); color: var(--color-text-on-dark); }
.contact__inner { display: grid; grid-template-columns: 1fr 480px; gap: 80px; align-items: center; }
.contact__left { display: flex; flex-direction: column; gap: 20px; align-items: flex-start; }
.contact__left h2 {
  max-width: 540px;
  font-size: 52px;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -1.5px;
}
.contact__left p { max-width: 540px; font-size: 17px; color: var(--color-text-on-dark-soft); line-height: 1.55; }
.contact__left .btn { margin-top: 12px; }
.contact__left .btn i[data-lucide] { width: 18px; height: 18px; }

.contact__list { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact__card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 20px;
  border-radius: 14px;
  border: 1px solid #26262A;
}
.contact__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius-md);
  background: var(--color-primary-soft);
}
.contact__icon { color: #fff; }
.contact__icon i[data-lucide] { width: 16px; height: 16px; color: #fff; }
.contact__label { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; color: var(--color-text-tertiary); }
.contact__value { font-size: 15px; font-weight: 500; color: #fff; }

/* ============================================================
   10 Footer
   ============================================================ */
.footer { background: var(--color-primary); color: var(--color-text-on-dark); padding: 80px 0; }
.footer__inner { display: flex; flex-direction: column; gap: 48px; }
.footer__top {
  display: grid;
  grid-template-columns: 380px 170px 170px 1fr;
  gap: 40px;
}
.footer__brand { display: flex; flex-direction: column; gap: 20px; }
.footer__logo { height: 42px; width: auto; max-width: none; object-fit: contain; align-self: flex-start; }
.footer__brand p { font-size: 14px; color: var(--color-text-on-dark-soft); line-height: 1.6; }
.footer__socials { display: flex; gap: 10px; }
.footer__socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255, 255, 255, .14);
  color: #fff;
  transition: background .15s ease;
}
.footer__socials a:hover { background: rgba(255, 255, 255, .08); }
.footer__socials i[data-lucide] { width: 16px; height: 16px; }
.footer__col { display: flex; flex-direction: column; gap: 12px; }
.footer__col h5 { font-size: 12px; font-weight: 600; letter-spacing: 1.4px; margin-bottom: 6px; }
.footer__col a, .footer__col span { font-size: 14px; color: var(--color-text-on-dark-soft); }
.footer__col a:hover { color: #fff; }
.footer__divider { height: 1px; background: rgba(255, 255, 255, .1); }
.footer__bottom { display: flex; align-items: center; gap: 24px; font-size: 13px; color: var(--color-text-on-dark-soft); }
.footer__bottom a:hover { color: #fff; }
.footer__sep { color: var(--color-text-tertiary); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1100px) {
  :root { --section-padding-x: 48px; --section-padding-y: 72px; }
  .hero__inner { grid-template-columns: 1fr; gap: 48px; }
  .hero__heading h1 { font-size: 64px; }
  .hero__media { min-height: 0; height: 420px; }
  .why__inner { grid-template-columns: 1fr; gap: 48px; }
  .contact__inner { grid-template-columns: 1fr; gap: 48px; }
  .gallery__grid { grid-template-columns: 1fr 300px; }
}

@media (max-width: 860px) {
  :root { --section-padding-x: 24px; --section-padding-y: 56px; }
  .navbar__links { display: none; }
  .navbar__links.is-open {
    display: flex;
    position: absolute;
    top: 84px; left: 0; right: 0;
    flex-direction: column;
    gap: 20px;
    padding: 24px;
    background: #fff;
    border-bottom: 1px solid var(--color-border);
  }
  .navbar__toggle { display: inline-flex; }
  .grid--3 { grid-template-columns: 1fr; }
  .section__head h2, .section__head h2.display { font-size: 36px; letter-spacing: -0.5px; }
  .hero__heading h1 { font-size: 48px; letter-spacing: -1.5px; }
  .why__row { grid-template-columns: 1fr; gap: 28px; }
  .gallery__grid { grid-template-columns: 1fr; height: auto; }
  .gallery__col--right { flex-direction: row; }
  .gallery__img--short, .gallery__img--fill, .gallery__img--mini { height: 180px; flex: 1; }
  .gallery__head-left h2 { font-size: 36px; }
  .contact__list { grid-template-columns: 1fr; }
  .contact__left h2 { font-size: 36px; }
  .footer__top { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 520px) {
  .navbar__actions .btn--sm { display: none; }
  .hero__stats { gap: 24px; }
  .hero__heading h1 { font-size: 40px; }
  .footer__top { grid-template-columns: 1fr; }
  .footer__bottom { flex-wrap: wrap; gap: 10px; }
}
