:root{
  --bg:#ffffff;
  --fg:#111111;
  --muted:#666;
  --line:#e9e9e9;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;
  background:var(--bg);
  color:var(--fg);
}

.wrap{
  max-width: 980px;
  margin: 0 auto;
  padding: 56px 20px 90px;
}

.hero{
  padding: 10px 0 42px;
}

.title{
  font-size: 56px;
  line-height: 1.05;
  margin: 0 0 10px;
  letter-spacing: -0.02em;
}
.subtitle{
  margin: 0 0 26px;
  color: var(--muted);
  font-size: 18px;
}

.lead{
  font-size: 18px;
  line-height: 1.6;
  max-width: 820px;
}
.lead ul{
  margin: 14px 0 10px 18px;
  padding: 0;
}
.quote{margin-top:18px; font-style: italic;}
.muted{color:var(--muted);}

.memories{padding-top: 34px;}
.memories-title{
  margin: 0 0 12px;
  font-size: 22px;
  letter-spacing: -0.01em;
}

.list{
  border-top: 1px solid var(--line);
}

.row{
  display:flex;
  gap: 20px;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
  will-change: transform, opacity;
}

.author{
  flex: 0 0 240px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.text{
  flex: 1 1 auto;
  font-size: 14px;
  line-height: 1.5;
  white-space: pre-wrap;
}

.meta{
  margin-top: 4px;
  font-size: 13px;
  color: var(--muted);
}

.footer-note{
  margin-top: 16px;
  font-size: 14px;
}

/* reveal on scroll */
.row.reveal{
  opacity: 0;
  transform: translateY(10px);
}
.row.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
  transition: opacity 600ms ease, transform 600ms ease;
}

/* swap animation via FLIP */
.row.is-swapping{
  transition: transform 650ms cubic-bezier(.2,.8,.2,1);
}

@media (max-width: 760px){
  .title{font-size: 42px;}
  .row{flex-direction: column; gap: 8px;}
  .author{flex: 1 1 auto;}
  .text{font-size: 14px;}
}

.footer-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top: 16px;
}

.btn-primary{
  border:none;
  background:#111;
  color:#fff;
  padding: 10px 14px;
  border-radius: 999px;
  cursor:pointer;
  font-size: 14px;
}
.btn-primary:disabled{opacity:.6; cursor:not-allowed;}

.btn-ghost{
  border:1px solid var(--line);
  background:#fff;
  color:#111;
  padding: 10px 14px;
  border-radius: 999px;
  cursor:pointer;
  font-size: 14px;
}

/* modal */
.modal{display:none;}
.modal.is-open{display:block;}

.modal-backdrop{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(2px);
}

.modal-dialog{
  position:fixed;
  left:50%;
  top:50%;
  transform: translate(-50%, -48%);
  width: min(640px, calc(100vw - 32px));
  background:#fff;
  border:1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 14px 14px 16px;
  animation: modalIn 220ms ease-out;
}

@keyframes modalIn{
  from { opacity:0; transform: translate(-50%, -46%) scale(.98); }
  to   { opacity:1; transform: translate(-50%, -48%) scale(1); }
}

.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 6px 6px 10px;
}
.modal-head h3{margin:0; font-size: 18px; letter-spacing:-0.01em;}

.modal-close{
  width:36px;
  height:36px;
  border-radius: 999px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
}

.modal-form{padding: 4px 6px 2px;}
.form-row{margin-top: 10px;}
.form-row label{display:block; font-size: 13px; color: var(--muted); margin: 0 0 6px;}
.form-row input, .form-row textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #ddd;
  border-radius: 12px;
  font: inherit;
}
.form-row textarea{min-height: 120px; resize: vertical; white-space: pre-wrap;}

.form-actions{
  display:flex;
  gap:10px;
  margin-top: 12px;
}

.form-status{
  margin-top: 10px;
  font-size: 14px;
  color: var(--muted);
}

/* hide honeypot */
.hp{
  position:absolute;
  left:-10000px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.pause-fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 50;

  border: 1px solid var(--line);
  background: rgba(255,255,255,.92);
  color: #111;

  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 14px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
}

.pause-fab:hover{
  background: rgba(255,255,255,.98);
}

.pause-fab.is-paused{
  background: #111;
  color: #fff;
  border-color: #111;
}

