@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500;600&display=swap');

/* ─── TOKENS ─────────────────────────────── */
:root {
  --cream:        #faf7f2;
  --cream-2:      #f5f0e8;
  --cream-3:      #ede5d8;
  --brown:        #8B4513;
  --brown-dk:     #6B3410;
  --gold:         #C4923A;
  --gold-lt:      #D4A857;
  --rust:         #B85C38;
  --text:         #1a1a1a;
  --text-md:      #4a4a4a;
  --text-lt:      #7a7a7a;
  --border:       #e8e0d0;
  --white:        #ffffff;

  /* gradient button — matches screenshot: rust→gold→olive-gold */
  --grad-btn: linear-gradient(135deg, #b85230 0%, #c4923a 50%, #a08030 100%);
  --grad-btn-hover: linear-gradient(135deg, #a04525 0%, #b07f2e 50%, #8a6e28 100%);

  /* gradient hero bg — matches second image: sky-blue top→gold mid→deep-red bottom */
  --grad-hero: radial-gradient(ellipse at 60% 0%,   #a8c8e0 0%, transparent 55%),
               radial-gradient(ellipse at 20% 30%,  #e8c87a 0%, transparent 50%),
               radial-gradient(ellipse at 80% 60%,  #d4704a 0%, transparent 50%),
               radial-gradient(ellipse at 30% 80%,  #8b3a20 0%, transparent 60%),
               linear-gradient(160deg, #c8dce8 0%, #e8c878 35%, #d46040 65%, #8b2e18 100%);
}

/* ─── RESET ──────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', sans-serif;
  background-color: var(--cream);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4 { font-family: 'Playfair Display', serif; line-height: 1.2; }

/* ─── GRADIENT BUTTON ────────────────────── */
.btn-grad {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--grad-btn);
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  border: none;
  border-radius: 100px;
  padding: 13px 28px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  box-shadow: 0 4px 20px rgba(184,82,48,0.30);
  text-decoration: none;
  letter-spacing: 0.02em;
}
.btn-grad::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.18) 0%, transparent 60%);
  pointer-events: none;
}
.btn-grad:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(184,82,48,0.45);
  background: var(--grad-btn-hover);
}
.btn-grad:active { transform: translateY(0); box-shadow: 0 3px 12px rgba(184,82,48,0.3); }

.btn-grad-sm { padding: 9px 20px; font-size: 12px; }
.btn-grad-lg { padding: 16px 38px; font-size: 15px; }

/* outline ghost variant */
.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent;
  color: var(--rust);
  border: 1.5px solid var(--rust);
  border-radius: 100px;
  padding: 11px 26px;
  font-size: 14px; font-weight: 600;
  cursor: pointer; text-decoration: none;
  transition: all 0.25s ease;
}
.btn-outline:hover { background: var(--grad-btn); color: #fff; border-color: transparent; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(184,82,48,0.3); }

/* ─── NAV ─────────────────────────────────── */
.site-nav {
  position: sticky; top: 0; z-index: 200;
  background: rgba(250,247,242,0.88);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(232,224,208,0.6);
  transition: box-shadow 0.3s;
}
.site-nav.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,0.08); }

/* ─── HERO GRADIENT BG ───────────────────── */
.hero-grad-bg {
  background: var(--grad-hero);
  background-size: cover;
}

/* ─── REVEAL ANIMATION ───────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.75s cubic-bezier(.22,.68,0,1.2), transform 0.75s cubic-bezier(.22,.68,0,1.2);
}
.reveal.active { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ─── FADE IN ─────────────────────────────── */
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-in-up { animation: fadeInUp 0.8s cubic-bezier(.22,.68,0,1.1) both; }
.fade-delay-1 { animation-delay: 0.15s; }
.fade-delay-2 { animation-delay: 0.3s; }
.fade-delay-3 { animation-delay: 0.45s; }
.fade-delay-4 { animation-delay: 0.6s; }

/* ─── CAROUSEL ────────────────────────────── */
.carousel-track { display: flex; transition: transform 0.7s cubic-bezier(.77,0,.175,1); }
.carousel-slide { min-width: 100%; }
.carousel-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.4); transition: all 0.3s; }
.carousel-dot.active { width: 28px; border-radius: 4px; background: #fff; }

/* ─── CARDS ───────────────────────────────── */
.card-hover {
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.card-hover:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(0,0,0,0.10); }

/* ─── FORM INPUTS ─────────────────────────── */
.form-input {
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 12px 16px 12px 44px;
  width: 100%;
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  outline: none;
  background: #fff;
  color: var(--text);
  transition: border-color 0.25s, box-shadow 0.25s;
}
.form-input:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(196,146,58,0.12); }
.form-input::placeholder { color: #b8ad9e; }
.form-input option { background: #fff; color: var(--text); }
.input-wrap { position: relative; }
.input-icon { position: absolute; left: 15px; top: 50%; transform: translateY(-50%); color: #b8ad9e; font-size: 13px; pointer-events: none; }
.toggle-pass { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: #b8ad9e; cursor: pointer; font-size: 13px; }

/* ─── ACCORDION ───────────────────────────── */
.accordion-content {
  max-height: 0; overflow: hidden;
  transition: max-height 0.45s cubic-bezier(.4,0,.2,1);
}
.accordion-content.open { max-height: 400px; }

/* ─── SCROLL TO TOP ───────────────────────── */
#to-top {
  position: fixed; bottom: 28px; right: 28px;
  width: 46px; height: 46px;
  background: var(--grad-btn);
  color: #fff; border: none; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 300;
  box-shadow: 0 4px 20px rgba(184,82,48,0.4);
  opacity: 0; visibility: hidden;
  transform: translateY(12px);
  transition: opacity 0.35s, visibility 0.35s, transform 0.35s;
}
#to-top.show { opacity: 1; visibility: visible; transform: translateY(0); }
#to-top:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(184,82,48,0.5); }

/* ─── BADGE ───────────────────────────────── */
.badge-live { background: #ef4444; color: #fff; font-size: 9px; font-weight: 700; padding: 3px 8px; border-radius: 999px; letter-spacing: .04em; text-transform: uppercase; }
.badge-full { background: #9ca3af; color: #fff; font-size: 9px; font-weight: 700; padding: 3px 8px; border-radius: 999px; letter-spacing: .04em; text-transform: uppercase; }

/* ─── SOCIAL BTN ──────────────────────────── */
.social-btn { border: 1.5px solid var(--border); border-radius: 12px; padding: 11px; width: 100%; font-size: 13px; font-weight: 500; color: var(--text-md); background: #fff; cursor: pointer; transition: all 0.25s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.social-btn:hover { background: var(--cream-2); border-color: var(--gold); color: var(--brown); }

/* ─── PILL TAG ────────────────────────────── */
.pill { display: inline-block; background: var(--cream-2); border: 1px solid var(--border); border-radius: 100px; padding: 4px 14px; font-size: 11px; font-weight: 500; color: var(--text-md); }

/* ─── CALENDAR ────────────────────────────── */
.cal-day { min-height: 88px; border: 1px solid var(--border); border-radius: 12px; padding: 8px; background: #fff; transition: all 0.2s; cursor: pointer; }
.cal-day:hover { border-color: var(--gold); background: var(--cream-2); }
.cal-day.has-class { background: linear-gradient(135deg,#fdf6ec,#faf0e0); border-color: var(--gold); }
.cal-day.today { border-color: var(--rust); box-shadow: 0 0 0 2px rgba(184,92,56,0.2); }
.cal-day.other-month { opacity: 0.35; }
.cal-event { font-size: 10px; font-weight: 600; color: var(--brown); background: rgba(196,146,58,0.15); border-radius: 4px; padding: 2px 5px; margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ─── DASHBOARD ───────────────────────────── */
.dash-card { background: #fff; border: 1px solid var(--border); border-radius: 20px; padding: 24px; transition: box-shadow 0.3s; }
.dash-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.07); }
.stat-ring { width: 64px; height: 64px; border-radius: 50%; border: 3px solid var(--cream-3); border-top-color: var(--gold); animation: spin 1.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ─── SCROLLBAR ───────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--cream-2); }
::-webkit-scrollbar-thumb { background: var(--cream-3); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ─── MARQUEE ─────────────────────────────── */
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.marquee-track { animation: marquee 30s linear infinite; display: flex; width: max-content; }
.marquee-track:hover { animation-play-state: paused; }

/* ─── GLASS CARD ──────────────────────────── */
.glass { background: rgba(255,255,255,0.55); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,0.7); }

/* ─── FOOTER ──────────────────────────────── */
.site-footer { background: linear-gradient(160deg, #2a1a10 0%, #1a0e08 100%); color: rgba(255,255,255,0.7); }
.site-footer h4 { color: #fff; }
.site-footer a { color: rgba(255,255,255,0.6); text-decoration: none; transition: color 0.2s; }
.site-footer a:hover { color: var(--gold); }
