/* ============================================================
   AVALANCHE LEADS — pages.css
   Component layer: all .avl-* page components.
   Naming: .avl-[component]__[element]--[modifier]
   Mobile-first. Breakpoints: 768px (tablet), 1024px (desktop).
   ============================================================ */

/* ============================================================
   §1  HERO
   ============================================================ */

.avl-hero {
  position: relative;
  overflow: hidden;
  min-height: 90vh;
  display: flex;
  align-items: center;
  background-color: var(--avl-black);
}

/* Background image layer */
.avl-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.avl-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  opacity: 0.35;
  display: block;
}

/* Dark overlay so text stays legible */
.avl-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(11, 14, 17, 0.55) 0%,
    rgba(11, 14, 17, 0.80) 60%,
    rgba(11, 14, 17, 0.95) 100%
  );
}

.avl-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--avl-max-content);
  margin: 0 auto;
  padding: var(--avl-s24) var(--avl-s4);
  padding-top: calc(var(--avl-s24) + 64px); /* account for sticky header */
}

.avl-hero__eyebrow {
  display: block;
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--avl-amber);
  margin-bottom: var(--avl-s6);
}

.avl-hero__h1 {
  font-family: var(--avl-font-display);
  font-size: var(--avl-h1);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--avl-bone);
  max-width: 18ch;
  margin: 0 0 var(--avl-s6) 0;
}

.avl-hero__sub {
  font-family: var(--avl-font-body);
  font-size: var(--avl-body-lg);
  line-height: 1.55;
  color: var(--avl-steel);
  max-width: 58ch;
  margin: 0 0 var(--avl-s8) 0;
}

.avl-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--avl-s4);
  margin-bottom: var(--avl-s12);
}

/* Receipt strip — 4 numbers in mono */
.avl-receipt-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--avl-s2) var(--avl-s8);
  border-top: 1px solid var(--avl-slate);
  padding-top: var(--avl-s8);
  margin-top: var(--avl-s4);
}

.avl-receipt-item {
  display: flex;
  flex-direction: column;
  gap: var(--avl-s1);
}

.avl-receipt-item__number {
  font-family: var(--avl-font-mono);
  font-size: 28px;
  font-weight: 700;
  color: var(--avl-amber);
  letter-spacing: -0.01em;
}

.avl-receipt-item__label {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--avl-steel);
}

@media (min-width: 768px) {
  .avl-hero__inner {
    padding: calc(var(--avl-s32) + 64px) var(--avl-s8) var(--avl-s24);
  }

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

/* ============================================================
   §2  CALLOUT SECTION — "What you've been paying for"
   ============================================================ */

.avl-callout-section {
  background-color: var(--avl-smoke);
}

.avl-callout-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--avl-s8);
  margin-top: var(--avl-s12);
}

.avl-callout-card {
  border: 1px solid var(--avl-slate);
  border-radius: var(--avl-radius-card);
  padding: var(--avl-s8);
  background-color: var(--avl-black);
}

.avl-callout-card__label {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--avl-amber);
  margin-bottom: var(--avl-s3);
}

.avl-callout-card__title {
  font-family: var(--avl-font-display);
  font-size: clamp(20px, 2.5vw, 28px);
  line-height: 1.1;
  color: var(--avl-bone);
  margin-bottom: var(--avl-s4);
}

.avl-callout-card__body {
  font-family: var(--avl-font-body);
  font-size: var(--avl-body);
  line-height: 1.6;
  color: var(--avl-steel);
  margin: 0;
  max-width: none;
}

@media (min-width: 768px) {
  .avl-callout-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================================
   §3  THE AVALANCHE WAY — architecture flow diagram
   ============================================================ */

.avl-machine-section {
  background-color: var(--avl-black);
}

.avl-machine-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--avl-s4);
  margin-top: var(--avl-s12);
  align-items: center;
}

.avl-channel-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--avl-s4);
}

.avl-channel-box {
  border: 1px solid var(--avl-slate);
  border-radius: var(--avl-radius-card);
  padding: var(--avl-s6);
  text-align: center;
}

.avl-channel-box__label {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--avl-steel);
  margin-bottom: var(--avl-s2);
}

.avl-channel-box__name {
  font-family: var(--avl-font-display);
  font-size: 18px;
  color: var(--avl-bone);
  margin: 0;
}

.avl-flow-arrow {
  text-align: center;
  font-family: var(--avl-font-mono);
  font-size: 24px;
  color: var(--avl-amber);
  padding: var(--avl-s2) 0;
}

.avl-monday-box {
  border: 2px solid var(--avl-amber);
  border-radius: var(--avl-radius-card);
  padding: var(--avl-s8);
  text-align: center;
  background-color: var(--avl-smoke);
}

.avl-monday-box__label {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--avl-amber);
  margin-bottom: var(--avl-s2);
}

.avl-monday-box__title {
  font-family: var(--avl-font-display);
  font-size: clamp(20px, 2.5vw, 28px);
  color: var(--avl-bone);
  margin: 0;
}

@media (min-width: 768px) {
  .avl-machine-flow {
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
  }

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

  .avl-flow-arrow {
    font-size: 32px;
    padding: 0 var(--avl-s4);
  }
}

/* ============================================================
   §4  PILLARS
   ============================================================ */

.avl-pillars-section {
  background-color: var(--avl-smoke);
}

.avl-pillars-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--avl-s8);
  margin-top: var(--avl-s12);
}

.avl-pillar {
  border-top: 2px solid var(--avl-amber);
  padding-top: var(--avl-s6);
}

.avl-pillar__number {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--avl-amber);
  margin-bottom: var(--avl-s3);
}

.avl-pillar__title {
  font-family: var(--avl-font-display);
  font-size: clamp(22px, 3vw, 32px);
  line-height: 1.05;
  color: var(--avl-bone);
  margin-bottom: var(--avl-s4);
}

.avl-pillar__body {
  font-family: var(--avl-font-body);
  font-size: var(--avl-body);
  line-height: 1.6;
  color: var(--avl-steel);
  margin-bottom: var(--avl-s6);
  max-width: none;
}

.avl-pillar__dismantles {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  letter-spacing: 0.04em;
  color: var(--avl-slate);
  border-left: 2px solid var(--avl-slate);
  padding-left: var(--avl-s4);
  margin: 0;
}

@media (min-width: 768px) {
  .avl-pillars-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================================
   §5  MONDAY LOG COMPONENT (rendered HTML, not an image)
   ============================================================ */

.avl-log-section {
  background-color: var(--avl-black);
}

.avl-log-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--avl-s12);
  margin-top: var(--avl-s12);
  align-items: start;
}

/* The mock log — rendered in HTML as the brand's calling card */
.avl-log-mock {
  background-color: var(--avl-smoke);
  border: 1px solid var(--avl-slate);
  border-radius: var(--avl-radius-card);
  overflow: hidden;
  font-family: var(--avl-font-mono);
}

.avl-log-mock__header {
  background-color: var(--avl-slate);
  padding: var(--avl-s3) var(--avl-s6);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.avl-log-mock__title {
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--avl-bone);
}

.avl-log-mock__date {
  font-size: var(--avl-caption);
  color: var(--avl-steel);
}

.avl-log-mock__body {
  padding: var(--avl-s4) var(--avl-s6);
}

.avl-log-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: var(--avl-s4);
  align-items: center;
  padding: var(--avl-s3) 0;
  border-bottom: 1px solid var(--avl-slate);
  font-size: var(--avl-caption);
}

.avl-log-row:last-child {
  border-bottom: none;
}

.avl-log-row__channel {
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--avl-steel);
  font-weight: 500;
  white-space: nowrap;
}

.avl-log-row__status-text {
  color: var(--avl-steel);
  font-size: 11px;
}

.avl-log-row__count {
  font-size: 18px;
  font-weight: 700;
  color: var(--avl-amber);
  text-align: right;
}

.avl-log-row__label {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--avl-steel);
}

.avl-log-mock__footer {
  border-top: 1px solid var(--avl-slate);
  padding: var(--avl-s3) var(--avl-s6);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.avl-log-mock__total-label {
  font-size: var(--avl-caption);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--avl-steel);
}

.avl-log-mock__total-number {
  font-size: 24px;
  font-weight: 700;
  color: var(--avl-success);
}

/* Right column — explanation text */
.avl-log-explain__eyebrow {
  display: block;
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--avl-amber);
  margin-bottom: var(--avl-s4);
}

.avl-log-explain__title {
  font-family: var(--avl-font-display);
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.05;
  color: var(--avl-bone);
  margin-bottom: var(--avl-s6);
}

.avl-log-explain__body {
  font-family: var(--avl-font-body);
  font-size: var(--avl-body);
  line-height: 1.6;
  color: var(--avl-steel);
  margin-bottom: var(--avl-s4);
  max-width: none;
}

@media (min-width: 768px) {
  .avl-log-grid {
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }
}

/* ============================================================
   §6  COMPARISON TABLE
   ============================================================ */

.avl-compare-section {
  background-color: var(--avl-smoke);
  overflow-x: auto;
}

.avl-compare-table {
  width: 100%;
  min-width: 640px;
  border-collapse: collapse;
  margin-top: var(--avl-s12);
  font-family: var(--avl-font-body);
}

.avl-compare-table th {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: var(--avl-s4) var(--avl-s6);
  text-align: left;
  border-bottom: 2px solid var(--avl-slate);
  color: var(--avl-steel);
}

.avl-compare-table th.avl-compare-table__avl-col {
  color: var(--avl-amber);
  border-bottom-color: var(--avl-amber);
}

.avl-compare-table td {
  font-size: var(--avl-body-sm);
  padding: var(--avl-s4) var(--avl-s6);
  border-bottom: 1px solid var(--avl-slate);
  color: var(--avl-steel);
  vertical-align: middle;
}

.avl-compare-table td.avl-compare-table__avl-col {
  color: var(--avl-bone);
  font-weight: 600;
}

.avl-compare-table tr:last-child td {
  border-bottom: none;
}

.avl-compare-table__row-label {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--avl-slate);
}

/* Mark glyphs */
.avl-mark--yes  { color: var(--avl-amber); font-weight: 700; }
.avl-mark--no   { color: var(--avl-danger); font-weight: 700; }
.avl-mark--maybe { color: var(--avl-steel); font-weight: 700; }

/* ============================================================
   §7  FAQ ACCORDION
   ============================================================ */

.avl-faq-section {
  background-color: var(--avl-black);
}

.avl-faq-list {
  margin-top: var(--avl-s12);
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--avl-slate);
}

.avl-faq-item {
  border-bottom: 1px solid var(--avl-slate);
}

.avl-faq-item__q {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--avl-s4);
  padding: var(--avl-s6) 0;
  font-family: var(--avl-font-display);
  font-size: clamp(16px, 2vw, 22px);
  line-height: 1.2;
  color: var(--avl-bone);
  cursor: pointer;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  min-height: 44px;
}

.avl-faq-item__q-text {
  flex: 1;
}

.avl-faq-item__icon {
  flex-shrink: 0;
  font-size: 20px;
  color: var(--avl-amber);
  line-height: 1;
  font-family: var(--avl-font-mono);
  transition: transform 0.2s ease;
  user-select: none;
}

.avl-faq-item.is-open .avl-faq-item__icon {
  transform: rotate(45deg);
}

.avl-faq-item__a {
  display: none;
  padding: 0 0 var(--avl-s6) 0;
  font-family: var(--avl-font-body);
  font-size: var(--avl-body);
  line-height: 1.6;
  color: var(--avl-steel);
  max-width: 70ch;
}

.avl-faq-item.is-open .avl-faq-item__a {
  display: block;
}

/* ============================================================
   §8  FINAL CTA / CONTACT
   ============================================================ */

.avl-cta-section {
  background-color: var(--avl-smoke);
  text-align: center;
}

.avl-cta-section .avl-eyebrow {
  margin-bottom: var(--avl-s6);
}

.avl-cta-section h2 {
  margin-bottom: var(--avl-s8);
}

.avl-phone-display {
  font-family: var(--avl-font-display);
  font-size: clamp(28px, 5vw, 56px);
  letter-spacing: -0.02em;
  color: var(--avl-amber);
  margin-bottom: var(--avl-s8);
  display: block;
  text-decoration: none;
}

.avl-phone-display:hover {
  color: var(--avl-bone);
  text-decoration: none;
}

/* Fallback form */
.avl-form {
  max-width: 420px;
  margin: var(--avl-s12) auto 0;
  text-align: left;
  border-top: 1px solid var(--avl-slate);
  padding-top: var(--avl-s8);
}

.avl-form__label {
  display: block;
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--avl-steel);
  margin-bottom: var(--avl-s2);
}

.avl-form__input {
  display: block;
  width: 100%;
  font-family: var(--avl-font-body);
  font-size: var(--avl-body);
  color: var(--avl-bone);
  background-color: var(--avl-black);
  border: 1px solid var(--avl-slate);
  border-radius: var(--avl-radius-input);
  padding: var(--avl-s3) var(--avl-s4);
  min-height: 44px;
  margin-bottom: var(--avl-s6);
  transition: border-color 0.15s ease;
  appearance: none;
  -webkit-appearance: none;
}

.avl-form__input:focus {
  outline: none;
  border-color: var(--avl-amber);
}

.avl-form__input::placeholder {
  color: var(--avl-steel);
}

.avl-form__submit {
  width: 100%;
}

/* ============================================================
   §9  STICKY CTA (mobile — for Sonic Boom to mount on)
   ============================================================ */

.avl-sticky-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background-color: var(--avl-black);
  border-top: 1px solid var(--avl-amber);
  padding: var(--avl-s3) var(--avl-s4);
  gap: var(--avl-s3);
  align-items: center;
  justify-content: center;
}

.avl-sticky-cta.is-visible {
  display: flex;
}

@media (min-width: 769px) {
  .avl-sticky-cta {
    display: none !important;
  }
}

/* ============================================================
   §10  SECTION HEADER (shared utility)
   ============================================================ */

.avl-section-header {
  max-width: 70ch;
  margin-bottom: var(--avl-s12);
}

.avl-section-header--centered {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.avl-section-header h2 {
  margin-bottom: 0;
}

/* ============================================================
   §11  SCROLL-REVEAL UTILITY (JS applies .is-visible)
   ============================================================ */

.avl-reveal {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.avl-reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* Skip the animation for users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  .avl-reveal {
    opacity: 1;
    transform: none;
  }
}

/* ============================================================
   §12  TOC (for article pages — Stage 4 prep)
   ============================================================ */

.avl-toc {
  border: 1px solid var(--avl-slate);
  border-radius: var(--avl-radius-card);
  padding: var(--avl-s6);
  background-color: var(--avl-smoke);
  margin-bottom: var(--avl-s8);
}

.avl-toc__label {
  font-family: var(--avl-font-mono);
  font-size: var(--avl-caption);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--avl-steel);
  margin-bottom: var(--avl-s4);
}

.avl-toc ol {
  margin: 0;
  padding-left: var(--avl-s6);
}

.avl-toc li {
  font-size: var(--avl-body-sm);
  color: var(--avl-steel);
  margin-bottom: var(--avl-s2);
}

.avl-toc a {
  color: var(--avl-steel);
  text-decoration: none;
}

.avl-toc a:hover {
  color: var(--avl-amber);
}

/* TOC order fix for mobile: appears above body */
@media (max-width: 860px) {
  .avl-article-layout .avl-toc {
    order: -1;
  }
}
