/* ==========================================================================
   Layout — sections, hero, pricing, comparison, FAQ, footer
   ========================================================================== */

/* ───────── Page container / mesh background ───────── */
.page-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.page-bg::before,
.page-bg::after {
  content: '';
  position: absolute;
  inset: -25%;
  background:
    radial-gradient(ellipse 60% 55% at 22% 8%,  rgba(212,175,55,0.18) 0%, transparent 55%),
    radial-gradient(circle  40% 40% at 82% 24%, rgba(242,213,131,0.08) 0%, transparent 60%),
    radial-gradient(circle  50% 50% at 50% 70%, rgba(212,175,55,0.07) 0%, transparent 60%);
  filter: blur(40px);
  animation: mesh-drift 28s var(--ease-inout) infinite;
}
.page-bg::after {
  inset: -25% -25% -25% -25%;
  background:
    radial-gradient(ellipse 50% 40% at 70% 5%, rgba(212,175,55,0.06) 0%, transparent 50%),
    radial-gradient(circle 30% 30% at 18% 60%, rgba(242,213,131,0.04) 0%, transparent 60%);
  animation: mesh-drift 36s var(--ease-inout) infinite reverse;
  opacity: 0.85;
}
@keyframes mesh-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(2.5%, -2%) scale(1.05); }
  66%      { transform: translate(-2%, 1.5%) scale(0.97); }
}

main { position: relative; z-index: var(--z-content); }

.section {
  padding: 110px 22px;
  max-width: var(--container);
  margin: 0 auto;
  position: relative;
}
.section-tight { padding: 80px 22px; }
.section-head {
  text-align: center;
  margin-bottom: 64px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.section-head h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2rem, 5.5vw, 3.4rem);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-bottom: 16px;
  background: var(--grad-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.section-head p {
  color: var(--text-3);
  font-size: clamp(1rem, 2.4vw, 1.15rem);
  line-height: 1.55;
  max-width: 56ch;
  margin: 0 auto;
}

/* ───────── Hero — typography only, no 3D overlap ───────── */
.hero {
  position: relative;
  padding: 110px 22px 60px;
  text-align: center;
  overflow: hidden;
}
.hero-inner {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
  z-index: 2;
}

/* ───────── Showcase — 3D centerpiece + caption + stats ───────── */
.showcase {
  position: relative;
  padding: 60px 22px 90px;
}
.showcase-inner {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  align-items: center;
}
@media (min-width: 920px) {
  .showcase-inner { grid-template-columns: 1.05fr 0.95fr; gap: 60px; }
}
.showcase-canvas-wrap {
  position: relative;
  aspect-ratio: 1 / 1;
  width: 100%;
  max-width: 540px;
  margin: 0 auto;
  display: grid;
  place-items: center;
}
.hero-canvas {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 30px 60px rgba(212,175,55,0.22));
}
.showcase-copy {
  text-align: left;
}
.showcase-copy h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-bottom: 16px;
  background: var(--grad-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.showcase-copy p {
  color: var(--text-3);
  font-size: 1.04rem;
  line-height: 1.6;
  max-width: 50ch;
  margin-bottom: 36px;
}
.showcase-copy .stats {
  margin-top: 0;
  border-top: 1px solid var(--border);
  border-bottom: none;
  padding: 28px 0 0;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  text-align: left;
}
.showcase-copy .stat-num { font-size: clamp(1.7rem, 3.6vw, 2.2rem); }
.showcase-copy .stat-label { letter-spacing: 0.14em; }
@media (max-width: 919px) {
  .showcase-inner { text-align: center; }
  .showcase-copy { text-align: center; }
  .showcase-copy p { margin-left: auto; margin-right: auto; }
  .showcase-copy .stats { text-align: center; }
}

.hero h1 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.6rem, 9.2vw, 6.5rem);
  letter-spacing: -0.035em;
  line-height: 0.96;
  margin: 28px auto 28px;
  max-width: 16ch;
  background: var(--grad-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero h1 em {
  font-style: normal;
  background: var(--grad-text-gold);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  position: relative;
}
.hero h1 em::after {
  content: '';
  position: absolute;
  left: 4%;
  right: 4%;
  bottom: -0.04em;
  height: 0.06em;
  background: var(--grad-gold);
  border-radius: var(--r-pill);
  transform-origin: left;
  transform: scaleX(0);
  animation: blade-draw 1.4s var(--ease-out) 0.6s forwards;
  opacity: 0.85;
}
@keyframes blade-draw {
  to { transform: scaleX(1); }
}
.hero .lede {
  font-size: clamp(1.06rem, 2.8vw, 1.28rem);
  color: var(--text-2);
  max-width: 52ch;
  margin: 0 auto 38px;
  line-height: 1.5;
}
.hero .cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-bottom: 26px;
}
.hero .trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 22px;
  justify-content: center;
  font-size: 0.82rem;
  color: var(--text-3);
}
.hero .trust-strip span { display: inline-flex; align-items: center; gap: 8px; }
.hero .trust-strip span::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 8px var(--gold-glow);
}

/* CTA forms — same shape as anchor buttons */
.cta-form { margin: 0; padding: 0; }

/* ───────── Face-row trust signal (hero) — placeholder until we have customers ───────── */
.face-row {
  margin-top: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.face-row-pills { display: inline-flex; align-items: center; }
.face-pill {
  width: 28px; height: 28px;
  border-radius: 50%;
  margin-right: -9px;
  background: linear-gradient(135deg, var(--bg-card), var(--bg-elevated));
  border: 2px solid var(--bg-base);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.face-pill:last-child { margin-right: 0; }
.face-row-label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.10em;
  color: var(--text-3);
  text-transform: lowercase;
}

/* ───────── Benefits grid — "Why work with us" ───────── */
.benefits {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 760px)  { .benefits { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .benefits { grid-template-columns: repeat(4, 1fr); } }
.benefit {
  padding: 30px 26px;
  display: flex;
  flex-direction: column;
}
.benefit-num {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--accent);
  margin-bottom: 16px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.benefit-num::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--accent-faint), transparent);
}
.benefit h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.16rem;
  letter-spacing: -0.018em;
  line-height: 1.20;
  margin-bottom: 8px;
}
.benefit p {
  color: var(--text-3);
  font-size: 0.92rem;
  line-height: 1.55;
}

/* ───────── Testimonials — placeholder, dashed-border, dimmed ───────── */
.testimonials {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 760px) { .testimonials { grid-template-columns: repeat(3, 1fr); } }
.testimonial-card {
  padding: 28px 26px;
  background: var(--bg-overlay);
  border: 1px dashed var(--border-2);
  border-radius: var(--r-lg);
  opacity: 0.50;
  transition: opacity var(--d-soft) var(--ease-out), border-color var(--d-soft) var(--ease-out);
}
.testimonial-card:hover {
  opacity: 0.75;
  border-color: var(--accent-faint);
}
.testimonial-slot {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.testimonial-avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bg-card), var(--bg-elevated));
  border: 1px solid var(--border-2);
  flex: 0 0 auto;
}
.testimonial-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.96rem;
  color: var(--text-2);
  letter-spacing: -0.01em;
}
.testimonial-role {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  color: var(--text-3);
  text-transform: uppercase;
  margin-top: 4px;
}
.testimonial-quote {
  font-size: 0.86rem;
  color: var(--text-3);
  letter-spacing: 0.04em;
  line-height: 1.5;
}

/* ───────── Stat band — used inside .showcase ───────── */
.stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 26px 22px;
  text-align: center;
}
@media (min-width: 920px) { .stats { grid-template-columns: repeat(4, 1fr); } }
.stat-num {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.1rem, 5vw, 3.2rem);
  letter-spacing: -0.028em;
  line-height: 1;
}
.stat-num .accent { color: var(--gold); }
.stat-label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: 10px;
}

/* ───────── Brand strip (removed — kept selector for backwards compat if needed) ───────── */

/* ───────── Process steps ───────── */
.steps {
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
}
@media (min-width: 880px) { .steps { grid-template-columns: repeat(3, 1fr); } }
.step { position: relative; padding: 38px 30px; }
.step-num {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  color: var(--gold);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.step-num::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--gold-faint), transparent);
}
.step h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.42rem;
  letter-spacing: -0.018em;
  line-height: 1.18;
  margin-bottom: 10px;
}
.step p {
  color: var(--text-3);
  font-size: 0.96rem;
  line-height: 1.6;
}

/* ───────── Pricing ───────── */
.pricing {
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
  align-items: stretch;
}
@media (min-width: 880px) {
  .pricing {
    grid-template-columns: repeat(3, 1fr);
    align-items: stretch;
    gap: 16px;
  }
}
.tier {
  position: relative;
  background: var(--bg-overlay);
  backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid var(--border-2);
  border-radius: var(--r-xl);
  padding: 38px 32px;
  display: flex;
  flex-direction: column;
  transition:
    transform var(--d-soft) var(--ease-out),
    border-color var(--d-soft) var(--ease-out),
    box-shadow var(--d-soft) var(--ease-out);
}
.tier:hover { transform: translateY(-4px); border-color: var(--border-3); }
.tier-name {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 16px;
  font-weight: 600;
}
.tier-name.gold { color: var(--gold); }
.tier-price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 3.1rem;
  letter-spacing: -0.032em;
  line-height: 1;
  margin-bottom: 10px;
}
.tier-price .currency {
  font-size: 1.4rem;
  vertical-align: top;
  color: var(--text-3);
  margin-right: 2px;
}
.tier-sub {
  color: var(--text-3);
  font-size: 0.96rem;
  line-height: 1.5;
  min-height: 3em;
  margin-bottom: 28px;
}
.tier ul {
  list-style: none;
  flex: 1;
  margin: 0 0 30px;
  padding: 0;
  display: grid;
  gap: 11px;
}
.tier li {
  font-size: 0.95rem;
  display: flex;
  gap: 11px;
  align-items: flex-start;
  color: rgba(244,234,222,0.92);
}
.tier li::before {
  content: '';
  flex: 0 0 auto;
  width: 18px; height: 18px;
  margin-top: 2px;
  background: var(--gold-faint);
  border: 1px solid var(--gold);
  border-radius: 50%;
  background-image:
    linear-gradient(135deg, transparent 40%, var(--gold) 41%, var(--gold) 50%, transparent 51%),
    linear-gradient(45deg,  transparent 40%, var(--gold) 41%, var(--gold) 50%, transparent 51%);
  background-size: 50% 50%;
  background-position: 6px 8px, 4px 4px;
  background-repeat: no-repeat;
}
.tier-cta { width: 100%; }

/* SURGE feature elevation — anchor decoy */
.tier-featured {
  border-color: rgba(212,175,55,0.50);
  background:
    linear-gradient(180deg, rgba(212,175,55,0.10) 0%, var(--bg-elevated) 100%);
  box-shadow:
    0 0 0 1px rgba(212,175,55,0.36),
    0 32px 80px rgba(0,0,0,0.55),
    0 0 80px rgba(212,175,55,0.16);
  z-index: 1;
}
@media (min-width: 880px) {
  .tier-featured { transform: scale(1.04); }
  .tier-featured:hover { transform: scale(1.04) translateY(-4px); }
}

/* ───────── Comparison table ───────── */
.compare {
  margin-top: 64px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--bg-overlay);
  backdrop-filter: blur(8px);
}
.compare table { width: 100%; border-collapse: collapse; font-size: 0.94rem; }
.compare th, .compare td { padding: 16px 18px; text-align: left; border-top: 1px solid var(--border); }
.compare thead th {
  background: rgba(255,255,255,0.025);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-3);
  font-weight: 600;
  border-top: none;
}
.compare th:not(:first-child),
.compare td:not(:first-child) { text-align: center; }
.compare .tick { color: var(--text); font-weight: 600; }
.compare .dash { color: rgba(255,255,255,0.22); font-weight: 600; }
.compare td { color: var(--text); }
.compare .featured-col { background: rgba(212,175,55,0.05); color: var(--gold-hi); }
.compare tr:hover td { background: rgba(255,255,255,0.015); }

@media (max-width: 720px) {
  .compare table, .compare thead, .compare tbody, .compare tr,
  .compare th, .compare td { display: block; }
  .compare thead { display: none; }
  .compare tr { padding: 16px 18px; border-top: 1px solid var(--border); }
  .compare td { padding: 6px 0; border-top: none; text-align: left !important; display: flex; justify-content: space-between; align-items: center; }
  .compare td::before {
    content: attr(data-label);
    font-family: var(--font-mono);
    color: var(--text-3);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
  }
  .compare td:first-child {
    font-weight: 600;
    padding-bottom: 10px;
    color: var(--text);
  }
  .compare td:first-child::before { display: none; }
}

/* ───────── FAQ ───────── */
.faq {
  max-width: 760px;
  margin: 0 auto;
}
.faq-item {
  border-bottom: 1px solid var(--border);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 22px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.22rem;
  letter-spacing: -0.014em;
  line-height: 1.35;
  transition: color var(--d-snap) var(--ease-out);
  color: var(--text);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--text);
  font-size: 1.6rem;
  transition: transform var(--d-snap) var(--ease-spring);
  flex: 0 0 auto;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item summary:hover { color: var(--text-2); }
.faq-item p {
  padding: 0 50px 22px 0;
  color: var(--text-2);
  line-height: 1.65;
  font-size: 1.04rem;
  max-width: 64ch;
}

/* ───────── Final CTA ───────── */
.final-cta {
  padding: 130px 22px 100px;
  text-align: center;
  position: relative;
}
.final-cta h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.9rem, 5vw, 2.9rem);
  letter-spacing: -0.022em;
  line-height: 1.16;
  max-width: 24ch;
  margin: 0 auto 36px;
  background: var(--grad-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.final-cta h2 em {
  font-style: normal;
  background: var(--grad-text-gold);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ───────── Footer ───────── */
.footer {
  padding: 56px 22px 48px;
  border-top: 1px solid var(--border);
  position: relative;
  z-index: var(--z-content);
  background: rgba(10,10,10,0.6);
  backdrop-filter: blur(8px);
}
.footer-inner {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
  text-align: center;
  color: var(--text-3);
  font-size: 0.86rem;
}
.footer-links { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; }
.footer-links a { transition: color var(--d-snap) var(--ease-out); }
.footer-links a:hover { color: var(--gold); }
.footer-tag {
  font-family: var(--font-display);
  font-style: italic;
  letter-spacing: 0.005em;
  color: var(--text-2);
}
@media (min-width: 760px) {
  .footer-inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    text-align: left;
  }
  .footer-links { justify-content: flex-end; }
}
