/* ==========================================================================
   LETNOVA COMPONENTS
   Reusable component styles for the Letnova WordPress theme
   ========================================================================== */

/* ══════════════════════════════════════════════════════════════════════
   TYPOGRAPHY HELPERS
   ══════════════════════════════════════════════════════════════════════ */

.ln-heading-display {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-display);
  font-weight: var(--ln-weight-bold);
  line-height: var(--ln-leading-tight);
  letter-spacing: var(--ln-tracking-tight);
  color: var(--ln-secondary);
}

.ln-heading-1 {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-h1);
  font-weight: var(--ln-weight-semibold);
  line-height: var(--ln-leading-snug);
  color: var(--ln-secondary);
}

.ln-heading-2 {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-h2);
  font-weight: var(--ln-weight-semibold);
  line-height: var(--ln-leading-snug);
  color: var(--ln-secondary);
}

.ln-heading-3 {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-h3);
  font-weight: var(--ln-weight-semibold);
  line-height: var(--ln-leading-snug);
  color: var(--ln-secondary);
}

.ln-text-lg {
  font-size: var(--ln-text-lg);
}

.ln-text-md {
  font-size: var(--ln-text-md);
}

.ln-text-sm {
  font-size: var(--ln-text-sm);
}

.ln-text-gold {
  color: var(--ln-primary);
}

.ln-text-light {
  color: var(--ln-text-light);
}

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

/* ══════════════════════════════════════════════════════════════════════
   LAYOUT HELPERS
   ══════════════════════════════════════════════════════════════════════ */

.ln-container {
  width: 100%;
  max-width: var(--ln-container);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.ln-grid {
  display: grid;
  gap: var(--ln-gap);
}

.ln-grid--2 {
  grid-template-columns: repeat(2, 1fr);
}

@media (max-width: 768px) {
  .ln-grid--2 {
    grid-template-columns: 1fr;
  }
}

.ln-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 960px) {
  .ln-grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .ln-grid--3 {
    grid-template-columns: 1fr;
  }
}

.ln-grid--4 {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 960px) {
  .ln-grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .ln-grid--4 {
    grid-template-columns: 1fr;
  }
}

.ln-flex {
  display: flex;
  gap: var(--ln-gap);
}

.ln-flex--center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--ln-gap);
}

.ln-flex--between {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ln-gap);
}

/* ══════════════════════════════════════════════════════════════════════
   SECTIONS
   ══════════════════════════════════════════════════════════════════════ */

.ln-section {
  padding-top: var(--ln-section);
  padding-bottom: var(--ln-section);
  background-color: var(--ln-white);
}

.ln-section--light {
  background-color: var(--ln-light);
}

.ln-section--dark {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
}

.ln-section--dark .ln-heading-display,
.ln-section--dark .ln-heading-1,
.ln-section--dark .ln-heading-2,
.ln-section--dark .ln-heading-3 {
  color: var(--ln-white);
}

.ln-section--dark .ln-text-light {
  color: var(--ln-text-light);
}

.ln-section--accent {
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
}

.ln-section--sm {
  padding-top: var(--ln-section-sm);
  padding-bottom: var(--ln-section-sm);
}

/* ══════════════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════════════ */

.ln-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--ln-font-body);
  font-weight: var(--ln-weight-medium);
  font-size: var(--ln-text-md);
  line-height: 1;
  padding: 0.75rem 1.75rem;
  border: 2px solid transparent;
  border-radius: var(--ln-radius-full);
  cursor: pointer;
  transition: all var(--ln-duration) var(--ln-ease);
  text-decoration: none;
  white-space: nowrap;
}

.ln-btn:focus-visible {
  outline: 2px solid var(--ln-primary);
  outline-offset: 2px;
}

.ln-btn:disabled {
  opacity: 0.5;
  pointer-events: none;
}

.ln-btn--gold {
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
  border-color: var(--ln-primary);
}

.ln-btn--gold:hover {
  background-color: var(--ln-accent);
  border-color: var(--ln-accent);
}

.ln-btn--outline {
  background-color: transparent;
  color: var(--ln-secondary);
  border-color: var(--ln-border);
}

.ln-btn--outline:hover {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
  border-color: var(--ln-secondary);
}

/* When inside dark section */
.ln-section--dark .ln-btn--outline {
  color: var(--ln-white);
  border-color: rgba(255, 255, 255, 0.3);
}

.ln-section--dark .ln-btn--outline:hover {
  background-color: var(--ln-white);
  color: var(--ln-secondary);
  border-color: var(--ln-white);
}

.ln-btn--dark {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
  border-color: var(--ln-secondary);
}

.ln-btn--dark:hover {
  background-color: var(--ln-secondary-90);
  border-color: var(--ln-secondary-90);
}

.ln-btn--sm {
  font-size: var(--ln-text-sm);
  padding: 0.5rem 1.25rem;
}

.ln-btn--lg {
  font-size: var(--ln-text-lg);
  padding: 1rem 2.25rem;
}

/* ══════════════════════════════════════════════════════════════════════
   CARDS
   ══════════════════════════════════════════════════════════════════════ */

.ln-card {
  background-color: var(--ln-white);
  border-radius: var(--ln-radius);
  padding: var(--ln-gap);
  border: 1px solid var(--ln-border);
  transition: all var(--ln-duration) var(--ln-ease);
}

.ln-card--hover:hover {
  box-shadow: var(--ln-shadow-lg);
  transform: translateY(-4px);
}

.ln-card--feature {
  border-color: var(--ln-primary);
  box-shadow: var(--ln-shadow-md);
  position: relative;
}

.ln-card--feature::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background-color: var(--ln-primary);
  border-radius: var(--ln-radius) var(--ln-radius) 0 0;
}

.ln-card--dark {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
  border-color: rgba(255, 255, 255, 0.1);
}

.ln-card--dark .ln-heading-2,
.ln-card--dark .ln-heading-3 {
  color: var(--ln-white);
}

.ln-card--glass {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: var(--ln-white);
}

/* ══════════════════════════════════════════════════════════════════════
   STATS BAR
   ══════════════════════════════════════════════════════════════════════ */

.ln-stats {
  padding-top: var(--ln-gap-lg);
  padding-bottom: var(--ln-gap-lg);
  text-align: center;
}

.ln-stats__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ln-gap);
}

@media (max-width: 600px) {
  .ln-stats__grid {
    grid-template-columns: 1fr;
    gap: var(--ln-gap-sm);
  }
}

.ln-stats__value {
  font-family: var(--ln-font-heading);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: var(--ln-weight-bold);
  line-height: 1;
  color: var(--ln-primary);
  font-variant-numeric: tabular-nums;
}

.ln-stats__label {
  font-size: var(--ln-text-sm);
  color: var(--ln-text-light);
  margin-top: 0.5rem;
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
}

/* ══════════════════════════════════════════════════════════════════════
   BEFORE / AFTER BLOCKS
   ══════════════════════════════════════════════════════════════════════ */

.ln-before-after {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--ln-gap);
  border-radius: var(--ln-radius);
  overflow: hidden;
  box-shadow: var(--ln-shadow-lg);
}

@media (max-width: 768px) {
  .ln-before-after {
    grid-template-columns: 1fr;
  }
}

.ln-before-after__col {
  padding: var(--ln-gap);
}

.ln-before-after__antes {
  background-color: var(--ln-white);
  border-left: 4px solid var(--ln-danger);
}

.ln-before-after__con {
  background-color: var(--ln-white);
  border-left: 4px solid var(--ln-success);
}

.ln-before-after__resultado {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
}

.ln-before-after__title {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  margin-bottom: var(--ln-gap-sm);
}

.ln-before-after__antes .ln-before-after__title {
  color: var(--ln-danger);
}

.ln-before-after__con .ln-before-after__title {
  color: var(--ln-success);
}

.ln-before-after__resultado .ln-before-after__title {
  color: var(--ln-primary);
}

/* ══════════════════════════════════════════════════════════════════════
   PLAN CARDS
   ══════════════════════════════════════════════════════════════════════ */

.ln-plan-card {
  background-color: var(--ln-white);
  border: 1px solid var(--ln-border);
  border-radius: var(--ln-radius);
  padding: var(--ln-gap-lg) var(--ln-gap);
  text-align: center;
  position: relative;
  transition: all var(--ln-duration) var(--ln-ease);
}

.ln-plan-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--ln-shadow-xl);
}

.ln-plan-card--popular {
  border-color: var(--ln-primary);
  box-shadow: var(--ln-shadow-gold);
  transform: scale(1.03);
}

.ln-plan-card--popular:hover {
  transform: scale(1.03) translateY(-6px);
}

.ln-plan-card__badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-xs);
  font-weight: var(--ln-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  padding: 0.35rem 1.25rem;
  border-radius: var(--ln-radius-full);
}

.ln-plan-card__name {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-h3);
  font-weight: var(--ln-weight-semibold);
  color: var(--ln-secondary);
  margin-bottom: 0.5rem;
}

.ln-plan-card__price {
  font-family: var(--ln-font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--ln-weight-bold);
  color: var(--ln-secondary);
  line-height: 1;
  margin-bottom: 0.25rem;
}

.ln-plan-card__price span {
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-regular);
  color: var(--ln-text-light);
}

.ln-plan-card__features {
  text-align: left;
  margin-top: var(--ln-gap);
  margin-bottom: var(--ln-gap);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.ln-plan-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--ln-text-sm);
  color: var(--ln-text);
}

.ln-plan-card__features li::before {
  content: '\2713';
  color: var(--ln-success);
  font-weight: var(--ln-weight-bold);
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════════════
   CASE CARDS
   ══════════════════════════════════════════════════════════════════════ */

.ln-case-card {
  border-radius: var(--ln-radius);
  overflow: hidden;
  background-color: var(--ln-white);
  border: 1px solid var(--ln-border);
  transition: box-shadow var(--ln-duration) var(--ln-ease);
}

.ln-case-card:hover {
  box-shadow: var(--ln-shadow-lg);
}

.ln-case-card:hover .ln-case-card__img img {
  transform: scale(1.05);
}

.ln-case-card__img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.ln-case-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--ln-duration-slow) var(--ln-ease);
}

.ln-case-card__body {
  padding: var(--ln-gap);
}

.ln-case-card__quote {
  font-style: italic;
  color: var(--ln-text);
  margin-bottom: var(--ln-gap-sm);
  border-left: 3px solid var(--ln-primary);
  padding-left: var(--ln-gap-sm);
}

.ln-case-card__stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
  gap: var(--ln-gap-sm);
  margin-bottom: var(--ln-gap-sm);
  text-align: center;
}

.ln-case-card__stat-value {
  font-family: var(--ln-font-heading);
  font-weight: var(--ln-weight-bold);
  font-size: var(--ln-text-lg);
  color: var(--ln-primary);
}

.ln-case-card__stat-label {
  font-size: var(--ln-text-xs);
  color: var(--ln-text-light);
}

.ln-case-card__link {
  font-weight: var(--ln-weight-medium);
  color: var(--ln-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: gap var(--ln-duration) var(--ln-ease);
}

.ln-case-card__link:hover {
  gap: 0.5rem;
}

.ln-case-card__link::after {
  content: '\2192';
}

/* ══════════════════════════════════════════════════════════════════════
   STEPS
   ══════════════════════════════════════════════════════════════════════ */

/* .ln-steps is used as a section wrapper — grid is on .ln-steps__grid */

.ln-step {
  text-align: center;
  position: relative;
}

.ln-step__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-h3);
  font-weight: var(--ln-weight-bold);
  margin-bottom: var(--ln-gap-sm);
  position: relative;
  z-index: 1;
}

/* Connecting line between steps */
.ln-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 1.75rem;
  left: calc(50% + 2rem);
  width: calc(100% - 4rem);
  height: 2px;
  background-color: var(--ln-border);
}

@media (max-width: 600px) {
  .ln-step:not(:last-child)::after {
    display: none;
  }
}

.ln-step__title {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-lg);
  font-weight: var(--ln-weight-semibold);
  color: var(--ln-secondary);
  margin-bottom: 0.25rem;
}

.ln-step__subtitle {
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-medium);
  color: var(--ln-primary);
  margin-bottom: 0.5rem;
}

.ln-step__desc {
  font-size: var(--ln-text-sm);
  color: var(--ln-text);
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}

/* ══════════════════════════════════════════════════════════════════════
   CTA SECTION
   ══════════════════════════════════════════════════════════════════════ */

.ln-cta {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
  text-align: center;
  padding-top: var(--ln-section);
  padding-bottom: var(--ln-section);
  position: relative;
  overflow: hidden;
}

.ln-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(226, 180, 80, 0.1) 0%, transparent 60%);
  pointer-events: none;
}

.ln-cta__content {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.ln-cta__title {
  font-family: var(--ln-font-heading);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: var(--ln-weight-bold);
  color: var(--ln-white);
  margin-bottom: var(--ln-gap-sm);
}

.ln-cta__text {
  color: var(--ln-text-light);
  margin-bottom: var(--ln-gap);
  font-size: var(--ln-text-lg);
}

/* ══════════════════════════════════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════════════════════════════════ */

/* --- Navbar: matches header.php structure --- */
.ln-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--ln-z-navbar);
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ln-border);
  transition: background var(--ln-duration) var(--ln-ease),
              box-shadow var(--ln-duration) var(--ln-ease);
}

.ln-navbar--scrolled {
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--ln-shadow-md);
}

/* .ln-navbar__container from header.php */
.ln-navbar__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--ln-container);
  margin: 0 auto;
  padding: 0 var(--ln-gap);
  height: 5rem;
}

/* Logo */
.ln-navbar__logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  flex-shrink: 0;
}

.ln-navbar__logo-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.ln-navbar__logo-text {
  font-family: var(--ln-font-heading);
  font-size: 1.5rem;
  font-weight: var(--ln-weight-bold);
  color: var(--ln-secondary);
}

/* Desktop nav — WordPress generates <ul class="ln-navbar__menu"><li class="menu-item"><a> */
.ln-navbar__nav {
  display: flex;
  align-items: center;
}

.ln-navbar__menu {
  display: flex;
  align-items: center;
  gap: 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ln-navbar__menu .menu-item a {
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-medium);
  color: var(--ln-secondary);
  text-decoration: none;
  transition: color var(--ln-duration-fast) var(--ln-ease);
  padding: 0.5rem 0;
}

.ln-navbar__menu .menu-item a:hover,
.ln-navbar__menu .current-menu-item a {
  color: var(--ln-primary);
}

/* CTA button in navbar */
.ln-navbar__cta {
  display: inline-flex;
  align-items: center;
  padding: 0.625rem 1.5rem;
  background: var(--ln-primary);
  color: var(--ln-secondary);
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-semibold);
  border-radius: var(--ln-radius-full);
  text-decoration: none;
  transition: background var(--ln-duration-fast) var(--ln-ease);
  flex-shrink: 0;
}

.ln-navbar__cta:hover {
  background: var(--ln-accent);
}

/* Hamburger toggle */
.ln-navbar__toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  width: 2.5rem;
  height: 2.5rem;
}

.ln-navbar__toggle-bar {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--ln-secondary);
  border-radius: 1px;
  transition: transform var(--ln-duration) var(--ln-ease),
              opacity var(--ln-duration) var(--ln-ease);
}

/* Mobile menu — hidden by default */
.ln-navbar__mobile {
  display: none;
  background: var(--ln-white);
  border-bottom: 1px solid var(--ln-border);
  box-shadow: var(--ln-shadow-lg);
  padding: 1.5rem var(--ln-gap);
}

.ln-navbar__mobile.is-open {
  display: block;
}

.ln-navbar__mobile-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.ln-navbar__mobile-menu .menu-item a {
  font-size: 1.125rem;
  font-weight: var(--ln-weight-medium);
  color: var(--ln-secondary);
  text-decoration: none;
  display: block;
  padding: 0.5rem 0;
}

.ln-navbar__mobile-menu .menu-item a:hover {
  color: var(--ln-primary);
}

.ln-navbar__cta--mobile {
  display: block;
  text-align: center;
  margin-top: 1rem;
  width: 100%;
}

@media (max-width: 768px) {
  .ln-navbar__nav,
  .ln-navbar__cta:not(.ln-navbar__cta--mobile) {
    display: none;
  }

  .ln-navbar__toggle {
    display: flex;
  }
}

@media (min-width: 769px) {
  .ln-navbar__mobile {
    display: none !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════════════ */

.ln-footer {
  background-color: var(--ln-secondary);
  color: var(--ln-white);
  padding-top: var(--ln-section-sm);
}

.ln-footer__grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: var(--ln-gap-lg);
  padding-bottom: var(--ln-gap-lg);
}

@media (max-width: 768px) {
  .ln-footer__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .ln-footer__grid {
    grid-template-columns: 1fr;
  }
}

.ln-footer__brand img {
  height: 2rem;
  margin-bottom: var(--ln-gap-sm);
}

.ln-footer__brand p {
  color: var(--ln-text-light);
  font-size: var(--ln-text-sm);
  max-width: 280px;
}

.ln-footer__title {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  margin-bottom: var(--ln-gap-sm);
  color: var(--ln-white);
}

.ln-footer__links {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ln-footer__links a {
  font-size: var(--ln-text-sm);
  color: var(--ln-text-light);
  transition: color var(--ln-duration-fast) var(--ln-ease);
}

.ln-footer__links a:hover {
  color: var(--ln-primary);
}

.ln-footer__social {
  display: flex;
  gap: 0.75rem;
  margin-top: var(--ln-gap-sm);
}

.ln-footer__social-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--ln-white);
  font-size: var(--ln-text-sm);
  transition: all var(--ln-duration-fast) var(--ln-ease);
}

.ln-footer__social-icon:hover {
  background-color: var(--ln-primary);
  border-color: var(--ln-primary);
  color: var(--ln-secondary);
}

.ln-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: var(--ln-gap-sm);
  padding-bottom: var(--ln-gap-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--ln-text-xs);
  color: var(--ln-text-light);
}

@media (max-width: 600px) {
  .ln-footer__bottom {
    flex-direction: column;
    gap: 0.5rem;
    text-align: center;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════════════════════════════════ */

.ln-form {
  display: flex;
  flex-direction: column;
  gap: var(--ln-gap);
}

.ln-form__group {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.ln-form__label {
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-medium);
  color: var(--ln-secondary);
}

.ln-form__input,
.ln-form__textarea,
.ln-form__select {
  padding: 0.75rem 1rem;
  border: 1px solid var(--ln-border);
  border-radius: var(--ln-radius-sm);
  font-size: var(--ln-text-md);
  color: var(--ln-secondary);
  background-color: var(--ln-white);
  transition: border-color var(--ln-duration-fast) var(--ln-ease),
    box-shadow var(--ln-duration-fast) var(--ln-ease);
}

.ln-form__input::placeholder,
.ln-form__textarea::placeholder,
.ln-form__select::placeholder {
  color: var(--ln-text-light);
}

.ln-form__input:focus,
.ln-form__textarea:focus,
.ln-form__select:focus {
  outline: none;
  border-color: var(--ln-primary);
  box-shadow: 0 0 0 3px var(--ln-primary-20);
}

.ln-form__textarea {
  min-height: 120px;
  resize: vertical;
}

.ln-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ln-gap);
}

@media (max-width: 600px) {
  .ln-form__row {
    grid-template-columns: 1fr;
  }
}

.ln-toast {
  position: fixed;
  bottom: var(--ln-gap);
  right: var(--ln-gap);
  z-index: var(--ln-z-toast);
  padding: 1rem 1.5rem;
  border-radius: var(--ln-radius-sm);
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-medium);
  box-shadow: var(--ln-shadow-lg);
  transform: translateY(120%);
  opacity: 0;
  transition: all var(--ln-duration) var(--ln-ease-bounce);
}

.ln-toast.is-visible {
  transform: translateY(0);
  opacity: 1;
}

.ln-toast--success {
  background-color: var(--ln-success);
  color: var(--ln-white);
}

.ln-toast--error {
  background-color: var(--ln-danger);
  color: var(--ln-white);
}

/* ══════════════════════════════════════════════════════════════════════
   FRONT PAGE — MISSING COMPONENT SELECTORS FIX (2026-04-06)
   ══════════════════════════════════════════════════════════════════════ */

/* --- Plan card: highlighted variant (alias for --popular) --- */
.ln-plan-card--highlighted {
  border-color: var(--ln-primary);
  box-shadow: var(--ln-shadow-gold);
  transform: scale(1.03);
  position: relative;
  z-index: 2;
}

.ln-plan-card--highlighted:hover {
  transform: scale(1.03) translateY(-6px);
}

/* --- Plan card inner elements --- */
.ln-plan-card__tier {
  display: block;
  font-size: var(--ln-text-xs);
  font-weight: var(--ln-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  color: var(--ln-primary);
  margin-bottom: 0.5rem;
}

.ln-plan-card__title {
  font-family: var(--ln-font-heading);
  font-size: 1.5rem;
  font-weight: var(--ln-weight-semibold);
  color: var(--ln-secondary);
  margin-bottom: 0.75rem;
}

.ln-plan-card__pain {
  font-style: italic;
  color: var(--ln-text);
  font-size: var(--ln-text-sm);
  flex-grow: 1;
  margin-bottom: 1.5rem;
}

.ln-plan-card__price {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.5rem;
}

.ln-plan-card__from {
  font-size: var(--ln-text-xs);
  color: var(--ln-text-light);
  text-transform: lowercase;
}

.ln-plan-card__amount {
  font-family: var(--ln-font-heading);
  font-size: 1.75rem;
  font-weight: var(--ln-weight-bold);
  color: var(--ln-secondary);
  line-height: 1.2;
}

.ln-plan-card__badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-xs);
  font-weight: var(--ln-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  padding: 0.35rem 1.25rem;
  border-radius: var(--ln-radius-full);
  white-space: nowrap;
}

/* --- Steps section & items --- */
.ln-steps__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ln-gap-lg);
  position: relative;
}

@media (max-width: 768px) {
  .ln-steps__grid {
    grid-template-columns: 1fr;
  }
}

.ln-steps__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
}

/* Connecting line between step circles */
.ln-steps__item:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 2rem;
  left: calc(50% + 2.5rem);
  width: calc(100% - 5rem);
  height: 2px;
  background-color: var(--ln-border);
}

@media (max-width: 768px) {
  .ln-steps__item:not(:last-child)::after {
    display: none;
  }
}

.ln-steps__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  border: 3px solid var(--ln-primary);
  background-color: var(--ln-white);
  color: var(--ln-secondary);
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-h3);
  font-weight: var(--ln-weight-bold);
  margin-bottom: var(--ln-gap-sm);
  position: relative;
  z-index: 1;
}

.ln-steps__title {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-lg);
  font-weight: var(--ln-weight-semibold);
  color: var(--ln-secondary);
  margin-bottom: 0.25rem;
}

.ln-steps__timeline {
  font-size: var(--ln-text-xs);
  font-weight: var(--ln-weight-medium);
  color: var(--ln-primary);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  margin-bottom: 0.5rem;
}

.ln-steps__desc {
  font-size: var(--ln-text-sm);
  color: var(--ln-text);
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}

.ln-steps__cta {
  text-align: center;
  margin-top: 3rem;
}

/* --- Case card: featured variant --- */
.ln-case-card--featured {
  grid-column: span 2;
  border-color: var(--ln-primary);
  border-width: 1px;
  box-shadow: var(--ln-shadow-gold);
}

@media (max-width: 960px) {
  .ln-case-card--featured {
    grid-column: span 1;
  }
}

/* --- Case card: media container --- */
.ln-case-card__media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  border-radius: var(--ln-radius) var(--ln-radius) 0 0;
}

.ln-case-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--ln-duration-slow) var(--ln-ease);
}

.ln-case-card:hover .ln-case-card__media img {
  transform: scale(1.05);
}

/* --- Case card: badge --- */
.ln-case-card__badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
  font-size: var(--ln-text-xs);
  font-weight: var(--ln-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  padding: 0.25rem 0.75rem;
  border-radius: var(--ln-radius-full);
}

/* --- Case card: body --- */
.ln-case-card__body {
  padding: var(--ln-gap);
}

/* --- Case card: category --- */
.ln-case-card__category {
  display: block;
  font-size: var(--ln-text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  color: var(--ln-text-light);
  margin-bottom: 0.25rem;
}

/* --- Case card: title --- */
.ln-case-card__title {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-lg);
  font-weight: var(--ln-weight-semibold);
  color: var(--ln-secondary);
  margin-bottom: 0.5rem;
}

/* --- Case card: quote --- */
.ln-case-card__quote {
  font-style: italic;
  color: var(--ln-text);
  border-left: 3px solid var(--ln-primary);
  padding-left: var(--ln-gap-sm);
  margin-bottom: var(--ln-gap-sm);
}

/* --- Case card: stats --- */
.ln-case-card__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ln-gap-sm);
  text-align: center;
  font-size: var(--ln-text-sm);
  list-style: none;
  padding: 0;
  margin: 0;
}

.ln-case-card__stats li strong {
  display: block;
  font-family: var(--ln-font-heading);
  font-weight: var(--ln-weight-bold);
  color: var(--ln-primary);
}

/* --- Footer: container --- */
.ln-footer__container {
  max-width: var(--ln-container);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--ln-gap);
  padding-right: var(--ln-gap);
}

/* --- Footer: bottom bar --- */
.ln-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 2rem;
  padding-bottom: 2rem;
  margin-top: 2rem;
}

.ln-footer__bottom-container {
  max-width: var(--ln-container);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--ln-gap);
  padding-right: var(--ln-gap);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

@media (max-width: 600px) {
  .ln-footer__bottom-container {
    flex-direction: column;
    text-align: center;
  }
}

.ln-footer__bottom-links {
  display: flex;
  gap: 1.5rem;
}

/* --- Footer: column brand variant --- */
.ln-footer__column--brand {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* --- Footer: logo --- */
.ln-footer__logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
}

.ln-footer__logo-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.ln-footer__logo-text {
  font-family: var(--ln-font-heading);
  font-size: 1.5rem;
  font-weight: var(--ln-weight-bold);
  color: var(--ln-white);
}

/* --- Footer: tagline --- */
.ln-footer__tagline {
  font-size: var(--ln-text-sm);
  color: var(--ln-text-light);
  max-width: 280px;
}

/* --- Footer: social link (circle icon) --- */
.ln-footer__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--ln-white);
  transition: background-color var(--ln-duration-fast) var(--ln-ease),
              color var(--ln-duration-fast) var(--ln-ease);
}

.ln-footer__social-link:hover {
  background-color: var(--ln-primary);
  color: var(--ln-secondary);
}

/* --- Footer: heading --- */
.ln-footer__heading {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  color: var(--ln-white);
  margin-bottom: var(--ln-gap-sm);
}

/* --- Footer: address --- */
.ln-footer__address {
  font-style: normal;
  font-size: var(--ln-text-sm);
  color: var(--ln-text-light);
  line-height: 1.6;
}

.ln-footer__flag {
  font-size: 1.25rem;
  margin-bottom: 0.25rem;
  display: inline-block;
}

/* --- Footer: copyright --- */
.ln-footer__copyright {
  font-size: var(--ln-text-xs);
  color: var(--ln-text-light);
}

/* --- Footer: legal links --- */
.ln-footer__legal {
  display: flex;
  gap: 1.5rem;
}

.ln-footer__legal a {
  font-size: var(--ln-text-xs);
  color: var(--ln-text-light);
  transition: color var(--ln-duration-fast) var(--ln-ease);
}

.ln-footer__legal a:hover {
  color: var(--ln-primary);
}

/* ══════════════════════════════════════════════════════════════════════
   FRONT PAGE — FULL LAYOUT AUDIT FIX (2026-04-06)
   Centering, grids, spacing, responsive breakpoints
   ══════════════════════════════════════════════════════════════════════ */

/* --- Section heading (used across all homepage sections) --- */
.ln-heading-section {
  font-family: var(--ln-font-heading);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: var(--ln-weight-bold);
  line-height: var(--ln-leading-snug);
  letter-spacing: var(--ln-tracking-tight);
  color: var(--ln-secondary);
  text-align: center;
  margin-bottom: var(--ln-gap-lg);
}

.ln-section--dark .ln-heading-section {
  color: var(--ln-white);
}

/* --- Text center helper with double dash --- */
.ln-text--center {
  text-align: center;
}

/* --- Stats: item & number (front-page uses __number not __value) --- */
.ln-stats__item {
  text-align: center;
}

.ln-stats__number {
  font-family: var(--ln-font-heading);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: var(--ln-weight-bold);
  line-height: 1;
  color: var(--ln-primary);
  display: block;
  font-variant-numeric: tabular-nums;
}

/* --- Hero: display heading margin --- */
.ln-hero__content .ln-heading-display {
  margin-bottom: var(--ln-gap-sm);
}

.ln-hero__content .ln-text-lg {
  color: var(--ln-text);
  margin-bottom: var(--ln-gap);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* --- Hero: badge (urgency strip) --- */
.ln-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: var(--ln-gap);
  background-color: var(--ln-primary-10);
  color: var(--ln-secondary);
  font-size: var(--ln-text-sm);
  font-weight: var(--ln-weight-medium);
  padding: 0.5rem 1.25rem;
  border-radius: var(--ln-radius-full);
}

.ln-hero__badge-icon {
  font-size: 1.1rem;
}

/* --- Before/After: grid of 3 articles stacked vertically --- */
.ln-before-after__grid {
  display: flex;
  flex-direction: column;
  gap: var(--ln-gap-lg);
  margin-top: var(--ln-gap-lg);
}

/* Before/After: each article layout */
.ln-before-after {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: auto auto;
  gap: 0 var(--ln-gap);
  align-items: center;
  background-color: var(--ln-white);
  border-radius: var(--ln-radius);
  padding: var(--ln-gap);
  box-shadow: var(--ln-shadow-md);
}

.ln-before-after__before {
  padding: var(--ln-gap-sm);
}

.ln-before-after__after {
  padding: var(--ln-gap-sm);
}

.ln-before-after__arrow {
  font-size: 1.5rem;
  color: var(--ln-primary);
  font-weight: var(--ln-weight-bold);
}

.ln-before-after__result {
  grid-column: 1 / -1;
  text-align: center;
  padding-top: var(--ln-gap-sm);
  border-top: 1px solid var(--ln-border);
  margin-top: var(--ln-gap-sm);
  color: var(--ln-primary);
}

.ln-before-after__tag {
  display: inline-block;
  font-size: var(--ln-text-xs);
  font-weight: var(--ln-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--ln-tracking-wide);
  padding: 0.2rem 0.6rem;
  border-radius: var(--ln-radius-full);
  margin-bottom: 0.5rem;
}

.ln-before-after__tag--before {
  background-color: rgba(239, 68, 68, 0.1);
  color: var(--ln-danger);
}

.ln-before-after__tag--after {
  background-color: rgba(34, 197, 94, 0.1);
  color: var(--ln-success);
}

@media (max-width: 768px) {
  .ln-before-after {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .ln-before-after__arrow {
    transform: rotate(90deg);
    margin: 0 auto;
  }
}

/* --- Plans: 3-column grid --- */
.ln-plans__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ln-gap);
  align-items: start;
  margin-top: var(--ln-gap-lg);
}

.ln-plan-card {
  display: flex;
  flex-direction: column;
  align-items: center;
}

@media (max-width: 960px) {
  .ln-plans__grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }

  .ln-plan-card--highlighted {
    transform: none;
    order: -1;
  }

  .ln-plan-card--highlighted:hover {
    transform: translateY(-6px);
  }
}

/* --- Tech: 4-column grid (2x2 on tablet, 1 on mobile) --- */
.ln-tech__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--ln-gap);
  margin-top: var(--ln-gap-lg);
}

.ln-tech-card {
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--ln-radius);
  padding: var(--ln-gap);
  text-align: center;
  transition: all var(--ln-duration) var(--ln-ease);
}

.ln-tech-card:hover {
  border-color: var(--ln-primary);
  box-shadow: var(--ln-shadow-gold);
  transform: translateY(-4px);
}

.ln-tech-card__icon {
  font-size: 2.5rem;
  margin-bottom: var(--ln-gap-sm);
  display: block;
}

.ln-tech-card__title {
  font-family: var(--ln-font-heading);
  font-size: var(--ln-text-lg);
  font-weight: var(--ln-weight-semibold);
  color: var(--ln-white);
  margin-bottom: 0.5rem;
}

.ln-tech-card__desc {
  font-size: var(--ln-text-sm);
  color: var(--ln-text-light);
}

@media (max-width: 960px) {
  .ln-tech__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .ln-tech__grid {
    grid-template-columns: 1fr;
  }
}

/* --- Cases: grid layout (featured spans 2 cols) --- */
.ln-cases__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--ln-gap);
  margin-top: var(--ln-gap-lg);
}

@media (max-width: 960px) {
  .ln-cases__grid {
    grid-template-columns: 1fr;
  }

  .ln-case-card--featured {
    grid-column: span 1;
  }
}

/* --- CTA: inner container --- */
.ln-cta__inner {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.ln-cta__inner .ln-heading-section {
  color: var(--ln-white);
}

.ln-cta__inner .ln-text-lg {
  color: var(--ln-text-light);
  margin-bottom: var(--ln-gap);
}

.ln-cta__proof {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: var(--ln-gap);
  font-size: var(--ln-text-sm);
  color: rgba(255, 255, 255, 0.7);
}

.ln-cta__proof-item {
  display: block;
}

.ln-cta__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ln-gap-sm);
}

.ln-cta__link {
  font-size: var(--ln-text-sm);
  color: var(--ln-primary);
  transition: color var(--ln-duration-fast) var(--ln-ease);
}

.ln-cta__link:hover {
  color: var(--ln-accent);
}

/* --- Mobile responsive: 768px --- */
@media (max-width: 768px) {
  .ln-section {
    padding-top: var(--ln-section-sm);
    padding-bottom: var(--ln-section-sm);
  }

  .ln-hero__actions {
    flex-direction: column;
    width: 100%;
  }

  .ln-hero__actions .ln-btn {
    width: 100%;
  }

  .ln-heading-section {
    font-size: clamp(1.5rem, 5vw, 2rem);
  }

  .ln-plans__grid {
    grid-template-columns: 1fr;
  }

  .ln-steps__grid {
    grid-template-columns: 1fr;
  }

  .ln-cases__grid {
    grid-template-columns: 1fr;
  }

  .ln-footer__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .ln-footer__grid {
    grid-template-columns: 1fr;
  }
}

/* --- Reveal animations (placeholders for JS IntersectionObserver) --- */
.ln-reveal {
  opacity: 0;
  transform: translateY(1.5rem);
  transition: opacity var(--ln-duration-slow) var(--ln-ease),
              transform var(--ln-duration-slow) var(--ln-ease);
}

.ln-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.ln-reveal-stagger {
  opacity: 0;
  transform: translateY(1.5rem);
  transition: opacity var(--ln-duration-slow) var(--ln-ease),
              transform var(--ln-duration-slow) var(--ln-ease);
}

.ln-reveal-stagger.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children: each delays by 100ms */
.ln-stagger-group .ln-reveal-stagger:nth-child(1) { transition-delay: 0ms; }
.ln-stagger-group .ln-reveal-stagger:nth-child(2) { transition-delay: 100ms; }
.ln-stagger-group .ln-reveal-stagger:nth-child(3) { transition-delay: 200ms; }
.ln-stagger-group .ln-reveal-stagger:nth-child(4) { transition-delay: 300ms; }
