/* Candle — warm paper-and-ink birthday notebook */

:root {
  --paper: #faf1e0;
  --paper-deep: #f3e5cc;
  --card: #fffcf4;
  --ink: #35222d;
  --ink-soft: #7a6270;
  --marigold: #e39312;
  --coral: #e4573d;
  --coral-deep: #c93f27;
  --sage: #7d9b76;
  --line: #e6d3b4;
  --shadow: 0 2px 0 var(--line), 0 10px 24px -14px rgba(53, 34, 45, .35);
  --radius: 18px;
  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Karla", "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html { height: 100%; }

body {
  margin: 0;
  min-height: 100%;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* scattered confetti dots, fixed behind everything */
.confetti-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle 3px at 12% 18%, var(--coral) 98%, transparent),
    radial-gradient(circle 2px at 78% 9%, var(--marigold) 98%, transparent),
    radial-gradient(circle 3px at 90% 42%, var(--sage) 98%, transparent),
    radial-gradient(circle 2px at 32% 64%, var(--marigold) 98%, transparent),
    radial-gradient(circle 3px at 8% 81%, var(--sage) 98%, transparent),
    radial-gradient(circle 2px at 64% 88%, var(--coral) 98%, transparent),
    radial-gradient(circle 2px at 47% 33%, var(--coral) 98%, transparent),
    radial-gradient(circle 3px at 85% 71%, var(--marigold) 98%, transparent);
  opacity: .5;
}

.page {
  position: relative;
  z-index: 1;
  max-width: 620px;
  margin: 0 auto;
  padding: 16px 16px calc(96px + env(safe-area-inset-bottom));
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

/* ---------- header ---------- */

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0 20px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--ink);
}

.brand-name {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.5rem;
  letter-spacing: -.02em;
}

.topnav {
  display: flex;
  align-items: center;
  gap: 14px;
  font-weight: 700;
  font-size: .85rem;
  text-transform: lowercase;
}

.topnav a, .link-btn {
  color: var(--ink-soft);
  text-decoration: none;
  border: 0;
  background: none;
  font: inherit;
  cursor: pointer;
  padding: 2px 0;
  border-bottom: 2px solid transparent;
}

.topnav a:hover, .link-btn:hover { color: var(--coral); border-bottom-color: var(--coral); }

/* ---------- the candle ---------- */

.candle {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 34px;
}

.candle .wax {
  position: absolute;
  bottom: 0;
  left: 2px;
  width: 10px;
  height: 22px;
  border-radius: 3px 3px 4px 4px;
  background: repeating-linear-gradient(135deg, var(--coral) 0 4px, #f2907c 4px 8px);
}

.candle .flame {
  position: absolute;
  top: 0;
  left: 3px;
  width: 8px;
  height: 11px;
  border-radius: 50% 50% 50% 50% / 62% 62% 38% 38%;
  background: radial-gradient(circle at 50% 78%, #fff3b0 0 30%, var(--marigold) 70%);
  box-shadow: 0 0 12px 3px rgba(227, 147, 18, .55);
  transform-origin: 50% 90%;
  animation: flicker 2.4s ease-in-out infinite;
}

.candle-big { width: 22px; height: 58px; }
.candle-big .wax { left: 4px; width: 14px; height: 38px; }
.candle-big .flame { left: 5px; width: 12px; height: 17px; }

@keyframes flicker {
  0%, 100% { transform: scale(1) rotate(-2deg); opacity: 1; }
  25%      { transform: scale(1.08, .94) rotate(2deg); opacity: .92; }
  55%      { transform: scale(.94, 1.06) rotate(-3deg); }
  80%      { transform: scale(1.04) rotate(1deg); opacity: .96; }
}

/* ---------- typography ---------- */

.page-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 2rem;
  letter-spacing: -.03em;
  margin: 0 0 18px;
}

/* ---------- cards ---------- */

.cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.riser {
  animation: rise .45s cubic-bezier(.2, .9, .3, 1.2) backwards;
}

@keyframes rise {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: none; }
}

.card {
  background: var(--card);
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease;
}

.card:hover { transform: translateY(-2px); }

.card-link {
  display: block;
  padding: 14px 16px;
  color: inherit;
  text-decoration: none;
}

.card-face {
  display: flex;
  align-items: center;
  gap: 12px;
}

.avatar {
  flex: none;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  font-size: 24px;
  background: var(--paper-deep);
  border-radius: 50%;
  border: 1.5px dashed var(--line);
}

.who { flex: 1; min-width: 0; }

.name {
  display: block;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.15rem;
  letter-spacing: -.01em;
}

.meta {
  display: block;
  color: var(--ink-soft);
  font-size: .82rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.when { text-align: right; flex: none; }

.count {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.7rem;
  line-height: 1;
  color: var(--marigold);
}

.count-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink-soft);
  margin-left: 3px;
}

.date {
  display: block;
  font-size: .78rem;
  color: var(--ink-soft);
  margin-top: 2px;
}

.notes {
  margin: 10px 0 0;
  padding-top: 10px;
  border-top: 1.5px dashed var(--line);
  font-size: .85rem;
  color: var(--ink-soft);
}

.card-soon .count { color: var(--coral); }

.meta-place { font-size: .75rem; margin-top: 1px; }

/* custom-date (event) cards */
.avatar-event { background: var(--paper); border-style: solid; font-size: 20px; }
.card-event .name { font-size: 1.02rem; }

/* wished tracking on today's card */
.wish-zone {
  padding: 0 16px 14px;
  display: flex;
  justify-content: flex-end;
}

.btn-wish {
  background: #fff3b0;
  color: var(--ink);
  border-color: transparent;
  padding: 8px 16px;
  font-size: .85rem;
}

.wished-mark {
  font-weight: 700;
  font-size: .9rem;
  color: #fff3b0;
}

/* today's card: full celebration */
.card-today {
  background: linear-gradient(135deg, var(--coral) 0%, var(--coral-deep) 100%);
  border-color: var(--coral-deep);
  color: #fff7ee;
  transform: rotate(-.8deg);
  animation: rise .45s cubic-bezier(.2, .9, .3, 1.2) backwards,
             wiggle 3.2s ease-in-out .6s infinite;
}

@keyframes wiggle {
  0%, 100% { transform: rotate(-.8deg); }
  50%      { transform: rotate(.6deg); }
}

.card-today .meta, .card-today .date, .card-today .count-label, .card-today .notes { color: #ffd9c4; }
.card-today .notes { border-top-color: rgba(255, 247, 238, .35); }
.card-today .avatar { background: rgba(255, 247, 238, .18); border-color: rgba(255, 247, 238, .5); }
.count-today {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.45rem;
  font-style: italic;
  color: #fff3b0;
}

/* ---------- empty state ---------- */

.empty { text-align: center; padding: 56px 12px; color: var(--ink-soft); }
.empty-cake { font-size: 56px; display: block; margin-bottom: 10px; }
.empty .page-title { color: var(--ink); }

/* ---------- forms ---------- */

.sheet {
  background: var(--card);
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.lbl, .lbl-sub {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 700;
  font-size: .85rem;
}

fieldset.lbl { border: 0; padding: 0; margin: 0; }
fieldset.lbl legend { padding: 0; margin-bottom: 6px; }

.hint { font-weight: 400; color: var(--ink-soft); font-size: .78rem; }

.field {
  font: inherit;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px;
  width: 100%;
}

.field:focus {
  outline: none;
  border-color: var(--marigold);
  box-shadow: 0 0 0 3px rgba(227, 147, 18, .22);
}

textarea.field { resize: vertical; }

/* avatar button + emoji picker popup */
.name-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: end;
}

.avatar-slot { position: relative; }

.avatar-btn {
  width: 62px;
  height: 62px;
  font-size: 30px;
  line-height: 1;
  display: grid;
  place-items: center;
  background: var(--paper);
  border: 1.5px dashed var(--line);
  border-radius: 16px;
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}

.avatar-btn:hover {
  transform: translateY(-2px);
  border-color: var(--marigold);
  box-shadow: 0 0 0 3px rgba(227, 147, 18, .18);
}

.picker-pop {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 20;
  background: var(--card);
  border: 1.5px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 6px;
  animation: rise .2s ease backwards;
}

.picker-pop emoji-picker {
  width: min(344px, calc(100vw - 60px));
  height: 360px;
  /* keep all category tabs visible — the tab row doesn't scroll */
  --emoji-size: 1.25rem;
  --emoji-padding: 0.45rem;
  --category-emoji-size: 1.05rem;
  --category-emoji-padding: 0.4rem;
  --background: var(--card);
  --border-color: var(--line);
  --border-radius: 12px;
  --indicator-color: var(--coral);
  --input-border-color: var(--line);
  --input-font-color: var(--ink);
  --input-placeholder-color: var(--ink-soft);
  --button-hover-background: var(--paper-deep);
  --button-active-background: var(--paper-deep);
  --category-font-color: var(--ink-soft);
  --outline-color: var(--marigold);
}

.picker-clear {
  display: block;
  margin: 4px auto 6px;
  font-size: .8rem;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1.4fr 1fr; gap: 10px; align-items: end; }

@media (max-width: 430px) {
  .grid-2 { grid-template-columns: 1fr; }
}

.tweaks {
  border-top: 1.5px dashed var(--line);
  padding-top: 12px;
}

.tweaks summary {
  cursor: pointer;
  font-weight: 700;
  font-size: .85rem;
  color: var(--ink-soft);
}

.tweaks[open] summary { color: var(--coral); margin-bottom: 12px; }
.tweaks > .lbl { margin-top: 12px; }

.chips { display: flex; flex-wrap: wrap; gap: 8px; }

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border: 1.5px solid var(--line);
  border-radius: 999px;
  background: var(--paper);
  font-weight: 700;
  font-size: .82rem;
  cursor: pointer;
  user-select: none;
}

.chip input { accent-color: var(--coral); margin: 0; }
.chip:has(input:checked) { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ---------- buttons ---------- */

.btn {
  font: inherit;
  font-weight: 700;
  border: 1.5px solid transparent;
  border-radius: 999px;
  padding: 11px 22px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  transition: transform .12s ease, box-shadow .12s ease;
}

.btn:active { transform: scale(.97); }

.btn-primary {
  background: var(--ink);
  color: var(--paper);
  box-shadow: 0 4px 0 var(--coral-deep);
}

.btn-primary:hover { box-shadow: 0 2px 0 var(--coral-deep); transform: translateY(2px); }

.btn-ghost {
  background: transparent;
  color: var(--ink-soft);
  border-color: var(--line);
}

.btn-danger {
  background: transparent;
  color: var(--coral-deep);
  border-color: var(--coral-deep);
}

.btn-danger:hover { background: var(--coral-deep); color: #fff7ee; }

.form-actions { display: flex; gap: 10px; align-items: center; }

.danger-zone, .test-zone { margin-top: 22px; text-align: center; }

/* other-dates + calendar sheets */
.section-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -.02em;
  margin: 0;
}

.dates-sheet, .calendar-sheet { margin-top: 22px; }
.channels-sheet { margin-bottom: 22px; }

.channel-grid { display: grid; grid-template-columns: 1fr 2.2fr; gap: 10px; }
@media (max-width: 430px) { .channel-grid { grid-template-columns: 1fr; } }

.channel-url { font-family: ui-monospace, monospace; font-size: .72rem; word-break: break-all; }

.event-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1.5px dashed var(--line);
  font-size: .9rem;
}

.event-delete { color: var(--coral-deep); font-size: .8rem; }

.event-actions { display: flex; gap: 14px; align-items: center; flex: none; }
.event-actions .link-btn { font-size: .8rem; font-weight: 700; }
.event-quiet .event-label { color: var(--ink-soft); }

/* everyone page */
.people .card-link.person-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 14px;
}

.avatar-sm { width: 38px; height: 38px; font-size: 19px; }

.count-badge {
  font-family: var(--font-body);
  font-size: .9rem;
  font-weight: 700;
  color: var(--paper);
  background: var(--coral);
  border-radius: 999px;
  padding: 3px 10px;
  vertical-align: middle;
}

.event-add { display: flex; flex-direction: column; gap: 12px; margin-top: 4px; }
.event-add .btn { align-self: flex-start; }

.inline-form { display: inline; }

/* floating add button */
.fab {
  position: fixed;
  bottom: calc(20px + env(safe-area-inset-bottom));
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  background: var(--coral);
  color: #fff7ee;
  font-weight: 700;
  text-decoration: none;
  padding: 14px 26px;
  border-radius: 999px;
  box-shadow: 0 4px 0 var(--coral-deep), 0 14px 28px -12px rgba(201, 63, 39, .6);
  transition: transform .12s ease, box-shadow .12s ease;
}

.fab:hover { transform: translateX(-50%) translateY(2px); box-shadow: 0 2px 0 var(--coral-deep); }

/* ---------- login ---------- */

.login-wrap {
  min-height: 88dvh;
  display: grid;
  place-items: center;
}

.login-card {
  text-align: center;
  background: var(--card);
  border: 1.5px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
  padding: 44px 34px 38px;
  width: min(360px, 92vw);
}

.login-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 2.6rem;
  letter-spacing: -.04em;
  margin: 14px 0 2px;
}

.login-sub { color: var(--ink-soft); font-size: .9rem; margin: 0 0 26px; }

.login-form { display: flex; flex-direction: column; gap: 12px; }

.form-error { color: var(--coral-deep); font-weight: 700; font-size: .85rem; margin: 0; }

/* ---------- flashes & footer ---------- */

.flash {
  border-radius: 12px;
  padding: 12px 16px;
  font-weight: 700;
  font-size: .88rem;
  margin: 0 0 16px;
}

.flash-ok { background: #e7efe0; color: #3d5c36; border: 1.5px solid var(--sage); }
.flash-err { background: #fbe3dc; color: var(--coral-deep); border: 1.5px solid var(--coral); }

.footer {
  text-align: center;
  color: var(--ink-soft);
  font-size: .75rem;
  padding-top: 40px;
}

@media (prefers-reduced-motion: reduce) {
  .riser, .card-today, .candle .flame { animation: none !important; }
}
