/* ═══════════════════════════════════════════════════════════════
   guest.css — Topline guest preview page
   ═══════════════════════════════════════════════════════════════ */

/* ── GUEST HEADER ────────────────────────────────────────────── */
.header-guest-app {
  border-bottom: 1px solid var(--border-dark);
}

/* ── SIGNUP NUDGE BANNER ─────────────────────────────────────── */
.guest-banner {
  background: var(--charcoal);
  border-bottom: 2px solid var(--terra);
  padding: 0.75rem 2rem;
  position: sticky;
  top: var(--header-h);
  z-index: 90;
}
.guest-banner-inner {
  max-width: var(--content-max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-md);
  flex-wrap: wrap;
}
.guest-banner-text {
  font-size: 0.8rem;
  font-weight: 300;
  color: rgba(253,250,245,0.75);
  letter-spacing: 0.02em;
}
.guest-banner-text strong {
  font-weight: 500;
  color: var(--cream);
}

/* ── DEMO TAG ────────────────────────────────────────────────── */
.demo-tag {
  display: inline-block;
  font-family: 'Jost', sans-serif;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: var(--radius);
  background: var(--terra-pale);
  color: var(--terra);
  vertical-align: middle;
  margin-left: 8px;
  position: relative;
  top: -3px;
}

/* ── LOCKED LABELS ───────────────────────────────────────────── */
.guest-locked-label {
  font-size: 0.63rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--muted);
}

/* ── GUEST ROWS ──────────────────────────────────────────────── */
.guest-row { cursor: pointer; }
.guest-row:hover td { background: var(--terra-pale) !important; }

/* ── LOCK BUTTON ─────────────────────────────────────────────── */
.lock-icon { font-size: 0.8rem; }
.guest-lock-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.68rem;
}

/* ── SIGNUP CTA CARD ─────────────────────────────────────────── */
.guest-cta-card {
  background: var(--cream);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius);
  padding: 1.8rem;
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.guest-cta-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--terra), var(--sage));
}
.guest-cta-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--charcoal);
  margin-bottom: 0.6rem;
}
.guest-cta-body {
  font-size: 0.78rem;
  font-weight: 300;
  color: var(--muted);
  line-height: 1.75;
  margin-bottom: 1.4rem;
}
.guest-signin-link {
  display: block;
  text-align: center;
  margin-top: 0.8rem;
  font-size: 0.68rem;
  letter-spacing: 0.04em;
  color: var(--muted);
  transition: color 0.2s;
}
.guest-signin-link:hover { color: var(--terra); }

/* ── MODAL ───────────────────────────────────────────────────── */
.guest-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(14,26,17,0.6);
  backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center;
  z-index: 200;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease;
}
.guest-modal-overlay.visible {
  opacity: 1; pointer-events: all;
}
.guest-modal {
  background: var(--cream);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius);
  padding: 2.2rem;
  max-width: 420px;
  width: 90%;
  box-shadow: var(--shadow-lg);
  position: relative;
}
.guest-modal::before {
  content: '';
  position: absolute; top: 0; left: 2rem; right: 2rem;
  height: 2px;
  background: linear-gradient(90deg, var(--terra), var(--sage));
}
.guest-modal-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem; font-weight: 400;
  color: var(--charcoal); margin-bottom: 0.6rem;
}
.guest-modal-body {
  font-size: 0.78rem; font-weight: 300;
  color: var(--muted); line-height: 1.75;
  margin-bottom: 1.5rem;
}
.guest-modal-actions {
  display: flex; gap: 10px; justify-content: flex-end;
}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width: 600px) {
  .guest-banner-inner { flex-direction: column; align-items: flex-start; }
  .guest-modal-actions { flex-direction: column; }
  .guest-modal-actions .btn { width: 100%; justify-content: center; }
}

/* ── BANNER ACTIONS ──────────────────────────────────────────── */
.guest-banner-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}
.btn-banner-ghost {
  padding: 10px 16px;
  border-radius: var(--radius);
  font-family: 'Jost', sans-serif;
  font-size: 0.68rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.2);
  background: transparent;
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.btn-banner-ghost:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.4);
  color: var(--cream);
}

/* ── CTA LINKS ───────────────────────────────────────────────── */
.guest-cta-links {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 0.8rem;
  align-items: center;
}
.guest-guide-link {
  font-size: 0.68rem; letter-spacing: 0.04em;
  color: var(--sage); display: inline-flex;
  align-items: center; gap: 6px;
  transition: color 0.2s;
}
.guest-guide-link:hover { color: var(--charcoal); }
.guest-guide-link i { font-size: 0.75rem; }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width: 600px) {
  .guest-banner-inner   { flex-direction: column; align-items: flex-start; }
  .guest-banner-actions { flex-wrap: wrap; }
}
