/* Components — adopts the zamtraveler .fp-* visual language.
   Class names kept close to prod: .fp-bg, .fp-overlay, .fp-back, .fp-card,
   .fp-tag, .fp-back-btn, .feature-pill. Plus a few additions for trip UI. */

/* ── Full-screen hero background (matches prod .fp-bg / .fp-overlay) ── */
.fp-bg {
  position: fixed; inset: 0;
  z-index: -2;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.fp-overlay {
  position: fixed; inset: 0;
  z-index: -1;
  background: linear-gradient(
    to bottom,
    rgba(10, 14, 26, 0.55) 0%,
    rgba(10, 14, 26, 0.75) 50%,
    rgba(10, 14, 26, 0.92) 100%
  );
}

/* ── Back link (top-left) ───────────────────────────── */
.fp-back {
  position: fixed;
  top: 24px; left: 24px;
  z-index: 10;
  color: var(--text-muted);
  font-size: 0.9rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color var(--dur) ease, transform var(--dur) ease;
}
.fp-back:hover { color: var(--accent-amber); transform: translateX(-3px); }
@media (max-width: 768px) { .fp-back { top: 16px; left: 16px; font-size: 0.85rem; } }

/* ── Badge / eyebrow-pill (matches .fp-badge) ───────── */
.fp-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 600;
  padding: 6px 18px;
  border-radius: var(--radius-pill);
  background: var(--amber-bg-medium);
  color: var(--accent-amber);
  border: 1px solid var(--amber-border-medium);
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* Icon (used for country pages, 64px SVG with amber glow float) */
.fp-icon {
  width: 64px; height: 64px;
  margin-bottom: 16px;
  color: var(--accent-amber);
  filter: drop-shadow(0 0 20px rgba(245, 158, 11, 0.3));
  animation: fp-icon-float 3s ease-in-out infinite;
}
@keyframes fp-icon-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* ── Cards (matches .fp-card, blurred glass) ────────── */
.fp-card {
  background: var(--bg-card);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--border-amber-card);
  border-radius: var(--radius-card);
  padding: 36px 32px;
  text-align: left;
}
@media (max-width: 768px) {
  .fp-card { padding: 28px 22px; border-radius: 20px; }
}

/* Generic surface card (less-decorated variant) */
.card {
  background: var(--bg-card);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card-sm);
  padding: var(--space-6);
}

/* ── Tags / pills (matches .fp-tag and .feature-pill in prod) ── */
.fp-tag, .feature-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 500;
  padding: 6px 16px;
  border-radius: var(--radius-pill);
  background: var(--amber-bg-soft);
  color: var(--accent-amber);
  border: 1px solid var(--amber-border-soft);
  letter-spacing: 0.3px;
  text-decoration: none;
  cursor: pointer;
  transition: all var(--dur) var(--ease-spring);
}
.fp-tag:hover, .feature-pill:hover {
  background: var(--amber-bg-strong);
  border-color: var(--amber-border-strong);
  transform: translateY(-2px);
  box-shadow: 0 4px 20px var(--amber-glow);
  color: var(--accent-amber);
}
.feature-pill.active {
  background: var(--accent-amber);
  color: var(--bg-primary);
  border-color: var(--accent-amber);
  font-weight: 600;
}

/* ── CTA back button (bottom of page) ──────────────── */
.fp-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: var(--radius-pill);
  background: var(--amber-bg-medium);
  color: var(--accent-amber);
  border: 1px solid var(--amber-border-medium);
  font-size: 0.9rem;
  font-weight: 600;
  transition: all var(--dur) var(--ease-spring);
}
.fp-back-btn:hover {
  background: var(--amber-bg-strong);
  border-color: var(--amber-border-strong);
  transform: translateY(-2px);
  box-shadow: 0 4px 20px var(--amber-glow);
  color: var(--accent-amber);
}

/* ── CTA-primary (filled amber) ─────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: var(--radius-pill);
  background: var(--accent-gradient);
  color: #0a0e1a;
  font-size: 0.95rem;
  font-weight: 700;
  transition: transform var(--dur) var(--ease-spring), box-shadow var(--dur) ease;
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(245, 158, 11, 0.4);
  color: #0a0e1a;
}

/* ── Form inputs (admin) ────────────────────────────── */
.input, .textarea, .select {
  width: 100%;
  padding: 12px 16px;
  background: rgba(10, 14, 26, 0.6);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 0.95rem;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--amber-border-strong);
}
.textarea { resize: vertical; min-height: 100px; }
.label { display: block; margin-bottom: var(--space-2); font-size: 0.8rem; font-weight: 500; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.1em; }

/* ── Footer ─────────────────────────────────────────── */
footer {
  padding: var(--space-12) var(--space-6) var(--space-8);
  text-align: center;
  color: var(--text-muted);
  font-size: 0.8rem;
  border-top: 1px solid var(--border-subtle);
}
footer a { color: var(--accent-amber); }
