/* ==========================================================================
   home.css — Athena Land Buyers
   Single long-scroll marketing page: hero + lead form, trust bar, services,
   process, about, investor band, FAQ, CTA band, contact.
   ========================================================================== */

/* Hero */
.hero { position: relative; min-height: 100vh; padding-top: 18vh; padding-bottom: 80px; background-color: var(--color-forest); overflow: hidden; display: flex; }
@media (min-width: 768px) { .hero { padding-top: 22vh; padding-bottom: 128px; } }
.hero-bg { position: absolute; inset: 0; opacity: 0.4; pointer-events: none; }
/* 3-photo rotating hero (sunrise/farm/pond) — slides crossfade via .is-active, JS in home.js */
.hero-slide { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; object-position: center; opacity: 0; transition: opacity 1.5s ease; }
.hero-slide.is-active { opacity: 1; }
.hero-slide--sunrise { object-position: center top; }
@media (min-width: 768px) { .hero-slide--sunrise { object-position: center 15%; } }
.hero-content { position: relative; z-index: 10; display: grid; gap: 48px; align-items: start; width: 100%; }
@media (min-width: 768px) { .hero-content { grid-template-columns: 1.1fr 0.9fr; gap: 80px; } }
.hero-text-col { color: var(--color-cream); margin-top: 32px; }
@media (min-width: 768px) { .hero-text-col { margin-top: 0; } }
.hero-subtitle { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.hero-subtitle-text { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.2em; color: var(--color-gold); }
.hero-subtitle-line { height: 1px; width: 48px; background-color: rgba(201,162,39,0.5); }
.hero-title { line-height: 1.1; margin-bottom: 24px; }
.hero-title-main { display: block; font-size: 3rem; font-style: italic; font-family: var(--font-serif); }
.hero-title-sub { display: block; font-size: 1.875rem; font-family: var(--font-sans); font-weight: 400; margin-top: 8px; }
@media (min-width: 768px) { .hero-title-main { font-size: 4.5rem; } .hero-title-sub { font-size: 3rem; } }
@media (min-width: 1024px) { .hero-title-main { font-size: 5rem; } }
.hero-desc { font-family: var(--font-sans); font-weight: 300; font-size: 1.125rem; opacity: 0.85; max-width: 36rem; margin-bottom: 40px; line-height: 1.625; text-wrap: balance; }
@media (min-width: 768px) { .hero-desc { font-size: 1.25rem; } }
.hero-chips { display: flex; flex-wrap: wrap; align-items: center; gap: 16px 32px; margin-bottom: 40px; }
.hero-chip-item { display: flex; align-items: center; gap: 8px; }
.hero-chip-text { font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.8; white-space: nowrap; }
.hero-chip-line { height: 12px; width: 1px; background-color: rgba(245,240,232,0.2); display: none; }
@media (min-width: 640px) { .hero-chip-line { display: block; } }
.hero-phone-group { margin-top: 16px; }
.hero-phone-label { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(201,162,39,0.6); margin-bottom: 8px; font-weight: 500; }
.hero-phone-link { display: inline-flex; align-items: center; gap: 12px; font-size: 1.5rem; font-weight: 700; transition: color 0.2s; }
.hero-phone-link:hover { color: var(--color-gold); }
@media (min-width: 768px) { .hero-phone-link { font-size: 2.25rem; } }

/* Hero Form Area */
.hero-form-wrapper { position: relative; width: 100%; z-index: 60; margin-top: 16px; height: 110px; }
@media (min-width: 768px) { .hero-form-wrapper { margin-top: 48px; } }
.hero-form-start { position: absolute; top:0; left:0; width: 100%; background-color: var(--color-cream); color: var(--color-ink); padding: 24px 32px; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; text-align: center; border-top: 4px solid var(--color-gold); min-height: 130px; margin-top: -15px; cursor: pointer; transition: background-color 0.2s; }
.hero-form-start:hover { background-color: #fff; }
.hero-form-start:hover .hero-form-start-btn { background-color: var(--color-forest-mid); }
.hero-form-start-title { font-family: var(--font-serif); font-style: italic; font-size: 1.875rem; }
@media (min-width: 768px) { .hero-form-start-title { font-size: 2.25rem; } }
.hero-form-start-btn { background-color: var(--color-forest); color: var(--color-cream); padding: 12px 32px; font-size: 0.82rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1); transition: background-color 0.2s; margin-top: 4px; display: inline-flex; align-items: center; gap: 8px; }

.hero-form-card { position: absolute; top: 0; left: 0; width: 100%; background-color: var(--color-cream); padding: 32px; box-shadow: 0 40px 80px rgba(0,0,0,0.3); text-align: left; transform-origin: top; margin-top: -15px; display: none; }
@media (min-width: 768px) { .hero-form-card { padding: 40px; } }
.hero-form-card.open { display: block; animation: formSlideDown 0.4s cubic-bezier(0.22, 1, 0.36, 1) forwards; }
@keyframes formSlideDown { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }
.form-close-btn { position: absolute; top: 24px; right: 24px; color: rgba(26,26,24,0.7); background: transparent; padding: 8px; transition: color 0.2s; }
.form-close-btn:hover { color: var(--color-ink); }
.form-header { margin-bottom: 32px; padding-right: 48px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.form-header-title { font-family: var(--font-serif); font-size: 1.875rem; font-style: italic; color: var(--color-ink); margin-bottom: 4px; transition: color 0.2s; }
.form-header:hover .form-header-title { color: var(--color-ink-soft); }
.form-header-subtitle { font-size: 0.7rem; font-weight: 500; color: var(--color-gold); text-transform: uppercase; letter-spacing: 0.1em; }

/* Hero "submitted" success state (replaces the form after a POST) */
.hero-form-success { position: absolute; top: 0; left: 0; width: 100%; background-color: var(--color-cream); color: var(--color-ink); padding: 32px; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); border-top: 4px solid var(--color-gold); margin-top: -15px; text-align: center; }
.hero-form-success-title { font-family: var(--font-serif); font-style: italic; font-size: 2rem; color: var(--color-forest); margin-bottom: 8px; }
.hero-form-success p { font-size: 0.95rem; color: var(--color-ink-soft); line-height: 1.6; margin: 0; }
/* Mobile: the absolute-overlay form (a desktop technique) overflows its fixed-height
   wrapper and gets clipped/overlapped on phones. Let it flow in normal document order
   instead, and hide the START button once the form is open. */
@media (max-width: 767px) {
  .hero-form-wrapper { height: auto; }
  .hero-form-start,
  .hero-form-card,
  .hero-form-success { position: relative; margin-top: 0; }
  .hero-form-wrapper.is-open .hero-form-start { display: none; }
}

/* Form Inputs (shared by hero form and contact form) */
.form-field { margin-bottom: 16px; }
.form-row { display: grid; gap: 16px; margin-bottom: 16px; }
@media (min-width: 640px) { .form-row { grid-template-columns: 1fr 1fr; } }
.form-input { width: 100%; padding: 12px 16px; border: 1px solid rgba(237,232,223,0.5); background-color: #fff; outline: none; transition: border-color 0.2s; color: var(--color-ink); font-weight: 500; box-sizing: border-box; }
.form-input:focus { border-color: var(--color-gold); }
.form-input::placeholder { color: rgba(26,26,24,0.4); }
.form-select { appearance: none; }
.form-textarea { resize: none; width: 100%; }

.form-checkbox-wrap { padding-top: 8px; margin-bottom: 16px; }
.form-checkbox-label { display: flex; gap: 12px; cursor: pointer; align-items: flex-start; }
.form-checkbox-box { position: relative; display: flex; align-items: center; justify-content: center; padding-top: 4px; }
.form-checkbox-input { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); border: 0; }
.form-checkbox-visible { height: 16px; width: 16px; background-color: #fff; border: 1px solid var(--color-ink-soft); border-radius: 2px; transition: all 0.2s; min-width: 16px; flex-shrink: 0; }
.form-checkbox-input:checked + .form-checkbox-visible { background-color: var(--color-forest); border-color: var(--color-forest); }
.form-checkbox-icon { position: absolute; color: white; transform: scale(0); transition: transform 0.2s; pointer-events: none; }
.form-checkbox-input:checked ~ .form-checkbox-icon { transform: scale(0.75); }
.form-checkbox-text { font-size: 0.65rem; color: var(--color-ink-soft); line-height: 1.625; transition: color 0.2s; }
.form-checkbox-label:hover .form-checkbox-text { color: var(--color-ink); }
.form-checkbox-text a { text-decoration: underline; transition: color 0.2s; }
.form-checkbox-text a:hover { color: var(--color-forest); }
.form-submit-btn { width: 100%; background-color: var(--color-forest); color: var(--color-cream); padding: 16px; font-family: var(--font-sans); font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.82rem; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1); transition: background-color 0.2s; display: inline-flex; justify-content: center; align-items: center; gap: 4px; border: none; cursor: pointer; }
.form-submit-btn:hover { background-color: var(--color-forest-mid); }
.form-submit-btn svg { transition: transform 0.2s; }
.form-submit-btn:hover svg { transform: translate(4px, -4px); }
.form-disclaimer { font-size: 0.62rem; color: rgba(74,74,70,0.6); text-align: center; margin-top: 16px; }

/* Trust Bar */
.trust-bar { background-color: var(--color-forest); padding: 32px 0; border-top: 1px solid rgba(255,255,255,0.1); }
.trust-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px 0; }
@media (min-width: 768px) { .trust-grid { grid-template-columns: repeat(4, 1fr); gap: 0; } }
.trust-item { display: flex; justify-content: center; padding: 0 16px; }
.trust-item:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.1); }
@media (min-width: 768px) { .trust-item:nth-child(odd) { border-right: none; } .trust-item { border-right: 1px solid rgba(255,255,255,0.1); } .trust-item:last-child { border-right: none; } }
.trust-content { display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center; }
@media (min-width: 768px) { .trust-content { flex-direction: row; text-align: left; align-items: center; } }
.trust-icon { color: var(--color-gold); display: flex; align-items: center; justify-content: center; }
.trust-label { color: var(--color-cream); font-size: 0.85rem; font-weight: 500; letter-spacing: -0.025em; white-space: nowrap; }

/* Services */
.services-section { padding: 96px 0; background-color: var(--color-cream); overflow: hidden; }
.section-header { margin-bottom: 80px; text-align: center; }
@media (min-width: 768px) { .section-header.desktop-left { text-align: left; } }
.section-kicker { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.2em; color: var(--color-gold); margin-bottom: 12px; display: block; }
.section-title { font-size: 2.25rem; font-style: italic; color: var(--color-ink); }
@media (min-width: 768px) { .section-title { font-size: 3rem; } }
@media (min-width: 1024px) { .section-title { font-size: 3.75rem; } }

.services-grid { display: grid; border-left: 1px solid rgba(201,162,39,0.2); border-bottom: 1px solid rgba(201,162,39,0.2); }
@media (min-width: 640px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .services-grid { grid-template-columns: repeat(4, 1fr); border-bottom: none; } }
.service-card { padding: 40px; display: flex; flex-direction: column; gap: 24px; border-right: 1px solid rgba(201,162,39,0.2); border-top: 1px solid rgba(201,162,39,0.2); }
.service-icon { color: var(--color-forest); }
.service-title { font-family: var(--font-sans); font-weight: 700; font-size: 0.82rem; letter-spacing: 0.1em; color: var(--color-ink); text-transform: uppercase; margin: 0; }
.service-img-wrap { overflow: hidden; background-color: rgba(27,67,50,0.05); }
.service-img { width: 100%; aspect-ratio: 3/4; object-fit: cover; transition: transform 0.7s; opacity: 0.9; }
.service-card:hover .service-img { opacity: 1; transform: scale(1.05); }
.service-img.transform-flip { transform: scaleX(-1); }
.service-card:hover .service-img.transform-flip { transform: scaleX(-1.05) scaleY(1.05); }
.service-desc { font-size: 0.9rem; line-height: 1.625; color: var(--color-ink-soft); margin: 0; }
.service-action { margin-top: auto; padding-top: 16px; display: flex; justify-content: flex-end; }
.service-btn { width: 44px; height: 44px; border: 1px solid var(--color-ink); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: all 0.2s; color: var(--color-ink); box-sizing: border-box; }
.service-card:hover .service-btn { background-color: var(--color-forest); color: var(--color-cream); border-color: var(--color-forest); }

/* Process */
.process-section { padding: 96px 0; background-color: var(--color-stone); position: relative; }
.process-grid { display: grid; gap: 64px; position: relative; }
@media (min-width: 768px) { .process-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; } }
.process-line { display: none; position: absolute; top: 24px; left: 15%; right: 15%; height: 1px; background-color: rgba(201,162,39,0.3); z-index: 0; }
@media (min-width: 768px) { .process-line { display: block; } }
.process-step { position: relative; z-index: 10; text-align: center; display: flex; flex-direction: column; align-items: center; }
@media (min-width: 768px) { .process-step { text-align: left; align-items: flex-start; } }
.process-num { width: 48px; height: 48px; background-color: var(--color-gold); display: flex; align-items: center; justify-content: center; color: var(--color-forest); font-weight: 700; margin-bottom: 24px; box-shadow: 0 1px 2px rgba(0,0,0,0.05); }
.process-title { font-size: 1.5rem; font-family: var(--font-serif); font-style: italic; color: var(--color-ink); margin-bottom: 16px; }
.process-desc { font-size: 0.88rem; line-height: 1.625; color: var(--color-ink-soft); max-width: 20rem; margin: 0; }

/* About */
.about-section { padding: 96px 0; background-color: var(--color-forest); color: var(--color-cream); text-align: center; }
.about-inner { max-width: 48rem; margin: 0 auto; }
.about-kicker { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.2em; color: var(--color-gold); margin-bottom: 32px; display: block; }
.about-title { font-size: 1.875rem; font-style: italic; font-family: var(--font-serif); line-height: 1.25; margin-bottom: 40px; }
@media (min-width: 768px) { .about-title { font-size: 3rem; } }
.about-text { color: rgba(245,240,232,0.85); font-family: var(--font-sans); font-weight: 300; font-size: 1.125rem; line-height: 1.625; text-wrap: balance; display: flex; flex-direction: column; gap: 24px; }
.about-text p { margin: 0; }
.about-profile { margin-top: 64px; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.about-avatar { width: 90px; height: 90px; border-radius: 50%; overflow: hidden; border: 2px solid var(--color-gold); display: flex; align-items: center; justify-content: center; background-color: var(--color-cream); position: relative; }
.about-avatar img { position: absolute; width: 100%; height: 100%; object-fit: cover; mix-blend-mode: darken; }
.about-name { display: block; font-family: var(--font-sans); font-weight: 700; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-gold); font-style: italic; margin-bottom: 4px; }
.about-role { display: block; font-size: 0.72rem; opacity: 0.5; text-transform: uppercase; letter-spacing: -0.025em; }

/* Investor Band */
.investor-section { background-color: var(--color-forest); padding: 80px 0; border-top: 1px solid rgba(255,255,255,0.05); }
.investor-grid { display: grid; gap: 48px; align-items: center; }
@media (min-width: 768px) { .investor-grid { grid-template-columns: 1.2fr 0.8fr; } }
.investor-title { font-size: 1.875rem; font-style: italic; color: var(--color-cream); line-height: 1.25; margin-bottom: 24px; }
@media (min-width: 768px) { .investor-title { font-size: 3rem; } }
.investor-desc { font-size: 1.125rem; font-family: var(--font-sans); font-weight: 300; color: rgba(245,240,232,0.7); max-width: 36rem; margin: 0; }
.investor-cards { display: flex; flex-direction: column; gap: 16px; }
.investor-card { padding: 32px; border: 1px solid rgba(255,255,255,0.1); transition: border-color 0.2s; cursor: pointer; display: block; }
.investor-card:hover { border-color: rgba(201,162,39,0.4); }
.investor-card-title { color: var(--color-gold); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 700; margin-bottom: 8px; margin-top: 0; }
.investor-card-text { color: rgba(245,240,232,0.8); font-size: 0.875rem; margin-bottom: 16px; margin-top: 0; }
.investor-card-link { color: var(--color-cream); font-weight: 500; display: inline-flex; align-items: center; gap: 8px; transition: color 0.2s; font-size: 1rem;}
.investor-card:hover .investor-card-link { color: var(--color-gold); }
.investor-card-link svg { transition: transform 0.2s; }
.investor-card:hover .investor-card-link svg { transform: translate(2px, -2px); }

/* FAQ */
.faq-section { padding: 96px 0; background-color: var(--color-stone); }
.faq-container { max-width: 1000px; margin: 0 auto; }
.faq-list { border-top: 1px solid rgba(26,26,24,0.1); }
.faq-item { padding: 24px 0; border-bottom: 1px solid rgba(26,26,24,0.1); }
.faq-btn { width: 100%; display: flex; justify-content: space-between; align-items: center; text-align: left; background: transparent; transition: color 0.2s; cursor: pointer; color: var(--color-ink); outline: none; }
.faq-btn:hover { color: var(--color-forest); }
.faq-q { font-family: var(--font-sans); font-weight: 700; font-size: 1.05rem; }
.faq-icon { color: var(--color-gold); display: flex; align-items: center; justify-content: center;}
.faq-a-wrapper { overflow: hidden; display: none; margin-top: 16px; }
.faq-a-wrapper.open { display: block; animation: accordionDown 0.3s ease-out forwards; }
@keyframes accordionDown { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
.faq-a { color: var(--color-ink-soft); line-height: 1.625; font-size: 0.95rem; font-weight: 300; max-width: 48rem; margin: 0; }
.faq-icon .icon-x { display: none; }
.faq-item.active .faq-icon .icon-x { display: block; }
.faq-item.active .faq-icon .icon-arrow { display: none; }

/* CTA Band */
.cta-band { background-color: var(--color-forest); padding: 96px 0; text-align: center; overflow: hidden; position: relative; }
.cta-line { position: absolute; top: 0; left: 0; width: 100%; height: 1px; background-color: rgba(255,255,255,0.1); }
.cta-content { position: relative; z-index: 10; max-width: 56rem; margin: 0 auto; padding: 0 24px; }
.cta-title { font-size: 2.25rem; font-style: italic; color: var(--color-cream); line-height: 1.25; margin-bottom: 24px; }
@media (min-width: 768px) { .cta-title { font-size: 3.75rem; } }
.cta-desc { font-size: 1.25rem; font-family: var(--font-sans); font-weight: 300; color: rgba(245,240,232,0.7); margin-bottom: 40px; margin-top: 0; }
.cta-actions { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.cta-btn { display: inline-block; background-color: var(--color-gold); color: var(--color-forest); padding: 20px 40px; font-family: var(--font-sans); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1); transition: all 0.2s; font-size: 0.875rem; margin-bottom: 16px; border: none; }
.cta-btn:hover { background-color: rgba(201,162,39,0.9); }
.cta-disclaimer { font-size: 0.62rem; color: rgba(245,240,232,0.45); text-transform: uppercase; letter-spacing: 0.15em; font-weight: 300; font-style: italic; margin: 0; }

/* Contact */
.contact-section { padding: 96px 0; background-color: var(--color-cream); }
.contact-header { text-align: center; margin-bottom: 48px; max-width: 42rem; margin-left: auto; margin-right: auto;}
.contact-header-title { font-size: 2.25rem; font-style: italic; color: var(--color-ink); margin-bottom: 48px; }
@media (min-width: 768px) { .contact-header-title { font-size: 3rem; } }
.contact-phone-kicker { font-size: 0.72rem; font-weight: 700; color: var(--color-gold); text-transform: uppercase; letter-spacing: 0.25em; margin-bottom: 16px; display: block; }
.contact-phone { font-size: 2.25rem; font-family: var(--font-sans); font-weight: 700; color: var(--color-forest); display: block; margin-bottom: 16px; transition: color 0.2s; }
.contact-phone:hover { color: var(--color-forest-mid); }
@media (min-width: 768px) { .contact-phone { font-size: 3rem; } }
@media (min-width: 1024px) { .contact-phone { font-size: 3.75rem; } }
.contact-email { font-size: 1.125rem; color: var(--color-ink); font-weight: 500; transition: color 0.2s; }
.contact-email:hover { color: var(--color-gold); }
.contact-divider { width: 60%; height: 1px; background-color: rgba(201,162,39,0.3); margin: 48px auto; }
.contact-form { max-width: 32rem; margin: 0 auto; text-align: left; display: flex; flex-direction: column; gap: 24px; }
.contact-textarea { padding: 16px 20px; border: 1px solid var(--color-stone); }
.contact-success { max-width: 32rem; margin: 0 auto; text-align: center; background-color: #fff; border-top: 4px solid var(--color-gold); padding: 40px 32px; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.15); }
.contact-success-title { font-family: var(--font-serif); font-style: italic; font-size: 1.875rem; color: var(--color-forest); margin-bottom: 12px; }
.contact-success p { color: var(--color-ink-soft); line-height: 1.6; margin: 0; }

/* Anti-spam honeypot — visually hidden, kept off-screen (bots fill it) */
.alb-hp { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }

/* Inline form validation message (shown on invalid submit redirect) */
.form-error { color: #9b2c2c; background-color: rgba(155,44,44,0.08); border: 1px solid rgba(155,44,44,0.25); padding: 12px 16px; font-size: 0.82rem; margin-bottom: 16px; border-radius: 2px; }
