/* husprotokol.css — "Husprotokollen"
 *
 * Alle klasser starter med .hp-*. Bygger på CSS-variablerne i :root (main.css).
 * Sektioner:
 *   1. Stage (wheel + header)
 *   2. Wheel-layer
 *   3. Stat-strip
 *   4. Ledger section + variant switch
 *   5. Variant I: Hotelprotokol
 *   6. Variant II: Avisspalte
 *   7. Variant III: Almanak
 *   8. Drawer
 *   9. Modal
 *  10. Shared mini-buttons / tags / dots
 */

/* ─── 1. Stage ────────────────────────────────────────────────────────── */

.hp-app {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 28px 80px;
}

.hp-stage {
  padding-top: 32px;
  padding-bottom: 40px;
}

.hp-stage-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}

.hp-stage-left {
  position: relative;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.hp-stage-right {
  align-self: stretch;
}

.hp-wheel-hint {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: center;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brass-soft);
}

/* Faux tudside (preview only) */
.hp-faux-tudside { padding-top: 8px; }
.hp-faux-banner {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 18px;
  display: flex; align-items: center; gap: 12px;
}
.hp-faux-banner::before,
.hp-faux-banner::after {
  content: ''; flex: 1; height: 0; border-top: 0.5px solid var(--rule);
}
.hp-faux-eyebrow {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 8px;
}
.hp-faux-tag { color: var(--brass); }
.hp-faux-title {
  margin: 0 0 12px;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 44px;
  line-height: 1;
  color: var(--ink);
}
.hp-faux-epigraph {
  margin: 0 0 22px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  line-height: 1.45;
  color: var(--ink-soft);
  max-width: 48ch;
}
.hp-faux-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  padding-top: 18px;
  border-top: 0.5px solid var(--rule);
}
.hp-faux-fact { display: flex; flex-direction: column; gap: 3px; }
.hp-faux-fact-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  color: var(--ink-muted);
}
.hp-faux-fact-value {
  font-family: var(--font-serif);
  font-size: 17px;
  color: var(--ink);
}
.hp-faux-italic { font-style: italic; }
.hp-faux-omitted {
  margin-top: 32px;
  padding: 24px 16px;
  border-top: 0.5px solid var(--rule);
  border-bottom: 0.5px solid var(--rule);
  text-align: center;
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.4em;
  color: var(--ink-faint);
}

/* Faux tudside sections (mockup placeholders for the real app's existing UI) */
.hp-faux-section {
  margin-top: 32px;
  padding-top: 18px;
  border-top: 0.5px solid var(--rule);
  position: relative;
}
.hp-faux-section-head {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 14px;
}
.hp-faux-section-head h3 {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  color: var(--ink);
}
.hp-faux-section-rule {
  flex: 1;
  height: 0;
  border-bottom: 0.5px solid var(--rule);
}
.hp-faux-section-meta {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-faux-section-placeholder {
  padding: 36px 20px;
  text-align: center;
  background: rgba(245, 236, 214, 0.015);
  border: 0.5px dashed rgba(245, 236, 214, 0.12);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.36em;
  text-transform: uppercase;
  color: var(--ink-faint);
  line-height: 1.8;
}
.hp-faux-section-placeholder em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  text-transform: none;
  color: var(--ink-muted);
}

/* Faux gallery (after kalender) */
.hp-faux-gallery {
  margin-top: 56px;
  padding-top: 40px;
  border-top: 0.5px solid var(--rule);
}
.hp-faux-gallery-head {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 20px;
}
.hp-faux-gallery-eyebrow {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-faux-gallery-title {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 36px;
  color: var(--ink);
  line-height: 1;
}
.hp-faux-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
}
.hp-faux-gallery-tile {
  aspect-ratio: 4 / 3;
  background: var(--bg-soft);
  border: 0.5px solid var(--rule);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* ─── 2. Wheel-layer ─────────────────────────────────────────────────── */

.hp-wheel-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
}

.hp-wheel-inner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hp-wheel-inner .year-wheel {
  width: 100%;
  height: auto;
}

.hp-wheel-layer {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.hp-wheel-layer * { pointer-events: none; }
.hp-wheel-layer .hp-wedge path[style*="cursor"] { pointer-events: auto; }

.hp-wedge.is-hovered path:first-of-type {
  /* hover background fill — declared inline */
}

/* ─── 3. Stat-strip ──────────────────────────────────────────────────── */

.hp-stat-strip {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 20px;
  padding-top: 12px;
  padding-bottom: 4px;
  border-top: 0.5px solid var(--rule);
  border-bottom: 0.5px solid var(--rule);
}
.hp-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 6px 0;
}
.hp-stat-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-stat-value {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 17px;
  color: var(--ink);
  letter-spacing: -0.003em;
}
.hp-stat-value-name {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 17px;
  color: var(--brass);
}
.hp-stat-unit {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
  margin-left: 4px;
}

/* ─── 4. Ledger section ──────────────────────────────────────────────── */

.hp-ledger-section,
.hp-kalender-section {
  padding-top: 22px;
  padding-bottom: 0;
  border-top: 0.5px solid var(--rule);
}

.hp-kalender-head {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: stretch;
  margin-bottom: 18px;
}
.hp-kalender-head.is-compact { margin-bottom: 14px; }

.hp-kalender-titles { display: flex; flex-direction: column; gap: 10px; }
.hp-kalender-eyebrow {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-kalender-title {
  margin: 0;
  font-family: var(--font-serif);
  font-weight: 500;
  font-style: italic;
  font-size: 32px;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.008em;
}
.hp-kalender-lede {
  margin: 4px 0 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 48ch;
  text-wrap: pretty;
}
.hp-kalender-lede em { color: var(--brass); }

.hp-kalender-aside {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.hp-kalender-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.hp-kalender-actions .hp-btn-save {
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.hp-btn-cal {
  appearance: none;
  background: rgba(201, 161, 74, 0.06);
  border: 0.5px solid var(--brass);
  color: var(--brass);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 10px 16px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  transition: background 0.15s, color 0.15s, border-color 0.15s, opacity 0.15s;
}
.hp-btn-cal:hover:not(:disabled) {
  background: var(--brass);
  color: var(--bg-deep);
}
.hp-btn-cal:disabled { opacity: 0.32; cursor: default; }
.hp-btn-cal-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 16px;
  padding: 0 5px;
  background: var(--brass);
  color: var(--bg-deep);
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.04em;
  border-radius: 8px;
}
.hp-btn-cal:hover:not(:disabled) .hp-btn-cal-count {
  background: var(--bg-deep);
  color: var(--brass);
}

.hp-ledger-section {
  /* Legacy ledger header — kept for backwards-compat with old preview/code */
}
.hp-ledger-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.hp-ledger-eyebrow {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 6px;
}
.hp-ledger-title {
  margin: 0;
  font-family: var(--font-serif);
  font-weight: 500;
  font-style: italic;
  font-size: 32px;
  line-height: 1;
  color: var(--ink);
}

/* Variant switch */
.hp-variant-switch {
  display: inline-flex;
  border: 0.5px solid var(--rule);
  background: var(--bg-soft);
  border-radius: 0;
  overflow: hidden;
  margin-bottom: 24px;
}

/* Collapsed kalender preview */
.hp-kalender-section.is-collapsed {
  padding-top: 32px;
  padding-bottom: 28px;
}
.hp-kalender-head.is-compact {
  margin-bottom: 18px;
  align-items: center;
}
.hp-kalender-head.is-compact .hp-kalender-title { font-size: 26px; }

.hp-kalender-collapsed {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  padding-top: 14px;
  border-top: 0.5px solid var(--rule);
}

.hp-kalender-next {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  flex: 1;
}
.hp-kalender-next-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-kalender-next-body {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.hp-kalender-next-mark {
  color: var(--brass);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1;
  width: 22px;
  text-align: center;
}
.hp-kalender-next-title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  color: var(--ink);
}
.hp-kalender-next-dates {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-kalender-next.is-trip .hp-kalender-next-title em { color: var(--brass); }

.hp-kalender-toggle {
  appearance: none;
  background: transparent;
  border: 0.5px solid var(--rule);
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 10px 18px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  transition: border-color 0.14s, color 0.14s, background 0.14s;
  align-self: center;
  white-space: nowrap;
}
.hp-kalender-toggle:hover {
  border-color: var(--brass);
  color: var(--brass);
  background: rgba(201, 161, 74, 0.04);
}
.hp-kalender-toggle.is-collapse {
  display: flex;
  margin: 28px auto 0;
}
.hp-variant-btn {
  appearance: none;
  background: transparent;
  border: none;
  padding: 10px 18px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  border-right: 0.5px solid var(--rule);
  transition: background 0.15s, color 0.15s;
}
.hp-variant-btn:last-child { border-right: none; }
.hp-variant-roman {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  line-height: 1;
  color: var(--ink-muted);
}
.hp-variant-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-variant-btn:hover {
  background: rgba(245, 236, 214, 0.03);
}
.hp-variant-btn:hover .hp-variant-roman,
.hp-variant-btn:hover .hp-variant-label { color: var(--ink); }
.hp-variant-btn.is-active {
  background: rgba(201, 161, 74, 0.08);
}
.hp-variant-btn.is-active .hp-variant-roman { color: var(--brass); }
.hp-variant-btn.is-active .hp-variant-label { color: var(--brass-soft); }

.hp-ledger-empty {
  padding: 64px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
}
.hp-ledger-empty p {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  color: var(--ink-muted);
  max-width: 36ch;
}
.hp-empty-ornament {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.5em;
  color: var(--ink-faint);
}

/* ─── 5. Variant I: Hotelprotokol ────────────────────────────────────── */

.hp-hotel {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.hp-hotel-month {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.hp-hotel-month-head {
  display: grid;
  grid-template-columns: 56px auto 1fr;
  align-items: center;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 0.5px solid var(--rule);
  margin-bottom: 4px;
}
.hp-hotel-month-numeral {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 30px;
  color: var(--brass);
  text-align: center;
  letter-spacing: 0.02em;
}
.hp-hotel-month-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hp-hotel-month-name {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 26px;
  line-height: 1;
  color: var(--ink);
}
.hp-hotel-month-year {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
}
.hp-hotel-month-count {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-hotel-month-rule {
  height: 0;
}

.hp-hotel-rows {
  display: flex;
  flex-direction: column;
}

.hp-hotel-row {
  display: grid;
  grid-template-columns: 40px 84px 1fr;
  align-items: start;
  gap: 14px;
  padding: 18px 4px 20px;
  border-bottom: 0.5px solid var(--rule);
  position: relative;
}
.hp-hotel-row:last-child { border-bottom: none; }
.hp-hotel-row::before {
  content: '';
  position: absolute;
  left: 0; top: 14px; bottom: 14px;
  width: 1px;
  background: rgba(201, 161, 74, 0.18);
}
.hp-hotel-row.is-mine::before {
  background: var(--brass);
  width: 2px;
}
.hp-hotel-row.is-mine {
  background: rgba(201, 161, 74, 0.03);
}

.hp-hotel-row-num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--ink-faint);
  padding-top: 4px;
  padding-left: 10px;
}

.hp-hotel-row-rail {
  display: grid;
  grid-template-columns: auto auto auto;
  grid-template-rows: auto auto;
  gap: 0 4px;
  align-items: center;
  padding-top: 2px;
  border-right: 0.5px solid var(--rule);
  padding-right: 12px;
  min-height: 48px;
}
.hp-hotel-row-rail-day {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 28px;
  line-height: 1;
  color: var(--ink);
}
.hp-hotel-row-rail-sep {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  color: var(--ink-muted);
}
.hp-hotel-row-rail-month {
  grid-column: 1 / -1;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--ink-muted);
  margin-top: 4px;
}

.hp-hotel-row-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.hp-hotel-row-eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-muted);
  flex-wrap: wrap;
}
.hp-hotel-row-eyebrow em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  text-transform: none;
  color: var(--ink-soft);
}
.hp-hotel-row-byname em {
  color: var(--ink);
}

.hp-hotel-row-title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}
.hp-hotel-row-title-small {
  font-size: 17px;
}
.hp-hotel-row-title-small em {
  color: var(--brass);
}

.hp-hotel-row-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.hp-hotel-row-meta em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  color: var(--ink-soft);
  text-transform: none;
}

.hp-hotel-row-actions {
  display: flex;
  gap: 8px;
  margin-top: 6px;
  flex-wrap: wrap;
}

/* Trip-row variants — season-tinted */
.hp-hotel-row.is-trip {
  background: rgba(245, 236, 214, 0.015);
}
.hp-hotel-row.is-trip::before { background: rgba(245, 236, 214, 0.18); }
.hp-hotel-row.is-trip.is-spring::before { background: var(--moss); }
.hp-hotel-row.is-trip.is-summer::before { background: var(--bark-warm); }
.hp-hotel-row.is-trip.is-autumn::before { background: var(--terracotta); }
.hp-hotel-row.is-trip.is-winter::before { background: var(--night); }
.hp-hotel-row.is-trip .hp-hotel-row-title { color: var(--ink); }

.hp-tag-trip {
  color: var(--brass);
  letter-spacing: 0.24em;
}

/* ─── 6. Variant II: Avisspalte ──────────────────────────────────────── */

.hp-avis {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}

.hp-avis-trip {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 48px 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  background: var(--bg-soft);
  border: 0.5px solid var(--rule);
  border-left: 2px solid var(--brass);
  position: relative;
}
.hp-avis-trip.is-spring { border-left-color: var(--moss); }
.hp-avis-trip.is-summer { border-left-color: var(--bark-warm); }
.hp-avis-trip.is-autumn { border-left-color: var(--terracotta); }
.hp-avis-trip.is-winter { border-left-color: #6a7a9a; }

.hp-avis-trip-mark {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 28px;
  color: var(--brass);
  text-align: center;
  line-height: 1;
}
.hp-avis-trip-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 6px;
}
.hp-avis-trip-title {
  margin: 0 0 4px;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 24px;
  line-height: 1.1;
  color: var(--ink);
}
.hp-avis-trip-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.hp-avis-trip-meta em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  color: var(--ink-soft);
  text-transform: none;
}
.hp-avis-trip-lock {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--brass-soft);
}

.hp-avis-card {
  background: var(--bg-soft);
  border: 0.5px solid var(--rule);
  display: grid;
  grid-template-columns: 76px 1fr;
  position: relative;
  transition: border-color 0.15s;
}
.hp-avis-card:hover { border-color: rgba(201, 161, 74, 0.32); }
.hp-avis-card.is-mine {
  border-left: 2px solid var(--brass);
}
.hp-avis-card-rail {
  background: rgba(20, 16, 12, 0.4);
  border-right: 0.5px solid var(--rule);
  padding: 18px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1px;
}
.hp-avis-card-day {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 36px;
  line-height: 1;
  color: var(--brass);
}
.hp-avis-card-month {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--ink-soft);
  margin-top: 2px;
}
.hp-avis-card-year {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--ink-faint);
}
.hp-avis-card-nights {
  margin-top: auto;
  padding-top: 12px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  color: var(--ink-soft);
  text-align: center;
  line-height: 1.05;
}
.hp-avis-card-nights span {
  display: block;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 8.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: 2px;
}

.hp-avis-card-body {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.hp-avis-card-eyebrow {
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--brass);
}
.hp-avis-card-title {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 21px;
  line-height: 1.15;
  color: var(--ink);
  text-wrap: pretty;
}
.hp-avis-card-byline {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-avis-card-byline em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  color: var(--ink-soft);
  text-transform: none;
}
.hp-avis-card-meta {
  border-top: 0.5px solid var(--rule);
  padding-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hp-avis-card-meta-row {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 12px;
  align-items: baseline;
}
.hp-avis-card-meta-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-avis-card-meta-value {
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--ink-soft);
}
.hp-avis-card-meta-value em { font-style: italic; color: var(--brass); }

.hp-avis-card-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  flex-wrap: wrap;
}

/* ─── 7. Variant III: Almanak ────────────────────────────────────────── */

.hp-almanak {
  display: flex;
  flex-direction: column;
  gap: 56px;
}

.hp-alm-month {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.hp-alm-month-head {
  display: grid;
  grid-template-columns: 56px 1fr;
  align-items: center;
  gap: 14px;
  padding-bottom: 12px;
  border-bottom: 0.5px solid var(--rule);
}
.hp-alm-month-numeral {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 30px;
  color: var(--brass);
  text-align: center;
}
.hp-alm-month-name {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 26px;
  line-height: 1;
  color: var(--ink);
}
.hp-alm-month-year {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
}
.hp-alm-month-count {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: 2px;
}

.hp-alm-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}

.hp-alm-wdhead {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
  text-align: center;
  padding: 6px 0 8px;
  border-bottom: 0.5px solid var(--rule);
}
.hp-alm-wdhead.is-weekend { color: var(--brass-soft); }

.hp-alm-day {
  appearance: none;
  background: rgba(245, 236, 214, 0.015);
  border: 0.5px solid var(--rule);
  color: var(--ink-soft);
  min-height: 86px;
  padding: 6px 8px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  cursor: default;
  transition: background 0.14s, border-color 0.14s;
  text-align: left;
  position: relative;
}
.hp-alm-day-blank {
  background: transparent;
  border-color: transparent;
}
.hp-alm-day-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  line-height: 1;
  color: var(--ink-soft);
}
.hp-alm-day.is-weekend .hp-alm-day-num { color: var(--brass-soft); }
.hp-alm-day.is-today {
  border-color: var(--brass);
  background: rgba(201, 161, 74, 0.08);
}
.hp-alm-day.is-today .hp-alm-day-num { color: var(--brass); }
.hp-alm-day.is-past { opacity: 0.4; }
.hp-alm-day.is-free { cursor: pointer; }
.hp-alm-day.is-free:hover {
  background: rgba(201, 161, 74, 0.06);
  border-color: rgba(201, 161, 74, 0.32);
}
.hp-alm-day.is-free::after {
  content: '+';
  position: absolute;
  right: 6px;
  bottom: 4px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--brass);
  opacity: 0;
  transition: opacity 0.14s;
}
.hp-alm-day.is-free:hover::after { opacity: 0.75; }

.hp-alm-day.is-trip {
  background: rgba(245, 236, 214, 0.04);
  border-color: rgba(245, 236, 214, 0.2);
}
.hp-alm-day.is-trip.is-spring  { background: rgba(90, 106, 62, 0.18);  border-color: rgba(90, 106, 62, 0.45); }
.hp-alm-day.is-trip.is-summer  { background: rgba(122, 90, 50, 0.20);  border-color: rgba(122, 90, 50, 0.5); }
.hp-alm-day.is-trip.is-autumn  { background: rgba(138, 62, 42, 0.18);  border-color: rgba(138, 62, 42, 0.5); }
.hp-alm-day.is-trip.is-winter  { background: rgba(31, 37, 50, 0.55);   border-color: rgba(74, 86, 108, 0.5); }

.hp-alm-day-trip {
  position: absolute;
  top: 4px;
  right: 6px;
  color: var(--brass);
  font-family: var(--font-serif);
  font-size: 12px;
  line-height: 1;
}

.hp-alm-day.is-booked {
  background: rgba(201, 161, 74, 0.05);
  border-color: rgba(201, 161, 74, 0.28);
}

.hp-alm-day-chips {
  margin-top: auto;
  display: flex;
  gap: 3px;
  flex-wrap: wrap;
  align-items: center;
}
.hp-alm-day-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.04em;
  background: rgba(20, 16, 12, 0.7);
  border: 0.5px solid rgba(201, 161, 74, 0.4);
  color: var(--ink-soft);
  padding: 1px 5px;
  border-radius: 8px;
  line-height: 1.4;
}
.hp-alm-day-chip.is-mine {
  background: rgba(201, 161, 74, 0.18);
  border-color: var(--brass);
  color: var(--brass);
}
.hp-alm-day-chip-more {
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.06em;
  color: var(--ink-muted);
}

.hp-alm-caption {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 12px;
  border-top: 0.5px solid var(--rule);
}
.hp-alm-caption-row {
  display: grid;
  grid-template-columns: 22px 1fr auto auto;
  gap: 12px;
  align-items: center;
  padding: 8px 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
  border-bottom: 0.5px dashed rgba(245, 236, 214, 0.08);
}
.hp-alm-caption-row:last-child { border-bottom: none; }
.hp-alm-caption-row.is-mine { background: rgba(201, 161, 74, 0.03); }
.hp-alm-caption-mark {
  font-family: var(--font-serif);
  font-size: 16px;
  color: var(--brass);
  text-align: center;
  line-height: 1;
}
.hp-alm-caption-label em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-soft);
  text-transform: none;
  letter-spacing: 0.002em;
}
.hp-alm-caption-label {
  text-transform: none;
  color: var(--ink-muted);
  letter-spacing: 0.06em;
  font-size: 11px;
}
.hp-alm-caption-guests em { color: var(--ink-muted); }
.hp-alm-caption-dates {
  color: var(--ink-muted);
}
.hp-alm-caption-actions {
  display: flex;
  gap: 6px;
}

/* ─── 8. Drawer ──────────────────────────────────────────────────────── */

.hp-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 8, 6, 0.55);
  z-index: 7000;
  display: flex;
  justify-content: flex-end;
  animation: hp-fade-in 0.2s ease;
}
@keyframes hp-fade-in {
  from { opacity: 0; } to { opacity: 1; }
}
@keyframes hp-slide-in {
  from { transform: translateX(40px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

.hp-drawer {
  width: 100%;
  max-width: 440px;
  height: 100%;
  background: var(--bg-card);
  border-left: 0.5px solid rgba(245, 236, 214, 0.16);
  display: flex;
  flex-direction: column;
  box-shadow: -20px 0 60px rgba(0, 0, 0, 0.6);
  animation: hp-slide-in 0.25s ease;
}

.hp-drawer-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 22px 24px 16px;
  border-bottom: 0.5px solid var(--rule);
}
.hp-drawer-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 4px;
}
.hp-drawer-title {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 24px;
  line-height: 1.05;
  color: var(--ink);
}

.hp-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 0;
}
.hp-drawer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.hp-drawer-list > li { border-bottom: 0.5px solid var(--rule); }
.hp-drawer-list > li:last-child { border-bottom: none; }

.hp-drawer-empty {
  padding: 60px 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.hp-drawer-empty p {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  color: var(--ink-muted);
}

.hp-drawer-entry {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 12px;
  padding: 16px 24px;
  align-items: flex-start;
}
.hp-drawer-entry-mark {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--brass);
  text-align: center;
  line-height: 1.3;
}
.hp-drawer-entry-trip { background: rgba(245, 236, 214, 0.015); }
.hp-drawer-entry-trip.is-spring { box-shadow: inset 2px 0 0 var(--moss); }
.hp-drawer-entry-trip.is-summer { box-shadow: inset 2px 0 0 var(--bark-warm); }
.hp-drawer-entry-trip.is-autumn { box-shadow: inset 2px 0 0 var(--terracotta); }
.hp-drawer-entry-trip.is-winter { box-shadow: inset 2px 0 0 #6a7a9a; }
.hp-drawer-entry-booking.is-mine { box-shadow: inset 2px 0 0 var(--brass); }

.hp-drawer-entry-eyebrow {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-muted);
  flex-wrap: wrap;
}
.hp-drawer-entry-eyebrow em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  text-transform: none;
  color: var(--ink-soft);
}
.hp-drawer-entry-title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 19px;
  color: var(--ink);
  margin: 4px 0 4px;
  line-height: 1.2;
}
.hp-drawer-entry-title-small {
  font-family: var(--font-serif);
  font-size: 15px;
  color: var(--ink-soft);
  margin: 2px 0;
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.hp-drawer-entry-nights {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-drawer-entry-meta {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 4px;
}
.hp-drawer-entry-meta em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.002em;
  text-transform: none;
  color: var(--ink-soft);
}
.hp-drawer-entry-guests { color: var(--ink-muted); }
.hp-drawer-entry-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.hp-drawer-entry-lock {
  color: var(--ink-faint);
  align-self: center;
}

.hp-drawer-foot {
  border-top: 0.5px solid var(--rule);
  padding: 14px 24px 18px;
}
.hp-btn-full { width: 100%; }

/* ─── 9. Modal ───────────────────────────────────────────────────────── */

.hp-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 8, 6, 0.78);
  z-index: 8000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: hp-fade-in 0.18s ease;
}

.hp-modal {
  width: 100%;
  max-width: 540px;
  max-height: 92vh;
  background: var(--bg-card);
  border: 0.5px solid rgba(245, 236, 214, 0.16);
  display: flex;
  flex-direction: column;
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.7);
  overflow: hidden;
}

.hp-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 22px 24px 16px;
  border-bottom: 0.5px solid var(--rule);
}
.hp-modal-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 4px;
}
.hp-modal-title {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 24px;
  line-height: 1.1;
  color: var(--ink);
}
.hp-modal-x {
  appearance: none;
  background: none;
  border: none;
  color: var(--ink-muted);
  cursor: pointer;
  padding: 6px;
  transition: color 0.12s;
}
.hp-modal-x:hover { color: var(--ink); }

.hp-modal-body {
  padding: 18px 24px;
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.hp-field-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 12px;
  align-items: end;
}
.hp-field-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 10px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  color: var(--ink-muted);
}

.hp-field { display: flex; flex-direction: column; gap: 6px; }
.hp-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.hp-input {
  appearance: none;
  background: var(--bg-soft);
  border: 0.5px solid var(--rule);
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 16px;
  padding: 10px 12px;
  outline: none;
  transition: border-color 0.14s;
}
.hp-input:focus { border-color: var(--brass); }
.hp-input-date {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  color-scheme: dark;
}
.hp-input::placeholder { color: var(--ink-faint); font-style: italic; }

.hp-summary {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding: 6px 0;
  border-bottom: 0.5px solid var(--rule);
}
.hp-summary-strong {
  color: var(--brass);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0.005em;
  text-transform: none;
}
.hp-summary-dot { opacity: 0.5; }

.hp-conflict {
  padding: 12px 14px;
  border: 0.5px solid;
  background: rgba(20, 16, 12, 0.4);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hp-conflict-trip    { border-color: rgba(201, 161, 74, 0.4);  }
.hp-conflict-booking { border-color: rgba(138, 62, 42, 0.5); }
.hp-conflict-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--terracotta);
}
.hp-conflict-trip .hp-conflict-eyebrow { color: var(--brass); }
.hp-conflict-body {
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--ink-soft);
}
.hp-conflict-body em {
  font-style: italic;
  color: var(--ink);
}

.hp-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 24px 18px;
  border-top: 0.5px solid var(--rule);
}

/* ─── 10. Shared buttons / tags ──────────────────────────────────────── */

.hp-btn-save, .hp-btn-cancel, .hp-btn-ghost {
  appearance: none;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 10px 18px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s, opacity 0.15s;
}
.hp-btn-save {
  background: var(--brass);
  border: 0.5px solid var(--brass);
  color: var(--bg-deep);
  font-weight: 500;
}
.hp-btn-save:hover:not(:disabled) {
  background: var(--brass-soft);
  border-color: var(--brass-soft);
}
.hp-btn-save:disabled { opacity: 0.32; cursor: default; }
.hp-btn-cancel {
  background: transparent;
  border: 0.5px solid var(--rule);
  color: var(--ink-muted);
}
.hp-btn-cancel:hover {
  border-color: var(--ink-muted);
  color: var(--ink);
}
.hp-btn-ghost {
  background: transparent;
  border: 0.5px solid var(--rule);
  color: var(--ink-soft);
}
.hp-btn-ghost:hover {
  border-color: var(--brass);
  color: var(--brass);
}

.hp-mini-btn {
  appearance: none;
  background: transparent;
  border: 0.5px solid var(--rule);
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 5px 10px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: border-color 0.12s, color 0.12s, background 0.12s;
}
.hp-mini-btn:hover {
  border-color: var(--brass);
  color: var(--brass);
}
.hp-mini-btn-del:hover {
  border-color: var(--terracotta);
  color: var(--terracotta);
}

.hp-dot {
  color: var(--ink-faint);
  opacity: 0.5;
}

/* ─── 12. Invite grid (in modal) ─────────────────────────────────────── */

.hp-label-soft {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0.002em;
  text-transform: none;
  color: var(--ink-faint);
  margin-left: 8px;
}

.hp-invite-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 6px;
}
.hp-invite-chip {
  appearance: none;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-soft);
  border: 0.5px solid var(--rule);
  color: var(--ink-soft);
  padding: 7px 10px;
  cursor: pointer;
  transition: border-color 0.14s, background 0.14s, color 0.14s;
  text-align: left;
}
.hp-invite-chip:hover {
  border-color: rgba(201, 161, 74, 0.4);
  background: rgba(201, 161, 74, 0.04);
  color: var(--ink);
}
.hp-invite-chip.is-on {
  background: rgba(90, 106, 62, 0.18);
  border-color: var(--moss);
  color: var(--ink);
}
.hp-invite-chip-name {
  flex: 1;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
}
.hp-invite-chip-check {
  width: 14px;
  height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--moss);
}
.hp-invite-chip.is-on .hp-invite-chip-check { color: #a4b785; }

.hp-invite-summary {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: 8px;
}
.hp-invite-summary em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0.002em;
  color: var(--brass);
}

/* ─── 13. Invited row (on booking entries) ───────────────────────────── */

.hp-invited-row {
  display: grid;
  grid-template-columns: 88px 1fr;
  align-items: start;
  gap: 12px;
  padding: 10px 0 6px;
  margin-top: 6px;
  border-top: 0.5px dashed rgba(245, 236, 214, 0.1);
}
.hp-invited-row.is-compact { padding: 6px 0 2px; }
.hp-invited-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding-top: 4px;
}
.hp-invited-groups {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}
.hp-invited-group {
  display: grid;
  grid-template-columns: 14px auto 1fr;
  gap: 6px 10px;
  align-items: baseline;
}
.hp-invited-mark {
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1;
  text-align: center;
  font-weight: 500;
}
.hp-invited-count {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  white-space: nowrap;
}
.hp-invited-names {
  font-family: var(--font-serif);
  font-size: 14px;
  line-height: 1.45;
  color: var(--ink-soft);
  text-wrap: pretty;
  letter-spacing: 0.002em;
  /* Wrap navne over flere linjer i stedet for at flyde ud af sektionen.
     JSX'en sætter ingen whitespace mellem name+separator-spans, så browseren
     mangler break-points uden flex-wrap. */
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 0;
  row-gap: 2px;
  min-width: 0;
}
.hp-invited-name { font-style: italic; }
.hp-invited-name.is-me { color: var(--brass); }
.hp-invited-name-sep {
  margin: 0 6px;
  color: var(--ink-faint);
  opacity: 0.5;
  font-style: normal;
}
.hp-invited-group.is-yes .hp-invited-mark,
.hp-invited-group.is-yes .hp-invited-count { color: var(--moss); }
.hp-invited-group.is-yes .hp-invited-names { color: var(--ink); }
.hp-invited-group.is-no .hp-invited-mark,
.hp-invited-group.is-no .hp-invited-count { color: var(--terracotta); }
.hp-invited-group.is-no .hp-invited-names {
  color: var(--ink-muted);
  text-decoration: line-through;
  text-decoration-color: rgba(138, 62, 42, 0.4);
}
.hp-invited-group.is-pending .hp-invited-mark,
.hp-invited-group.is-pending .hp-invited-count { color: var(--brass-soft); }
.hp-invited-group.is-pending .hp-invited-names { color: var(--ink-muted); }

/* Guests line label */
.hp-guests-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-right: 6px;
}
.hp-drawer-entry-meta .hp-guests-lbl { margin-right: 4px; }

/* ─── 14. RSVP row (when current user is invited) ────────────────────── */

.hp-rsvp-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 8px 10px;
  background: rgba(201, 161, 74, 0.08);
  border-left: 2px solid var(--brass);
  margin-top: 8px;
}
.hp-rsvp-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--brass);
}
.hp-rsvp-buttons {
  display: inline-flex;
  gap: 6px;
}
.hp-rsvp-btn {
  appearance: none;
  background: transparent;
  border: 0.5px solid rgba(245, 236, 214, 0.25);
  color: var(--ink-soft);
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 6px 12px;
  cursor: pointer;
  transition: background 0.14s, border-color 0.14s, color 0.14s;
}
.hp-rsvp-btn:hover { border-color: var(--ink); color: var(--ink); }
.hp-rsvp-btn.is-yes {
  background: var(--moss);
  border-color: var(--moss);
  color: var(--ink);
}
.hp-rsvp-btn.is-no {
  background: var(--rust);
  border-color: var(--terracotta);
  color: var(--ink);
}

.hp-mini-btn.is-yes {
  background: rgba(90, 106, 62, 0.4);
  border-color: var(--moss);
  color: var(--ink);
}

.hp-alm-caption-invited {
  color: var(--brass-soft);
  font-style: italic;
  letter-spacing: 0.005em;
  font-family: var(--font-serif);
  font-size: 13px;
}

.hp-drawer-entry-booking.is-invited {
  background: rgba(201, 161, 74, 0.04);
}

/* ─── 11. Responsive ─────────────────────────────────────────────────── */

@media (max-width: 980px) {
  .hp-stage-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .hp-stage-left {
    position: relative;
    top: auto;
    max-width: 620px;
    margin: 0 auto;
    width: 100%;
  }
  .hp-stage-title { font-size: 32px; }
  .hp-kalender-head { grid-template-columns: 1fr; gap: 24px; }
  .hp-faux-title { font-size: 32px; }
  .hp-kalender-title { font-size: 32px; }
}

@media (max-width: 720px) {
  .hp-invited-row { grid-template-columns: 1fr; gap: 4px; }
  .hp-invited-lbl { padding-top: 0; }
  .hp-app { padding: 0 16px 60px; }
  .hp-stat-strip {
    grid-template-columns: 1fr 1fr;
  }
  .hp-stat:last-child { grid-column: span 2; }

  .hp-ledger-head { flex-direction: column; align-items: stretch; }
  .hp-variant-switch { width: 100%; }
  .hp-variant-btn { flex: 1; }

  .hp-hotel-row { grid-template-columns: 28px 68px 1fr; gap: 10px; }
  .hp-hotel-row-rail-day { font-size: 22px; }
  .hp-hotel-row-title { font-size: 18px; }

  .hp-avis { grid-template-columns: 1fr; }
  .hp-avis-card { grid-template-columns: 60px 1fr; }
  .hp-avis-card-day { font-size: 28px; }
  .hp-avis-card-title { font-size: 18px; }

  .hp-alm-day { min-height: 56px; padding: 4px 5px; }
  .hp-alm-day-num { font-size: 13px; }
  .hp-alm-day-chip { font-size: 7.5px; padding: 0 4px; }

  .hp-drawer { max-width: 100%; }

  .hp-field-row { grid-template-columns: 1fr; }
  .hp-field-divider { display: none; }
}
