:root {
  --sl-navy: #0A1A2F;
  --sl-gold: #C7A86F;
  --sl-ivory: #F8F6F2;
  --sl-charcoal: #2A2A2A;
  /* Agaron-inspired */
  --sl-bg: #F8F6F2;
  --sl-text: #2A2A2A;
  --sl-copper: #C8A06A; /* gold */
  --sl-copper-600: #B38C58;
  --sl-bg-warm: #F2ECE3; /* prior page background, now used for header */

}
:root { --sl-header-h: 92px; }
@media (min-width: 720px){ :root { --sl-header-h: 104px; } }


* { box-sizing: border-box; }
html, body { height: 100%; }
body.sl-body {
  margin: 0;
  color: var(--sl-text);
  background: var(--sl-bg);
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: 0.15px;
  line-height: 1.65;
}

.sl-display {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 500;
  letter-spacing: 0.3px;
  color: var(--sl-charcoal);
  font-size: clamp(2rem, 3vw + 1rem, 4rem);
  line-height: 1.15;
}

.sl-lead { font-size: 1.125rem; color: #4a4a4a; }

.sl-container {
  width: min(1180px, 92%);
  margin-inline: auto;
}

/* Unified page spacing and headers */
.sl-section { padding: 56px 0 72px; }
.sl-page-header { margin-bottom: 22px; }
.sl-page-header .sl-display { margin: 0 0 8px; }
.sl-page-header .sl-lead { margin: 0; color: var(--sl-navy); }

.sl-page-header--gold .sl-display{ color: var(--sl-gold); }

.sl-projects .sl-display{ color: var(--sl-gold); }


/* Header - Agaron style */
.sl-header { position: sticky; top: 0; z-index: 100; background: var(--sl-bg-warm); border-bottom: 1px solid rgba(42,42,42,.06); }
.sl-header .sl-container { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; }
.sl-logo { display: inline-flex; align-items: center; text-decoration: none; gap: 10px; }
.sl-logo__mark { height: 72px; width: auto; display: block; }
.sl-logo__wordmark { height: 48px; width: auto; display: block; }
@media (min-width: 720px){ .sl-logo__mark { height: 84px; } .sl-logo__wordmark { height: 56px; } }
.sl-nav { display: flex; gap: 20px; align-items: center; }
/* Burger */
.sl-burger { width: 28px; height: 22px; display: inline-grid; gap: 5px; cursor: pointer; background: transparent; border: none; padding: 0; }
.sl-burger span { height: 1px; background: var(--sl-text); display: block; transition: transform .25s ease, opacity .25s ease; }
/* Slide-in panel + overlay */
.sl-nav-panel { position: fixed; top: calc(var(--sl-header-h) + 12px); right: 16px; height: auto; max-height: calc(100vh - (var(--sl-header-h) + 28px)); width: min(86vw, 380px); transform: translateX(calc(100% + 16px)); transition: transform .35s ease, opacity .2s ease; background: var(--sl-bg-warm); box-shadow: -12px 12px 34px rgba(0,0,0,.14); border-radius: 12px; padding: 16px 20px; z-index: 9999; overflow-y: auto; }
.sl-nav-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.45); opacity: 0; pointer-events: none; transition: opacity .3s ease; z-index: 9998; }
.sl-nav-open .sl-nav-panel { transform: translateX(0); opacity: 1; }
.sl-nav-open .sl-nav-overlay { opacity: 1; pointer-events: auto; }
/* Stack links in panel */
.sl-nav-panel .sl-nav { display: flex; flex-direction: column; gap: 6px; align-items: stretch; }
/* Make toggle buttons visually identical to links */
.sl-nav__toggle{ appearance:none; -webkit-appearance:none; background:transparent; border:0; padding:0; margin:0; font:inherit; color:inherit; text-align:inherit; letter-spacing:inherit; cursor:pointer; }
.sl-nav__toggle:focus{ outline:none; }
.sl-nav__toggle:focus-visible{ outline:2px solid rgba(200,160,106,.5); outline-offset:2px; border-radius:6px; }

.sl-nav-panel .sl-nav__link { color: var(--sl-text); text-decoration: none; transition: color .2s ease; opacity: .9; display: block; padding: 10px 0; width: 100%; text-align: left; }
.sl-nav__link:hover { color: var(--sl-text); opacity: 1; }
/* Prevent background scroll when open */
.sl-nav-open { overflow: hidden; }

/* Comfort spacing in the panel */
.sl-nav-panel .sl-nav{ margin-top: 0; margin-bottom: 0; }
.sl-nav-panel .sl-nav__link{ padding: 8px 2px; }
/* Reduce bottom white space under last item */
.sl-nav-panel .sl-nav > .sl-nav__item:last-child{ margin-bottom: 0; }
.sl-nav-panel .sl-nav > .sl-nav__item{ margin-bottom: 2px; }

/* Ensure button sits at top */
/* Equal top/bottom breathing room */
.sl-nav-panel .sl-nav{ padding-block: 4px; }

/* Normalize headings for top-level items in panel */
.sl-nav-panel .sl-nav__item > .sl-nav__link,
.sl-nav-panel > .sl-nav > .sl-nav__link{ font-weight: 500; letter-spacing:.2px; }


/* Hero */
.sl-hero { position: relative; min-height: 70vh; display: grid; place-items: center; overflow: clip; }
.sl-hero__bg { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,26,47,.50), rgba(10,26,47,.25)); filter: saturate(.95); }
/* Background image helper for hero */
/* Full viewport landing hero */
.sl-hero--full{ min-height: calc(100vh - var(--sl-header-h)); }

.sl-hero--bg { background-size: cover; background-position: center; background-repeat: no-repeat; }
/* Villa details: make title gold */
.villas-detail .sl-display{ color: var(--sl-gold); }

/* Improve hero text legibility */
.sl-hero--bg .sl-display { color: #ffffff; text-shadow: 0 2px 12px rgba(0,0,0,.35); }
.sl-hero--bg .sl-lead { color: rgba(255,255,255,.95); text-shadow: 0 1px 8px rgba(0,0,0,.35); }
.sl-hero__content { position: relative; color: var(--sl-ivory); text-align: center; padding: 80px 0; }
/* Tighter spacing on detail header */
.villas-detail .sl-hero__content { padding: 16px 0 8px; }

/* Buttons */
.sl-btn { display: inline-block; padding: 12px 20px; border-radius: 999px; text-decoration: none; transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease; }
.sl-btn--gold { background: var(--sl-copper); color: #fff; border: 1px solid var(--sl-copper); }
.sl-btn--gold:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(0,0,0,.14); }
/* New variants */
.sl-btn--copper { background: var(--sl-copper); color: #fff; border: 1px solid var(--sl-copper); }
.sl-btn--copper:hover { background: var(--sl-copper-600); border-color: var(--sl-copper-600); }
.sl-btn--outline-copper { background: transparent; color: var(--sl-text); border: 1px solid var(--sl-copper); }
.sl-btn--outline-copper:hover { background: rgba(200,160,106,.08); }

/* Villas grid */
.sl-villas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
@media (max-width: 1024px) { .sl-villas-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px) { .sl-villas-grid { grid-template-columns: 1fr; } }
.sl-villa-card { position: relative; background: var(--sl-bg-warm); border-radius: 16px; padding: 0 0 20px; box-shadow: 0 12px 28px rgba(0,0,0,.18), 0 2px 10px rgba(0,0,0,.10); transition: transform .2s ease, box-shadow .2s ease; overflow: hidden; }
.sl-villa-card:hover { transform: translateY(-3px); box-shadow: 0 20px 60px rgba(0,0,0,.28), 0 4px 14px rgba(0,0,0,.14); }
.sl-villa-thumb { display: block; aspect-ratio: 3/2; background: #ddd; overflow: hidden; }
.sl-villa-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sl-villa-title { margin: 14px 16px 6px; font-family: "Cormorant Garamond", Georgia, serif; color: var(--sl-navy); font-size: 1.35rem; font-weight: 600; letter-spacing: .3px; }
.sl-villa-title a { color: inherit; text-decoration: none; }
/* Diagonal ribbon for sold cards */
.sl-ribbon { position: absolute; top: 14px; left: -42px; width: 180px; text-align: center; transform: rotate(-45deg); background: var(--sl-copper); color: #fff; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; font-size: .85rem; padding: 7px 0; box-shadow: 0 6px 14px rgba(0,0,0,.18); pointer-events: none; }
.sl-ribbon--sold { background: var(--sl-copper); }

.sl-villa-meta { color: #6a6a6a; font-size: 0.95rem; margin: 0 16px 8px; }
.sl-villa-price { color: var(--sl-copper); font-weight: 600; margin: 0 16px; }

/* Villa detail hero cycling */
.sl-hero-media { position: relative; border-radius: 16px; overflow: hidden; max-height: calc(100vh - 220px); }
.sl-hero-media .sl-hero-image { width: 100%; height: auto; display: block; object-fit: contain; max-height: calc(100vh - 220px); }
.sl-gallery-nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(10,26,47,.6); color: #fff; border: none; border-radius: 999px; width: 38px; height: 38px; display: grid; place-items: center; cursor: pointer; }
.sl-gallery-nav.left { left: 10px; }
.sl-gallery-nav.right { right: 10px; }
.sl-gallery-nav:hover { background: rgba(10,26,47,.8); }

/* Thumbnails row */
.sl-thumbs { display:flex; gap:10px; margin: 10px 0 8px; flex-wrap: wrap; justify-content: center; align-items: center; }
.sl-thumb { border: 2px solid transparent; border-radius: 10px; padding: 0; background: transparent; cursor: pointer; overflow: hidden; }
/* Themed copy */
.sl-copy { max-width: 860px; color: #5a5a5a; font-size: 1.05rem; line-height: 1.7; }
.sl-copy p { margin: 0 0 1em; }
.sl-copy strong { color: var(--sl-navy); }

.sl-thumb img { width: 120px; height: 80px; object-fit: cover; display:block; }
.sl-thumb[aria-current="true"], .sl-thumb.active { border-color: var(--sl-copper); }
@media (max-width: 680px) { .sl-thumb img { width: 90px; height: 60px; } }


/* Inquire form (villa details) */
.sl-inquire { margin-top: 8px; }
.sl-form-card { background: #ffffff; border: 1px solid #e8e2d8; border-radius: 16px; padding: 18px; box-shadow: 0 10px 24px rgba(10,26,47,.06); }
.sl-field-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width:720px){ .sl-field-grid { grid-template-columns: 1fr; } }
.sl-input { width: 100%; padding: 12px 14px; border: 1px solid #ded7cc; border-radius: 12px; background: #fff; color: var(--sl-charcoal); font: inherit; transition: border-color .2s ease, box-shadow .2s ease; }
.sl-input::placeholder { color: #9a958b; }
.sl-input:focus { outline: none; border-color: var(--sl-copper); box-shadow: 0 0 0 3px rgba(200,160,106,.18); }
.sl-textarea { margin-top: 12px; min-height: 140px; resize: vertical; }
.sl-form-actions { margin-top: 12px; }
.sl-form-result { margin-top: 12px; }


/* Footer */
.sl-footer { background: #f1eee7; color: #5a5a5a; }
.sl-footer .sl-container { display: flex; align-items: center; justify-content: space-between; padding: 28px 0; font-size: 0.95rem; }
.sl-footer a { color: inherit; text-decoration: none; margin-left: 16px; }

/* Responsiveness */
@media (max-width: 720px) {
  .sl-header .sl-container { padding: 12px 0; }
  .sl-nav { gap: 14px; }
  .sl-hero__content { padding: 64px 0; }
}



/* Project spec icons and cards */
.sl-icon { width: 18px; height: 18px; display: inline-block; line-height: 1; vertical-align: middle; color: var(--sl-navy); }
/* Specs list: consistent left/right margin on listing cards and tidy alignment */
.sl-specs { list-style: none; padding: 0; margin: 8px 0 12px; display: flex; flex-wrap: wrap; gap: 10px 16px; align-items: center; }
/* Only on villa listing cards, align with title/price margins */
.sl-villa-card > .sl-specs { margin-left: 16px; margin-right: 16px; }
/* Per-item alignment and icon/text gap */
.sl-spec { display: inline-flex; align-items: center; gap: 8px; color: var(--sl-navy); font-size: .98rem; }
.sl-spec__icon { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; min-width: 20px; }
.sl-spec__label { white-space: nowrap; }

.sl-villa-card--project { padding: 16px; position: relative; }
.sl-villa-card--project .sl-villa-title { margin: 4px 0 8px; font-size: 1.3rem; }
.sl-card-overlay-link { position: absolute; inset: 0; text-indent: -9999px; overflow: hidden; }

/* Projects grids */
.sl-project-cards, .sl-projects-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 900px) { .sl-project-cards, .sl-projects-grid { grid-template-columns: 1fr; } }

.sl-project-card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,.06); position: relative; transition: transform .2s ease, box-shadow .2s ease; }
.sl-project-card:hover { transform: translateY(-2px); box-shadow: 0 16px 40px rgba(0,0,0,.10); }
.sl-project-card__media img { width: 100%; height: 320px; object-fit: cover; display: block; }
.sl-project-card__meta { padding: 14px 16px 16px; }
.sl-project-card__title { font-family: "Cormorant Garamond", Georgia, serif; color: var(--sl-navy); font-size: 1.35rem; margin: 0 0 4px; }
.sl-project-card__by { color: #6a6a6a; font-size: .95rem; }

/* Lightbox */
.sl-lightbox { position: fixed; inset: 0; display: grid; place-items: center; z-index: 9999; }
.sl-lightbox[hidden] { display: none !important; }
.sl-lightbox__backdrop { position: absolute; inset: 0; background: rgba(10,26,47,.78); backdrop-filter: blur(2px); }
.sl-lightbox__inner { position: relative; max-width: 92vw; max-height: 92vh; display: grid; place-items: center; }
.sl-lightbox__img { max-width: 92vw; max-height: 88vh; box-shadow: 0 20px 60px rgba(0,0,0,.35); border-radius: 10px; }
.sl-lightbox__close { position: absolute; top: -8px; right: -8px; width: 40px; height: 40px; border-radius: 999px; border: none; background: var(--sl-gold); color: var(--sl-ivory); font-size: 22px; cursor: pointer; box-shadow: 0 10px 24px rgba(0,0,0,.25); }
.sl-lightbox__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 999px; border: none; background: rgba(10,26,47,.7); color: #fff; cursor: pointer; }
.sl-lightbox__nav--prev { left: -56px; }
.sl-lightbox__nav--next { right: -56px; }
@media (max-width: 780px) { .sl-lightbox__nav--prev { left: 10px; } .sl-lightbox__nav--next { right: 10px; } .sl-lightbox__close { top: 8px; right: 8px; } }

/* Header dropdown for Projects */
.sl-nav { position: relative; }
.sl-nav__item { position: relative; }
.sl-dropdown { position: absolute; display: none; min-width: 220px; background: #0b1b31; border: 1px solid rgba(255,255,255,.08); border-radius: 12px; box-shadow: 0 18px 48px rgba(0,0,0,.3); padding: 8px; top: 100%; left: 0; }
.sl-dropdown a { display: block; color: #f3efe7; padding: 10px 12px; border-radius: 8px; text-decoration: none; opacity: .92; }
.sl-dropdown a:hover { background: rgba(255,255,255,.06); opacity: 1; }
.sl-nav__item:hover > .sl-dropdown, .sl-nav__item:focus-within > .sl-dropdown { display: block; }

/* Material Symbols alignment for icons used as text */
.material-symbols-outlined, .material-symbols-outlined.sl-icon {
  font-family: 'Material Symbols Outlined';
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  font-size: 18px;
  line-height: 1;
  vertical-align: middle;
  color: var(--sl-navy);
  display: inline-block;
}

/* Dropdown inside slide-in panel: inline expanding */
.sl-nav-panel .sl-nav__item { position: static; }
.sl-nav-panel .sl-dropdown {
  position: static;
  display: block;
  background: transparent; /* same as panel */
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  margin: 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .25s ease, opacity .2s ease, margin .2s ease;
}
.sl-nav-panel .sl-dropdown a {
  display: block;
  color: var(--sl-text);
  padding: 10px 12px;
  border-radius: 8px;
  text-decoration: none;
}
.sl-nav-panel .sl-dropdown a:hover { background: rgba(0,0,0,.04); }
.sl-nav-panel .sl-dropdown__divider { height: 1px; background: rgba(42,42,42,.08); margin: 6px 8px; }
.sl-nav-panel .sl-nav__item:hover > .sl-dropdown,
.sl-nav-panel .sl-nav__item:focus-within > .sl-dropdown {
  max-height: 60vh; opacity: 1; margin: 4px 0 0; /* no outline, flush with panel */
}



/* Projects split gateway */
.sl-projects-split { min-height: calc(100vh - var(--sl-header-h)); display: flex; align-items: stretch; }
.split-container { position: relative; display: flex; width: 100%; }
.split-panel { position: relative; flex: 1 1 50%; display: grid; place-items: center; text-decoration: none; overflow: hidden; }
.split-image { position: absolute; inset: -12px; width: calc(100% + 24px); height: calc(100% + 24px); object-fit: cover; filter: blur(8px); transition: filter .25s ease; }
.split-title { position: relative; z-index: 1; color: #ffffff; text-shadow: 0 2px 12px rgba(0,0,0,.35); font-size: clamp(1.4rem, 2.2vw + 0.6rem, 2.6rem); }
/* .split-divider removed by request; no separator between panels */

.split-panel:hover .split-image, .split-panel:focus-within .split-image { filter: none; }


.split-panels { display: grid; grid-template-columns: repeat(var(--cols, 2), 1fr); width: 100%; min-height: calc(100vh - var(--sl-header-h)); }
.split-panels { gap: 0; }
@media (max-width: 720px){ .split-panels { grid-template-columns: 1fr; } }

@media (max-width: 720px){
  .split-container { flex-direction: column; }
  .split-divider { height: 1px; width: 100%; }
}

/* Projects category grids */
.projects-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 1100px){ .projects-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px){ .projects-grid { grid-template-columns: 1fr; } }
.project-tile { position: relative; display: block; aspect-ratio: 3/2; overflow: hidden; text-decoration: none; border-radius: 12px; box-shadow: 0 12px 28px rgba(0,0,0,.18), 0 2px 10px rgba(0,0,0,.10); }
.project-tile { position: relative; display: block; width: 100%; /* aspect fallback */ }
.project-tile::before { content: ""; display: block; padding-top: 66.666%; }
.project-tile__image { position: absolute; inset: -10px; width: calc(100% + 20px); height: calc(100% + 20px); object-fit: cover; filter: blur(8px); transition: filter .25s ease; }
.project-tile:hover .project-tile__image, .project-tile:focus .project-tile__image, .project-tile:focus-within .project-tile__image { filter: none; }
.project-tile__title { position: absolute; left: 16px; bottom: 12px; margin: 0; color: #fff; text-shadow: 0 2px 12px rgba(0,0,0,.35); font-size: clamp(1.1rem, 1.6vw + .4rem, 1.6rem); }
