/* Timeheat landing — self-contained, no build step. */
* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font-family: 'Archivo', sans-serif; color: #1c1917; background: #fff;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; }
/* machine values only (time-zone codes, hex, spec) — never times or labels */
.mono { font-family: 'JetBrains Mono', monospace; }

.wrap { max-width: 1180px; margin: 0 auto; padding-left: 32px; padding-right: 32px; }
.band { padding-top: 84px; padding-bottom: 84px; }
.band-alt { background: #faf9f7; }
.band-hair { border-top: 1px solid #e7e5e4; border-bottom: 1px solid #f0eeec; }
.band-top { border-top: 1px solid #e7e5e4; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 3px; font-weight: 600; font-size: 13px; padding: 9px 16px;
  border: 1px solid transparent; cursor: pointer; transition: opacity .15s, background .15s;
}
.btn-lg { font-size: 15px; padding: 14px 26px; }
.btn-rose { background: #e11d48; color: #fff; }
.btn-rose:hover { background: #c81041; }
.btn-outline { border-color: #1c1917; color: #1c1917; background: transparent; }
.btn-outline:hover { background: #1c1917; color: #fff; }
.btn-white { background: #fff; color: #1c1917; }
.btn-white:hover { opacity: .9; }
.btn.block { width: 100%; }

/* ---------- nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 20;
  background: rgba(255, 255, 255, 0.86); backdrop-filter: blur(10px);
  border-bottom: 1px solid #f0eeec;
}
.nav-inner {
  max-width: 1180px; margin: 0 auto; padding: 15px 32px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: 9px; }
.mark { width: 18px; height: 18px; background: #e11d48; flex: none; }
.mark.sm { width: 16px; height: 16px; }
.wordmark { font-size: 13px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; }
.nav-links { display: flex; gap: 30px; }
.nav-links a { font-size: 13px; font-weight: 500; color: #57534e; }
.nav-links a:hover { color: #1c1917; }
.nav-cta { display: flex; align-items: center; gap: 12px; }
.nav-cta .link { font-size: 13px; font-weight: 500; color: #1c1917; }

/* ---------- typography ---------- */
.display { margin: 0 0 22px; font-size: 60px; line-height: 1.0; font-weight: 700; letter-spacing: -0.04em; }
.lead { margin: 0 0 32px; font-size: 18px; line-height: 1.55; color: #57534e; max-width: 440px; }
.lead.center { max-width: 540px; margin-left: auto; margin-right: auto; text-align: center; }
.lead.muted { color: #9a928b; }
.h2 { margin: 0 0 44px; font-size: 38px; font-weight: 700; letter-spacing: -0.03em; }
.h2.narrow { max-width: 640px; }
.h2.light { color: #f5f3f1; }
.h2.xl { font-size: 46px; letter-spacing: -0.035em; }
.eyebrow { font-size: 12px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: #a8a29e; margin-bottom: 10px; }
.eyebrow-dot { display: flex; align-items: center; gap: 12px; color: #1c1917; }
.eyebrow-dot::before { content: ""; width: 9px; height: 9px; background: #e11d48; flex: none; }

/* ---------- hero ---------- */
.hero { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding-top: 96px; padding-bottom: 80px; }
.hero-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.hero-art { position: relative; }
.hero-art-bg { position: absolute; inset: -28px -28px -28px -10px; background: #faf9f7; border-radius: 10px; }
.hero-art-fg { position: relative; }

/* ---------- cards / grids ---------- */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.card { border: 1px solid #e7e5e4; border-radius: 6px; padding: 28px; background: #fff; }
.card-title { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 9px; }
.card-title.sm { font-size: 16px; margin-bottom: 7px; }
.card-body { margin: 0; font-size: 14px; line-height: 1.6; color: #78716c; }
.card-body.sm { font-size: 13.5px; line-height: 1.55; }
.step-no {
  display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px;
  background: #e11d48; color: #fff; font-size: 13px;
  font-weight: 700; border-radius: 3px; margin-bottom: 18px;
}
.case-title { font-size: 20px; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 10px; }

/* ---------- features ---------- */
.feature-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: #e7e5e4; border: 1px solid #e7e5e4; border-radius: 6px; overflow: hidden;
}
.feature { background: #fff; padding: 28px; }
.feature-icon { height: 30px; display: flex; align-items: center; margin-bottom: 16px; }
.bars { display: flex; align-items: flex-end; gap: 3px; height: 24px; }
.bars i { width: 8px; border-radius: 2px; background: #e11d48; display: block; }
.swatch-maybe { width: 40px; height: 20px; border-radius: 3px; border: 1px solid #f9a8b8; background: repeating-linear-gradient(45deg, rgba(225,29,72,0.6) 0 3px, #fff1f2 3px 6px); }
.toggle { width: 36px; height: 20px; border-radius: 999px; background: #e11d48; position: relative; }
.toggle span { position: absolute; top: 2px; left: 18px; width: 16px; height: 16px; border-radius: 50%; background: #fff; }
.avatars { display: flex; }
.avatars b { width: 22px; height: 22px; border-radius: 50%; background: #fde4e8; border: 2px solid #fff; margin-left: -7px; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: #9f1239; }
.avatars b:first-child { margin-left: 0; }
.mono.strong { font-size: 13px; font-weight: 700; color: #1c1917; }
.theme-pair { display: flex; gap: 6px; }
.theme-pair span { width: 15px; height: 15px; border-radius: 2px; display: block; }
.theme-pair .light { background: #fff; border: 1px solid #e7e5e4; }
.theme-pair .dark { background: #1a1715; }

/* ---------- dark showcase ---------- */
.dark { background: #1a1715; }
.dark-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding-top: 88px; padding-bottom: 88px; }
.ticks { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.ticks li { display: flex; align-items: flex-start; gap: 11px; font-size: 14.5px; line-height: 1.45; color: #d9d3ce; }
.tick { width: 15px; height: 15px; background: #e11d48; border-radius: 2px; flex: none; margin-top: 2px; }

/* ---------- pricing ---------- */
.pricing { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 980px; margin: 0 auto; }
.price { display: flex; flex-direction: column; position: relative; padding: 32px; }
.price-tag { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #a8a29e; margin-bottom: 18px; }
.price-amount { display: flex; align-items: baseline; gap: 8px; margin-bottom: 10px; }
.price-amount .num { font-size: 44px; font-weight: 700; letter-spacing: -0.03em; }
.price-amount .unit { font-size: 16px; font-weight: 600; color: #57534e; }
.price .card-body { margin-bottom: 24px; }
.price .btn { margin-top: auto; }
.price-featured { border-color: #1c1917; }
.ribbon {
  position: absolute; top: 0; right: 0; background: #e11d48; color: #fff;
  font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 10px; border-bottom-left-radius: 6px; border-top-right-radius: 5px;
}

/* ---------- faq ---------- */
.narrow-wrap { max-width: 820px; }
.faq { border-top: 1px solid #e7e5e4; }
.faq details { border-bottom: 1px solid #e7e5e4; }
.faq summary {
  list-style: none; cursor: pointer; padding: 22px 0; display: flex;
  align-items: baseline; justify-content: space-between; gap: 20px;
  font-size: 17px; font-weight: 600; letter-spacing: -0.01em; color: #1c1917;
}
.faq summary::-webkit-details-marker { display: none; }
.faq .sign { flex: none; }
.faq .sign::after { content: "+"; font-size: 18px; color: #e11d48; line-height: 1; }
.faq details[open] .sign::after { content: "\2212"; }
.faq .answer { font-size: 14.5px; line-height: 1.6; color: #78716c; max-width: 680px; margin-top: -4px; padding-bottom: 22px; }
.answer-link { display: inline-block; margin-top: 11px; font-size: 13.5px; font-weight: 600; color: #e11d48; }

/* ---------- final CTA ---------- */
.cta-rose { background: #e11d48; }
.cta-rose .h2 { color: #fff; }
.center-col { text-align: center; padding-top: 88px; padding-bottom: 88px; }
.cta-sub { color: #ffe0e6; max-width: 460px; margin: 0 auto 34px; }

/* ---------- footer ---------- */
.footer { background: #fff; border-top: 1px solid #f0eeec; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 20px; padding-top: 40px; padding-bottom: 40px; }
.footer-links { display: flex; gap: 26px; }
.footer-links a { font-size: 13px; color: #78716c; }
.footer-links a:hover { color: #1c1917; }
.copyright { font-size: 11px; color: #a8a29e; }

/* ---------- heatmap mock ---------- */
.hm { background: #fff; border: 1px solid #e7e5e4; border-radius: 10px; padding: 18px; box-shadow: 0 12px 32px rgba(0,0,0,0.07); }
.hm-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.hm-title { font-size: 14px; font-weight: 600; }
.hm-best { font-size: 11px; font-weight: 600; color: #9f1239; background: #fff1f2; border: 1px solid #fbd0d8; padding: 3px 9px; border-radius: 999px; }
.hm-grid { display: flex; flex-direction: column; gap: 5px; }
.hm-days, .hm-row { display: grid; grid-template-columns: 44px repeat(4, 1fr); gap: 5px; align-items: center; }
.hm-t { font-size: 10px; color: #a8a29e; text-align: right; padding-right: 4px; }
.hm-d { text-align: center; line-height: 1.1; }
.hm-d b { display: block; font-size: 9px; letter-spacing: 0.06em; color: #a8a29e; }
.hm-d i { font-style: normal; font-size: 12px; font-weight: 600; }
.hm-c { height: 26px; border-radius: 3px; background: rgba(225, 29, 72, var(--a, 0.07)); }
.hm-c.full { background: #e11d48; box-shadow: inset 0 0 0 2px #9f1239; }
.hm-c.maybe { background: repeating-linear-gradient(45deg, rgba(225,29,72,0.55) 0 3px, #fff1f2 3px 6px); }
.hm-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; }
.hm-scale { display: flex; }
.hm-scale i { width: 18px; height: 10px; background: rgba(225, 29, 72, var(--a)); }
.hm-rep { font-size: 10px; color: #a8a29e; }
.hm--dark { background: #211d1a; border-color: #2f2926; box-shadow: 0 20px 44px rgba(0,0,0,0.45); }
.hm--dark .hm-title { color: #f5f3f1; }
.hm--dark .hm-d i { color: #e7e2dc; }
.hm--dark .hm-c { background: rgba(225, 29, 72, var(--a, 0.10)); }
.hm--dark .hm-c.maybe { background: repeating-linear-gradient(45deg, rgba(225,29,72,0.6) 0 3px, #3a2328 3px 6px); }
.hm--dark .hm-best { background: #3a2328; border-color: #5b2230; color: #fda4af; }

/* ---------- responsive ---------- */
@media (max-width: 880px) {
  .nav-links { display: none; }
  .hero, .dark-grid { grid-template-columns: 1fr; gap: 36px; }
  .grid-3, .feature-grid, .pricing { grid-template-columns: 1fr; }
  .display { font-size: 44px; }
  .h2, .h2.xl { font-size: 30px; }
  .band { padding-top: 56px; padding-bottom: 56px; }
}
