/* ══════════════════════════════════════════════════════════════════
   Groundwork — front-page.css
   Home page styles only. Loaded exclusively on front-page.php.
   ══════════════════════════════════════════════════════════════════ */

/* ── HERO */
.hero {
    background: var(--color-hero-bg);
    padding: clamp(64px, 10vw, 120px) var(--pad);
    overflow: hidden;
}
.hero__inner {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; gap: var(--space-8); align-items: end;
}
.hero__kicker {
    font-family: var(--font-body); font-size: 12px; font-weight: 600;
    letter-spacing: .2em; text-transform: uppercase;
    color: var(--color-primary); opacity: .65; margin-bottom: var(--space-5);
}
.hero h1 {
    color: var(--color-hero-text);
    font-size: clamp(42px, 7vw, 88px);
    line-height: .97; letter-spacing: -.03em;
}
.hero h1 .hero__light { color: var(--color-white); }
.hero__sub {
    max-width: 520px;
    font-size: clamp(16px, 2vw, 19px);
    color: var(--color-hero-text); opacity: .78;
    line-height: 1.6; margin-top: var(--space-6);
}
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-7); }
.hero__proof {
    display: flex; flex-wrap: wrap;
    border-top: 1px solid rgba(12,35,64,.2);
    margin-top: var(--space-8); padding-top: var(--space-7);
}
.hero__stat { padding: 0 var(--space-7) 0 0; margin-right: var(--space-7); border-right: 1px solid rgba(12,35,64,.15); }
.hero__stat:last-child { border-right: none; padding-right: 0; margin-right: 0; }
.hero__stat-num {
    font-family: var(--font-display); font-weight: 800;
    font-size: 36px; color: var(--color-primary); line-height: 1;
}
.hero__stat-label { font-size: 12px; color: var(--color-primary); opacity: .6; margin-top: 4px; }

@media (min-width: 1024px) {
    .hero__inner { grid-template-columns: 1fr 360px; }
    .hero__proof {
        margin-top: 0; padding-top: 0; border-top: none;
        border-left: 1px solid rgba(12,35,64,.2); padding-left: var(--space-8);
        flex-direction: column; gap: var(--space-6);
    }
    .hero__stat {
        border-right: none; border-bottom: 1px solid rgba(12,35,64,.15);
        padding: 0 0 var(--space-6) 0; margin-right: 0;
    }
    .hero__stat:last-child { border-bottom: none; padding-bottom: 0; }
}

/* ── STRIP */
.strip {
    background: var(--color-primary);
    padding: 18px var(--pad); overflow: hidden;
}
.strip__inner { max-width: var(--max-w); margin: 0 auto; display: flex; gap: var(--space-8); flex-wrap: wrap; }
.strip__item {
    display: flex; align-items: center; gap: 10px;
    font-size: 15px; font-weight: 600;
    color: rgba(255,255,255,.6); white-space: nowrap;
}
.strip__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--color-accent); flex-shrink: 0; }

/* ── PROBLEM */
.problem { padding: clamp(64px, 10vw, 120px) var(--pad); background: var(--color-white); }
.problem__inner { max-width: var(--max-w); margin: 0 auto; display: grid; gap: var(--space-8); }
.problem__statement { font-size: clamp(28px, 4vw, 48px); max-width: 760px; }
.problem__statement em { color: var(--color-accent); font-style: normal; }
.problem__grid { display: grid; gap: var(--space-7); }
.problem__item { display: grid; grid-template-columns: 48px 1fr; gap: var(--space-5); }
.problem__num { font-family: var(--font-display); font-weight: 800; font-size: 13px; color: var(--color-accent); padding-top: 4px; }
.problem__item h3 { font-size: 19px; margin-bottom: var(--space-2); }
.problem__item p { font-size: 15px; color: var(--color-text-soft); line-height: 1.65; margin: 0; }
.problem__callout {
    background: var(--color-surface); border-left: 6px solid var(--color-accent);
    padding: var(--space-6) var(--space-7); border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    max-width: var(--max-w); margin: 0 auto;
}
.problem__callout p { font-family: var(--font-display); font-weight: 700; font-size: clamp(18px, 2.5vw, 26px); line-height: 1.4; margin: 0; }
.problem__callout p em { color: var(--color-accent); font-style: normal; }
.problem__callout .problem__citations { font-family: var(--font-body); font-size: 13px; color: var(--color-text-soft); margin-top: var(--space-4); font-weight: 400; }
.problem__callout .problem__citations a { color: var(--color-accent); border-bottom: 1px solid rgba(200,134,30,.3); }
@media (min-width: 768px) { .problem__grid { grid-template-columns: 1fr 1fr; } }

/* ── SYSTEM */
.system { padding: clamp(64px, 10vw, 120px) var(--pad); background: var(--color-surface); }
.system__inner { max-width: var(--max-w); margin: 0 auto; }
.system__header { max-width: 760px; margin-bottom: var(--space-8); }
.system__header h2 { margin: var(--space-4) 0 var(--space-5); }
.system__header p { font-size: 18px; color: var(--color-text-soft); }
.system__table { width: 100%; border-collapse: collapse; }
.system__table thead tr { border-bottom: 2px solid var(--color-primary); }
.system__table th {
    font-family: var(--font-body); font-size: 11px; font-weight: 600;
    letter-spacing: .15em; text-transform: uppercase;
    color: var(--color-text-soft); padding: 0 0 14px; text-align: left;
}
.system__table th:last-child { text-align: right; }
.system__table td { padding: var(--space-6) 0; border-bottom: 1px solid var(--color-border); vertical-align: top; }
.system__table td:last-child { text-align: right; }
.system__table tr:last-child td { border-bottom: none; }
.sys__num { font-family: var(--font-display); font-weight: 800; font-size: 11px; letter-spacing: .1em; color: var(--color-accent); display: block; margin-bottom: 6px; }
.sys__name { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--color-primary); }
.sys__desc { font-size: 14px; color: var(--color-text-soft); margin-top: 4px; max-width: 480px; line-height: 1.55; }
.sys__tag {
    display: inline-block; font-size: 12px; font-weight: 600;
    color: var(--color-primary); background: rgba(12,35,64,.07);
    padding: 4px 10px; border-radius: 100px; white-space: nowrap;
}
.system__price {
    margin-top: var(--space-8); background: var(--color-primary);
    border-radius: var(--radius-xl); padding: var(--space-7) var(--space-8);
    display: flex; flex-wrap: wrap; gap: var(--space-6);
    align-items: center; justify-content: space-between;
}
.system__price-amount { font-family: var(--font-display); font-weight: 800; font-size: clamp(40px, 6vw, 64px); color: var(--color-accent); line-height: 1; }
.system__price-label { font-size: 14px; color: rgba(255,255,255,.55); margin-top: 6px; }
.system__price-detail { font-size: 14px; color: rgba(255,255,255,.55); max-width: 320px; }
.system__price-detail strong { color: var(--color-white); display: block; margin-bottom: 4px; font-size: 16px; font-weight: 600; }

/* ── PROCESS */
.process { padding: clamp(64px, 10vw, 120px) var(--pad); background: var(--color-white); }
.process__inner { max-width: var(--max-w); margin: 0 auto; }
.process__header { max-width: 640px; margin-bottom: var(--space-8); }
.process__header h2 { margin: var(--space-4) 0 var(--space-5); }
.process__header p { font-size: 18px; color: var(--color-text-soft); }
.process__step {
    display: grid; grid-template-columns: 80px 1fr; gap: var(--space-6);
    padding: var(--space-7) 0; border-bottom: 1px solid var(--color-border); align-items: start;
}
.process__step:last-child { border-bottom: none; }
.process__num {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(48px, 6vw, 72px); color: var(--color-surface);
    line-height: 1; letter-spacing: -.03em; user-select: none;
}
.process__content { padding-top: 8px; }
.process__timing {
    font-size: 12px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    color: var(--color-accent); margin-bottom: var(--space-2); display: block;
}
.process__content h3 { font-size: clamp(18px, 2.5vw, 24px); margin-bottom: var(--space-3); }
.process__content p { font-size: 15px; color: var(--color-text-soft); line-height: 1.65; max-width: 600px; margin: 0; }

/* ── GSO */
.gso { padding: clamp(64px, 10vw, 120px) var(--pad); background: var(--color-primary); }
.gso__inner { max-width: var(--max-w); margin: 0 auto; }
.gso__header { max-width: 640px; margin-bottom: var(--space-8); }
.gso__header h2 { color: var(--color-white); margin: var(--space-4) 0 var(--space-5); }
.gso__header p { font-size: 18px; color: rgba(255,255,255,.6); }
.gso__grid { display: grid; gap: var(--space-5); }
.gso__card {
    background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--radius-lg); padding: var(--space-6);
}
.gso__card-label {
    font-size: 12px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
    color: var(--color-accent); margin-bottom: var(--space-3); display: block;
}
.gso__card blockquote {
    font-family: var(--font-display); font-weight: 700;
    font-size: clamp(15px, 2vw, 19px); color: var(--color-white);
    line-height: 1.4; border: none; padding: 0; font-style: normal;
}
.gso__note { font-size: 13px; color: rgba(255,255,255,.45); margin-top: var(--space-3); }
@media (min-width: 768px) { .gso__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .gso__grid { grid-template-columns: 1fr 1fr 1fr; } }

/* ── PROOF */
.proof { padding: clamp(64px, 10vw, 120px) var(--pad); background: var(--color-surface); }
.proof__inner { max-width: var(--max-w); margin: 0 auto; }
.proof__header { max-width: 640px; margin-bottom: var(--space-8); }
.proof__header h2 { margin: var(--space-4) 0 var(--space-5); }
.proof__header p { font-size: 18px; color: var(--color-text-soft); }
.proof__byline { font-size: 13px; color: var(--color-text-soft); margin-top: var(--space-3); }
.proof__layout { display: grid; gap: var(--space-8); }
.proof__case-meta { background: var(--color-primary); border-radius: var(--radius-xl); padding: var(--space-7); }
.proof__case-label { font-size: 12px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--color-accent); margin-bottom: var(--space-4); display: block; }
.proof__case-meta h3 { font-size: clamp(20px, 3vw, 28px); color: var(--color-white); margin-bottom: var(--space-7); line-height: 1.2; }
.proof__stats { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.proof__stat-val { font-family: var(--font-display); font-weight: 800; font-size: 40px; color: var(--color-accent); line-height: 1; }
.proof__stat-desc { font-size: 13px; color: rgba(255,255,255,.55); margin-top: 4px; }
.proof__delivered h4 { font-family: var(--font-display); font-weight: 700; font-size: 17px; margin: var(--space-6) 0 var(--space-5); }
.proof__list { display: flex; flex-direction: column; gap: var(--space-3); }
.proof__list li { display: flex; gap: var(--space-3); align-items: flex-start; font-size: 15px; color: var(--color-primary); line-height: 1.5; }
.proof__list li::before { content: '✓'; color: var(--color-accent); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.proof__quote-block { border: 2px solid var(--color-accent); border-radius: var(--radius-xl); padding: var(--space-7); }
.proof__placeholder { font-size: 13px; color: var(--color-text-soft); background: rgba(200,134,30,.1); border: 1px dashed var(--color-accent); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); margin-bottom: var(--space-5); }
.proof__quote-block blockquote { font-family: var(--font-display); font-weight: 700; font-size: clamp(18px, 2.5vw, 24px); color: var(--color-primary); line-height: 1.4; font-style: italic; margin-bottom: var(--space-5); }
.proof__quote-block cite { font-size: 14px; color: var(--color-text-soft); font-style: normal; font-weight: 600; }
.proof__referral { margin-top: var(--space-6); padding: var(--space-6); background: var(--color-white); border-radius: var(--radius-xl); border: 1px solid var(--color-border); }
.proof__referral h4 { font-family: var(--font-display); font-weight: 700; font-size: 17px; margin-bottom: var(--space-4); }
.proof__referral p { font-size: 15px; color: var(--color-text-soft); line-height: 1.65; margin-bottom: var(--space-3); }
.proof__referral p:last-child { margin-bottom: 0; }
@media (min-width: 1024px) { .proof__layout { grid-template-columns: 1fr 1fr; align-items: start; } }

/* ── FAQ */
.faq { padding: clamp(64px, 10vw, 120px) var(--pad); background: var(--color-white); }
.faq__inner { max-width: var(--max-w); margin: 0 auto; display: grid; gap: var(--space-8); }
.faq__header h2 { margin: var(--space-4) 0 var(--space-5); }
.faq__header p { font-size: 18px; color: var(--color-text-soft); }
@media (min-width: 1024px) { .faq__inner { grid-template-columns: 300px 1fr; align-items: start; } }

/* ── CTA SECTION */
.cta-section { padding: clamp(80px, 12vw, 140px) var(--pad); background: var(--color-accent); }
.cta-section__inner { max-width: 900px; margin: 0 auto; }
.cta-section__inner h2 { font-size: clamp(32px, 5vw, 64px); letter-spacing: -.03em; line-height: .97; color: var(--color-primary); margin-bottom: var(--space-5); }
.cta-section__inner h2 .cta__light { color: var(--color-white); }
.cta-section__inner p { font-size: 18px; color: var(--color-primary); opacity: .75; max-width: 520px; margin-bottom: var(--space-7); line-height: 1.6; }
.cta__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* ── CALENDLY CONTAINER */
#calendly-container {
    margin-top: var(--space-7); background: var(--color-white);
    border-radius: var(--radius-lg); overflow: hidden;
    min-height: 520px; display: flex; align-items: center; justify-content: center;
}
.calendly-placeholder { text-align: center; padding: var(--space-8); }
.calendly-placeholder h3 { font-size: 20px; color: var(--color-primary); margin-bottom: var(--space-2); }
.calendly-placeholder p { color: var(--color-text-soft); font-size: 15px; margin-bottom: var(--space-5); }
.calendly-placeholder__bar { width: 40px; height: 4px; background: var(--color-accent); border-radius: 2px; margin: 0 auto; }
