/* ============================================================
   book.peerjuelich.com — design system
   matched to live peerjuelich.com (dark + glassmorphism)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }

:root {
  --color-bg: #0b0d12;
  --color-surface: #ffffff0a;
  --color-border: #ffffff14;
  --color-border-strong: #ffffff24;
  --color-text: #fafaf7;
  --color-text-2: #b6b6b0;
  --color-text-3: #7a7a74;
  --color-accent: #e8c77e;
  --color-accent-2: #c89a4a;
  --color-danger: #d97a7a;
  --color-success: #9dc78b;

  --font-display: "Inter Tight", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --font-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, "Liberation Mono", monospace;

  --radius: 18px;
  --radius-md: 10px;
  --radius-pill: 999px;

  --pad-x: clamp(1.25rem, 4vw, 2rem);
  --max-w: 1240px;
}

body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 15px;
  line-height: 1.55;
  min-height: 100dvh;
  position: relative;
  overflow-x: clip;
}

a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
ul, ol { list-style: none; }
button {
  font: inherit; cursor: pointer; border: 0;
  background: none; color: inherit;
}
input, textarea, select { font: inherit; color: inherit; }
::selection { background: var(--color-accent); color: var(--color-bg); }

/* ============================================================
   AMBIENT (glowing blobs) + GRAIN
   ============================================================ */
.ambient {
  pointer-events: none; z-index: 0;
  position: fixed; inset: 0; overflow: hidden;
}
.ambient::before,
.ambient::after,
.ambient .blob-1,
.ambient .blob-2 {
  content: ''; position: absolute;
  filter: blur(120px);
  opacity: .55;
  border-radius: 50%;
}
.ambient::before {
  background: radial-gradient(circle, #3c32828c, #1e194600 70%);
  width: 60vw; height: 60vw; top: -10vw; left: -10vw;
}
.ambient::after {
  background: radial-gradient(circle, #14506473, #0a283200 70%);
  width: 55vw; height: 55vw; top: 30vh; right: -15vw;
}
.ambient .blob-1 {
  background: radial-gradient(circle, #b4502847, #501e0f00 70%);
  width: 50vw; height: 50vw; top: 90vh; left: 10vw;
}
.ambient .blob-2 {
  background: radial-gradient(circle, #285a8c52, #0f233c00 70%);
  width: 40vw; height: 40vw; top: 160vh; right: 15vw;
}

.grain-overlay {
  pointer-events: none; z-index: 1;
  opacity: .05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  position: fixed; inset: 0;
}

.page { position: relative; z-index: 2; }

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.container-x {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--pad-x);
}

.pad-card { padding: clamp(1.25rem, min(3vw, 3.5vh), 2.5rem); }
.pad-card-lg { padding: clamp(1.25rem, min(3.5vw, 4vh), 3.5rem); }

/* ============================================================
   GLASS
   ============================================================ */
.glass {
  -webkit-backdrop-filter: blur(22px) saturate(150%);
          backdrop-filter: blur(22px) saturate(150%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: linear-gradient(145deg, #ffffff0b, #ffffff05);
  box-shadow: inset 0 1px #ffffff0f, 0 24px 64px -32px #0009, 0 8px 32px -16px #0006;
  position: relative;
}
.glass-soft {
  -webkit-backdrop-filter: blur(18px) saturate(140%);
          backdrop-filter: blur(18px) saturate(140%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: linear-gradient(145deg, #ffffff08, #ffffff03);
  box-shadow: inset 0 1px #ffffff0a, 0 12px 32px -16px #00000080;
}
.glass-strong {
  -webkit-backdrop-filter: blur(28px) saturate(170%);
          backdrop-filter: blur(28px) saturate(170%);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius);
  background: linear-gradient(145deg, #ffffff12, #ffffff08);
  box-shadow: inset 0 1px #ffffff14, 0 32px 80px -32px #000000b3;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.display-xl {
  font-family: var(--font-display);
  letter-spacing: -.036em;
  font-size: clamp(1.875rem, min(4.6vw, 6vh), 4.25rem);
  font-weight: 600;
  line-height: 1;
}
.display-lg {
  font-family: var(--font-display);
  letter-spacing: -.03em;
  font-size: clamp(1.5rem, min(3vw, 4.4vh), 2.625rem);
  font-weight: 600;
  line-height: 1.04;
}
.display-md {
  font-family: var(--font-display);
  letter-spacing: -.02em;
  font-size: clamp(1.25rem, 2.4vw, 1.875rem);
  font-weight: 600;
  line-height: 1.1;
}
.lede {
  color: var(--color-text-2);
  max-width: 60ch;
  font-size: clamp(.9375rem, min(1.1vw, 1.8vh), 1.125rem);
  line-height: 1.55;
}

.eyebrow {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
  font-size: clamp(.625rem, 1.5vw, .75rem);
  font-weight: 500;
}
.eyebrow-accent {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-accent-2);
  font-size: clamp(.625rem, 1.5vw, .75rem);
  font-weight: 500;
}
.eyebrow-dot::before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  width: 6px; height: 6px;
  margin-right: .6em;
  background: var(--color-accent);
  box-shadow: 0 0 12px var(--color-accent);
  border-radius: 50%;
}

.mono { font-family: var(--font-mono); }
.muted { color: var(--color-text-2); }
.muted-2 { color: var(--color-text-3); }
.italic-em { font-style: italic; font-weight: 500; color: var(--color-text-2); }

/* ============================================================
   NAV
   ============================================================ */
.site-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  padding-top: clamp(.75rem, 1.5vw, 1.25rem);
}
.site-nav__inner {
  padding: 9px 14px;
  border-radius: var(--radius-pill);
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
@media (min-width: 768px) {
  .site-nav__inner { padding: 10px 20px; }
}
.site-nav__brand {
  display: flex; align-items: center; gap: 10px;
  min-width: 0;
}
.site-nav__badge {
  width: 26px; height: 26px;
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 600;
  font-size: 12px; letter-spacing: -.02em;
  color: var(--color-text);
  background: linear-gradient(135deg, #ffffff1a, #ffffff05);
  border: 1px solid var(--color-border);
  flex-shrink: 0;
}
.site-nav__name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 15px;
  letter-spacing: -.01em;
  color: var(--color-text);
}
.site-nav__links {
  display: flex; align-items: center;
  gap: 4px;
  font-size: 13px;
}
.site-nav__link {
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  color: var(--color-text-2);
  transition: color .2s ease;
}
.site-nav__link:hover { color: var(--color-text); }
.site-nav__link.is-active {
  background: #ffffff10;
  color: var(--color-text);
}
.site-nav__cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  background: #ffffff10;
  border: 1px solid var(--color-border-strong);
  font-size: 13px;
  color: var(--color-text);
  transition: color .2s ease, border-color .2s ease;
}
.site-nav__cta:hover { color: var(--color-accent); }
@media (max-width: 640px) {
  .site-nav__link { display: none; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  border-radius: var(--radius-pill);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -.005em;
  cursor: pointer;
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
  white-space: nowrap;
}
.btn--primary {
  background: var(--color-text);
  color: var(--color-bg);
}
.btn--primary:hover:not(:disabled) {
  background: var(--color-accent);
  color: var(--color-bg);
}
.btn--ghost {
  background: #ffffff08;
  color: var(--color-text);
  border: 1px solid var(--color-border);
}
.btn--ghost:hover:not(:disabled) {
  background: #ffffff14;
  border-color: var(--color-border-strong);
}
.btn--danger {
  background: transparent;
  color: var(--color-danger);
  border: 1px solid #ffffff14;
}
.btn--danger:hover:not(:disabled) {
  background: #d97a7a14;
  color: var(--color-danger);
  border-color: #d97a7a40;
}
.btn--sm { padding: 8px 14px; font-size: 12px; }
.btn--lg { padding: 14px 26px; font-size: 15px; }
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn__arrow { transition: transform .2s ease; }
.btn:hover:not(:disabled) .btn__arrow { transform: translate(2px, -2px); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding-top: clamp(5.25rem, 9vh, 7rem);
  padding-bottom: clamp(2rem, 5vh, 4rem);
}
.hero__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2vw, 1.75rem);
}
@media (min-width: 1024px) {
  .hero__inner {
    grid-template-columns: 7fr 5fr;
    align-items: stretch;
  }
}
.hero__main { display: flex; flex-direction: column; gap: 1rem; }
.hero__side  { display: flex; flex-direction: column; gap: 1rem; }

.hero__intro h1 {
  max-width: 18ch;
  margin-top: clamp(1rem, 2.5vh, 1.5rem);
}
.hero__intro .lede { margin-top: clamp(1rem, 2vh, 1.5rem); }

/* ============================================================
   SECTIONS
   ============================================================ */
.section {
  padding-top: clamp(3.5rem, 7vh, 6rem);
  padding-bottom: clamp(3.5rem, 7vh, 6rem);
}
.section__head {
  display: flex; flex-direction: column; gap: .75rem;
  margin-bottom: clamp(1.5rem, 3vh, 2.5rem);
  max-width: 720px;
}
.section__title em {
  font-style: italic; font-weight: 500;
  color: var(--color-text-2);
}
.section__sub {
  color: var(--color-text-2);
  font-size: 15px;
  line-height: 1.55;
  max-width: 60ch;
}

/* ============================================================
   STATS CHIPS (in hero glass card)
   ============================================================ */
.chips {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media (min-width: 480px) { .chips { grid-template-columns: repeat(4, 1fr); } }
.chip {
  display: flex; flex-direction: column; gap: 4px;
  padding: 14px 16px;
  border-radius: 12px;
  background: #ffffff05;
  border: 1px solid var(--color-border);
}
.chip__label {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
}
.chip__value {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 600;
  letter-spacing: -.02em;
  color: var(--color-text);
}
.chip__value em {
  color: var(--color-accent);
  font-style: normal; font-weight: 500;
  font-size: 16px;
  margin-left: 2px;
}

/* ============================================================
   BOOKING WIDGET
   ============================================================ */
.booking-card {
  border-radius: var(--radius);
  overflow: hidden;
}
.booking-card__head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 14px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--color-border);
}
.booking-card__meta {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 18px;
  font-size: 13px;
  color: var(--color-text-2);
}
.booking-card__meta-row {
  display: inline-flex; align-items: center; gap: 8px;
}
.booking-card__meta-row svg { width: 15px; height: 15px; stroke: var(--color-accent); }
.booking-card__meta-row strong { color: var(--color-text); font-weight: 500; }

/* Steps */
.steps {
  display: flex; gap: 10px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--color-border);
}
.steps__item {
  flex: 1;
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-text-3);
  border-top: 1px solid var(--color-border);
  transition: color .25s ease, border-color .25s ease;
}
.steps__item.is-active {
  color: var(--color-text);
  border-top-color: var(--color-accent);
}
.steps__item.is-done {
  color: var(--color-text-2);
  border-top-color: var(--color-accent-2);
}
.steps__num {
  color: var(--color-accent);
  font-weight: 500;
}

/* Body */
.booking-body {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  min-height: 480px;
}
@media (max-width: 820px) { .booking-body { grid-template-columns: 1fr; } }

/* Calendar */
.cal {
  padding: 24px 24px;
  border-right: 1px solid var(--color-border);
}
@media (max-width: 820px) {
  .cal { border-right: 0; border-bottom: 1px solid var(--color-border); }
}
.cal__head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
}
.cal__month {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -.02em;
  color: var(--color-text);
}
.cal__nav { display: flex; gap: 6px; }
.cal__nav-btn {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  background: #ffffff08;
  border: 1px solid var(--color-border);
  color: var(--color-text-2);
  transition: background .2s ease, color .2s ease, border-color .2s ease;
  font-size: 15px;
}
.cal__nav-btn:hover:not(:disabled) {
  background: #ffffff14;
  color: var(--color-text);
  border-color: var(--color-border-strong);
}
.cal__nav-btn:disabled { opacity: .3; cursor: not-allowed; }

.cal__weekdays {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 4px; margin-bottom: 6px;
}
.cal__weekday {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
  padding: 8px 0;
}
.cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal__day {
  aspect-ratio: 1 / 1;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  font-weight: 400;
  color: var(--color-text-2);
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  font-variant-numeric: tabular-nums;
  position: relative;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
  cursor: pointer;
}
.cal__day:hover:not(:disabled):not(.is-selected) {
  background: #ffffff08;
  color: var(--color-text);
  border-color: var(--color-border);
}
.cal__day.is-empty { visibility: hidden; pointer-events: none; }
.cal__day.is-disabled, .cal__day:disabled {
  color: var(--color-text-3); opacity: .35; cursor: not-allowed;
}
.cal__day.is-today { color: var(--color-accent); }
.cal__day.is-today::after {
  content: ''; position: absolute; bottom: 5px;
  width: 3px; height: 3px; border-radius: 50%;
  background: var(--color-accent);
}
.cal__day.is-selected {
  background: var(--color-text);
  color: var(--color-bg);
  font-weight: 500;
  border-color: var(--color-text);
}
.cal__day.is-selected::after { background: var(--color-accent-2); }

/* Slots */
.slots {
  padding: 24px;
  display: flex; flex-direction: column;
  min-height: 480px;
}
.slots__head { margin-bottom: 14px; }
.slots__date {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -.015em;
  color: var(--color-text);
  margin-bottom: 4px;
}
.slots__hint {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .04em;
  color: var(--color-text-3);
}
.slots__list {
  display: flex; flex-direction: column; gap: 7px;
  overflow-y: auto;
  max-height: 400px;
  padding-right: 4px;
}
.slots__list::-webkit-scrollbar { width: 6px; }
.slots__list::-webkit-scrollbar-track { background: transparent; }
.slots__list::-webkit-scrollbar-thumb { background: var(--color-border-strong); border-radius: 999px; }

.slot-btn {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px;
  border-radius: 12px;
  background: #ffffff05;
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: 14px;
  font-variant-numeric: tabular-nums;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
  cursor: pointer;
}
.slot-btn:hover:not(:disabled):not(.is-selected) {
  background: #ffffff0d;
  border-color: var(--color-border-strong);
  transform: translateX(2px);
}
.slot-btn.is-selected {
  background: var(--color-text);
  color: var(--color-bg);
  border-color: var(--color-text);
}
.slot-btn:disabled { opacity: .35; cursor: not-allowed; }
.slot-btn__arrow { font-size: 13px; opacity: .5; transition: all .2s ease; }
.slot-btn:hover:not(:disabled):not(.is-selected) .slot-btn__arrow {
  opacity: 1; transform: translateX(3px);
  color: var(--color-accent);
}

.slots__empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  flex: 1;
  padding: 24px 16px;
  color: var(--color-text-3);
}
.slots__empty-icon {
  font-family: var(--font-display);
  font-size: 38px;
  color: var(--color-accent);
  opacity: .55;
  margin-bottom: 14px;
}
.slots__empty-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -.015em;
  color: var(--color-text-2);
  margin-bottom: 6px;
}
.slots__empty-text { font-size: 13px; max-width: 240px; line-height: 1.5; }

.slots__skeleton { display: flex; flex-direction: column; gap: 8px; }
.slots__skeleton-row {
  height: 46px;
  background: linear-gradient(90deg, #ffffff04, #ffffff0c, #ffffff04);
  background-size: 200% 100%;
  border-radius: 12px;
  animation: shimmer 1.4s ease-in-out infinite;
}
@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Confirm step */
.confirm {
  padding: 28px;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 28px;
}
@media (max-width: 820px) { .confirm { grid-template-columns: 1fr; } }
.confirm__summary {
  align-self: start;
  padding: 22px;
  border-radius: var(--radius);
  background: #ffffff04;
  border: 1px solid var(--color-border);
}
.confirm__summary-tag {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-accent-2);
  margin-bottom: 14px;
  display: inline-block;
}
.confirm__summary-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  letter-spacing: -.025em;
  margin-bottom: 12px;
  color: var(--color-text);
}
.confirm__summary-title em { color: var(--color-text-2); font-style: italic; font-weight: 500; }
.confirm__summary-rows {
  display: flex; flex-direction: column; gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border);
}
.confirm__summary-row {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px;
  color: var(--color-text-2);
}
.confirm__summary-row svg { width: 15px; height: 15px; stroke: var(--color-accent); flex-shrink: 0; }
.confirm__summary-row strong { color: var(--color-text); font-weight: 500; }

/* Form */
.book-form { display: flex; flex-direction: column; gap: 14px; }
.form__row { display: flex; flex-direction: column; gap: 6px; }
.form__label {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-text-3);
}
.form__label .opt {
  text-transform: none; color: var(--color-text-3);
  font-family: var(--font-sans); margin-left: 4px;
}
.form__input,
.form__textarea {
  padding: 12px 14px;
  background: #ffffff05;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  color: var(--color-text);
  font-size: 14px;
  font-family: inherit;
  width: 100%;
  outline: none;
  transition: border-color .2s ease, background .2s ease;
}
.form__input:focus,
.form__textarea:focus {
  border-color: var(--color-accent);
  background: #ffffff08;
}
.form__input::placeholder,
.form__textarea::placeholder { color: var(--color-text-3); }
.form__textarea { min-height: 100px; resize: vertical; line-height: 1.5; }
.form__hint {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-text-3);
}
.book-form__actions {
  display: flex; gap: 10px; justify-content: space-between; align-items: center;
  margin-top: 6px;
}
.book-form__honeypot {
  position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden;
}
.form-status {
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 13px;
  display: none;
}
.form-status.is-visible { display: block; }
.form-status--error {
  background: #d97a7a18;
  color: var(--color-danger);
  border: 1px solid #d97a7a40;
}
.form-status--success {
  background: #9dc78b1c;
  color: var(--color-success);
  border: 1px solid #9dc78b40;
}

/* Success */
.success {
  padding: clamp(2.5rem, 5vh, 4rem) 28px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  gap: 16px;
}
.success__icon {
  width: 60px; height: 60px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: #e8c77e1c;
  color: var(--color-accent);
  border: 1px solid #e8c77e40;
  font-size: 26px;
}
.success__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(2rem, 5vw, 3.25rem);
  line-height: 1;
  letter-spacing: -.035em;
  color: var(--color-text);
}
.success__title em { color: var(--color-text-2); font-style: italic; font-weight: 500; }
.success__sub {
  max-width: 460px;
  font-size: 15px;
  color: var(--color-text-2);
  line-height: 1.55;
}
.success__details {
  display: inline-flex; flex-direction: column; gap: 8px;
  padding: 18px 24px;
  border-radius: var(--radius);
  background: #ffffff05;
  border: 1px solid var(--color-border);
  text-align: left;
  font-size: 14px;
  font-variant-numeric: tabular-nums;
  color: var(--color-text-2);
}
.success__details strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 19px;
  letter-spacing: -.02em;
  color: var(--color-text);
}

/* ============================================================
   TOPICS / CARDS
   ============================================================ */
.topic-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 760px) { .topic-grid { grid-template-columns: 1fr; } }
.topic-card {
  padding: 26px;
  border-radius: var(--radius);
  background: linear-gradient(145deg, #ffffff07, #ffffff03);
  border: 1px solid var(--color-border);
  display: flex; flex-direction: column; gap: 12px;
  transition: border-color .25s ease, background .25s ease, transform .25s ease;
  cursor: pointer;
}
.topic-card:hover {
  border-color: var(--color-border-strong);
  background: linear-gradient(145deg, #ffffff0c, #ffffff05);
  transform: translateY(-2px);
}
.topic-card__head {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-text-3);
}
.topic-card__num { color: var(--color-accent); }
.topic-card__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -.025em;
  color: var(--color-text);
}
.topic-card__desc {
  color: var(--color-text-2);
  font-size: 14px;
  line-height: 1.55;
}
.topic-card__foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--color-border);
  font-size: 13px;
  color: var(--color-text-2);
}
.topic-card__price {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  color: var(--color-text);
}
.topic-card__price small {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-text-3);
  margin-left: 4px;
}
.topic-card__cta {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--color-accent);
  transition: gap .2s ease;
}
.topic-card:hover .topic-card__cta { gap: 10px; }

/* ============================================================
   SOCIAL ROW
   ============================================================ */
.find-me {
  display: flex; align-items: center; gap: 18px;
  padding: 16px 22px;
  border-radius: var(--radius);
  flex-wrap: wrap;
}
.find-me__label {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
  white-space: nowrap;
}
.find-me__list {
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap;
}
.find-me__list a {
  font-size: 13px;
  color: var(--color-text-2);
  transition: color .2s ease;
}
.find-me__list a:hover { color: var(--color-accent); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  padding: 64px var(--pad-x) 32px;
  border-top: 1px solid var(--color-border);
}
.footer__row {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 32px;
  max-width: var(--max-w);
  margin: 0 auto;
}
@media (max-width: 700px) { .footer__row { grid-template-columns: 1fr; gap: 24px; } }
.footer__brand h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -.02em;
  color: var(--color-text);
  margin-bottom: 6px;
}
.footer__brand p {
  font-size: 13px;
  color: var(--color-text-3);
  max-width: 320px;
  line-height: 1.5;
}
.footer__col h4 {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
  margin-bottom: 14px;
}
.footer__col ul li { margin-bottom: 8px; }
.footer__col ul li a {
  font-size: 13px;
  color: var(--color-text-2);
  transition: color .2s ease;
}
.footer__col ul li a:hover { color: var(--color-text); }
.footer__bottom {
  max-width: var(--max-w);
  margin: 32px auto 0;
  padding-top: 20px;
  border-top: 1px solid var(--color-border);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-text-3);
  flex-wrap: wrap; gap: 10px;
}

/* ============================================================
   ADMIN
   ============================================================ */
.admin-shell {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x) 80px;
}
.admin-head { padding-top: clamp(5.25rem, 9vh, 7rem); padding-bottom: 1rem; }
.admin-head__eyebrow { margin-bottom: 1rem; }
.admin-head__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(2rem, 5vw, 3.25rem);
  letter-spacing: -.035em;
  line-height: 1;
  color: var(--color-text);
  margin-bottom: 12px;
}
.admin-head__title em { color: var(--color-text-2); font-style: italic; font-weight: 500; }
.admin-head__sub {
  font-size: 15px;
  color: var(--color-text-2);
  max-width: 56ch;
  line-height: 1.55;
}
.admin-head__actions {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 22px;
}

.admin-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 32px 0 56px;
}
@media (max-width: 800px) { .admin-stats { grid-template-columns: repeat(2, 1fr); } }
.admin-stat {
  padding: 22px;
  border-radius: var(--radius);
  background: linear-gradient(145deg, #ffffff07, #ffffff03);
  border: 1px solid var(--color-border);
  display: flex; flex-direction: column; gap: 6px;
  transition: border-color .25s ease;
}
.admin-stat:hover { border-color: var(--color-border-strong); }
.admin-stat__label {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
}
.admin-stat__num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 34px;
  letter-spacing: -.03em;
  line-height: 1;
  color: var(--color-text);
}
.admin-stat__num em { color: var(--color-accent); font-style: italic; font-weight: 500; }

.admin-section { margin-bottom: 56px; }
.admin-section__head {
  display: flex; align-items: end; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.admin-section__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(1.5rem, 3vw, 2rem);
  letter-spacing: -.025em;
  line-height: 1.05;
  color: var(--color-text);
}
.admin-section__title em { color: var(--color-text-2); font-style: italic; font-weight: 500; }
.admin-section__hint {
  font-size: 13px;
  color: var(--color-text-3);
  margin-top: 6px;
  max-width: 56ch;
}

.admin-card {
  border-radius: var(--radius);
  background: linear-gradient(145deg, #ffffff07, #ffffff03);
  border: 1px solid var(--color-border);
}

.booking-row {
  display: grid;
  grid-template-columns: 200px 1fr 150px 80px;
  gap: 22px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--color-border);
  align-items: center;
  transition: background .2s ease, padding-left .25s ease;
}
.booking-row:last-child { border-bottom: 0; }
.booking-row:hover { background: #ffffff05; padding-left: 28px; }
@media (max-width: 820px) {
  .booking-row { grid-template-columns: 1fr; gap: 6px; }
  .booking-row:hover { padding-left: 22px; }
}
.booking-row__when { display: flex; flex-direction: column; gap: 2px; }
.booking-row__date {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -.015em;
  color: var(--color-text);
}
.booking-row__time {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--color-text-3);
}
.booking-row__who-name { font-weight: 500; color: var(--color-text); font-size: 14px; }
.booking-row__who-meta { font-size: 13px; color: var(--color-text-3); margin-top: 2px; }
.booking-row__who-meta a {
  color: var(--color-text-2);
  border-bottom: 1px solid transparent;
  transition: color .2s ease, border-color .2s ease;
}
.booking-row__who-meta a:hover { color: var(--color-accent); border-color: var(--color-accent); }
.booking-row__msg {
  margin-top: 4px;
  font-size: 12px;
  color: var(--color-text-3);
  font-style: italic;
  line-height: 1.45;
}

.source-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .04em;
  padding: 4px 10px;
  background: #e8c77e1c;
  border: 1px solid #e8c77e40;
  border-radius: 999px;
  color: var(--color-accent);
}
.source-tag--unknown {
  background: #ffffff05; color: var(--color-text-3);
  border-color: var(--color-border);
}

.admin-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--color-text-3);
}
.admin-empty-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -.015em;
  color: var(--color-text-2);
  margin-bottom: 4px;
}

/* Link rows */
.link-row {
  display: grid;
  grid-template-columns: 1.4fr 2fr auto auto;
  gap: 18px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--color-border);
  align-items: center;
  transition: background .2s ease, padding-left .25s ease;
}
.link-row:last-child { border-bottom: 0; }
.link-row:hover { background: #ffffff05; padding-left: 28px; }
@media (max-width: 800px) {
  .link-row { grid-template-columns: 1fr; gap: 10px; }
}
.link-row__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -.02em;
  color: var(--color-text);
}
.link-row__desc {
  font-size: 12px;
  color: var(--color-text-3);
  margin-top: 2px;
}
.link-row__url {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--color-text-2);
  word-break: break-all;
  padding: 8px 12px;
  background: #ffffff05;
  border: 1px solid var(--color-border);
  border-radius: 8px;
}
.link-row__count {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -.02em;
  color: var(--color-accent);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.link-row__count-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-3);
  margin-left: 6px;
}

/* ============================================================
   LOGIN
   ============================================================ */
.login-shell {
  min-height: 100dvh;
  display: flex; align-items: center; justify-content: center;
  padding: var(--pad-x);
}
.login-card {
  width: 100%; max-width: 420px;
  padding: 36px 32px;
  border-radius: var(--radius);
}
.login-card__eyebrow {
  margin-bottom: 18px;
}
.login-card__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 36px; letter-spacing: -.035em;
  line-height: 1;
  color: var(--color-text);
  margin-bottom: 6px;
}
.login-card__title em { color: var(--color-text-2); font-style: italic; font-weight: 500; }
.login-card__sub {
  font-size: 14px;
  color: var(--color-text-3);
  margin-bottom: 24px;
}

/* ============================================================
   MODAL
   ============================================================ */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(11, 13, 18, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease;
}
.modal-backdrop.is-visible { opacity: 1; pointer-events: auto; }
.modal {
  width: 100%; max-width: 480px;
  padding: 30px;
  border-radius: var(--radius);
  transform: translateY(10px);
  transition: transform .25s ease;
}
.modal-backdrop.is-visible .modal { transform: translateY(0); }
.modal__eyebrow { margin-bottom: 8px; }
.modal__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  letter-spacing: -.025em;
  line-height: 1.1;
  color: var(--color-text);
  margin-bottom: 6px;
}
.modal__title em { color: var(--color-text-2); font-style: italic; font-weight: 500; }
.modal__sub {
  font-size: 13px;
  color: var(--color-text-3);
  margin-bottom: 22px;
  line-height: 1.55;
}
.modal__actions {
  display: flex; gap: 10px; justify-content: flex-end;
  margin-top: 24px;
}

/* ============================================================
   TOAST
   ============================================================ */
.toast {
  position: fixed;
  bottom: 24px; right: 24px;
  z-index: 1000;
  padding: 13px 18px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 500;
  background: linear-gradient(145deg, #ffffff14, #ffffff08);
  border: 1px solid var(--color-border-strong);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  color: var(--color-text);
  box-shadow: 0 24px 60px -20px rgba(0,0,0,0.6);
  transform: translateY(20px); opacity: 0;
  transition: all .25s ease;
  max-width: 320px;
}
.toast.is-visible { transform: translateY(0); opacity: 1; }
.toast--success { border-color: #9dc78b66; }
.toast--error { border-color: #d97a7a66; }

/* ============================================================
   UTILITIES
   ============================================================ */
.hidden { display: none !important; }
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
