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

:root {
  --ivory: #FAF8F3;
  --cream: #F4EFE4;
  --warm-white: #FFFEF9;
  --ink: #0F1A0E;
  --deep: #152414;
  --forest: #1B4332;
  --jade: #2D6A4F;
  --sage: #52B788;
  --mint: #95D5B2;
  --gold: #C9952A;
  --gold-light: #F0C45E;
  --copper: #B5682A;
  --red: #C1121F;
  --border: rgba(43,83,50,0.12);
  --shadow: 0 32px 80px rgba(15,26,14,0.12);
  --shadow-sm: 0 8px 32px rgba(15,26,14,0.08);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Outfit',sans-serif; background:var(--ivory); color:var(--ink); overflow-x:hidden; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--cream); }
::-webkit-scrollbar-thumb { background:var(--jade); border-radius:4px; }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:0 5%; height:72px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(250,248,243,0.97); backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 40px rgba(15,26,14,0.06);
  transition:all 0.4s;
}
.nav-logo { display:flex; align-items:center; gap:11px; text-decoration:none; }
.logo-emblem { width:42px; height:42px; background:linear-gradient(135deg,var(--forest),var(--jade)); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; box-shadow:0 4px 16px rgba(27,67,50,0.25); transition:transform 0.3s; }
.nav-logo:hover .logo-emblem { transform:rotate(-5deg) scale(1.05); }
.logo-wordmark { font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:700; color:var(--forest); letter-spacing:-0.5px; line-height:1; }
.logo-wordmark em { color:var(--gold); font-style:normal; }
.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a { font-size:14px; font-weight:500; color:var(--ink); text-decoration:none; position:relative; transition:color 0.2s; }
.nav-links a::after { content:''; position:absolute; bottom:-3px; left:0; right:0; height:1.5px; background:var(--jade); transform:scaleX(0); transition:transform 0.3s; transform-origin:right; }
.nav-links a:hover { color:var(--jade); }
.nav-links a:hover::after { transform:scaleX(1); transform-origin:left; }
.nav-links a.active { color:var(--jade); }
.nav-links a.active::after { transform:scaleX(1); }
.nav-cta { display:flex; align-items:center; gap:12px; }
.btn-emergency { background:var(--red); color:white; padding:8px 16px; border-radius:8px; font-size:12px; font-weight:700; letter-spacing:0.5px; text-decoration:none; text-transform:uppercase; animation:pulse-emerg 2.5s infinite; }
@keyframes pulse-emerg { 0%,100%{box-shadow:0 0 0 0 rgba(193,18,31,0.4)} 50%{box-shadow:0 0 0 8px rgba(193,18,31,0)} }
.btn-book-nav { background:linear-gradient(135deg,var(--forest),var(--jade)); color:white; padding:10px 22px; border-radius:10px; font-size:13px; font-weight:600; text-decoration:none; box-shadow:0 4px 16px rgba(27,67,50,0.2); transition:all 0.3s; }
.btn-book-nav:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(27,67,50,0.3); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.hamburger span { width:22px; height:2px; background:var(--ink); border-radius:2px; display:block; }
.mobile-nav { display:none; position:fixed; top:72px; left:0; right:0; z-index:999; background:rgba(250,248,243,0.97); backdrop-filter:blur(20px); padding:20px 5%; border-bottom:1px solid var(--border); }
.mobile-nav.open { display:block; }
.mobile-nav a { display:block; padding:13px 0; border-bottom:1px solid var(--border); font-size:15px; font-weight:500; color:var(--ink); text-decoration:none; }
.mobile-nav a:last-child { border-bottom:none; }

/* ── PAGE HERO ── */
.page-hero { background:linear-gradient(160deg,var(--ink) 0%,var(--deep) 50%,var(--forest) 100%); padding:140px 5% 80px; position:relative; overflow:hidden; }
.ph-mesh { position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(45,106,79,0.25) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 20% 80%,rgba(201,149,42,0.08) 0%,transparent 60%); pointer-events:none; }
.ph-grain { position:absolute; inset:0; opacity:0.03; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); pointer-events:none; }
.ph-inner { position:relative; z-index:2; }
.ph-eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--gold-light); margin-bottom:18px; opacity:0.8; }
.ph-eyebrow::before { content:''; width:24px; height:1px; background:var(--gold-light); }
.ph-title { font-family:'Cormorant Garamond',serif; font-size:clamp(40px,6vw,72px); font-weight:300; color:white; line-height:1.08; letter-spacing:-0.5px; margin-bottom:18px; }
.ph-title strong { font-weight:700; }
.ph-title em { font-style:italic; color:var(--gold-light); }
.ph-sub { font-size:16px; color:rgba(255,255,255,0.5); line-height:1.75; max-width:520px; font-weight:300; }

/* ── EMERGENCY STRIP ── */
.emergency-strip { background:linear-gradient(135deg,#6B0011,#C1121F,#8B0019); padding:16px 5%; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.es-left { display:flex; align-items:center; gap:14px; }
.es-pulse { width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,0.15); display:flex; align-items:center; justify-content:center; font-size:18px; animation:pulse-emerg 2s infinite; }
.es-content h3 { color:white; font-weight:700; font-size:15px; }
.es-content p { color:rgba(255,255,255,0.6); font-size:12px; }
.es-number { font-family:'Space Grotesk',monospace; font-size:22px; font-weight:700; color:white; letter-spacing:1px; background:rgba(255,255,255,0.15); padding:10px 20px; border-radius:10px; border:1px solid rgba(255,255,255,0.25); }

/* ── SECTIONS ── */
section { padding:100px 5%; }
.eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--jade); margin-bottom:16px; }
.eyebrow::before { content:''; width:28px; height:1.5px; background:linear-gradient(90deg,var(--jade),var(--sage)); }
.section-title { font-family:'Cormorant Garamond',serif; font-size:clamp(34px,4.5vw,56px); font-weight:300; color:var(--ink); line-height:1.1; letter-spacing:-0.5px; margin-bottom:14px; }
.section-title strong { font-weight:700; }
.section-title em { font-style:italic; color:var(--jade); }
.section-body { font-size:16px; color:#4A5A48; line-height:1.8; font-weight:300; max-width:560px; }

/* ── BUTTONS ── */
.btn-primary { background:linear-gradient(135deg,var(--jade),var(--forest)); color:white; padding:16px 32px; border-radius:14px; font-size:15px; font-weight:600; text-decoration:none; display:inline-flex; align-items:center; gap:8px; box-shadow:0 8px 32px rgba(27,67,50,0.3); transition:all 0.3s; }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(27,67,50,0.4); }
.btn-outline { background:transparent; color:var(--jade); padding:14px 28px; border-radius:12px; font-size:14px; font-weight:600; text-decoration:none; border:1.5px solid var(--jade); transition:all 0.3s; display:inline-flex; align-items:center; gap:7px; }
.btn-outline:hover { background:var(--jade); color:white; }
.btn-gold { background:linear-gradient(135deg,var(--gold),var(--copper)); color:white; padding:16px 32px; border-radius:14px; font-size:15px; font-weight:700; text-decoration:none; box-shadow:0 8px 28px rgba(201,149,42,0.3); transition:all 0.3s; }
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 12px 40px rgba(201,149,42,0.45); }

/* ── CARDS ── */
.card { background:white; border-radius:22px; padding:32px; border:1px solid rgba(0,0,0,0.05); transition:all 0.4s cubic-bezier(0.16,1,0.3,1); }
.card:hover { transform:translateY(-6px); box-shadow:0 24px 64px rgba(15,26,14,0.09); }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.grid-auto { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; }

/* ── FORMS ── */
.form-group { margin-bottom:20px; }
.form-label { display:block; font-size:11px; font-weight:700; letter-spacing:0.8px; text-transform:uppercase; color:#4A5A48; margin-bottom:8px; }
.form-input, .form-select, .form-textarea { width:100%; padding:14px 18px; border:1.5px solid var(--border); border-radius:12px; font-size:14px; font-family:'Outfit',sans-serif; color:var(--ink); background:white; transition:all 0.2s; appearance:none; outline:none; }
.form-textarea { resize:vertical; min-height:120px; line-height:1.6; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--jade); box-shadow:0 0 0 4px rgba(45,106,79,0.08); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.submit-btn { width:100%; background:linear-gradient(135deg,var(--jade),var(--forest)); color:white; border:none; padding:16px; border-radius:12px; font-size:15px; font-weight:700; font-family:'Outfit',sans-serif; cursor:pointer; transition:all 0.3s; box-shadow:0 8px 28px rgba(27,67,50,0.25); }
.submit-btn:hover { transform:translateY(-2px); box-shadow:0 14px 44px rgba(27,67,50,0.35); }

/* ── FOOTER ── */
footer { background:#060D06; padding:64px 5% 28px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand .logo-wordmark { font-size:28px; color:white; margin-bottom:14px; display:block; }
.footer-tagline { font-size:13px; color:rgba(255,255,255,0.32); line-height:1.7; max-width:240px; margin-bottom:20px; }
.footer-emerg { background:rgba(193,18,31,0.12); border:1px solid rgba(193,18,31,0.25); border-radius:10px; padding:14px; }
.fe-lbl { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,0.35); margin-bottom:4px; }
.fe-num { font-family:'Space Grotesk',monospace; font-size:18px; font-weight:700; color:#FF6B6B; }
.fc-head { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.25); margin-bottom:18px; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,0.45); text-decoration:none; transition:color 0.2s; }
.footer-links a:hover { color:var(--sage); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.fb-copy { font-size:12px; color:rgba(255,255,255,0.2); }
.fb-links { display:flex; gap:20px; }
.fb-links a { font-size:12px; color:rgba(255,255,255,0.2); text-decoration:none; transition:color 0.2s; }
.fb-links a:hover { color:rgba(255,255,255,0.5); }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(28px); transition:all 0.7s cubic-bezier(0.16,1,0.3,1); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── BADGE ── */
.badge { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600; padding:4px 12px; border-radius:100px; }
.badge-green { background:rgba(45,106,79,0.08); color:var(--jade); border:1px solid rgba(45,106,79,0.18); }
.badge-gold { background:rgba(201,149,42,0.1); color:var(--gold); border:1px solid rgba(201,149,42,0.2); }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .grid-2,.grid-3 { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
}
@media(max-width:640px) { .footer-grid { grid-template-columns:1fr; } section { padding:70px 5%; } }
