:root { --r: 0; }

.d4 { transition-delay: .4s; }

/* Page header */
.wwm-header { padding: 160px 0 0; border-bottom: 1px solid var(--rule); position: relative; overflow: hidden; }
.wwm-header-bg {
  position: absolute; inset: 0; z-index: 0;
  background-image: linear-gradient(var(--rule-2) 1px, transparent 1px), linear-gradient(90deg, var(--rule-2) 1px, transparent 1px);
  background-size: 80px 80px;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 25%, #000 75%, transparent 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 25%, #000 75%, transparent 100%);
}
.wwm-header-inner { position: relative; z-index: 1; }
.wwm-eyebrow {
  font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--accent); display: flex; align-items: center; gap: 10px;
  margin-bottom: 22px; opacity: 0; animation: fadeUp .7s var(--ease) .1s forwards;
}
.wwm-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--accent); }
.wwm-h {
  font-family: var(--jakarta); font-weight: 800;
  font-size: clamp(44px, 6.5vw, 92px);
  line-height: .94; letter-spacing: -.04em; max-width: 14ch;
}
.wwm-h .line { display: block; overflow: hidden; }
.wwm-h .line span { display: block; opacity: 0; transform: translateY(100%); animation: slideUp .9s var(--ease) forwards; }
.wwm-h .line:nth-child(1) span { animation-delay: .2s; }
.wwm-h .line:nth-child(2) span { animation-delay: .32s; }
.wwm-h .line:nth-child(3) span { animation-delay: .44s; }
.wwm-h .blue { color: var(--accent); }

.wwm-header-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-top: 64px; border-top: 1px solid var(--rule); }
.wwm-header-col { padding: 36px 0; }
.wwm-header-col:first-child { border-right: 1px solid var(--rule); padding-right: 56px; }
.wwm-header-col:last-child { padding-left: 56px; }
.wwm-sub { font-size: 18px; line-height: 1.7; color: var(--ink-2); opacity: 0; animation: fadeUp .8s var(--ease) .55s forwards; }
.wwm-sub strong { color: var(--ink); font-weight: 600; }

.ladder { opacity: 0; animation: fadeUp .8s var(--ease) .6s forwards; }
.ladder-label { font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 16px; }
.ladder-track { display: flex; flex-direction: column; gap: 2px; }
.ladder-rung {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: var(--off); border: 1px solid var(--rule);
  transition: all .25s; cursor: default;
}
.ladder-rung:hover { background: var(--accent-2); border-color: var(--accent); }
.ladder-rung .lr-name { font-family: var(--jakarta); font-size: 12px; font-weight: 700; letter-spacing: -.01em; }
.ladder-rung .lr-price { font-family: var(--jakarta); font-size: 13px; font-weight: 800; color: var(--accent); }
.ladder-rung.gateway { border-left: 3px solid var(--accent); }
.ladder-arrow { display: flex; justify-content: center; padding: 2px 0; }
.ladder-arrow span { font-size: 11px; color: var(--ink-4); }

/* Offers */
.offers { padding: 100px 0; }

.tier-marker { display: flex; align-items: center; gap: 16px; margin-bottom: 36px; }
.tier-num {
  font-family: var(--jakarta); font-weight: 800; font-size: 11px;
  letter-spacing: .16em; text-transform: uppercase;
  width: 36px; height: 36px; border: 1.5px solid var(--rule);
  display: flex; align-items: center; justify-content: center; color: var(--ink-4);
  flex: none;
}
.tier-num.accent { border-color: var(--accent); color: var(--accent); background: var(--accent-2); }
.tier-line { flex: 1; height: 1px; background: var(--rule); }
.tier-tag { font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-4); white-space: nowrap; }
.tier-tag.accent { color: var(--accent); }

.offer-block { margin-bottom: 80px; padding-bottom: 80px; border-bottom: 1px solid var(--rule); }
.offer-block:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }

.offer-layout { display: grid; grid-template-columns: 1fr 380px; gap: 64px; align-items: start; }
.offer-aside { position: sticky; top: 96px; }

.offer-head { margin-bottom: 28px; }
.offer-name {
  font-family: var(--jakarta); font-weight: 800;
  font-size: clamp(32px, 4.5vw, 56px);
  letter-spacing: -.035em; line-height: 1;
  margin: 0 0 10px;
}
.offer-mandatory {
  font-family: var(--jakarta); font-size: 11px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--accent);
  margin: 0; max-width: 52ch; line-height: 1.45;
}
.offer-hook {
  font-size: 20px; color: var(--ink-3); line-height: 1.55;
  max-width: 46ch; margin: 0 0 36px; font-weight: 300;
}
.offer-hook strong { color: var(--ink-2); font-weight: 500; }

.offer-body { font-size: 17px; line-height: 1.75; color: var(--ink-2); margin-bottom: 36px; }
.offer-body p { margin-bottom: 18px; }
.offer-body p:last-child { margin-bottom: 0; }
.offer-body strong { color: var(--ink); font-weight: 600; }

.offer-pull {
  border-left: 3px solid var(--accent);
  padding: 16px 0 16px 24px;
  font-family: var(--jakarta); font-size: 19px; font-weight: 700;
  letter-spacing: -.02em; color: var(--ink); line-height: 1.4;
  margin: 32px 0;
}

.offer-section-head {
  font-family: var(--jakarta); font-size: 10px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase; color: var(--ink-4);
  margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: space-between;
}
.offer-list { list-style: none; margin-bottom: 32px; }
.offer-list li {
  font-size: 15px; color: var(--ink-2); padding: 12px 0;
  border-bottom: 1px solid var(--rule-2); display: flex; gap: 14px; align-items: baseline;
}
.offer-list li:last-child { border-bottom: none; }
.offer-list li::before { content: '→'; color: var(--accent); font-family: var(--jakarta); font-weight: 700; flex: none; font-size: 12px; padding-top: 1px; }
.offer-list.check li::before { content: '✓'; }

.deliver-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: var(--rule); margin-bottom: 32px; }
.deliver-col { background: var(--white); padding: 24px 28px; }
.deliver-col h4 { font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 14px; }
.deliver-col h4.blue { color: var(--accent); }
.deliver-col ul { list-style: none; }
.deliver-col ul li { font-size: 14px; color: var(--ink-2); padding: 9px 0; border-bottom: 1px solid var(--rule-2); display: flex; gap: 11px; align-items: baseline; }
.deliver-col ul li:last-child { border-bottom: none; padding-bottom: 0; }
.deliver-col ul li::before { content: '—'; color: var(--accent); flex: none; font-family: var(--jakarta); font-weight: 700; }

.price-card { border: 1px solid var(--rule); overflow: hidden; margin-bottom: 2px; }
.price-card-head { background: var(--off); padding: 18px 24px; border-bottom: 1px solid var(--rule); display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.price-card-head .pch-label { font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-4); }
.price-card-head .pch-status { font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 4px 9px; border: 1px solid var(--rule); color: var(--ink-3); }
.price-card-head .pch-status.open { color: #22C55E; border-color: #22C55E; background: #F0FDF4; }
.price-card-head .pch-status.limited { color: var(--accent); border-color: var(--accent); background: var(--accent-2); }
.price-card-body { padding: 24px; }
.price-big { font-family: var(--jakarta); font-weight: 800; font-size: 48px; letter-spacing: -.04em; line-height: 1; margin-bottom: 4px; }
.price-sub { font-size: 13px; color: var(--ink-3); margin-bottom: 20px; }
.price-rows { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--rule); padding-top: 16px; margin-bottom: 20px; }
.price-row { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 0; border-bottom: 1px solid var(--rule-2); gap: 12px; }
.price-row:last-child { border-bottom: none; }
.price-row .prk { font-family: var(--jakarta); font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-4); }
.price-row .prv { font-size: 14px; color: var(--ink-2); text-align: right; }
.price-row .prv.accent { color: var(--accent); font-weight: 700; font-family: var(--jakarta); }
.price-note { background: var(--off); border: 1px solid var(--rule); border-top: none; padding: 16px 20px; }
.price-note p { font-size: 13px; color: var(--ink-3); line-height: 1.55; }

.apply-btn {
  width: 100%; font-family: var(--jakarta); font-size: 12px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; padding: 15px 20px;
  background: var(--ink); color: var(--white); border: none;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  cursor: pointer; transition: all .25s var(--ease);
}
.apply-btn svg { transition: transform .25s; }
.apply-btn:hover { background: var(--accent); color: var(--white); }
.apply-btn:hover svg { transform: translateX(4px); }
.apply-btn.ghost { background: transparent; color: var(--ink); border: 1px solid var(--rule); margin-top: 8px; }
.apply-btn.ghost:hover { border-color: var(--ink); background: transparent; color: var(--ink); }

.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: var(--rule); margin-top: 32px; }
.fit-col { background: var(--white); padding: 22px 26px; }
.fit-col-head { font-family: var(--jakarta); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 14px; }
.fit-col-head.blue { color: var(--accent); }
.fit-list { list-style: none; }
.fit-list li { font-size: 14px; color: var(--ink-2); padding: 9px 0; border-bottom: 1px solid var(--rule-2); display: flex; gap: 11px; align-items: baseline; }
.fit-list li:last-child { border-bottom: none; padding-bottom: 0; }
.fit-list.yes li::before { content: '✓'; color: #22C55E; font-family: var(--jakarta); font-weight: 700; flex: none; font-size: 12px; }
.fit-list.no li::before { content: '×'; color: var(--ink-4); font-family: var(--jakarta); font-weight: 700; flex: none; }

.steps { display: flex; flex-direction: column; gap: 0; margin-bottom: 32px; }
.step { display: flex; gap: 20px; padding: 20px 0; border-bottom: 1px solid var(--rule-2); align-items: flex-start; }
.step:last-child { border-bottom: none; }
.step-n {
  font-family: var(--jakarta); font-size: 11px; font-weight: 700;
  width: 32px; height: 32px; border: 1.5px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-4); flex: none; margin-top: 2px;
}
.step-n.accent { border-color: var(--accent); color: var(--accent); background: var(--accent-2); }
.step-title { font-family: var(--jakarta); font-size: 14px; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
.step-desc { font-size: 14px; color: var(--ink-3); line-height: 1.5; }

/* Comparison */
.comparison { padding: 0 0 100px; border-top: 1px solid var(--rule); padding-top: 100px; }
.comp-title { font-family: var(--jakarta); font-weight: 800; font-size: clamp(28px, 4vw, 44px); letter-spacing: -.03em; margin-bottom: 8px; }
.comp-sub { font-size: 16px; color: var(--ink-3); margin-bottom: 48px; }
.comp-table { width: 100%; border-collapse: collapse; border: 1px solid var(--rule); }
.comp-table th {
  font-family: var(--jakarta); font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; padding: 18px 20px; text-align: left;
  background: var(--off); border-bottom: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
}
.comp-table th:first-child { color: var(--ink-4); width: 220px; }
.comp-table th.featured { background: var(--accent); color: var(--white); }
.comp-table td {
  padding: 16px 20px; border-bottom: 1px solid var(--rule-2);
  border-right: 1px solid var(--rule); font-size: 14px; color: var(--ink-2);
  vertical-align: top;
}
.comp-table td:first-child { font-family: var(--jakarta); font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-4); background: var(--off); }
.comp-table td.featured { background: var(--accent-2); }
.comp-table tr:last-child td { border-bottom: none; }
.comp-table .check-y { color: #22C55E; font-weight: 700; }
.comp-table .check-n { color: var(--ink-4); }
.comp-table .check-p { color: var(--accent); font-weight: 700; font-family: var(--jakarta); font-size: 12px; }

/* Pathway */
.pathway { background: var(--off); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: 80px 0; }
.pathway-inner { max-width: 900px; margin: 0 auto; }
.pathway-title { font-family: var(--jakarta); font-weight: 800; font-size: clamp(24px, 3.5vw, 38px); letter-spacing: -.03em; margin-bottom: 8px; text-align: center; }
.pathway-sub { font-size: 15px; color: var(--ink-3); text-align: center; margin-bottom: 56px; }
.pathway-steps { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr; align-items: center; gap: 0; }
.pathway-node { text-align: center; padding: 0 8px; }
.pn-box {
  border: 1px solid var(--rule); background: var(--white); padding: 20px 16px;
  margin-bottom: 12px; transition: all .3s;
}
.pn-box:hover { border-color: var(--accent); background: var(--accent-2); }
.pn-price { font-family: var(--jakarta); font-weight: 800; font-size: 20px; letter-spacing: -.02em; color: var(--accent); }
.pn-name { font-family: var(--jakarta); font-weight: 700; font-size: 12px; letter-spacing: -.01em; margin-top: 4px; }
.pn-desc { font-size: 11px; color: var(--ink-3); line-height: 1.4; margin-top: 4px; }
.pathway-arrow { color: var(--ink-4); font-size: 18px; text-align: center; padding: 0 4px; flex: none; }
.pathway-note { text-align: center; margin-top: 36px; font-family: var(--jakarta); font-size: 12px; font-weight: 600; letter-spacing: .04em; color: var(--ink-4); }

/* CTA */
.wwm-cta { background: var(--ink); color: var(--white); padding: 80px 0; }
.wwm-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 40px; flex-wrap: wrap; }
.wwm-cta-left h2 { font-family: var(--jakarta); font-weight: 800; font-size: clamp(26px, 4vw, 46px); letter-spacing: -.03em; line-height: 1.06; max-width: 20ch; }
.wwm-cta-left h2 em { font-style: normal; color: #6666FF; }
.wwm-cta-right { display: flex; flex-direction: column; gap: 14px; align-items: flex-end; }
.wwm-cta-right p { font-size: 15px; color: rgba(255,255,255,.55); max-width: 34ch; text-align: right; line-height: 1.6; }
.btn-white {
  font-family: var(--jakarta); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  padding: 14px 26px; background: var(--white); color: var(--ink);
  display: inline-flex; align-items: center; gap: 10px; transition: all .25s; border: 1px solid var(--white);
}
.btn-white:hover { background: #6666FF; border-color: #6666FF; color: var(--white); }
.btn-white svg { transition: transform .25s; }
.btn-white:hover svg { transform: translateX(4px); }

.label-fire { color: var(--fire); }
.btn-fire {
  font-family: var(--jakarta); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  padding: 14px 26px; background: var(--fire); color: var(--white); border: 1px solid var(--fire);
  display: inline-flex; align-items: center; gap: 10px; transition: all .25s; white-space: nowrap;
}
.btn-fire:hover { background: #FF6B33; border-color: #FF6B33; }
.btn-fire svg { transition: transform .25s; }
.btn-fire:hover svg { transform: translateX(4px); }

.wwm-ignition {
  padding: 72px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  background: linear-gradient(135deg, var(--fire-2) 0%, var(--white) 55%);
}
.wwm-ignition-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 40px;
}
.wwm-ignition-h {
  font-family: var(--jakarta); font-size: clamp(28px, 4vw, 40px); font-weight: 800;
  letter-spacing: -.03em; line-height: 1.05; margin: 12px 0 14px;
}
.wwm-ignition-h .fire { color: var(--fire); }
.wwm-ignition-p { font-size: 15px; color: var(--ink-2); line-height: 1.65; max-width: 54ch; }

@media (max-width: 1020px) {
  .offer-layout { grid-template-columns: 1fr; }
  .offer-aside { position: static; }
  .pathway-steps { grid-template-columns: 1fr; gap: 12px; }
  .pathway-arrow { transform: rotate(90deg); }
}
@media (max-width: 960px) {
  .wwm-header-bottom { grid-template-columns: 1fr; }
  .wwm-header-col:first-child { border-right: none; border-bottom: 1px solid var(--rule); padding-right: 0; }
  .wwm-header-col:last-child { padding-left: 0; }
  .deliver-grid, .fit-grid { grid-template-columns: 1fr; }
  .wwm-cta-inner { flex-direction: column; }
  .wwm-cta-right { align-items: flex-start; }
  .wwm-cta-right p { text-align: left; }
  .wwm-ignition-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 600px) {
  .comp-table th:nth-child(3), .comp-table td:nth-child(3) { display: none; }
}
