/* Ahir Hospitality — shared site styles */

/* Layout */
.container        { max-width: var(--max-w-content); margin: 0 auto; padding: 0 var(--pad-x); }
.container-wide   { max-width: var(--max-w-wide);    margin: 0 auto; padding: 0 var(--pad-x); }
.container-narrow { max-width: var(--max-w-narrow);  margin: 0 auto; padding: 0 var(--pad-x); }

/* Nav — logo left, links middle/right, CTA far right */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 50; background: transparent; border-bottom: 1px solid transparent; transition: background .35s ease, border-color .35s ease, backdrop-filter .35s ease; }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--s-10); height: 96px; max-width: var(--max-w-wide); margin: 0 auto; padding: 0 var(--pad-x); position: relative; }
.nav-links { display: flex; align-items: center; gap: var(--s-10); }
.nav-logo-link { display: block; line-height: 0; flex: 0 0 auto; }
.nav-logo { height: 48px; width: auto; filter: brightness(0) invert(1); transition: filter .35s ease; }
.nav-link { color: rgba(255,255,255,.92); font-size: 21px; font-weight: 500; transition: color .35s ease, opacity .35s ease; letter-spacing: .2px; }
.nav-link:hover { color: #fff; }
.nav-link.active { color: #fff; }
.nav-link.active::after { content: ""; display: block; height: 1px; background: rgba(255,255,255,.6); margin-top: 2px; transition: background .35s ease; }
.nav-cta { background: rgba(255,255,255,.10); color: #fff; padding: var(--s-3) var(--s-6); border-radius: var(--r); font-size: 21px; font-weight: 500; border: 1px solid rgba(255,255,255,.30); backdrop-filter: blur(8px); transition: all .35s ease; }
.nav-cta:hover { background: #fff; color: var(--navy); border-color: #fff; }

/* Scrolled state — solid white */
.nav.is-scrolled { background: rgba(255,255,255,.96); border-bottom-color: var(--border); backdrop-filter: blur(10px); }
.nav.is-scrolled .nav-logo { filter: brightness(0); }
.nav.is-scrolled .nav-link { color: var(--text); }
.nav.is-scrolled .nav-link:hover, .nav.is-scrolled .nav-link.active { color: var(--blue); }
.nav.is-scrolled .nav-link.active::after { background: var(--blue); }
.nav.is-scrolled .nav-cta { background: var(--navy); color: #fff; border-color: transparent; backdrop-filter: none; }
.nav.is-scrolled .nav-cta:hover { background: var(--navy-2); color: #fff; }

/* Mobile hamburger button — hidden on desktop */
.nav-burger {
  display: none;
  background: transparent;
  border: 0;
  padding: var(--s-2);
  cursor: pointer;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: var(--r);
  transition: background .2s ease;
}
.nav-burger:hover { background: rgba(255,255,255,.10); }
.nav-burger:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
.nav.is-scrolled .nav-burger:hover { background: rgba(11,31,58,.06); }
.nav.is-scrolled .nav-burger:focus-visible { outline-color: var(--blue); }

.nav-burger-icon {
  position: relative;
  width: 22px;
  height: 16px;
  display: block;
}
.nav-burger-icon::before,
.nav-burger-icon::after,
.nav-burger-icon span {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: #fff;
  border-radius: 1px;
  transition: transform .3s cubic-bezier(.16,1,.3,1), top .3s cubic-bezier(.16,1,.3,1), opacity .2s ease, background-color .35s ease;
}
.nav-burger-icon::before { top: 0; }
.nav-burger-icon span    { top: 7px; left: 0; right: 0; display: block; }
.nav-burger-icon::after  { top: 14px; }
.nav.is-scrolled .nav-burger-icon::before,
.nav.is-scrolled .nav-burger-icon::after,
.nav.is-scrolled .nav-burger-icon span { background: var(--navy); }

/* X state when menu open */
.nav.is-open .nav-burger-icon::before { top: 7px; transform: rotate(45deg); }
.nav.is-open .nav-burger-icon::after  { top: 7px; transform: rotate(-45deg); }
.nav.is-open .nav-burger-icon span    { opacity: 0; }
.nav.is-open .nav-burger-icon::before,
.nav.is-open .nav-burger-icon::after  { background: #fff; }

/* Mobile breakpoint: hide desktop links + CTA, show hamburger */
@media (max-width: 900px) {
  .nav-burger { display: inline-flex; }

  /* CRITICAL: when menu is open, force the parent nav to drop its backdrop-filter
     and any background that would create a new containing block — so the
     position:fixed overlay children can fill the actual viewport. */
  .nav.is-open {
    background: var(--navy) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom-color: transparent !important;
  }

  /* Desktop links + CTA become a fullscreen overlay */
  .nav-links,
  .nav-cta {
    position: fixed;
    inset: 0;
    background: var(--navy);
    z-index: 49;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--s-6);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-12px);
    transition: opacity .35s ease, transform .35s ease;
    padding: var(--s-24) var(--pad-x) var(--s-12);
  }
  .nav-links { display: flex; }
  .nav-cta {
    /* Pin Partner CTA at the bottom of the overlay rather than centered with links */
    inset: auto 0 var(--s-12) 0;
    width: max-content;
    margin: 0 auto;
    padding: var(--s-3) var(--s-8);
    font-size: 18px;
    background: var(--blue);
    border-color: var(--blue);
    backdrop-filter: none;
  }
  .nav.is-open .nav-links,
  .nav.is-open .nav-cta {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  .nav.is-open .nav-cta:hover { background: #2657d6; border-color: #2657d6; color: #fff; }
  .nav-link {
    color: #fff;
    font-size: 28px;
    font-weight: 400;
    font-family: var(--serif);
    letter-spacing: -0.01em;
    padding: var(--s-2) 0;
  }
  .nav-link.active { color: var(--blue-soft); }
  .nav-link.active::after { display: none; }

  /* When scrolled state combines with mobile, force overlay back to navy */
  .nav.is-scrolled .nav-links { background: var(--navy); }
  .nav.is-scrolled .nav-link { color: #fff; }

  /* Lock body scroll when menu is open */
  body.nav-open { overflow: hidden; }
}

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: var(--s-2); padding: var(--s-4) var(--s-8); border-radius: var(--r); font-family: var(--sans); font-size: var(--fs-body); font-weight: 500; border: 1px solid transparent; cursor: pointer; transition: all var(--t-fast); text-decoration: none; }
.btn-primary { background: var(--blue); color: #fff; }
.btn-primary:hover { background: var(--blue-soft); color: #fff; }
.btn-secondary { background: transparent; color: var(--navy); border: 1px solid var(--navy); }
.btn-secondary:hover { background: var(--navy); color: #fff; }
.btn-ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.25); }
.btn-ghost-light:hover { background: rgba(255,255,255,.08); color: #fff; }
.btn-sm { padding: var(--s-2) var(--s-5); font-size: var(--fs-body-sm); }

/* Type helpers */
.eyebrow { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--faint); font-weight: 600; margin: 0 0 var(--s-3); }
.section-title { font-family: var(--serif); font-size: var(--fs-h1); line-height: var(--lh-tight); color: var(--navy); margin: 0 0 var(--s-4); letter-spacing: var(--ls-tight); }
.section-sub { font-size: var(--fs-body-lg); line-height: var(--lh-relaxed); color: var(--muted); margin: 0; max-width: 56ch; }

/* Hero */
.hero { background: var(--navy); color: #fff; padding: var(--s-24) 0 var(--s-20); position: relative; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 0%, rgba(59,130,246,.18), transparent 60%); pointer-events: none; }
.hero-inner { position: relative; z-index: 1; }
.hero-eyebrow { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: rgba(255,255,255,.5); font-weight: 600; margin: 0 0 var(--s-5); }
.hero-title { font-family: var(--serif); font-size: var(--fs-display); line-height: var(--lh-tight); color: #fff; margin: 0 0 var(--s-6); letter-spacing: var(--ls-tight); }
.hero-sub { font-size: var(--fs-body-lg); line-height: var(--lh-relaxed); color: rgba(255,255,255,.75); margin: 0 0 var(--s-10); max-width: 56ch; }
.hero-actions { display: flex; gap: var(--s-3); flex-wrap: wrap; }

/* Slim hero for inner pages */
.hero-slim { padding: var(--s-20) 0 var(--s-16); min-height: 48vh; display: flex; align-items: flex-end; }
.hero-slim .hero-inner { width: 100%; }
.hero-slim .hero-title { font-size: clamp(36px, 5vw, 110px); max-width: 22ch; margin-bottom: var(--s-4); letter-spacing: -0.02em; font-weight: 400; }
.hero-slim .hero-sub { font-size: var(--fs-body-lg); margin-bottom: 0; max-width: 56ch; }

/* Hero photo treatment (used on slim and full heroes) */
.hero-photo { position: relative; overflow: hidden; }
.hero-photo .hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-photo .hero-bg img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.04); animation: heroBgIn 1.6s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes heroBgIn { to { transform: scale(1); } }
.hero-photo .hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(11,31,58,.55) 0%, rgba(11,31,58,.35) 50%, rgba(11,31,58,.85) 100%); }
.hero-photo .hero-inner { position: relative; z-index: 2; }

/* Section */
.section       { padding: var(--s-20) 0; }
.section-bg-soft { background: var(--bg); }
.section-hdr   { margin-bottom: var(--s-12); }

/* Property card (public) */
.prop-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; transition: box-shadow var(--t-normal), transform var(--t-normal); text-decoration: none; color: inherit; display: block; }
.prop-card .prop-photo img { transition: transform .8s cubic-bezier(.16,1,.3,1); }
a.prop-card { cursor: pointer; }
a.prop-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
a.prop-card:hover .prop-photo img,
article.prop-card:hover .prop-photo img { transform: scale(1.06); }
article.prop-card:hover { box-shadow: var(--shadow-md); }

/* Scroll-triggered fade-in */
.fade-in { opacity: 0; transform: translateY(24px); transition: opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
.fade-in.is-visible { opacity: 1; transform: none; }
.prop-photo { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--navy-2), var(--navy)); position: relative; overflow: hidden; }
.prop-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.prop-photo-fallback { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.25); font-family: var(--serif); font-size: 56px; }
.prop-body { padding: var(--s-5); }
.prop-name { font-family: var(--sans); font-size: var(--fs-h3); font-weight: 600; color: var(--navy); margin: 0 0 var(--s-1); line-height: 1.3; }
.prop-meta { font-size: var(--fs-body-sm); color: var(--muted); margin: 0; }

/* Footer */
.footer { background: #06152a; color: #fff; padding: var(--s-16) 0 var(--s-8); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--s-12); margin-bottom: var(--s-12); }
.footer-brand img { height: 32px; filter: brightness(0) invert(1); margin-bottom: var(--s-4); }
.footer-tagline { font-size: var(--fs-body-sm); color: rgba(255,255,255,.6); margin: 0; max-width: 32ch; line-height: var(--lh-relaxed); }
.footer-col h4 { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: rgba(255,255,255,.4); margin: 0 0 var(--s-4); font-weight: 600; }
.footer-col a { color: rgba(255,255,255,.85); font-size: var(--fs-body-sm); display: block; margin-bottom: var(--s-3); transition: color var(--t-fast); }
.footer-col a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: var(--s-6); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--s-4); }
.footer-copy { font-size: var(--fs-caption); color: rgba(255,255,255,.4); margin: 0; }
@media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--s-8); } }

/* Pill selectors (county filter, property tabs) — implemented as <button> for a11y */
.pills { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--s-3); }
.pill { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: var(--s-4) var(--s-5); text-align: center; cursor: pointer; font-size: var(--fs-body-sm); font-weight: 600; color: var(--navy); transition: all var(--t-fast); user-select: none; font-family: var(--sans); width: 100%; }
.pill:hover { border-color: var(--blue); }
.pill.on, .pill[aria-pressed="true"] { background: var(--navy); color: #fff; border-color: var(--navy); }

/* Skip-to-content link — visible on focus */
.skip-link { position: absolute; top: -100px; left: var(--s-3); background: var(--navy); color: #fff; padding: var(--s-3) var(--s-5); z-index: 100; border-radius: var(--r); font-weight: 600; transition: top var(--t-fast); }
.skip-link:focus { top: var(--s-3); color: #fff; outline: 3px solid var(--blue-soft); outline-offset: 2px; }

/* Visually hidden text for screen readers */
.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; }

/* Focus styles — keyboard only via :focus-visible */
:focus { outline: none; }
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.pill:focus-visible,
[tabindex]:focus-visible { outline: 3px solid var(--blue-soft); outline-offset: 2px; border-radius: var(--r-sm); }
.btn:focus-visible { outline-offset: 3px; }
.nav-link:focus-visible { color: var(--blue); outline: 3px solid var(--blue-soft); outline-offset: 4px; border-radius: 4px; }
.prop-card:focus-visible { outline: 3px solid var(--blue-soft); outline-offset: 4px; }

/* Reduce motion preference */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}

/* ============ Editorial components (Parable-inspired) ============ */

/* Nav dropdown */
.nav-item { position: relative; }
.nav-item-trigger { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; }
.nav-item-trigger::after { content: ""; width: 6px; height: 6px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg); margin-top: -3px; opacity: .7; transition: transform .25s ease; }
.nav-item:hover .nav-item-trigger::after,
.nav-item:focus-within .nav-item-trigger::after { transform: rotate(225deg); margin-top: 3px; }
.nav-dropdown { position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%) translateY(8px); min-width: 200px; background: #fff; border-radius: var(--r); box-shadow: var(--shadow-lg); padding: var(--s-3); opacity: 0; visibility: hidden; transition: all .25s ease; pointer-events: none; }
.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); pointer-events: auto; }
.nav-dropdown a { display: block; padding: var(--s-2) var(--s-3); border-radius: var(--r-sm); color: var(--text); font-size: var(--fs-body-sm); font-weight: 500; transition: background .15s ease, color .15s ease; }
.nav-dropdown a:hover { background: var(--bg); color: var(--blue); }
@media (max-width: 768px) { .nav-dropdown { display: none; } }

/* Editorial section variant — generous whitespace */
.section-xl { padding: var(--s-32) 0; }
@media (max-width: 768px) { .section-xl { padding: var(--s-20) 0; } }

/* Three-phrase parallel block — like Parable's "Trust is built through..." */
.parallel-block { font-family: var(--serif); font-size: clamp(28px, 3.6vw, 80px); line-height: 1.25; color: var(--navy); letter-spacing: -0.015em; max-width: 32ch; margin: 0; }
.parallel-block span { display: block; }
.parallel-block span + span { margin-top: var(--s-3); color: var(--muted); }
.parallel-block span + span + span { color: var(--faint); }

/* Pillar grid — numbered editorial cards */
.pillar-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
@media (max-width: 1024px) { .pillar-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .pillar-grid { grid-template-columns: 1fr; } }
.pillar-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: var(--s-8); transition: all var(--t-normal); }
.pillar-card:hover { box-shadow: var(--shadow-md); border-color: var(--blue-soft); }
.pillar-num { font-family: var(--serif); font-size: 14px; color: var(--blue); letter-spacing: 1.5px; text-transform: uppercase; margin: 0 0 var(--s-4); font-weight: 600; }
.pillar-title { font-family: var(--serif); font-size: 24px; color: var(--navy); margin: 0 0 var(--s-3); line-height: 1.2; letter-spacing: -0.01em; }
.pillar-text { font-size: var(--fs-body); color: var(--muted); line-height: var(--lh-relaxed); margin: 0; }

/* Leader card grid */
.leader-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
@media (max-width: 1024px) { .leader-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .leader-grid { grid-template-columns: 1fr; } }
.leader-card { background: var(--surface); border-radius: var(--r); overflow: hidden; transition: all var(--t-normal); }
.leader-photo { aspect-ratio: 4/5; background: linear-gradient(135deg, var(--navy-2), var(--navy)); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.25); font-family: var(--serif); font-size: 56px; font-weight: 400; }
.leader-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.leader-body { padding: var(--s-5) 0 0; }
.leader-name { font-family: var(--serif); font-size: 22px; color: var(--navy); margin: 0 0 var(--s-1); line-height: 1.2; }
.leader-title { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--faint); font-weight: 600; margin: 0 0 var(--s-3); }
.leader-bio { font-size: var(--fs-body-sm); color: var(--muted); line-height: var(--lh-relaxed); margin: 0; }

/* Three-word tagline (e.g. "Experienced. Present. Grounded.") */
.tag-3 { font-family: var(--serif); font-size: clamp(36px, 5vw, 110px); line-height: 1.1; color: var(--navy); letter-spacing: -0.02em; margin: 0; }
.tag-3 span { display: inline-block; }
.tag-3 span + span::before { content: " · "; color: var(--blue); margin: 0 var(--s-1); }

/* CTA Strip variant — softer, Parable-style */
.cta-strip { background: var(--navy); color: #fff; padding: var(--s-24) 0; text-align: center; position: relative; overflow: hidden; }
.cta-strip::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 0%, rgba(59,130,246,.15), transparent 70%); pointer-events: none; }
.cta-strip-inner { position: relative; z-index: 1; }
.cta-strip h2 { font-family: var(--serif); font-size: clamp(36px, 5vw, 110px); line-height: 1.1; color: #fff; margin: 0 0 var(--s-5); letter-spacing: -0.02em; }
.cta-strip p { font-size: var(--fs-body-lg); color: rgba(255,255,255,.7); margin: 0 auto var(--s-10); max-width: 52ch; line-height: var(--lh-relaxed); }
.cta-strip .btn-primary { padding: var(--s-4) var(--s-10); font-size: var(--fs-body-lg); }

/* Editorial split — alternating image/text */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-16); align-items: center; }
.split.split-reverse > .split-text { order: 2; }
.split-image { aspect-ratio: 4/5; border-radius: var(--r-lg); overflow: hidden; background: var(--bg); position: relative; }
.split-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .8s cubic-bezier(.16,1,.3,1); }
.split:hover .split-image img { transform: scale(1.04); }
.split-eyebrow { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--blue); font-weight: 600; margin: 0 0 var(--s-3); }
.split-title { font-family: var(--serif); font-size: clamp(28px, 3.5vw, 76px); line-height: 1.15; color: var(--navy); margin: 0 0 var(--s-5); letter-spacing: -0.015em; }
.split-text p { font-size: var(--fs-body-lg); color: var(--text); line-height: var(--lh-relaxed); margin: 0 0 var(--s-4); }
.split-text p:last-of-type { margin-bottom: var(--s-6); }
@media (max-width: 768px) { .split { grid-template-columns: 1fr; gap: var(--s-8); } .split.split-reverse > .split-text { order: 0; } }

/* Sub-page nav (used on About sub-pages) */
.subnav { background: var(--surface); border-bottom: 1px solid var(--border); padding: 0 var(--pad-x); position: sticky; top: 72px; z-index: 30; }
.subnav-inner { max-width: var(--max-w-content); margin: 0 auto; display: flex; gap: var(--s-8); overflow-x: auto; -webkit-overflow-scrolling: touch; }
.subnav a { display: inline-block; padding: var(--s-4) 0; font-size: var(--fs-body-sm); color: var(--muted); font-weight: 500; border-bottom: 2px solid transparent; white-space: nowrap; transition: color .2s, border-color .2s; }
.subnav a:hover { color: var(--blue); }
.subnav a.active { color: var(--navy); border-bottom-color: var(--navy); }
