/* ============================================================
   LCS v9 — pages.css
   Layouts for services / fleet / gallery / contact pages.
   Depends on: tokens.css, global.css, components.css.
   ============================================================ */

/* ============================================================
   PAGE HERO — v10 cinematic editorial
   ============================================================ */
.page-hero {
  position: relative;
  padding-block: calc(var(--s-128) + 80px) var(--s-128);
  background: var(--bg-canvas-deep);
  text-align: center;
  overflow: hidden;
}
.page-hero::before,
.page-hero::after {
  content: "";
  position: absolute;
  width: 60px;
  height: 60px;
  border: 1px solid var(--gold);
  opacity: 0.35;
  pointer-events: none;
}
.page-hero::before {
  top: calc(var(--s-128) + 16px);
  left: var(--container-px-desktop);
  border-right: 0;
  border-bottom: 0;
}
.page-hero::after {
  bottom: 40px;
  right: var(--container-px-desktop);
  border-left: 0;
  border-top: 0;
}
@media (max-width: 1024px) {
  .page-hero::before { left: var(--container-px-tablet); }
  .page-hero::after  { right: var(--container-px-tablet); }
}
@media (max-width: 600px) {
  .page-hero::before, .page-hero::after { width: 36px; height: 36px; }
  .page-hero::before { top: 96px; left: var(--container-px-mobile); }
  .page-hero::after  { right: var(--container-px-mobile); }
}
.page-hero--dark { background: var(--bg-inverse-dark); color: var(--text-primary-on-dark); }
.page-hero--dark::before,
.page-hero--dark::after { border-color: var(--gold); opacity: 0.55; }
.page-hero__eyebrow { color: var(--gold); }
.page-hero__title {
  margin-block: var(--s-24);
  font-family: var(--font-display-editorial);
}
.page-hero__lead {
  max-width: 640px;
  margin-inline: auto;
  font-style: italic;
  font-family: var(--font-display);
  font-weight: 300;
}
@media (max-width: 768px) {
  .page-hero { padding-block: calc(var(--s-96) + 64px) var(--s-96); }
}

/* ============================================================
   SERVICES HUB
   ============================================================ */
.services-hub {
  background:
    radial-gradient(ellipse 50% 40% at 100% 0%, rgba(200, 163, 87, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse 55% 50% at 0% 100%, rgba(200, 163, 87, 0.05) 0%, transparent 50%),
    var(--bg-canvas);
}
.services-hub__layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--s-64);
  align-items: start;
}
@media (max-width: 1024px) {
  .services-hub__layout { grid-template-columns: 1fr; gap: var(--s-24); }
}

/* Sticky side-nav (desktop) */
.services-sidenav {
  position: sticky;
  top: 96px;
  padding-top: var(--s-32);
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
  border-left: 1px solid var(--border-subtle-light);
}
.services-sidenav__title {
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-tertiary-on-light);
  padding-left: var(--s-16);
  margin-bottom: var(--s-12);
}
.services-sidenav a {
  display: flex;
  align-items: center;
  gap: var(--s-12);
  font-family: var(--font-display);
  font-size: var(--fs-16);
  color: var(--text-secondary-on-light);
  padding: var(--s-8) var(--s-16);
  border-left: 2px solid transparent;
  margin-left: -1px;
  transition: color var(--d-micro), border-color var(--d-micro);
}
.services-sidenav a::before {
  content: attr(data-numeral);
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  color: var(--text-tertiary-on-light);
  width: 24px;
  flex: 0 0 auto;
}
.services-sidenav a:hover,
.services-sidenav a.is-active {
  color: var(--text-primary-on-light);
  border-left-color: var(--gold);
}
.services-sidenav a.is-active::before { color: var(--gold); }

/* Mobile chip-strip nav (replaces side-nav < 1024px) */
.services-chip-strip {
  display: none;
  position: sticky;
  top: 64px;
  z-index: 20;
  margin-inline: calc(var(--container-px-mobile) * -1);
  padding: var(--s-12) var(--container-px-mobile);
  background: rgba(245, 240, 230, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-subtle-light);
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.services-chip-strip::-webkit-scrollbar { display: none; }
.services-chip-strip__inner {
  display: inline-flex;
  gap: var(--s-8);
  width: max-content;
}
.services-chip-strip a {
  white-space: nowrap;
  padding: var(--s-8) var(--s-16);
  border: 1px solid var(--border-default-light);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: var(--fs-12);
  letter-spacing: 0.08em;
  color: var(--text-secondary-on-light);
  transition: all var(--d-micro);
}
.services-chip-strip a.is-active {
  background: var(--text-primary-on-light);
  color: var(--bg-canvas);
  border-color: var(--text-primary-on-light);
}
@media (max-width: 1024px) {
  .services-chip-strip { display: block; }
  .services-sidenav { display: none; }
}

/* Service sections */
.services-hub__sections {
  display: flex;
  flex-direction: column;
  gap: var(--s-192);
}
@media (max-width: 1024px) { .services-hub__sections { gap: var(--s-96); } }
@media (max-width: 600px)  { .services-hub__sections { gap: var(--s-64); } }

.svc-section {
  scroll-margin-top: 96px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-48);
  align-items: center;
}
.svc-section--reverse { direction: rtl; }
.svc-section--reverse > * { direction: ltr; }
@media (max-width: 900px) {
  .svc-section,
  .svc-section--reverse { grid-template-columns: 1fr; gap: var(--s-32); direction: ltr; }
}
.svc-section__media {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border: 1px solid var(--border-subtle-light);
  border-radius: 2px;
}
.svc-section__media img,
.svc-section__media picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.svc-section__copy {
  display: flex;
  flex-direction: column;
  gap: var(--s-16);
  padding-block: var(--s-32);
}
.svc-section__numeral {
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.32em;
  color: var(--gold);
}
.svc-section__title { margin-block: var(--s-8) 0; }
.svc-section__pullquote { margin: var(--s-12) 0; }
.svc-section__intro { color: var(--text-secondary-on-light); font-size: var(--fs-16); line-height: 1.62; }

.svc-section__items {
  list-style: none;
  margin: var(--s-16) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
  border-top: 1px solid var(--border-subtle-light);
  padding-top: var(--s-24);
}
.svc-section__items li {
  display: flex;
  align-items: baseline;
  gap: var(--s-12);
  font-size: var(--fs-14);
  line-height: 1.55;
}
.svc-section__items li::before {
  content: "—";
  color: var(--gold);
  flex: 0 0 auto;
}

/* How it works strip (bottom of services hub) */
.svc-how {
  background: var(--bg-canvas-deep);
  border-block: 1px solid var(--border-subtle-light);
}
.svc-how__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-48);
}
@media (max-width: 768px) { .svc-how__grid { grid-template-columns: 1fr; gap: var(--s-32); } }
.svc-how__step { display: flex; flex-direction: column; gap: var(--s-12); }
.svc-how__step-num {
  font-family: var(--font-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.18em;
  color: var(--gold);
}
.svc-how__step-title { font-family: var(--font-display); font-size: var(--fs-24); }
.svc-how__step-body  { color: var(--text-secondary-on-light); font-size: var(--fs-14); line-height: 1.62; }

/* CTA strip (shared, dark) */
.cta-strip {
  background: var(--bg-inverse-dark);
  color: var(--text-primary-on-dark);
  text-align: center;
}
.cta-strip__inner { max-width: 720px; margin-inline: auto; display: flex; flex-direction: column; gap: var(--s-24); align-items: center; }
.cta-strip__actions { display: flex; gap: var(--s-16); flex-wrap: wrap; justify-content: center; }

/* Coming-soon placeholder image */
.placeholder-photo {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--s-8);
  background:
    repeating-linear-gradient(135deg,
      rgba(200, 163, 87, 0.06) 0 10px,
      rgba(200, 163, 87, 0.02) 10px 20px),
    var(--bg-surface-1);
  color: var(--text-tertiary-on-light);
  border: 1px dashed var(--border-emphasized-light);
}
.placeholder-photo__icon { width: 32px; height: 32px; opacity: 0.6; }
.placeholder-photo__label {
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
}
.placeholder-photo__hint {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-14);
  color: var(--text-tertiary-on-light);
  max-width: 80%;
  text-align: center;
}

/* ============================================================
   FLEET — THE LAYERS
   ============================================================ */
.fleet-layout {
  background:
    radial-gradient(ellipse 60% 50% at 0% 0%, rgba(200, 163, 87, 0.07) 0%, transparent 50%),
    radial-gradient(ellipse 50% 45% at 100% 50%, rgba(200, 163, 87, 0.04) 0%, transparent 50%),
    var(--bg-canvas);
}
.fleet-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--s-8);
  margin-bottom: var(--s-64);
}
.fleet-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-32);
}
@media (max-width: 900px) { .fleet-grid { grid-template-columns: repeat(2, 1fr); gap: var(--s-16); } }
@media (max-width: 600px) { .fleet-grid { grid-template-columns: 1fr; } }

.fleet-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-canvas);
  border: 1px solid var(--border-subtle-light);
  border-radius: 2px;
  overflow: hidden;
  transition: border-color var(--d-quick) var(--ease-editorial);
}
.fleet-card:hover { border-color: var(--border-emphasized-light); }
.fleet-card.is-hidden { display: none; }
.fleet-card__media {
  position: relative;
  aspect-ratio: 16/11;
  overflow: hidden;
  background:
    radial-gradient(ellipse at center, rgba(232, 221, 201, 0.6) 0%, rgba(220, 207, 182, 0.85) 100%),
    var(--bg-surface-1);
  padding: var(--s-12);
}
.fleet-card__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  padding: var(--s-12);
  transition: transform var(--d-cinematic) var(--ease-editorial);
}
.fleet-card:hover .fleet-card__media img { transform: scale(1.03); }
.fleet-card__media img.is-mirrored { transform: scaleX(-1); }
.fleet-card:hover .fleet-card__media img.is-mirrored { transform: scaleX(-1) scale(1.03); }
/* Vivify rescue — for legacy v8 photos shipped heavily desaturated.
   Pulls colour back so they don't read as black-and-white next to the
   cinematic Gemini shots. */
.fleet-card--vivify .fleet-card__media img {
  filter: saturate(1.55) contrast(1.06) brightness(1.04);
}
.fleet-card__body { padding: var(--s-24); display: flex; flex-direction: column; gap: var(--s-12); flex: 1; }
.fleet-card__tag {
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
}
.fleet-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-24);
  font-weight: 400;
  line-height: 1.18;
}
.fleet-card__story {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-16);
  line-height: 1.5;
  color: var(--text-secondary-on-light);
}
.fleet-card__best-for {
  font-size: var(--fs-12);
  letter-spacing: 0.04em;
  color: var(--text-tertiary-on-light);
  border-top: 1px solid var(--border-subtle-light);
  padding-top: var(--s-12);
}
.fleet-card__specs {
  display: flex;
  gap: var(--s-12);
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary-on-light);
  margin-top: auto;
}
.fleet-card__specs span { display: inline-flex; align-items: center; gap: var(--s-4); }
.fleet-card__specs span + span { padding-left: var(--s-12); border-left: 1px solid var(--border-subtle-light); }

/* Yacht editorial sub-section — expandable cards */
.yachts-sub { background: var(--bg-inverse-dark); color: var(--text-primary-on-dark); }
.yacht-grid {
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
  margin-top: var(--s-48);
}
.yacht-card {
  background: var(--bg-inverse-dark-2);
  border: 1px solid var(--border-subtle-dark);
  border-radius: 2px;
  overflow: hidden;
  transition: border-color var(--d-quick) var(--ease-editorial);
}
.yacht-card[open],
.yacht-card:hover { border-color: var(--gold); }
.yacht-card summary {
  display: grid;
  grid-template-columns: 140px 1fr auto;
  gap: var(--s-24);
  align-items: center;
  padding: var(--s-12) var(--s-24) var(--s-12) var(--s-12);
  cursor: pointer;
  list-style: none;
}
.yacht-card summary::-webkit-details-marker { display: none; }
.yacht-card__media {
  width: 140px;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 2px;
  background: var(--bg-inverse-dark);
}
.yacht-card__media img { width: 100%; height: 100%; object-fit: cover; object-position: center 55%; }
.yacht-card__head { min-width: 0; }
.yacht-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-24);
  font-weight: 400;
  color: var(--text-primary-on-dark);
}
.yacht-card__class { color: var(--gold); font-style: italic; }
.yacht-card__tag {
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-tertiary-on-dark);
  margin-top: var(--s-4);
}
.yacht-card__chev {
  font-family: var(--font-mono);
  font-size: var(--fs-24);
  color: var(--gold);
  transition: transform var(--d-quick) var(--ease-editorial);
}
.yacht-card[open] .yacht-card__chev { transform: rotate(45deg); }
.yacht-card__body {
  padding: var(--s-12) var(--s-24) var(--s-32);
  display: flex;
  flex-direction: column;
  gap: var(--s-16);
  color: var(--text-secondary-on-dark);
}
.yacht-card__body .type-pullquote { color: var(--text-primary-on-dark); margin: 0; }
.yacht-card__body p { line-height: 1.62; }
.yacht-card__body .btn { align-self: flex-start; }
@media (max-width: 600px) {
  .yacht-card summary { grid-template-columns: 96px 1fr auto; gap: var(--s-12); }
  .yacht-card__media { width: 96px; }
  .yacht-card__name { font-size: var(--fs-18); }
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-page {
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(200, 163, 87, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 50% 100%, rgba(200, 163, 87, 0.04) 0%, transparent 50%),
    var(--bg-canvas);
}
.gallery-chapters {
  display: flex;
  justify-content: center;
  gap: var(--s-8);
  flex-wrap: wrap;
  margin-bottom: var(--s-48);
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-12);
}
@media (max-width: 1024px) { .gallery-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: var(--s-8); } }
/* Mobile: keep 2-column grid (no endless 1-col drop-down even on small screens) */
@media (max-width: 480px)  { .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; } }

.gallery-item {
  position: relative;
  display: block;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--bg-inverse-dark-2);
  border-radius: 2px;
  cursor: zoom-in;
  border: 0;
  padding: 0;
}
.gallery-item:nth-child(7n+1) { aspect-ratio: 16/10; }
.gallery-item:nth-child(11n+2) { aspect-ratio: 1; }
.gallery-item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 55%;
  transition: transform var(--d-cinematic) var(--ease-editorial), filter var(--d-quick) var(--ease-editorial);
}
.gallery-item:hover img { transform: scale(1.03); filter: brightness(1.04); }
.gallery-item.is-hidden { display: none; }

/* Gallery lightbox dialog */
.lightbox-shell {
  display: flex;
  flex-direction: column;
  background: var(--bg-inverse-dark);
  color: var(--text-primary-on-dark);
  padding: var(--s-24);
  gap: var(--s-16);
  max-height: 95vh;
}
.lightbox-shell__media {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
}
.lightbox-shell__media img {
  max-width: 100%;
  max-height: 80vh;
  width: auto;
  height: auto;
  border-radius: 2px;
}
.lightbox-shell__caption {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-16);
  color: var(--text-secondary-on-dark);
  text-align: center;
}
.lightbox-shell__nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--s-12);
  border-top: 1px solid var(--border-subtle-dark);
}
.lightbox-shell__nav button {
  color: var(--text-secondary-on-dark);
  font-family: var(--font-body);
  font-size: var(--fs-12);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: var(--s-8) var(--s-16);
  border: 1px solid var(--border-default-dark);
  border-radius: 2px;
  background: transparent;
  cursor: pointer;
}
.lightbox-shell__nav button:hover:not(:disabled) { border-color: var(--gold); color: var(--gold); }
.lightbox-shell__nav button:disabled { opacity: 0.4; cursor: not-allowed; }
.lightbox-shell__counter { font-family: var(--font-mono); font-size: var(--fs-11); letter-spacing: 0.22em; color: var(--text-tertiary-on-dark); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-page {
  background:
    radial-gradient(ellipse 55% 50% at 0% 0%, rgba(200, 163, 87, 0.07) 0%, transparent 50%),
    radial-gradient(ellipse 55% 50% at 100% 100%, rgba(200, 163, 87, 0.06) 0%, transparent 50%),
    var(--bg-canvas);
}
.contact-channels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-24);
  margin-bottom: var(--s-96);
}
@media (max-width: 900px) { .contact-channels { grid-template-columns: 1fr; gap: var(--s-16); } }
.contact-channel {
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
  padding: var(--s-32);
  border: 1px solid var(--border-default-light);
  border-radius: 2px;
  background: var(--bg-canvas);
  text-decoration: none;
  color: inherit;
  transition: border-color var(--d-quick), transform var(--d-quick);
}
.contact-channel:hover { border-color: var(--gold); transform: translateY(-2px); }
.contact-channel--primary {
  background: var(--bg-inverse-dark);
  color: var(--text-primary-on-dark);
  border-color: var(--gold);
}
.contact-channel--primary:hover { background: var(--bg-inverse-dark-2); border-color: var(--gold-hover); }
.contact-channel__label {
  font-family: var(--font-mono);
  font-size: var(--fs-11);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
}
.contact-channel__value {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 400;
  letter-spacing: 0.04em;
}
.contact-channel__sub {
  color: var(--text-secondary-on-light);
  font-size: var(--fs-14);
  margin-top: var(--s-8);
}
.contact-channel--primary .contact-channel__sub { color: var(--text-secondary-on-dark); }

.contact-form-card {
  background: var(--bg-canvas-deep);
  border: 1px solid var(--border-subtle-light);
  border-radius: 2px;
  padding: var(--s-48);
  max-width: 720px;
  margin: 0 auto;
}
.contact-form-card details {
  border-bottom: 1px solid var(--border-default-light);
}
.contact-form-card summary {
  list-style: none;
  cursor: pointer;
  padding: var(--s-24) 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-16);
  font-family: var(--font-display);
  font-size: var(--fs-18);
  color: var(--text-primary-on-light);
}
.contact-form-card summary::-webkit-details-marker { display: none; }
.contact-form-card summary::after {
  content: "+";
  font-family: var(--font-mono);
  font-size: var(--fs-24);
  color: var(--gold);
  transition: transform var(--d-micro);
}
.contact-form-card details[open] summary::after { transform: rotate(45deg); }
.contact-form-card .form-body { padding: var(--s-24) 0 var(--s-32); }

.contact-manifesto {
  background: var(--bg-inverse-dark);
  color: var(--text-primary-on-dark);
  text-align: center;
  padding-block: var(--s-128);
}
.contact-manifesto__quote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(28px, 3.6vw, 48px);
  line-height: 1.32;
  max-width: 800px;
  margin: 0 auto;
  color: var(--text-primary-on-dark);
}
.contact-location {
  font-family: var(--font-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-tertiary-on-light);
  text-align: center;
  margin-block: var(--s-64);
}
