/* ── Drew Media — brand stylesheet (Direction A: The Index) ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --paper: oklch(99% 0 0);
  --paper2: oklch(96.5% 0.002 280);
  --ink: oklch(20% 0.01 280);
  --ink-muted: oklch(45% 0.01 280);
  --ink-dim: oklch(62% 0.008 280);
  --line: oklch(20% 0.01 280 / 0.14);
  --line-strong: oklch(20% 0.01 280 / 0.3);
  --blue: oklch(50% 0.2 264);
  --blue-soft: oklch(50% 0.2 264 / 0.08);
  --blue-bright: oklch(68% 0.15 264);
  --dark: oklch(17% 0.012 285);
  --dark-line: oklch(98% 0 0 / 0.14);
  --dark-text: oklch(96% 0 0);
  --dark-muted: oklch(74% 0.008 285);
  --serif: 'Source Serif 4', Georgia, serif;
  --sans: 'Archivo', system-ui, sans-serif;
}

html { scroll-behavior: smooth; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
.wrap { width: min(1280px, calc(100% - 4rem)); margin: 0 auto; }
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.04; letter-spacing: -0.02em; }
h1 em, h2 em, h3 em { font-style: italic; color: var(--blue); }
p { text-wrap: pretty; }
img { max-width: 100%; }

.label {
  font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-muted);
}
.label--blue { color: var(--blue); }

.btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: var(--sans); font-size: 0.85rem; font-weight: 600;
  letter-spacing: 0.02em; text-decoration: none; cursor: pointer;
  padding: 0.85rem 1.6rem; border-radius: 2px; border: none;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.btn--ink { background: var(--ink); color: var(--paper); }
.btn--ink:hover { background: var(--blue); color: white; }
.btn--line { border: 1px solid var(--line-strong); color: var(--ink); background: transparent; }
.btn--line:hover { border-color: var(--blue); color: var(--blue); }
.btn--blue { background: var(--blue); color: white; }
.btn--blue:hover { background: var(--ink); }

/* ── NAV ── */
.site-nav { border-bottom: 1px solid var(--line); background: var(--paper); position: sticky; top: 0; z-index: 50; }
.nav-inner { display: flex; align-items: stretch; justify-content: space-between; height: 72px; }
.wordmark { display: flex; align-items: center; gap: 0.8rem; text-decoration: none; color: var(--ink); }
.wordmark img { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; }
.wordmark-text { font-family: var(--serif); font-size: 1.02rem; font-weight: 600; line-height: 1.1; }
.nav-pages { display: flex; align-items: stretch; list-style: none; }
.nav-pages a {
  display: flex; align-items: center; gap: 0.45rem; height: 100%;
  padding: 0 1.3rem; text-decoration: none; color: var(--ink-muted);
  font-size: 0.82rem; font-weight: 500; letter-spacing: 0.03em;
  border-left: 1px solid var(--line); transition: color 0.2s, background 0.2s;
}
.nav-pages li:last-child a { border-right: 1px solid var(--line); }
.nav-pages a span { font-size: 0.6rem; color: var(--ink-dim); font-weight: 600; }
.nav-pages a:hover { color: var(--ink); background: var(--paper2); }
.nav-pages a.active { color: var(--ink); box-shadow: inset 0 -2px 0 var(--blue); }
.nav-cta { display: flex; align-items: center; }

/* ── PAGE HEADER (interior pages) ── */
.page-head { padding: 5rem 0 0; }
.page-head-meta { display: flex; justify-content: space-between; align-items: center; padding-bottom: 1.4rem; border-bottom: 1px solid var(--line); }
.page-head h1 { font-size: clamp(2.8rem, 5.6vw, 5rem); padding: 2.75rem 0 2.5rem; max-width: 20ch; }
.page-head .lede { color: var(--ink-muted); font-size: 1.05rem; max-width: 56ch; padding-bottom: 3.25rem; margin-top: -1rem; }

/* ── HERO (home) ── */
.hero { padding: 5.5rem 0 0; }
.hero-meta { display: flex; justify-content: space-between; align-items: center; padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); }
.dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--blue); margin-right: 0.5rem; }
.hero h1 { font-size: clamp(3.2rem, 6.8vw, 6.6rem); padding: 3.5rem 0 3rem; max-width: 18ch; }
.hero-foot { display: grid; grid-template-columns: 1.2fr 1fr; gap: 3rem; align-items: end; padding-bottom: 3.5rem; }
.hero-foot p { color: var(--ink-muted); font-size: 1.05rem; max-width: 46ch; }
.hero-actions { display: flex; gap: 0.75rem; justify-content: flex-end; flex-wrap: wrap; }

/* ── STAT STRIP ── */
.stats { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 2rem 2rem 2rem 0; }
.stat + .stat { border-left: 1px solid var(--line); padding-left: 2rem; }
.stat-value { font-family: var(--serif); font-size: 2.6rem; line-height: 1; display: block; margin-bottom: 0.6rem; }
.stat-label { font-size: 0.8rem; color: var(--ink-muted); line-height: 1.5; display: block; max-width: 24ch; }

/* ── SECTION ── */
.section { padding: 6rem 0 0; }
.section:last-of-type { padding-bottom: 6rem; }
.section-head { display: flex; align-items: baseline; gap: 1.5rem; border-bottom: 1px solid var(--line-strong); padding-bottom: 1.25rem; }
.section-num { font-family: var(--serif); font-style: italic; font-size: 1.1rem; color: var(--blue); }
.section-head h2 { font-size: clamp(2rem, 3.8vw, 3.2rem); }
.section-head .label { margin-left: auto; }

/* ── OFFER GRID ── */
.offer-grid { display: grid; grid-template-columns: repeat(2, 1fr); background: var(--line); gap: 1px; border-bottom: 1px solid var(--line); }
.offer-grid--three { grid-template-columns: repeat(3, 1fr); }
.offer { background: var(--paper); padding: 2.25rem 2rem; display: flex; flex-direction: column; gap: 0.9rem; position: relative; }
.offer:hover { background: var(--paper2); }
.offer--featured { background: var(--blue-soft); }
.offer--featured:hover { background: var(--blue-soft); }
.offer-tag { position: absolute; top: 2.1rem; right: 2rem; font-size: 0.62rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blue); }
.offer h3 { font-size: 1.55rem; }
.offer-for { font-size: 0.82rem; color: var(--ink-muted); margin-top: -0.5rem; }
.offer-price { font-size: 1rem; }
.offer-price strong { font-family: var(--serif); font-size: 1.9rem; font-weight: 500; color: var(--blue); margin-right: 0.25rem; }
.offer ul { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; font-size: 0.88rem; color: var(--ink-muted); border-top: 1px solid var(--line); padding-top: 1rem; }
.offer ul li { position: relative; padding-left: 1.15rem; }
.offer ul li::before { content: ''; position: absolute; left: 0; top: 0.55em; width: 6px; height: 6px; background: var(--blue); }
.offer .btn { margin-top: auto; justify-content: center; }

/* ── TOOL GRID ── */
.tool-grid { display: grid; grid-template-columns: 1fr 1fr; background: var(--line); gap: 1px; border-bottom: 1px solid var(--line); }
.tool { background: var(--paper); padding: 2.5rem 2rem; display: flex; gap: 1.75rem; text-decoration: none; color: inherit; }
.tool:hover { background: var(--paper2); }
.tool-index { font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: var(--blue); }
.tool h3 { font-size: 1.55rem; margin: 0.35rem 0 0.6rem; }
.tool p { font-size: 0.9rem; color: var(--ink-muted); max-width: 44ch; }
.tool-go { margin-top: 1.1rem; font-size: 0.82rem; font-weight: 600; color: var(--blue); }

/* ── DARK BAND ── */
.dark-band { margin-top: 6rem; background: var(--dark); color: var(--dark-text); padding: 5.5rem 0; }
.dark-band .section-head { border-bottom-color: var(--dark-line); }
.dark-band .label { color: oklch(75% 0.01 285); }
.process-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.step { padding: 0 2.5rem 0.5rem 0; }
.step::before { content: ''; display: block; width: 34px; height: 2px; background: var(--blue-bright); margin-bottom: 1.6rem; }
.step + .step { border-left: 1px solid var(--dark-line); padding-left: 2.5rem; }
.step h3 { font-size: 1.6rem; margin: 0 0 0.7rem; letter-spacing: -0.015em; }
.step p { font-size: 0.9rem; color: var(--dark-muted); }

/* ── INSIGHT ROWS ── */
.insight-row {
  display: grid; grid-template-columns: 1fr auto auto; gap: 2rem; align-items: center;
  padding: 1.9rem 0; border-bottom: 1px solid var(--line); text-decoration: none; color: inherit;
}
.insight-row:hover h3 { color: var(--blue); }
.insight-row:hover .arrow { transform: translateX(4px); }
.insight-row h3 { font-size: 1.55rem; transition: color 0.2s; }
.insight-row .desc { grid-column: 1; margin-top: -1.4rem; padding-bottom: 0.4rem; color: var(--ink-muted); font-size: 0.9rem; max-width: 64ch; }
.insight-row .arrow { font-size: 1.3rem; color: var(--blue); transition: transform 0.2s; }

/* ── CTA BAND ── */
.cta-band { padding: 7rem 0; }
.cta-grid { display: grid; grid-template-columns: 1.25fr 1fr; gap: 4rem; align-items: center; }
.cta-band h2 { font-size: clamp(2.4rem, 4.4vw, 3.8rem); margin: 1.25rem 0 1.5rem; }
.cta-band .cta-copy p { color: var(--ink-muted); max-width: 50ch; margin-bottom: 2rem; }
.contact-meta { border-left: 1px solid var(--line-strong); padding-left: 3rem; display: flex; flex-direction: column; gap: 1.6rem; }
.contact-meta a { color: var(--ink); text-decoration: none; font-size: 1.02rem; }
.contact-meta a:hover { color: var(--blue); }
.guarantee { border: 1px solid var(--line); border-left: 2px solid var(--blue); padding: 1.1rem 1.3rem; font-size: 0.86rem; color: var(--ink-muted); max-width: 52ch; margin-bottom: 2rem; }
.guarantee strong { color: var(--ink); }

/* ── ACCORDIONS ── */
.acc { border-top: 1px solid var(--line-strong); }
.acc details { border-bottom: 1px solid var(--line); }
.acc summary {
  cursor: pointer; list-style: none; display: flex; justify-content: space-between;
  align-items: baseline; gap: 1.5rem; padding: 1.75rem 0;
}
.acc summary::-webkit-details-marker { display: none; }
.acc summary .acc-kicker { display: block; font-size: 0.65rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blue); margin-bottom: 0.4rem; }
.acc summary .acc-title { font-family: var(--serif); font-size: 1.45rem; font-weight: 500; letter-spacing: -0.015em; }
.acc summary .acc-plus { font-family: var(--serif); font-size: 1.5rem; color: var(--blue); transition: transform 0.2s; flex-shrink: 0; }
.acc details[open] .acc-plus { transform: rotate(45deg); }
.acc-body { padding: 0 0 2rem; }
.acc-body > p { color: var(--ink-muted); font-size: 0.95rem; max-width: 70ch; }
.timeline-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.timeline-cell { background: var(--paper); padding: 1.25rem; }
.timeline-cell strong { color: var(--blue); font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase; }
.timeline-cell p { color: var(--ink-muted); font-size: 0.86rem; margin-top: 0.4rem; }

/* ── FORMS ── */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.form-group { display: flex; flex-direction: column; gap: 0.45rem; }
.form-group--full { grid-column: 1 / -1; }
.form-label { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-muted); }
.form-input, .form-select, .form-textarea {
  font-family: var(--sans); font-size: 0.92rem; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line-strong);
  border-radius: 2px; padding: 0.8rem 0.95rem; width: 100%;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: 2px solid var(--blue); outline-offset: -1px; border-color: var(--blue); }
.form-textarea { min-height: 130px; resize: vertical; }
.form-note { background: var(--blue-soft); border: 1px solid oklch(50% 0.2 264 / 0.25); border-radius: 2px; padding: 0.9rem 1.1rem; font-size: 0.85rem; color: var(--ink); }
.form-note strong { color: var(--blue); }

/* ── FOOTER ── */
.site-foot { background: var(--dark); color: var(--dark-text); padding: 4.5rem 0 2.5rem; margin-top: 6rem; }
.site-foot--flush { margin-top: 0; }
.foot-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 3rem; padding-bottom: 3.5rem; border-bottom: 1px solid var(--dark-line); }
.foot-mark { font-family: var(--serif); font-size: clamp(2.6rem, 5vw, 4.2rem); line-height: 1; }
.foot-mark em { color: var(--blue-bright); }
.foot-cols { display: flex; gap: 5rem; }
.foot-col { display: flex; flex-direction: column; gap: 0.6rem; }
.foot-col .label { color: oklch(68% 0.008 285); margin-bottom: 0.4rem; }
.foot-col a { color: oklch(88% 0 0); text-decoration: none; font-size: 0.88rem; }
.foot-col a:hover { color: white; }
.foot-base { display: flex; justify-content: space-between; gap: 2rem; padding-top: 2rem; font-size: 0.78rem; color: oklch(62% 0.008 285); flex-wrap: wrap; }

/* ── WHATSAPP FLOAT ── */
.wa-float {
  position: fixed; right: 1.5rem; bottom: 1.5rem; z-index: 60;
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--blue); color: white;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 24px oklch(50% 0.2 264 / 0.4);
  transition: background 0.2s, transform 0.2s;
}
.wa-float:hover { background: var(--ink); transform: translateY(-2px); }

/* ── ARTICLE ── */
.article-wrap { width: min(760px, calc(100% - 3rem)); margin: 0 auto; padding: 4.5rem 0 5rem; }
.article-meta { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--blue); margin-bottom: 1.4rem; }
.article-wrap h1 { font-size: clamp(2.2rem, 4.4vw, 3.4rem); margin-bottom: 1.6rem; }
.article-intro { font-size: 1.12rem; color: var(--ink-muted); line-height: 1.75; margin-bottom: 3rem; padding-bottom: 3rem; border-bottom: 1px solid var(--line); }
.article-wrap h2 { font-size: 1.65rem; margin: 2.75rem 0 1rem; }
.article-wrap p { color: var(--ink-muted); margin-bottom: 1.2rem; line-height: 1.8; }
.article-wrap p strong { color: var(--ink); }
.article-wrap ul, .article-wrap ol { margin: 0 0 1.5rem 1.25rem; color: var(--ink-muted); line-height: 1.8; display: flex; flex-direction: column; gap: 0.6rem; }
.article-wrap li strong { color: var(--ink); }
.highlight-box { border-left: 2px solid var(--blue); background: var(--blue-soft); padding: 1.5rem 1.75rem; margin: 2.5rem 0; }
.highlight-box p { font-family: var(--serif); font-size: 1.18rem; font-style: italic; color: var(--ink); margin: 0; line-height: 1.55; }
.cta-box { border: 1px solid var(--line-strong); padding: 2.25rem; margin-top: 3.5rem; text-align: center; }
.cta-box h3 { font-size: 1.6rem; margin-bottom: 0.6rem; }
.cta-box p { margin-bottom: 1.5rem; }
.phase-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin: 2rem 0; }
.phase-card { background: var(--paper); padding: 1.5rem 1.4rem; }
.phase-card .phase-label { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blue); margin-bottom: 0.5rem; }
.phase-card h4 { font-size: 1.2rem; margin-bottom: 0.5rem; }
.phase-card p { font-size: 0.86rem; margin: 0; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .nav-pages a { padding: 0 0.9rem; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat, .stat + .stat { border-left: none; padding-left: 0; border-top: 1px solid var(--line); }
  .process-grid { grid-template-columns: 1fr; }
  .step + .step { border-left: none; padding-left: 0; border-top: 1px solid var(--dark-line); padding-top: 2rem; }
  .offer-grid--three { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .wrap { width: calc(100% - 2.5rem); }
  .nav-pages { display: none; }
  .hero-foot, .cta-grid { grid-template-columns: 1fr; gap: 2rem; }
  .hero-actions { justify-content: flex-start; }
  .offer-grid, .tool-grid { grid-template-columns: 1fr; }
  .contact-meta { border-left: none; padding-left: 0; border-top: 1px solid var(--line-strong); padding-top: 2rem; }
  .form-grid { grid-template-columns: 1fr; }
  .foot-top { flex-direction: column; }
  .foot-cols { gap: 3rem; }
  .insight-row { grid-template-columns: 1fr auto; }
  .insight-row .label { display: none; }
  .phase-grid { grid-template-columns: 1fr; }
}

/* ── POLISH ── */
*:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; border-radius: 1px; }
::selection { background: var(--blue); color: #fff; }
.offer, .tool, .insight-row, .timeline-cell, .phase-card { transition: background 0.2s ease; }
.btn { transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease; }
.btn:active { transform: translateY(1px); }
.wordmark img { transition: transform 0.3s ease; }
.wordmark:hover img { transform: rotate(-6deg); }
img { -webkit-user-drag: none; user-select: none; }

/* EC dollars / price note */
.price-note {
  display: flex; align-items: center; gap: 0.7rem;
  border: 1px solid var(--line); border-left: 2px solid var(--blue);
  background: var(--blue-soft); padding: 0.85rem 1.15rem;
  font-size: 0.84rem; color: var(--ink-muted); border-radius: 2px;
}
.price-note strong { color: var(--ink); font-weight: 600; }
.price-note .pn-tag { font-family: var(--sans); font-size: 0.62rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--blue); border: 1px solid var(--blue); border-radius: 2px; padding: 0.2rem 0.45rem; flex-shrink: 0; }
