/* Pact — drenched-dark concept page. The night screen, extended to the web. */

:root {
  --night:    oklch(0.115 0.014 274);
  --night-2:  oklch(0.150 0.016 273);
  --night-3:  oklch(0.205 0.018 273);
  --hair:     oklch(0.62 0.02 273 / 0.16);
  --hair-2:   oklch(0.62 0.02 273 / 0.28);

  --ink:      oklch(0.965 0.006 270);
  --ink-2:    oklch(0.795 0.014 272);
  --ink-3:    oklch(0.640 0.018 272);

  --indigo:   oklch(0.690 0.150 272);
  --indigo-2: oklch(0.560 0.160 272);
  --on-indigo: oklch(0.985 0.004 270);

  --ember:    oklch(0.760 0.130 66);
  --ember-hi: oklch(0.870 0.110 82);
  --ember-deep: oklch(0.560 0.150 52);

  --maxw: 1080px;
  --pad: clamp(1.25rem, 5vw, 4rem);

  --r-md: 12px;
  --r-lg: 18px;
  --r-phone: 30px;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --dur: 220ms;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  background: var(--night);
  color: var(--ink);
  font-family: "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, sans-serif;
  font-weight: 400;
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

h1, h2, h3 { font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; margin: 0; text-wrap: balance; }
p { margin: 0; text-wrap: pretty; }
a { color: inherit; }

.skip {
  position: absolute; left: -999px; top: 0; z-index: 50;
  background: var(--night-2); color: var(--ink);
  padding: 0.6rem 1rem; border-radius: var(--r-md); border: 1px solid var(--hair-2);
}
.skip:focus { left: var(--pad); top: 0.75rem; }

:focus-visible { outline: 2px solid var(--indigo); outline-offset: 3px; border-radius: 4px; }

/* ---- shell ---- */
.topbar {
  position: relative; z-index: 5;
  display: flex; align-items: center; justify-content: space-between;
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(1.1rem, 3vw, 1.75rem) var(--pad);
}
.wordmark {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-weight: 500; font-size: 1.0625rem; letter-spacing: -0.01em;
  text-decoration: none; color: var(--ink);
}
.wordmark__dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--ember);
  box-shadow: 0 0 10px 1px oklch(0.76 0.13 66 / 0.6);
}
.tag {
  font-size: 0.8125rem; color: var(--ink-3);
  border: 1px solid var(--hair); border-radius: 100px;
  padding: 0.3rem 0.7rem; letter-spacing: 0.01em;
}

/* ---- hero ---- */
.hero {
  position: relative;
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(2rem, 6vw, 5rem) var(--pad) clamp(3.5rem, 9vw, 7rem);
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 5vw, 4rem);
  align-items: center; min-height: min(82vh, 760px);
}
.hero__glow {
  position: absolute; z-index: 0; pointer-events: none;
  right: 8%; top: 38%; width: min(60vw, 620px); aspect-ratio: 1;
  transform: translateY(-50%);
  background: radial-gradient(circle, oklch(0.76 0.13 66 / 0.22), oklch(0.76 0.13 66 / 0.05) 42%, transparent 66%);
  filter: blur(8px);
}
.hero__copy { position: relative; z-index: 2; max-width: 34rem; }
h1 {
  font-size: clamp(2.6rem, 1.6rem + 4.6vw, 4.75rem);
  letter-spacing: -0.03em; line-height: 0.98;
}
.hero__sub {
  margin-top: 1.5rem; color: var(--ink-2);
  font-size: clamp(1.0625rem, 1rem + 0.4vw, 1.25rem); line-height: 1.55; max-width: 38ch;
}
.hero__actions { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: 0.75rem; }

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.7rem 1.2rem; border-radius: 100px;
  font-size: 0.96875rem; font-weight: 500; text-decoration: none;
  border: 1px solid transparent; cursor: pointer;
  transition: transform var(--dur) var(--ease), background-color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn--primary { background: var(--indigo); color: var(--on-indigo); }
.btn--primary:hover { background: oklch(0.73 0.15 272); }
.btn--ghost { color: var(--ink); border-color: var(--hair-2); }
.btn--ghost:hover { border-color: var(--ink-3); background: oklch(1 0 0 / 0.03); }
.btn:active { transform: translateY(1px); }

.hero__stage { position: relative; z-index: 2; display: flex; justify-content: center; }

/* ---- phone ---- */
.phone {
  width: 252px; max-width: 72vw;
  border-radius: var(--r-phone);
  background: linear-gradient(160deg, oklch(0.26 0.018 273), oklch(0.17 0.016 273));
  padding: 8px;
  border: 1px solid var(--hair-2);
  box-shadow: 0 40px 80px -40px oklch(0.02 0.01 274 / 0.9);
}
.phone--hero {
  width: 288px;
  transform: rotate(2.2deg);
  box-shadow: 0 50px 120px -50px oklch(0.76 0.13 66 / 0.35), 0 30px 70px -40px oklch(0.02 0.01 274 / 0.9);
}
.phone__screen {
  border-radius: calc(var(--r-phone) - 8px);
  height: 468px; padding: 22px 18px;
  display: flex; flex-direction: column;
  overflow: hidden; position: relative;
}
.phone--hero .phone__screen { height: 520px; }

/* night (dark) screens */
.night {
  background: radial-gradient(120% 80% at 50% 0%, oklch(0.17 0.018 274), oklch(0.095 0.012 274) 70%);
  align-items: center; text-align: center;
}
.night--mini .phone__screen, .night--mini { padding-top: 26px; }
.phone__screen.night--mini { height: 468px; }

.candle { position: relative; width: 26px; height: 40px; margin-top: 30px; display: grid; place-items: end center; }
.candle--mini { margin-top: 18px; transform: scale(0.85); }
.candle__glow {
  position: absolute; bottom: -6px; left: 50%; width: 90px; height: 90px;
  transform: translateX(-50%);
  background: radial-gradient(circle, oklch(0.78 0.13 70 / 0.55), transparent 62%);
  filter: blur(6px); border-radius: 50%;
  animation: breathe 4.5s var(--ease) infinite;
}
.candle__flame {
  position: relative; width: 17px; height: 26px;
  background: radial-gradient(120% 100% at 50% 80%, var(--ember-hi), var(--ember) 55%, var(--ember-deep));
  border-radius: 50% 50% 50% 50% / 64% 64% 36% 36%;
  transform-origin: 50% 100%;
  box-shadow: 0 0 14px 1px oklch(0.78 0.13 70 / 0.5);
  animation: flicker 3.6s ease-in-out infinite;
}
.candle__flame::after {
  content: ""; position: absolute; inset: 30% 28% 8% 28%;
  background: oklch(0.93 0.06 92); border-radius: 50% 50% 45% 45% / 60% 60% 40% 40%;
  opacity: 0.85;
}

.night__timer {
  margin-top: 16px; font-size: 1.875rem; font-weight: 500;
  letter-spacing: 0.01em; font-variant-numeric: tabular-nums;
  color: var(--ink);
}
.night__timer--mini { font-size: 1.5rem; margin-top: 14px; }
.night__label { margin-top: 4px; font-size: 0.8125rem; color: var(--ink-3); }
.night__people { display: flex; gap: 7px; margin-top: auto; }
.chip {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  font-size: 0.75rem; font-weight: 500;
  background: var(--night-3); color: var(--ink-2);
  border: 1px solid var(--hair);
}
.chip--lit { background: oklch(0.93 0.03 274); color: oklch(0.34 0.09 274); border: none; }
.chip--wait { background: transparent; border: 1px dashed var(--hair-2); color: var(--ink-3); }
.chip--indigo { background: var(--indigo-2); color: var(--on-indigo); border: none; }

.night__ask {
  margin-top: 14px; width: 100%;
  background: transparent; color: var(--ink-2);
  border: 1px solid var(--hair-2); border-radius: var(--r-md);
  padding: 9px 0; font: inherit; font-size: 0.8125rem; cursor: default;
}
.night__foot { margin-top: 12px; font-size: 0.75rem; line-height: 1.5; color: var(--ink-3); }

/* lit (light, pre-lock) screen */
.lit { background: oklch(0.965 0.004 270); color: oklch(0.22 0.02 274); align-items: stretch; text-align: left; }
.lit__h { font-size: 0.9375rem; font-weight: 500; }
.lit__sub { margin-top: 2px; font-size: 0.8125rem; color: oklch(0.46 0.02 274); }
.qr {
  margin: 18px auto 0; width: 104px; height: 104px;
  border-radius: var(--r-md); border: 1px solid oklch(0.22 0.02 274 / 0.16);
  display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(3, 1fr);
  gap: 9px; padding: 14px;
}
.qr span { background: oklch(0.30 0.04 274); border-radius: 3px; }
.qr span:nth-child(2), .qr span:nth-child(6), .qr span:nth-child(8) { background: oklch(0.30 0.04 274 / 0.25); }
.lit__code {
  margin: 9px 0 0; text-align: center; font-size: 0.8125rem; letter-spacing: 0.22em;
  color: oklch(0.46 0.02 274); font-variant-numeric: tabular-nums;
}
.lit__people { display: flex; gap: 6px; justify-content: center; margin-top: auto; }
.lit__hint { text-align: center; font-size: 0.75rem; color: oklch(0.5 0.02 274); margin-top: 9px; }
.lit__cta {
  margin-top: 12px; width: 100%; border: none; border-radius: var(--r-md);
  background: var(--indigo-2); color: var(--on-indigo);
  padding: 10px 0; font: inherit; font-size: 0.875rem; font-weight: 500; cursor: default;
}

/* ask screen */
.night--ask { align-items: stretch; text-align: left; padding-top: 20px; }
.ask__head { display: flex; align-items: center; gap: 9px; }
.ask__who { display: block; font-size: 0.8125rem; font-weight: 500; color: var(--ink); }
.ask__time { display: block; font-size: 0.6875rem; color: var(--ink-3); margin-top: 1px; }
.ask__reason {
  margin-top: 12px; font-size: 0.8125rem; line-height: 1.4;
  background: oklch(0.76 0.13 66 / 0.16); color: var(--ember-hi);
  border: 1px solid oklch(0.76 0.13 66 / 0.3);
  padding: 8px 11px; border-radius: 10px;
}
.ask__bar { margin-top: 12px; height: 3px; border-radius: 2px; background: var(--night-3); overflow: hidden; }
.ask__bar span { display: block; width: 38%; height: 100%; background: var(--ember); }
.ask__votes { list-style: none; margin: 14px 0 0; padding: 0; }
.ask__votes li {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.8125rem; padding: 8px 2px; color: var(--ink);
}
.ask__votes li + li { border-top: 1px solid var(--hair); }
.ask__votes .yes { color: oklch(0.78 0.11 165); font-size: 0.75rem; display: inline-flex; align-items: center; gap: 6px; }
.ask__votes .yes .dot { width: 6px; height: 6px; border-radius: 50%; background: oklch(0.72 0.12 165); }
.ask__votes .wait { color: var(--ink-3); font-size: 0.75rem; }
.ask__actions { display: flex; gap: 8px; margin-top: auto; }
.ask__allow, .ask__no {
  flex: 1; border-radius: var(--r-md); padding: 9px 0;
  font: inherit; font-size: 0.8125rem; font-weight: 500; cursor: default;
}
.ask__allow { border: none; background: var(--indigo); color: var(--on-indigo); }
.ask__no { border: 1px solid var(--hair-2); background: transparent; color: var(--ink-2); }
.ask__need { margin: 10px 0 0; text-align: center; font-size: 0.6875rem; color: var(--ink-3); }

/* ---- prose bands ---- */
.band { max-width: var(--maxw); margin: 0 auto; padding: clamp(3.5rem, 9vw, 7rem) var(--pad); }
.band--quiet { padding-top: clamp(2rem, 5vw, 3.5rem); }
.prose { max-width: 37rem; }
.prose h2 {
  font-size: clamp(2rem, 1.4rem + 2.6vw, 3.25rem); letter-spacing: -0.028em;
  margin-bottom: 1.5rem;
}
.prose p { color: var(--ink-2); font-size: clamp(1.0625rem, 1rem + 0.3vw, 1.1875rem); max-width: 60ch; }
.prose p + p { margin-top: 1.1rem; }

/* ---- how ---- */
.how { max-width: var(--maxw); margin: 0 auto; padding: clamp(2rem, 5vw, 4rem) var(--pad) clamp(3.5rem, 9vw, 6rem); }
.how__title { font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2rem); color: var(--ink-3); margin-bottom: clamp(2rem, 5vw, 3.5rem); }
.steps {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(2.5rem, 5vw, 3.5rem);
}
.step { display: flex; flex-direction: column; align-items: center; }
.step .phone { width: 240px; }
.step__text { margin-top: 1.75rem; max-width: 30ch; text-align: center; }
.step__n {
  display: inline-block; font-size: 0.8125rem; font-weight: 500;
  color: var(--ember); letter-spacing: 0.04em; margin-bottom: 0.6rem;
  font-variant-numeric: tabular-nums;
}
.step__text h3 { font-size: 1.375rem; letter-spacing: -0.02em; }
.step__text p { margin-top: 0.6rem; color: var(--ink-2); font-size: 1rem; }

/* ---- honest core ---- */
.honest {
  max-width: var(--maxw); margin: 0 auto; padding: clamp(3.5rem, 9vw, 7rem) var(--pad);
  display: grid; grid-template-columns: 1fr 0.9fr; gap: clamp(2.5rem, 6vw, 5rem); align-items: start;
}
.guarantees { list-style: none; margin: 0; padding: 0; display: grid; gap: 1px; background: var(--hair); border-radius: var(--r-lg); overflow: hidden; }
.guarantees li { background: var(--night); padding: 1.25rem 1.4rem; display: flex; flex-direction: column; gap: 0.35rem; }
.g__k { font-weight: 500; font-size: 1.0625rem; color: var(--ink); }
.g__v { font-size: 0.9375rem; color: var(--ink-3); line-height: 1.5; }

/* ---- closer ---- */
.closer { max-width: var(--maxw); margin: 0 auto; padding: clamp(4rem, 11vw, 9rem) var(--pad) clamp(3rem, 7vw, 5rem); }
.closer blockquote { margin: 0; }
.closer p {
  font-size: clamp(1.9rem, 1.1rem + 3.6vw, 3.75rem); font-weight: 500;
  letter-spacing: -0.03em; line-height: 1.02; color: var(--ink);
}

/* ---- footer ---- */
.foot { max-width: var(--maxw); margin: 0 auto; padding: clamp(2.5rem, 6vw, 4rem) var(--pad) clamp(2.5rem, 6vw, 4rem); border-top: 1px solid var(--hair); }
.foot__row { display: flex; flex-wrap: wrap; gap: 1.25rem 2rem; align-items: center; justify-content: space-between; }
.foot__links { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.foot__links a { color: var(--ink-2); text-decoration: none; font-size: 0.96875rem; transition: color var(--dur) var(--ease); }
.foot__links a:hover { color: var(--ink); }
.foot__note { margin-top: 1.75rem; max-width: 60ch; color: var(--ink-3); font-size: 0.9375rem; }

/* ---- motion ---- */
@keyframes breathe { 0%, 100% { opacity: 0.7; transform: translateX(-50%) scale(0.94); } 50% { opacity: 1; transform: translateX(-50%) scale(1.08); } }
@keyframes flicker {
  0%, 100% { transform: scaleY(1) scaleX(1) rotate(-1deg); }
  25% { transform: scaleY(1.06) scaleX(0.97) rotate(1deg); }
  50% { transform: scaleY(0.97) scaleX(1.02) rotate(-0.5deg); }
  75% { transform: scaleY(1.04) scaleX(0.99) rotate(0.8deg); }
}

.js .reveal { opacity: 0; transform: translateY(18px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.js .reveal.is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .candle__glow, .candle__flame { animation: none; }
  .js .reveal { opacity: 1; transform: none; transition: none; }
  .btn, .foot__links a { transition: none; }
}

/* ---- responsive ---- */
@media (max-width: 860px) {
  .hero { grid-template-columns: 1fr; gap: clamp(2.5rem, 8vw, 3.5rem); min-height: 0; padding-top: clamp(1rem, 4vw, 2rem); }
  .hero__copy { max-width: none; }
  .hero__glow { right: 50%; transform: translate(50%, -50%); top: 60%; }
  .honest { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .tag { display: none; }
  .hero__actions .btn { flex: 1; }
}
