/* ============================================================
   Local 1A — Live Jacó
   Design inspired by editorial real estate flyer:
   dark/cream split, photo collage, serif display, curved
   connector lines, triangle bullets.
   ============================================================ */

/* ---------- Reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--c-ink);
  background: var(--c-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--c-primary); text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { text-decoration-thickness: 2px; }
button { font: inherit; cursor: pointer; }
ul { padding-left: 1.25em; }
:focus-visible { outline: 3px solid var(--c-accent); outline-offset: 3px; border-radius: 4px; }

/* ---------- Tokens — Live Jacó tropical-editorial palette ---------- */
:root {
  --c-dark: #1c2a33;          /* deep navy/charcoal — main dark surface */
  --c-dark-2: #243641;        /* slightly lighter dark for cards on dark */
  --c-primary: #0e5566;       /* Live Jacó teal */
  --c-primary-light: #3d8593; /* lighter teal accent */
  --c-primary-soft: #d4e5e8;
  --c-cream: #f4e9d3;         /* main warm cream — body bg */
  --c-cream-2: #e9dcc1;       /* slightly deeper cream for cards */
  --c-sand: #d8c19a;          /* sand accent for triangles, lines */
  --c-sand-dark: #b89870;
  --c-accent: #b8702f;        /* warm copper for price/CTA */
  --c-accent-dark: #9a5a23;
  --c-ink: #1c2a33;           /* main text on cream */
  --c-ink-soft: #4a5963;      /* secondary text */
  --c-ink-mute: #7a8a93;      /* tertiary text */
  --c-on-dark: #f4e9d3;       /* main text on dark */
  --c-on-dark-soft: #c9bb98;  /* secondary text on dark */
  --c-whatsapp: #25d366;
  --c-whatsapp-dark: #1ebe5b;

  --font-display: "Cormorant Garamond", "Playfair Display", Georgia, "Times New Roman", serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --radius-sm: 4px;
  --radius: 8px;
  --shadow-soft: 0 8px 30px rgba(28, 42, 51, 0.12);
  --shadow-img: 0 16px 40px rgba(28, 42, 51, 0.25);

  --container: 1200px;
  --container-narrow: 880px;

  --space-1: 0.5rem;
  --space-2: 1rem;
  --space-3: 1.5rem;
  --space-4: 2rem;
  --space-5: 3rem;
  --space-6: 4rem;
  --space-7: 6rem;
  --space-8: 8rem;
}

/* ---------- Typography ---------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.05;
  margin: 0 0 var(--space-3);
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
h1 {
  font-size: clamp(2.6rem, 6vw + 1rem, 5.5rem);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 0.95;
}
h2 {
  font-size: clamp(1.8rem, 3.5vw + 0.8rem, 3rem);
  font-weight: 500;
  font-style: italic;
}
h3 {
  font-size: clamp(1.15rem, 0.6vw + 1rem, 1.35rem);
  font-weight: 600;
  font-style: normal;
  font-family: var(--font-body);
  letter-spacing: 0.01em;
}
p { margin: 0 0 var(--space-2); }

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--c-primary);
  margin-bottom: var(--space-2);
}
.eyebrow--on-dark { color: var(--c-sand); }

.lead {
  font-size: 1.1rem;
  color: var(--c-ink-soft);
  line-height: 1.7;
}

/* ---------- Layout helpers ---------- */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-3); }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--space-3); }
section { padding: var(--space-5) 0; }
@media (min-width: 1024px) { section { padding: var(--space-6) 0; } }
.hero { padding: 0; }

.skip-link {
  position: absolute; top: -100px; left: 0; padding: 0.75rem 1rem;
  background: var(--c-primary); color: #fff; text-decoration: none; z-index: 100;
}
.skip-link:focus { top: 0; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244, 233, 211, 0.94);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid rgba(216, 193, 154, 0.4);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-2);
  padding: 0.85rem var(--space-3);
  max-width: var(--container);
  margin: 0 auto;
}
.brand {
  display: flex; flex-direction: column; line-height: 1.1;
  text-decoration: none;
}
.brand__name {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--c-ink);
  text-transform: uppercase;
}
.brand__sub {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--c-ink-mute);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.nav { display: none; }
@media (min-width: 1024px) {
  .nav { display: flex; gap: var(--space-3); align-items: center; }
  .nav a {
    color: var(--c-ink); text-decoration: none;
    font-size: 0.85rem; font-weight: 500;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 0.4rem 0; border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease;
  }
  .nav a:hover { border-color: var(--c-primary); }
}
.header-actions { display: flex; gap: 0.5rem; align-items: center; }

.lang-toggle {
  display: inline-flex; align-items: center; gap: 0.25rem;
  background: transparent;
  border: 1px solid var(--c-sand-dark);
  color: var(--c-ink);
  padding: 0.45rem 0.7rem;
  border-radius: 0;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-decoration: none;
}
.lang-toggle:hover { border-color: var(--c-primary); color: var(--c-primary); }
.lang-toggle__current { color: var(--c-primary); font-weight: 700; }
.lang-toggle__sep { color: var(--c-ink-mute); }
.lang-toggle__other { color: var(--c-ink-mute); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: 0.95rem 1.6rem;
  border-radius: 2px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid transparent;
  transition: transform 0.1s ease, background 0.18s ease, color 0.18s ease;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--whatsapp {
  background: var(--c-primary); color: var(--c-on-dark);
}
.btn--whatsapp:hover { background: var(--c-primary-light); }
.btn--accent { background: var(--c-accent); color: var(--c-cream); }
.btn--accent:hover { background: var(--c-accent-dark); }
.btn--ghost {
  background: transparent;
  color: var(--c-ink); border-color: var(--c-ink);
}
.btn--ghost:hover { background: var(--c-ink); color: var(--c-cream); }
.btn--ghost-light {
  background: transparent;
  color: var(--c-on-dark); border-color: var(--c-sand);
}
.btn--ghost-light:hover { background: var(--c-sand); color: var(--c-dark); }
.btn--small { padding: 0.5rem 0.9rem; font-size: 0.72rem; }
.btn-icon { width: 1em; height: 1em; flex-shrink: 0; }

/* ---------- Hero — split dark/cream, contained to one viewport on desktop ---------- */
.hero {
  position: relative;
  background: var(--c-cream);
  overflow: hidden;
  padding: 0;
}
.hero__inner {
  display: grid;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .hero__inner {
    grid-template-columns: 1fr 1fr;
    min-height: calc(100vh - 70px); /* viewport minus header */
    max-height: 820px;              /* don't get absurd on tall screens */
  }
}

/* Left: dark column with overlapping photo collage, contained in viewport */
.hero__media {
  position: relative;
  background: var(--c-dark);
  padding: var(--space-4) var(--space-3);
  display: flex; flex-direction: column; gap: var(--space-2);
  align-items: stretch;
}
@media (min-width: 1024px) {
  .hero__media {
    padding: 0;
    display: block;
  }
}

.collage-photo {
  position: relative;
  width: 100%;
  background: var(--c-cream-2);
  box-shadow: var(--shadow-img);
  overflow: hidden;
}
.collage-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Mobile: stacked photos at sensible aspect ratio */
@media (max-width: 1023px) {
  .collage-photo { aspect-ratio: 4 / 3; max-width: 520px; margin: 0 auto; }
  .collage-photo--offset-l { align-self: flex-start; }
  .collage-photo--offset-r { align-self: flex-end; }
  /* Hide third photo on mobile to keep hero compact */
  .hero__media .collage-photo:nth-child(4) { display: none; }
}

/* Desktop: two photos absolutely positioned, overlapping at the cream boundary */
@media (min-width: 1024px) {
  .hero__media .collage-photo {
    position: absolute;
    box-shadow: 0 20px 50px rgba(0,0,0,0.35);
  }
  .hero__media .collage-photo:nth-of-type(1) {
    /* Top photo: large, anchored upper-left, slight tilt into cream */
    top: 10%;
    left: 6%;
    width: 78%;
    max-width: 480px;
    aspect-ratio: 4 / 3;
    z-index: 2;
  }
  .hero__media .collage-photo:nth-of-type(2) {
    /* Bottom photo: smaller, overlapping bottom-right boundary */
    bottom: 12%;
    right: -8%;
    width: 50%;
    max-width: 280px;
    aspect-ratio: 4 / 3;
    z-index: 3;
  }
  /* Hide third photo on desktop — two cards is plenty */
  .hero__media .collage-photo:nth-of-type(3) { display: none; }
}

/* Decorative connector — subtle, only desktop */
.hero__connector {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: none;
}
@media (min-width: 1024px) {
  .hero__connector {
    display: block;
    z-index: 1;
    width: 60%;
    height: 70%;
    top: 15%;
    left: 25%;
    inset: auto;
  }
}
.hero__connector path {
  fill: none;
  stroke: var(--c-sand);
  stroke-width: 1.2;
  opacity: 0.35;
}

/* Right: copy area */
.hero__copy {
  background: var(--c-cream);
  padding: var(--space-5) var(--space-3);
  display: flex; flex-direction: column; justify-content: center;
}
@media (min-width: 1024px) {
  .hero__copy { padding: var(--space-5) var(--space-5) var(--space-5) var(--space-4); }
}
.hero__copy h1 {
  color: var(--c-ink);
  margin: var(--space-2) 0 var(--space-3);
  text-align: right;
  font-size: clamp(2rem, 2.8vw + 0.8rem, 3.2rem);
  line-height: 0.95;
  letter-spacing: 0.01em;
}
.hero__copy h1 span { display: block; }
.hero__copy h1 .first-line { color: var(--c-ink); }
.hero__copy .eyebrow { display: inline-block; }

.hero__lede {
  font-size: 1rem;
  color: var(--c-ink-soft);
  line-height: 1.6;
  margin-bottom: var(--space-3);
  max-width: 38ch;
  margin-left: auto;
  text-align: right;
  padding-top: var(--space-2);
  border-top: 1px solid var(--c-sand);
}
.hero__price {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1.4vw + 0.8rem, 1.9rem);
  font-weight: 600;
  color: var(--c-accent);
  text-align: right;
  margin-bottom: var(--space-2);
  display: block;
  line-height: 1.1;
}
.hero__price small {
  display: block;
  font-family: var(--font-body);
  font-size: 0.65rem;
  color: var(--c-ink-mute);
  letter-spacing: 0.25em;
  text-transform: uppercase;
  margin-top: 0.35rem;
  font-weight: 600;
}
.hero__cta {
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  justify-content: flex-end;
  margin-top: var(--space-2);
}

/* ---------- Highlights — editorial, three columns ---------- */
.highlights { background: var(--c-cream); }
.section-head {
  text-align: center; max-width: 64ch; margin: 0 auto var(--space-5);
}
.section-head .eyebrow { display: inline-block; }

.cards {
  display: grid; gap: var(--space-3);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .cards { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); } }
@media (min-width: 1024px) { .cards { grid-template-columns: repeat(4, 1fr); } }

.card {
  display: flex; flex-direction: column; gap: var(--space-2);
  padding: var(--space-3) var(--space-2);
  border-top: 1px solid var(--c-sand-dark);
  background: transparent;
}
.card__icon {
  width: 36px; height: 36px;
  color: var(--c-primary);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--space-1);
}
.card__icon svg { width: 28px; height: 28px; }
.card h3 {
  color: var(--c-ink);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.4rem;
  margin: 0 0 0.4rem;
}
.card p { color: var(--c-ink-soft); margin: 0; font-size: 0.95rem; line-height: 1.65; }

/* ---------- Inspiration — business-idea renders ---------- */
.inspiration {
  background: var(--c-cream-2);
  position: relative;
}
.inspiration-grid {
  display: grid; gap: var(--space-3);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .inspiration-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); } }
@media (min-width: 1024px) { .inspiration-grid { grid-template-columns: repeat(4, 1fr); } }

.insp-card {
  display: flex; flex-direction: column;
  background: var(--c-cream);
  border-radius: var(--radius-sm);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.insp-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-img);
}
.insp-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--c-cream-2);
  overflow: hidden;
  cursor: zoom-in;
  border: 0; padding: 0; width: 100%;
  display: block;
}
.insp-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.insp-card__media:hover img,
.insp-card__media:focus-visible img { transform: scale(1.05); }

.insp-card__body {
  padding: var(--space-3) var(--space-2) var(--space-3);
  display: flex; flex-direction: column; gap: 0.4rem;
}
.insp-card__kicker {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--c-primary);
  margin: 0;
}
.insp-card__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.1;
  color: var(--c-ink);
  margin: 0;
}
.insp-card__desc {
  color: var(--c-ink-soft);
  font-size: 0.92rem;
  line-height: 1.6;
  margin: 0;
}
.inspiration__note {
  text-align: center;
  margin-top: var(--space-4);
  color: var(--c-ink-mute);
  font-size: 0.88rem;
  font-style: italic;
  max-width: 56ch;
  margin-left: auto;
  margin-right: auto;
}

/* ---------- Gallery — vertical collage feel ---------- */
.gallery-section {
  background: var(--c-cream);
  position: relative;
}
.gallery {
  display: grid; gap: var(--space-2);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px) { .gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .gallery { grid-template-columns: repeat(4, 1fr); gap: var(--space-3); } }
.gallery__item {
  position: relative; overflow: hidden;
  border-radius: 0;
  aspect-ratio: 4 / 3; background: var(--c-cream-2);
  cursor: zoom-in; border: 0; padding: 0; width: 100%;
  box-shadow: var(--shadow-soft);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.gallery__item:hover { transform: translateY(-4px); box-shadow: var(--shadow-img); }
.gallery__item:hover img, .gallery__item:focus-visible img { transform: scale(1.05); }

@media (min-width: 1024px) {
  .gallery__item:nth-child(1) {
    grid-column: span 2; grid-row: span 2;
    aspect-ratio: 1 / 1;
  }
}

/* ---------- Lightbox ---------- */
.lightbox {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(28, 42, 51, 0.97);
  display: none; align-items: center; justify-content: center;
  padding: var(--space-3);
}
.lightbox[hidden] { display: none; }
.lightbox.is-open { display: flex; }
.lightbox__img { max-width: 100%; max-height: 88vh; object-fit: contain; box-shadow: var(--shadow-img); }
.lightbox__btn {
  position: absolute; background: rgba(244,233,211,0.12); color: var(--c-cream);
  border: 1px solid rgba(244,233,211,0.25);
  width: 48px; height: 48px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background 0.18s ease;
}
.lightbox__btn:hover { background: rgba(244,233,211,0.28); }
.lightbox__btn svg { width: 22px; height: 22px; }
.lightbox__close { top: 1rem; right: 1rem; }
.lightbox__prev { left: 1rem; top: 50%; transform: translateY(-50%); }
.lightbox__next { right: 1rem; top: 50%; transform: translateY(-50%); }
.lightbox__caption {
  position: absolute; bottom: 1rem; left: 50%; transform: translateX(-50%);
  color: rgba(244,233,211,0.85); font-size: 0.85rem; max-width: 80%; text-align: center;
  font-family: var(--font-body); letter-spacing: 0.05em;
}

/* ---------- Floor plan ---------- */
.plan-section { background: var(--c-cream-2); }
.plan-grid {
  display: grid; gap: var(--space-4); align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) { .plan-grid { grid-template-columns: 1.2fr 1fr; gap: var(--space-6); } }
.plan-image {
  background: var(--c-cream); padding: var(--space-3);
  box-shadow: var(--shadow-soft);
  border-top: 3px solid var(--c-sand-dark);
}
.plan-image img { display: block; }

.areas-table { width: 100%; border-collapse: collapse; margin: var(--space-3) 0; }
.areas-table th, .areas-table td {
  text-align: left; padding: 0.85rem 0.5rem;
  border-bottom: 1px solid var(--c-sand-dark);
  font-size: 0.95rem;
}
.areas-table th {
  color: var(--c-ink-mute); font-weight: 600; font-size: 0.7rem;
  text-transform: uppercase; letter-spacing: 0.18em;
  border-bottom: 1px solid var(--c-ink);
}
.areas-table tr:last-child td {
  font-weight: 700; color: var(--c-primary);
  font-family: var(--font-display); font-size: 1.1rem;
  border-bottom: 0; border-top: 2px solid var(--c-primary);
}
.unit-toggle {
  background: transparent;
  border: 1px solid var(--c-sand-dark);
  color: var(--c-ink-soft);
  padding: 0.4rem 0.85rem;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.unit-toggle:hover { border-color: var(--c-primary); color: var(--c-primary); }

.plan-notes {
  list-style: none; padding: 0; margin: var(--space-3) 0 0;
  font-size: 0.9rem; color: var(--c-ink-soft);
}
.plan-notes li {
  padding-left: 1.5rem;
  position: relative;
  margin-bottom: 0.4rem;
}
.plan-notes li::before {
  content: "▲";
  position: absolute; left: 0; top: 0.1rem;
  color: var(--c-sand-dark);
  font-size: 0.65rem;
}

/* ---------- Location ---------- */
.location { background: var(--c-cream); }
.location-grid {
  display: grid; gap: var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) { .location-grid { grid-template-columns: 1fr 1.2fr; align-items: center; gap: var(--space-6); } }
.map-frame {
  overflow: hidden; box-shadow: var(--shadow-soft);
  aspect-ratio: 4 / 3; background: var(--c-cream-2);
  border-top: 3px solid var(--c-sand-dark);
}
.map-frame iframe { width: 100%; height: 100%; border: 0; display: block; }

/* ---------- About — dark band ---------- */
.about {
  background: var(--c-dark);
  color: var(--c-on-dark);
  position: relative;
  padding: var(--space-7) 0;
}
.about::before {
  content: "";
  position: absolute; left: 50%; top: 0; transform: translate(-50%, -50%);
  width: 120px; height: 1px;
  background: var(--c-sand);
}
.about h2 { color: var(--c-on-dark); }
.about p { color: var(--c-on-dark-soft); max-width: 60ch; }
.about a { color: var(--c-sand); }
.about .container-narrow { text-align: center; }

/* ---------- Terms — feature list with triangle bullets ---------- */
.terms { background: var(--c-cream-2); }
.terms-list {
  list-style: none; padding: 0; margin: 0 0 var(--space-5);
  display: grid; gap: var(--space-3);
}
@media (min-width: 640px) { .terms-list { grid-template-columns: repeat(2, 1fr); column-gap: var(--space-5); } }
.terms-list li {
  display: flex; gap: 0.85rem; align-items: flex-start;
  padding: 0;
  border-top: 1px solid var(--c-sand-dark);
  padding-top: var(--space-2);
  font-size: 1.02rem;
  color: var(--c-ink);
}
.terms-list li::before {
  content: "▲";
  flex-shrink: 0;
  color: var(--c-accent);
  font-size: 0.8rem;
  margin-top: 0.45rem;
}

/* ---------- Contact — dark editorial card ---------- */
.contact {
  background: var(--c-dark);
  color: var(--c-on-dark);
  position: relative;
}
.contact h2 { color: var(--c-on-dark); }
.contact .lead { color: var(--c-on-dark-soft); }

.contact-card {
  background: var(--c-dark-2);
  padding: var(--space-5);
  display: grid; gap: var(--space-3);
  max-width: 520px; margin: 0 auto;
  border-top: 3px solid var(--c-sand);
}
.contact-card__person { display: flex; flex-direction: column; gap: 0.25rem; }
.contact-card__name {
  font-family: var(--font-display);
  font-size: 1.6rem; font-weight: 600;
  color: var(--c-cream);
  letter-spacing: 0.02em;
}
.contact-card__role {
  color: var(--c-on-dark-soft);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.contact-card__rows { display: grid; gap: 0.8rem; }
.contact-row {
  display: flex; align-items: center; gap: 0.85rem;
  color: var(--c-on-dark);
  text-decoration: none;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
}
.contact-row:hover { color: var(--c-sand); }
.contact-row__icon {
  width: 32px; height: 32px;
  border: 1px solid var(--c-sand);
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-sand);
}
.contact-row__icon svg { width: 14px; height: 14px; }

.contact-card__buttons { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: 0.5rem; }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--c-dark);
  color: var(--c-on-dark-soft);
  padding: var(--space-4) 0;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  border-top: 1px solid rgba(216, 193, 154, 0.2);
}
.site-footer__inner {
  display: flex; flex-direction: column;
  gap: var(--space-2); align-items: flex-start;
}
@media (min-width: 640px) {
  .site-footer__inner { flex-direction: row; justify-content: space-between; align-items: center; }
}
.site-footer p { margin: 0; }
.site-footer a { color: var(--c-sand); }

/* ---------- Utilities ---------- */
.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;
}
.text-center { text-align: center; }
.text-right { text-align: right; }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }

/* divider — thin sand line, used between content blocks */
.divider {
  height: 1px;
  background: var(--c-sand-dark);
  margin: var(--space-5) auto;
  max-width: 200px;
}
