/* ============================================
   LAYOUT - page-level grids, wraps, sections
   ============================================ */

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
@media (max-width: 700px) { .wrap { padding: 0 20px; } }
@media (max-width: 380px) { .wrap { padding: 0 16px; } }

section { position: relative; padding: 72px 0; }
@media (max-width: 900px) { section { padding: 56px 0; } }
@media (max-width: 600px) { section { padding: 46px 0; } }

/* Section opener */
.section-head {
  max-width: 760px;
  margin: 0 auto 34px;
  text-align: center;
}
.section-head .lead { margin: 16px auto 0; }
.section-head .eyebrow { margin-bottom: 14px; }

/* HERO */
.hero { padding: 112px 0 68px; overflow: hidden; }
@media (max-width: 900px) { .hero { padding: 92px 0 46px; } }

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  align-items: center;
  gap: 56px;
}
@media (max-width: 1000px) { .hero-grid { grid-template-columns: minmax(0, 1fr); gap: 44px; text-align: center; } }
.hero-copy,
.hero-visual,
.hero-stage { min-width: 0; }

.hero h1 { margin-top: 18px; }
.hero .lead { margin-top: 18px; }
@media (max-width: 1000px) {
  .hero .lead { margin-left: auto; margin-right: auto; }
  .eyebrow { margin: 0 auto; }
}

.hero-cta {
  margin-top: 30px;
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
}
@media (max-width: 1000px) { .hero-cta { justify-content: center; } }

.hero-trust {
  margin-top: 22px;
  display: flex; align-items: center; gap: 22px; flex-wrap: wrap;
  color: var(--ink-mute);
  font-size: 13px;
}
@media (max-width: 1000px) { .hero-trust { justify-content: center; } }
.hero-trust .star { color: var(--gold); }

.hero-chips {
  margin-top: 22px;
  display: flex; gap: 8px; flex-wrap: wrap;
}
@media (max-width: 1000px) { .hero-chips { justify-content: center; } }

.hero-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 580px;
}
.hero-stage {
  position: relative;
  width: 100%;
  max-width: 460px;
  aspect-ratio: 460 / 640;
}
.hero-stage::before {
  content: "";
  position: absolute;
  inset: 8% 4%;
  border-radius: 28px;
  background:
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(135deg, rgba(91,124,255,0.18), rgba(24,184,166,0.08));
  background-size: 34px 34px, 34px 34px, auto;
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: var(--glow-soft);
}

@media (max-width: 560px) {
  .hero { padding: 82px 0 38px; }
  .hero-grid { gap: 34px; }
  .hero h1 {
    max-width: 10.5ch;
    margin-left: auto;
    margin-right: auto;
  }
  .hero .lead {
    max-width: 30ch;
    line-height: 1.55;
  }
  .hero-cta {
    width: 100%;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
    justify-content: stretch;
  }
  .hero-cta > * {
    flex: 1 1 100%;
    justify-content: center;
    min-height: 48px;
  }
  .hero-chips {
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
  .hero-trust {
    max-width: 30ch;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    gap: 8px 12px;
    line-height: 1.45;
  }
  .hero-visual { min-height: 500px; }
  .hero-stage {
    width: min(100%, 340px);
    aspect-ratio: 340 / 520;
  }
  .hero-stage::before {
    inset: 7% 0 5%;
    border-radius: 22px;
  }
}

@media (max-width: 380px) {
  .hero { padding-top: 78px; }
  .hero-grid { gap: 28px; }
  .hero-cta,
  .hero-chips { max-width: 288px; }
  .hero-visual { min-height: 450px; }
  .hero-stage {
    width: min(100%, 300px);
    aspect-ratio: 300 / 460;
  }
}

/* Pillars row */
.pillars {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 1000px) { .pillars { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .pillars { grid-template-columns: minmax(0, 1fr); } }

/* Pillar variants (the section under the hero uses 3-up or 2-up overrides) */
.pillars--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 1000px) { .pillars--3 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px)  { .pillars--3 { grid-template-columns: minmax(0, 1fr); } }
.pillars--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
@media (max-width: 780px)  { .pillars--2 { grid-template-columns: minmax(0, 1fr); } }

/* Feature split (alternating) */
.feature-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 64px;
  align-items: center;
}
@media (max-width: 980px) {
  .feature-split { grid-template-columns: minmax(0, 1fr); gap: 44px; }
  .feature-split.reverse .copy { order: 1; }
}
.feature-split + .feature-split { margin-top: 72px; }
@media (max-width: 980px) { .feature-split + .feature-split { margin-top: 56px; } }
@media (max-width: 560px) {
  .feature-split { gap: 30px; }
  .feature-split + .feature-split { margin-top: 46px; }
}

/* Centered solo feature band (no phone visual) */
.feature-solo { max-width: 660px; margin: 0 auto; text-align: center; }
.feature-solo .eyebrow { margin: 0 auto 18px; }
.feature-solo h2 { margin: 14px 0 12px; }
.feature-solo .lead { margin: 0 auto; }
.feature-solo ul { list-style: none; padding: 0; display: inline-flex; flex-direction: column; gap: 10px; text-align: left; margin: 24px 0 0; }
.feature-solo li {
  display: flex; gap: 12px; align-items: flex-start;
  color: var(--ink-soft); font-size: 15px; line-height: 1.5;
}
.feature-solo li .b {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 7px;
  background: rgba(143, 151, 255, 0.16);
  color: var(--primary-soft);
  display: grid; place-items: center;
  margin-top: 1px;
}

.feature-split .copy { max-width: 520px; }
.feature-split h2 { margin: 14px 0 12px; }
.feature-split .copy ul { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-direction: column; gap: 10px; }
.feature-split .copy li {
  display: flex; gap: 12px; align-items: flex-start;
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.5;
}
.feature-split .copy li .b {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 7px;
  background: rgba(143, 151, 255, 0.16);
  color: var(--primary-soft);
  display: grid; place-items: center;
  margin-top: 1px;
}

.visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 480px;
}
.visual .orb { display: none; }
@media (max-width: 560px) { .visual { min-height: 390px; } }
@media (max-width: 380px) { .visual { min-height: 350px; } }

/* Section padding overrides used inline previously */
.section--pt-60 { padding-top: 44px; }

/* PRICING grid */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  max-width: 900px;
  margin: 0 auto;
}
@media (max-width: 780px) { .pricing-grid { grid-template-columns: minmax(0, 1fr); } }

/* TESTI grid */
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
@media (max-width: 900px) { .testi-grid { grid-template-columns: minmax(0, 1fr); } }

/* FOOTER grid */
.footer-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) repeat(4, minmax(132px, 1fr));
  gap: 48px;
  align-items: start;
  margin-bottom: 52px;
}
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 36px; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 520px) { .footer-grid { grid-template-columns: minmax(0, 1fr); } }
