/* ─── DESIGN TOKENS — shared.css ────────────────────────────────── */
:root {
  --wine: #722F37;
  --cream: #FAF6F1;
  --gold: #C9A96E;
  --gold-text: #7A6340;
  --charcoal: #2C2C2C;
  --slate: #4A4A4A;
  --dark-wine: #4A1A20;
  --light-gold: #F5ECD7;
  --stone: #A69586;
  --white: #FFFFFF;
  --ff-display: 'Playfair Display', Georgia, serif;
  --ff-body: 'DM Sans', 'Helvetica Neue', sans-serif;
  --ff-accent: 'Cormorant Garamond', Garamond, serif;
  --radius-sm: 4px; --radius-md: 8px; --radius-lg: 16px; --radius-xl: 24px;
  --shadow-card: 0 4px 24px rgba(44,28,20,0.10);
  --shadow-hover: 0 12px 40px rgba(44,28,20,0.18);
  --transition: 220ms ease;
  --touch-min: 48px;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--ff-body); color: var(--charcoal); background: var(--cream); overflow-x: hidden; line-height: 1.6; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.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; }
.skip-link { position:absolute;top:-100%;left:1rem;background:var(--wine);color:var(--cream);padding:12px 24px;z-index:9999;font-size:14px;font-weight:600;border-radius:0 0 var(--radius-md) var(--radius-md);transition:top var(--transition); }
.skip-link:focus { top:0; }
*:focus-visible { outline:3px solid var(--wine);outline-offset:3px; }

/* ─── HEADER ─────────────────────────── */
.site-header { position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,5vw,60px);height:72px;background:transparent;transition:background var(--transition),box-shadow var(--transition),height var(--transition); }
.site-header.scrolled { background:rgba(250,246,241,0.97);box-shadow:0 1px 20px rgba(114,47,55,0.10);height:64px;backdrop-filter:blur(12px); }
.site-header.solid { background:rgba(250,246,241,0.97);box-shadow:0 1px 20px rgba(114,47,55,0.10);height:64px; }
.logo { display:flex;flex-direction:column;gap:5px; }
.logo-main { font-family:var(--ff-display);font-size:18px;font-weight:600;color:var(--cream);line-height:1.1;transition:color var(--transition);letter-spacing:0.01em; }
.logo-sub { font-family:var(--ff-body);font-size:10px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);line-height:1;transition:color var(--transition); }
.site-header.scrolled .logo-main, .site-header.solid .logo-main { color:var(--wine); }
.site-header.scrolled .logo-sub, .site-header.solid .logo-sub { color:var(--gold-text); }
.main-nav { display:flex;align-items:center;gap:8px; }
.nav-link { font-size:14px;font-weight:500;color:rgba(250,246,241,0.92);padding:8px 14px;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);min-height:var(--touch-min);display:flex;align-items:center; }
.nav-link:hover { color:var(--gold);background:rgba(250,246,241,0.08); }
.nav-link.active { color:var(--gold); }
.site-header.scrolled .nav-link, .site-header.solid .nav-link { color:var(--slate); }
.site-header.scrolled .nav-link:hover, .site-header.solid .nav-link:hover { color:var(--wine);background:rgba(114,47,55,0.07); }
.site-header.scrolled .nav-link.active, .site-header.solid .nav-link.active { color:var(--wine); }
.nav-right { display:flex;align-items:center;gap:8px; }
.lang-toggle { font-size:13px;font-weight:600;color:rgba(250,246,241,0.7);background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.25);padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);min-height:var(--touch-min);min-width:var(--touch-min);font-family:var(--ff-body); }
.lang-toggle:hover { background:rgba(255,255,255,0.22);color:var(--cream); }
.site-header.scrolled .lang-toggle, .site-header.solid .lang-toggle { color:var(--slate);background:transparent;border-color:var(--stone); }
.site-header.scrolled .lang-toggle:hover, .site-header.solid .lang-toggle:hover { border-color:var(--wine);color:var(--wine);background:rgba(114,47,55,0.05); }
.btn-book-nav { background:var(--gold);color:var(--dark-wine);font-family:var(--ff-body);font-size:14px;font-weight:600;padding:0 22px;height:44px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition),transform var(--transition);min-height:var(--touch-min);white-space:nowrap; }
.btn-book-nav:hover { background:#b8924d;transform:translateY(-1px); }
.site-header.scrolled .btn-book-nav, .site-header.solid .btn-book-nav { background:var(--wine);color:var(--cream); }
.site-header.scrolled .btn-book-nav:hover, .site-header.solid .btn-book-nav:hover { background:var(--dark-wine); }
.nav-hamburger { display:none;background:none;border:none;cursor:pointer;padding:8px;min-height:var(--touch-min);min-width:var(--touch-min);align-items:center;justify-content:center;flex-direction:column;gap:5px; }
.nav-hamburger span { display:block;width:22px;height:2px;background:var(--cream);border-radius:2px;transition:all var(--transition); }
.site-header.scrolled .nav-hamburger span, .site-header.solid .nav-hamburger span { background:var(--charcoal); }

/* ─── PAGE HERO (inner pages) ────────── */
.page-hero { position:relative;height:62vh;min-height:420px;display:flex;align-items:flex-end;justify-content:flex-start;overflow:hidden;padding:0 clamp(20px,5vw,60px) 56px; }
.page-hero-image { position:absolute;inset:0;background-size:cover;background-position:center; }
.page-hero-overlay { position:absolute;inset:0;background:linear-gradient(160deg,rgba(74,26,32,0.72) 0%,rgba(44,28,20,0.45) 60%,rgba(44,28,20,0.55) 100%); }
.page-hero-content { position:relative;z-index:2;max-width:680px; }
.page-hero-breadcrumb { display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:rgba(250,246,241,0.6);margin-bottom:16px; }
.page-hero-breadcrumb a { color:rgba(250,246,241,0.6);transition:color var(--transition); }
.page-hero-breadcrumb a:hover { color:var(--gold); }
.page-hero-breadcrumb span { color:rgba(250,246,241,0.3); }
.page-hero-eyebrow { display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px; }
.page-hero-title { font-family:var(--ff-display);font-size:clamp(32px,5vw,60px);font-weight:500;color:var(--cream);line-height:1.1;letter-spacing:-0.01em;margin-bottom:16px; }
.page-hero-title em { font-style:italic;color:var(--gold); }
.page-hero-sub { font-family:var(--ff-accent);font-size:clamp(15px,1.8vw,19px);font-style:italic;color:rgba(250,246,241,0.85);line-height:1.5; }

/* ─── SECTIONS ───────────────────────── */
.section { padding:clamp(56px,8vw,100px) clamp(20px,5vw,60px); }
.section-inner { max-width:1160px;margin:0 auto; }
.section-header { text-align:center;margin-bottom:clamp(36px,5vw,64px); }
.section-eyebrow { display:inline-block;font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-text);margin-bottom:14px; }
.section-title { font-family:var(--ff-display);font-size:clamp(26px,3.5vw,42px);font-weight:500;color:var(--charcoal);line-height:1.2;letter-spacing:-0.01em; }
.section-title em { font-style:italic;color:var(--wine); }
.section-desc { margin-top:14px;font-size:16px;line-height:1.75;color:var(--slate);max-width:580px;margin-left:auto;margin-right:auto; }
.divider { width:48px;height:2px;background:linear-gradient(90deg,var(--wine),var(--gold));margin:18px auto 0;border-radius:2px; }

/* ─── BUTTONS ────────────────────────── */
.btn-primary { background:var(--gold);color:var(--dark-wine);font-family:var(--ff-body);font-size:15px;font-weight:700;padding:0 36px;height:54px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition),transform var(--transition);min-height:var(--touch-min);letter-spacing:0.02em; }
.btn-primary:hover { background:#b8924d;transform:translateY(-2px); }
.btn-secondary { background:var(--wine);color:var(--cream);font-family:var(--ff-body);font-size:15px;font-weight:600;padding:0 36px;height:52px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition),transform var(--transition);min-height:var(--touch-min); }
.btn-secondary:hover { background:var(--dark-wine);transform:translateY(-2px); }
.btn-outline-wine { background:transparent;color:var(--wine);font-family:var(--ff-body);font-size:15px;font-weight:600;padding:0 32px;height:52px;border-radius:var(--radius-sm);border:2px solid var(--wine);cursor:pointer;transition:all var(--transition);min-height:var(--touch-min); }
.btn-outline-wine:hover { background:var(--wine);color:var(--cream); }

/* ─── FOOTER ─────────────────────────── */
.site-footer { background:var(--charcoal);color:rgba(250,246,241,0.7);padding:clamp(48px,6vw,80px) clamp(20px,5vw,60px) 32px; }
.footer-inner { max-width:1160px;margin:0 auto; }
.footer-top { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px; }
.footer-brand .logo-main { color:var(--cream);font-size:20px; }
.footer-brand .logo-sub { color:var(--gold); }
.footer-tagline { font-size:14px;line-height:1.6;margin-top:16px;opacity:0.7; }
.footer-col-title { font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold);margin-bottom:16px; }
.footer-links { list-style:none;display:flex;flex-direction:column;gap:10px; }
.footer-links a { font-size:14px;color:rgba(250,246,241,0.65);transition:color var(--transition); }
.footer-links a:hover { color:var(--cream); }
.footer-social { display:flex;gap:12px;margin-top:20px; }
.social-link { width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid rgba(250,246,241,0.18);display:flex;align-items:center;justify-content:center;color:rgba(250,246,241,0.65);transition:all var(--transition); }
.social-link:hover { border-color:var(--gold);color:var(--gold); }
.footer-bottom { padding-top:28px;border-top:1px solid rgba(250,246,241,0.1);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px; }
.footer-copy { font-size:13px; }
.footer-legal { display:flex;gap:20px; }
.footer-legal a { font-size:13px;color:rgba(250,246,241,0.5);transition:color var(--transition); }
.footer-legal a:hover { color:var(--cream); }

@media (max-width:1024px) { .footer-top { grid-template-columns:1fr 1fr;gap:32px; } }
@media (max-width:768px) { .main-nav { display:none; } .nav-hamburger { display:flex; } .footer-top { grid-template-columns:1fr;gap:24px; } .page-hero { height:52vh;min-height:360px; } }
