/* ═══════════════════════════════════════════
   LANDING PAGE SECTIONS
═══════════════════════════════════════════ */
.lp-section {
  border-top: 1px solid var(--rule);
  padding: 72px 24px;
}
.lp-inner { max-width: var(--max); margin: 0 auto; }

.lp-label {
  font-family: 'DM Mono', monospace; font-size: 11px; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase; color: var(--ink-dim);
  margin-bottom: 20px; display: flex; align-items: center; gap: 10px;
}
.lp-label::after { content:''; flex:1; height:1px; background:var(--rule); }

.lp-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(28px, 3.5vw, 44px); font-weight: 700;
  line-height: 1.15; letter-spacing: -.01em; margin-bottom: 16px;
}
.lp-sub {
  font-size: 17px; color: var(--ink-mid); font-weight: 300;
  max-width: 600px; margin-bottom: 52px;
}

/* About */
.about-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.about-desc { font-size: 18px; color: var(--ink-mid); font-weight: 300; line-height: 1.75; margin-bottom: 32px; }
.about-pills { display: flex; gap: 10px; flex-wrap: wrap; }
.about-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 14px; border-radius: 20px; border: 1.5px solid var(--rule);
  font-family: 'DM Mono', monospace; font-size: 12px; font-weight: 500;
  letter-spacing: .05em; text-transform: uppercase; color: var(--ink-mid);
}
.about-pill-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* Mechanic visual */
.mechanic-visual {
  background: #fff;
  border: 1.5px solid var(--rule);
  border-radius: 16px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mv-step {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mv-label {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mv-num {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--ink); color: #fff;
  font-family: 'DM Mono', monospace; font-size: 11px; font-weight: 500;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.mv-label-text {
  font-family: 'DM Mono', monospace; font-size: 11px; font-weight: 500;
  letter-spacing: .08em; text-transform: uppercase; color: var(--ink-dim);
}
.mv-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.mv-card {
  border-radius: 5px;
  background: #efefe6;
  padding: 10px 4px;
  text-align: center;
  font-family: 'Franklin Gothic Medium','Arial Narrow',Arial,sans-serif;
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: #1a1a1b;
  transition: background .2s, color .2s;
}
.mv-card.sel  { background: #5a594e; color: #fff; }
.mv-card.y    { background: var(--c0); }
.mv-card.g    { background: var(--c1); }
.mv-card.b    { background: var(--c2); }
.mv-card.p    { background: var(--c3); }
.mv-card.dim  { background: #efefe6; opacity: .4; }

.mv-divider   { border: none; border-top: 1px solid var(--rule); }

.mv-solved-rows { display: flex; flex-direction: column; gap: 6px; }
.mv-solved-row {
  border-radius: 6px;
  padding: 10px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mv-solved-name { font-family:'DM Mono',monospace; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.mv-solved-words { font-size:11px; letter-spacing:.03em; text-transform:uppercase; opacity:.7; }

/* animate the "selecting" step on hover/load */
@keyframes mvPulse {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-2px); }
}
.mv-card.sel { animation: mvPulse 1.6s ease infinite; }

@media(max-width:900px) {
  .about-layout { grid-template-columns: 1fr; gap: 40px; }
}

/* HTP steps */
.htp-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; counter-reset:step; }
.htp-step { position:relative; padding-top:56px; }
.htp-step::before {
  content:counter(step); counter-increment:step;
  position:absolute; top:0; left:0;
  width:40px; height:40px; border-radius:50%;
  background:var(--ink); color:var(--paper);
  font-family:'Playfair Display',Georgia,serif; font-size:18px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}
.htp-step-title { font-family:'Playfair Display',Georgia,serif; font-size:18px; font-weight:700; margin-bottom:10px; }
.htp-step-text { font-size:15px; color:var(--ink-mid); font-weight:300; line-height:1.65; }
.diff-row { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:52px; }
.diff-chip { border-radius:8px; padding:20px 16px; display:flex; flex-direction:column; gap:8px; }
.diff-chip-label { font-family:'DM Mono',monospace; font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.diff-chip-desc { font-size:13px; font-weight:300; line-height:1.5; }
@media(max-width:768px) {
  .htp-steps { grid-template-columns:repeat(2,1fr); }
  .diff-row { grid-template-columns:repeat(2,1fr); }
}
/* Tips */
.tips-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.tip-card { border:1.5px solid var(--rule); border-radius:10px; padding:28px 24px; transition:border-color .2s, box-shadow .2s; }
.tip-card:hover { border-color:var(--ink-dim); box-shadow:0 4px 20px rgba(0,0,0,.07); }
.tip-icon { width:40px; height:40px; border-radius:8px; background:var(--ink); color:var(--paper); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.tip-icon svg { width:20px; height:20px; }
.tip-title { font-family:'Playfair Display',Georgia,serif; font-size:18px; font-weight:700; margin-bottom:10px; }
.tip-text { font-size:15px; color:var(--ink-mid); font-weight:300; line-height:1.65; }
@media(max-width:768px) {
  .tips-grid { grid-template-columns:repeat(1,1fr) }
}
/* FAQ */
.faq-layout { display:grid; grid-template-columns:1fr 2fr; gap:64px; align-items:start; }
@media(max-width:768px) {
  .faq-layout { grid-template-columns:1fr; }
}
.faq-sidebar p { font-size:15px; color:var(--ink-mid); font-weight:300; line-height:1.65; margin-bottom:24px; }
.faq-cta {
  display:inline-flex; align-items:center; gap:6px;
  font-family:'DM Mono',monospace; font-size:12px; font-weight:500;
  letter-spacing:.06em; text-transform:uppercase; color:var(--ink);
  text-decoration:none; border-bottom:1px solid var(--ink); padding-bottom:2px; transition:opacity .15s;
}
.faq-cta:hover { opacity:.6; }
.faq-list { display:flex; flex-direction:column; }
.faq-item { border-top:1px solid var(--rule); }
.faq-item:last-child { border-bottom:1px solid var(--rule); }
.faq-q {
  width:100%; background:transparent; border:none; padding:22px 0;
  display:flex; justify-content:space-between; align-items:center; cursor:pointer; text-align:left; gap:16px;
}
.faq-q-text { font-family:'Playfair Display',Georgia,serif; font-size:17px; font-weight:600; color:var(--ink); line-height:1.3; }
.faq-chevron {
  flex-shrink:0; width:22px; height:22px; border-radius:50%; border:1.5px solid var(--rule);
  display:flex; align-items:center; justify-content:center; transition:background .2s, border-color .2s;
}
.faq-chevron svg { width:12px; height:12px; transition:transform .25s; }
.faq-item.open .faq-chevron { background:var(--ink); border-color:var(--ink); }
.faq-item.open .faq-chevron svg { stroke:var(--paper); transform:rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a-inner { padding:0 0 24px; font-size:15px; color:var(--ink-mid); font-weight:300; line-height:1.7; }

/* CTA band */
.cta-band { background:var(--ink); padding:80px 24px; }
.cta-band-inner {
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:48px;
}
@media(max-width:768px) {
  .cta-band-inner { grid-template-columns:1fr; }
}
.cta-band-title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(26px,3vw,40px); font-weight:700; color:var(--paper); line-height:1.2; margin-bottom:12px; }
.cta-band-sub { font-size:16px; color:rgba(250,248,243,.6); font-weight:300; }
.cta-band-btns { display:flex; gap:12px; flex-shrink:0; flex-wrap:wrap; }
.btn-white {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--paper); color:var(--ink); padding:14px 28px; border-radius:6px;
  font-family:'DM Mono',monospace; font-size:13px; font-weight:500; letter-spacing:.06em;
  text-transform:uppercase; text-decoration:none; transition:background .15s; white-space:nowrap;
}
.btn-white:hover { background:#ede9e3; }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:var(--paper); padding:14px 28px; border-radius:6px;
  border:1.5px solid rgba(250,248,243,.3); font-family:'DM Mono',monospace; font-size:13px;
  font-weight:500; letter-spacing:.06em; text-transform:uppercase; text-decoration:none;
  transition:border-color .15s, background .15s; white-space:nowrap;
}
.btn-ghost:hover { border-color:rgba(250,248,243,.7); background:rgba(250,248,243,.06); }

/* Footer */
footer { border-top:1px solid var(--rule); padding:48px 24px 36px; background:var(--paper); }
.footer-inner {
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px;
}
@media(max-width:768px) {
  .footer-inner { grid-template-columns:2fr 1fr; }
}
.footer-logo { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.footer-squares { display:grid; grid-template-columns:repeat(2,10px); grid-template-rows:repeat(2,10px); gap:2px; }
.footer-squares span { border-radius:2px; display:block; }
.footer-squares span:nth-child(1){background:var(--c0);}
.footer-squares span:nth-child(2){background:var(--c1);}
.footer-squares span:nth-child(3){background:var(--c2);}
.footer-squares span:nth-child(4){background:var(--c3);}
.footer-wordmark { font-family:'Playfair Display',Georgia,serif; font-size:18px; font-weight:700; letter-spacing:.04em; }
.footer-desc { font-size:14px; color:var(--ink-dim); font-weight:300; line-height:1.65; max-width:280px; }
.footer-col-title { font-family:'DM Mono',monospace; font-size:11px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); margin-bottom:16px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:14px; color:var(--ink-dim); text-decoration:none; font-weight:300; transition:color .15s; }
.footer-links a:hover { color:var(--ink); }
.footer-bottom {
  border-top:1px solid var(--rule); padding-top:28px;
  display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap;
  max-width:var(--max); margin:0 auto;
}
.footer-copy { font-family:'DM Mono',monospace; font-size:12px; color:var(--ink-dim); letter-spacing:.04em; }
.footer-legal { display:flex; gap:24px; }
.footer-legal a { font-family:'DM Mono',monospace; font-size:12px; color:var(--ink-dim); text-decoration:none; letter-spacing:.04em; transition:color .15s; }
.footer-legal a:hover { color:var(--ink); }

/* Shared helpers */
.bg-y{background:var(--c0);} .bg-g{background:var(--c1);} .bg-b{background:var(--c2);} .bg-p{background:var(--c3);}
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity:1; transform:none; }