/* Hispania Private — v9 (literal text + restrained gold system) */

:root{
  --bg:#060607;
  --fg:rgba(246,244,239,.96);
  --muted:rgba(246,244,239,.78);
  --muted2:rgba(246,244,239,.62);
  --line:rgba(246,244,239,.14);
  --card:rgba(246,244,239,.045);
  --shadow:0 26px 80px rgba(0,0,0,.55);
  --radius:22px;
  --max:1100px;

  /* Gold scale (3 levels) */
                /* key info */
  --gold: #cbb06f;                     /* headings/links */
  --gold-dim:rgba(203,176,111,.70);   /* labels */
}

*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
body{
  margin:0;
  color:var(--fg);
  background:var(--bg);
  font-family: "Libre Baskerville", Georgia, "Times New Roman", serif;
  line-height:1.68;
}
a{ color:inherit; text-decoration-color: rgba(203,176,111,.55); text-underline-offset: 4px; }
a:hover{ text-decoration-color: rgba(203,176,111,.90); }

/* Background */
.bg{
  position:fixed;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(900px 620px at 16% -10%, rgba(255,255,255,.08), transparent 62%),
    radial-gradient(980px 700px at 84% 16%, rgba(203,176,111,.22), transparent 62%),
    radial-gradient(960px 680px at 50% 118%, rgba(119,82,25,.28), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 28%, transparent 72%, rgba(119,82,25,.16));
}
.bg::before{
  content:"";
  position:absolute;
  inset:-10%;
  opacity:.30; /* requested */
  pointer-events:none;
  background: radial-gradient(circle, rgba(203,176,111,.26) 1.15px, transparent 1.35px) 0 0/10px 10px;
  -webkit-mask-image: radial-gradient(90% 70% at 25% 25%, #000 0%, transparent 62%);
          mask-image: radial-gradient(90% 70% at 25% 25%, #000 0%, transparent 62%);
  transform: rotate(-8deg);
}
.bg::after{
  content:"";
  position:absolute;
  inset:0;
  background-image: repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0px, rgba(255,255,255,.012) 1px, transparent 1px, transparent 7px);
  opacity:.20;
  mix-blend-mode:overlay;
  pointer-events:none;
}

/* Layout */
.container{ width:min(var(--max), calc(100% - 56px)); margin:0 auto; }
.narrow{ max-width: 860px; }

/* Header */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(12px);
  background: rgba(6,6,7,.74);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 0;
}
.brand{
  text-decoration:none;
  font-size:18px;
  letter-spacing:.04em;
  color:var(--fg);
}
.nav{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:12px;
  letter-spacing:.14em;
}
.nav a{
  color:var(--muted2);
  text-decoration:none;
  padding:8px 10px;
  border-radius:12px;
}
.nav a:hover{ color:var(--gold); background: rgba(246,244,239,.05); }
.nav-cta{
  color: var(--fg) !important;
  border: 1px solid rgba(203,176,111,.35);
  background: linear-gradient(180deg, rgba(203,176,111,.14), rgba(246,244,239,.03));
}

/* Sections */
.section{ padding: 92px 0; border-bottom:1px solid var(--line); }
.section.alt{ background: rgba(255,255,255,.012); }
.hero{ padding-top: 118px; }
.hero-inner{ max-width: 1040px; }

/* Typography */
.kicker{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 11px;
  color: var(--gold);
  margin:0 0 14px 0;
  opacity: 0.70;
}
h1{
  margin:0 0 14px 0;
  font-size: clamp(44px, 6vw, 72px);
  line-height:1.06;
}
h2{
  margin:0 0 26px 0;
  font-size: clamp(24px, 3.1vw, 36px);
  letter-spacing:.16em;
  text-transform: uppercase;
  color: var(--gold);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
h3{
  margin: 34px 0 10px 0;
  font-size: 14px;
  letter-spacing:.16em;
  text-transform: uppercase;
  color: var(--gold);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.lead{
  margin:0;
  max-width: 78ch;
  font-size: 18px;
  color: rgba(246,244,239,.92);
}
.body{ margin: 12px 0; color: var(--muted); max-width: 86ch; }
.body.small{ font-size: 14px; color: var(--muted2); }
.gold-strong{ color: var(--gold); font-weight: 650; }

/* Hero cards */
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:16px;
  margin-top: 26px;
}
.hero-card{
  border:1px solid rgba(246,244,239,.16);
  background: linear-gradient(180deg, rgba(246,244,239,.055), rgba(246,244,239,.02));
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
}
.hero-card.subtle{
  border-color: rgba(203,176,111,.24);
  background: linear-gradient(180deg, rgba(203,176,111,.10), rgba(246,244,239,.02));
}

/* Mini blocks */
.mini{ padding: 12px 0; border-bottom:1px solid rgba(246,244,239,.11); }
.mini:last-child{ border-bottom:0; }
.mini-title{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
  opacity: 0.70;
}
.mini-body{ color: rgba(246,244,239,.92); font-size: 16px; line-height: 1.6; }
.mini-body a{ color: var(--gold); text-decoration: none; }
.mini-body a:hover{ text-decoration: underline; text-underline-offset: 4px; }

/* Pills */
.pill-row{ display:flex; flex-wrap:wrap; gap:8px; margin-top: 14px; }
.pill{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(246,244,239,.16);
  background: rgba(246,244,239,.03);
  color: rgba(246,244,239,.90);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 12px;
  letter-spacing: .03em;
}

/* Lists */
.bullets{ margin: 14px 0 0 0; padding-left: 18px; color: var(--muted); max-width: 86ch; }
.bullets li{ margin: 7px 0; }

/* Cards */
.card{
  margin-top: 14px;
  border:1px solid rgba(246,244,239,.16);
  background: var(--card);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow);
}

/* Facts */
.facts{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}
.fact{
  border:1px solid rgba(246,244,239,.16);
  background: rgba(246,244,239,.04);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
}
.fact-title{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
  opacity: 0.70;
}
.fact-body{ color: rgba(246,244,239,.92); font-size: 14px; line-height: 1.5; }

/* Calendar */
.calendar{ margin-top: 14px; }
.calendar-row{
  display:grid;
  grid-template-columns: 1.2fr .7fr 1.3fr;
  gap: 12px;
  padding: 12px 0;
  border-bottom:1px solid rgba(246,244,239,.11);
}
.calendar-row:last-child{ border-bottom:0; }
.calendar-head{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.70;
}
.badge{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
  border:1px solid rgba(246,244,239,.16);
}
.badge.available{ background: rgba(203,176,111,.14); color: rgba(246,244,239,.95); border-color: rgba(203,176,111,.30); }
.badge.reserved{ background: rgba(246,244,239,.07); color: rgba(246,244,239,.95); }
.badge.onrequest{ background: rgba(246,244,239,.04); color: rgba(246,244,239,.88); }
.legend{ display:inline-flex; align-items:center; gap:8px; margin-right: 14px; }

/* Price badge */
.price-inline{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(203,176,111,.32);
  background: linear-gradient(180deg, rgba(203,176,111,.14), rgba(246,244,239,.02));
  color: var(--gold);
  font-weight: 650;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
}

/* Contact */
.contact-box{
  margin-top: 12px;
  border: 1px solid rgba(203,176,111,.28);
  background: linear-gradient(180deg, rgba(203,176,111,.10), rgba(246,244,239,.02));
  border-radius: var(--radius);
  padding: 16px;
}
.contact-email{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 18px;
  color: var(--gold);
  text-decoration: none;
}
.contact-email:hover{ text-decoration: underline; text-underline-offset: 4px; }

/* Footer */
.site-footer{ padding: 28px 0; }
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  color: var(--muted2);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 13px;
}

/* Reveal animation */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  filter: blur(6px);
  transition: opacity .85s ease, transform .85s ease, filter .95s ease;
  will-change: opacity, transform, filter;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; filter:none; transition:none; }
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 760px){
  .calendar-row{ grid-template-columns: 1fr; gap:6px; }
  .calendar-head{ display:none; }
}
@media (max-width: 640px){
  .container{ width: calc(100% - 40px); }
  .section{ padding: 74px 0; }
  .hero{ padding-top: 94px; }
  .card{ padding: 18px; }
}


/* v13: hero email should not be gold */
.hero .mini-body a{
  color: rgba(246,244,239,.92);
}
.hero .mini-body a:hover{
  text-decoration: underline;
  text-underline-offset: 4px;
}



/* v13: CONTACT spacing */
#contact .card .body{ margin: 16px 0; }
#contact .contact-box{ margin: 18px 0; }
#contact .body.small{ margin-top: 18px; }


/* v14: unify gold for all headings and labels */
.fact-title,
.calendar-head,
.mini-title,
.status-label,
.notes-label{
  color: var(--gold);
  opacity: 1;
}

/* v15: enforce single gold everywhere */
.kicker,
.section-title,
.fact-title,
.calendar-head,
.mini-title,
.status-label,
.notes-label,
nav a.active,
nav a:hover {
  color: var(--gold);
}


/* v16: Mobile header + overlay menu */
.menu-toggle{
  display:none;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gold);
  background: transparent;
  border: 1px solid rgba(246,244,239,.16);
  padding: 10px 12px;
  border-radius: 12px;
}

.menu-overlay{
  display:none;
}

@media (max-width: 760px){
  .header-inner{ padding: 12px 0; }
  .brand{
    font-size: 16px;
    letter-spacing: .03em;
    white-space: nowrap;
  }

  /* Hide desktop nav, show toggle */
  .nav{ display:none; }
  .menu-toggle{ display:inline-flex; align-items:center; justify-content:center; }

  .menu-overlay{
    display:block;
    position: fixed;
    inset: 0;
    background: rgba(6,6,7,.72);
    backdrop-filter: blur(14px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
    z-index: 80;
    padding: 20px;
  }
  .menu-overlay.is-open{
    opacity: 1;
    pointer-events: auto;
  }
  .menu-panel{
    max-width: 520px;
    margin: 72px auto 0 auto;
    border: 1px solid rgba(246,244,239,.16);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(246,244,239,.055), rgba(246,244,239,.02));
    box-shadow: 0 26px 80px rgba(0,0,0,.55);
    padding: 18px;
  }
  .menu-panel .nav{
    display:flex;
    flex-direction: column;
    gap: 8px;
    font-size: 12px;
  }
  .menu-panel .nav a{
    padding: 12px 12px;
  }
  .menu-panel .nav-cta{
    text-align: center;
    padding: 12px 12px;
  }

  body.menu-open{ overflow:hidden; }
}

/* v16: Mobile spacing for availability legend */
@media (max-width: 760px){
  .legend{
    display:flex;
    gap: 10px;
    margin: 10px 0;
  }
  .body.small .legend{
    margin-right: 0;
  }
}


/* v17: restore desktop nav */
@media (min-width: 761px){
  .nav{ display:flex !important; }
  .menu-toggle{ display:none !important; }
  .menu-overlay{ display:none !important; }
}

/* v18: desktop + mobile nav separation */
.desktop-nav{ display:flex; }
.mobile-nav{ display:flex; }

@media (max-width: 760px){
  .desktop-nav{ display:none !important; }
  .menu-toggle{ display:inline-flex !important; }
  .menu-overlay{ display:block !important; }
  .menu-panel .mobile-nav{ display:flex !important; }
}

@media (min-width: 761px){
  .desktop-nav{ display:flex !important; }
  .menu-toggle{ display:none !important; }
  .menu-overlay{ display:none !important; }
}


/* v19: mobile hero compaction (reduce initial above-the-fold whitespace) */
@media (max-width: 760px){
  .hero{ padding-top: 68px; } /* was ~94px */
  .kicker{ margin: 0 0 10px 0; }
  h1{ margin: 0 0 10px 0; }
  .lead{ font-size: 17px; }
  .hero-grid{ margin-top: 18px; }
  .hero-card{ padding: 16px; }
}



/* v22: contact visual breathing room */
.contact-card{ padding: 34px; }
.contact-lead{ margin-top: 18px; margin-bottom: 10px; }
.contact-bullets{ margin-top: 6px; margin-bottom: 18px; }
.contact-bullets li{ margin: 6px 0; }
.contact-foot{ opacity: .9; margin-top: 12px; }

@media (max-width: 760px){
  .contact-card{ padding: 22px; }
}

/* v25: email emphasis */
.email-box.gold{
  border-color: var(--gold);
  color: var(--gold);
}
