/* === FILE: assets/css/pages/services.css ===
   Shared styles for the Services hub (/services) and every service
   sub-page (aircraft-rentals, scenic-flight, wine-tours, photo-flights,
   student-housing, maintenance, international-students).

   Inherits the shared internal-page template (page-hero, page-content,
   page-sidebar, page-rates-table, page-info-callout, cta-banner) from
   demo-flight.css, then layers on a handful of service-specific
   components: hub cards, housing cards, itineraries, and step lists.
   ============================================================ */

@import url('demo-flight.css');

/* Dark hero fallback so service heroes stay legible before/without
   their background photo. */
.page-hero { background: var(--color-primary); }

/* Centered section header (not part of the shared template — the
   eyebrow comes from demo-flight.css; header + sub are defined here). */
.section-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 3.5rem;
}
.section-header h2 {
  font-size: clamp(1.75rem, 2vw + 1rem, 2.5rem);
  line-height: 1.15;
  margin: 0 0 1.25rem;
  color: var(--color-primary);
}
.section-sub {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
  line-height: 1.8;
  margin: 0;
  font-weight: 400;
}

/* Center the standalone (no-sidebar) prose column on sub-pages. */
.page-content { margin-inline: auto; }

/* ─── SERVICES HUB — CARD GRID ───────────────────────────────── */
.service-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 620px)  { .service-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .service-grid { grid-template-columns: repeat(3, 1fr); } }

.service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg, 10px);
  box-shadow: 0 10px 30px -20px rgba(17, 24, 39, .18);
  text-decoration: none;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.service-card:hover,
.service-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 28px 56px -24px rgba(17, 24, 39, .30);
  border-color: rgba(17, 24, 39, .18);
}

/* Photo header */
.service-card-media {
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-bg-soft);
}
.service-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 600ms cubic-bezier(.2, .7, .2, 1);
}
.service-card:hover .service-card-media img,
.service-card:focus-visible .service-card-media img { transform: scale(1.05); }

/* Small icon chip floating over the image corner */
.service-card-icon {
  position: absolute;
  top: .85rem;
  left: .85rem;
  z-index: 2;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  color: #fff;
  background: rgba(17, 24, 39, .58);
  backdrop-filter: blur(6px);
}
.service-card-icon svg { width: 22px; height: 22px; }

.service-card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.4rem 1.5rem 1.6rem;
}

.service-card-title {
  font-family: var(--font-display);
  font-size: 1.1875rem;
  color: var(--color-primary);
  margin: 0 0 .55rem;
}

.service-card-desc {
  font-size: .9375rem;
  line-height: 1.65;
  color: var(--color-text-muted);
  margin: 0 0 1.25rem;
}

.service-card-cta {
  margin-top: auto;
  font-family: var(--font-body);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--color-accent);
}
.service-card-cta::after { content: ' →'; }

/* ─── PRICE / OPTION CARDS (scenic, rentals extras) ──────────── */
.svc-options {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  margin: 1.75rem 0 2rem;
}
@media (min-width: 720px) { .svc-options { grid-template-columns: repeat(3, 1fr); } }

.svc-option {
  display: flex;
  flex-direction: column;
  padding: 1.5rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg, 10px);
}

.svc-option-name {
  font-family: var(--font-display);
  font-size: 1.0625rem;
  color: var(--color-primary);
  margin: 0 0 .25rem;
}
.svc-option-meta {
  font-size: .85rem;
  color: var(--color-text-muted);
  margin: 0 0 1rem;
}
.svc-option-price {
  margin-top: auto;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1;
}
.svc-option-price small {
  display: block;
  margin-top: .35rem;
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

/* ─── HOUSING CARDS ──────────────────────────────────────────── */
.svc-housing {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  margin: 1.75rem 0 1rem;
}
@media (min-width: 720px) { .svc-housing { grid-template-columns: repeat(2, 1fr); } }

/* Photo gallery grouped under a property name. */
.svc-housing-gallery { margin: 2.75rem 0; }
.svc-housing-gallery h3 { margin-bottom: 1.25rem; }

.svc-housing-card {
  padding: 1.6rem 1.5rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-md, 8px);
}
.svc-housing-card h4 {
  font-family: var(--font-display);
  font-size: 1.0625rem;
  color: var(--color-primary);
  margin: 0 0 .6rem;
}
.svc-housing-card p {
  font-size: .9375rem;
  line-height: 1.65;
  color: var(--color-text-muted);
  margin: 0 0 .5rem;
}
.svc-housing-card .svc-rate {
  display: inline-block;
  margin-top: .35rem;
  font-size: .82rem;
  font-weight: 600;
  color: var(--color-primary);
}

/* ─── ITINERARY (wine tours) ─────────────────────────────────── */
.svc-itins {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin: 1.75rem 0 1rem;
}
@media (min-width: 820px) { .svc-itins { grid-template-columns: repeat(3, 1fr); } }

.svc-itin {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg, 10px);
  overflow: hidden;
}
.svc-itin-head {
  padding: 1.1rem 1.35rem;
  background: var(--color-primary);
  color: #fff;
}
.svc-itin-head strong { display: block; font-family: var(--font-display); font-size: 1.0625rem; }
.svc-itin-head span { font-size: .8rem; opacity: .7; }

.svc-itin-stop {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  padding: .85rem 1.35rem;
  border-top: 1px solid var(--color-border);
  font-size: .9rem;
  line-height: 1.45;
}
.svc-itin-stop:first-of-type { border-top: 0; }
.svc-itin-time {
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .01em;
  color: var(--color-accent);
  font-variant-numeric: tabular-nums;
}
.svc-itin-place { color: var(--color-text); }

/* ─── NUMBERED STEPS (international students) ─────────────────── */
.svc-steps { list-style: none; margin: 1.5rem 0; padding: 0; counter-reset: step; }
.svc-step {
  position: relative;
  padding: 0 0 1.5rem 3.25rem;
  counter-increment: step;
}
.svc-step::before {
  content: counter(step);
  position: absolute;
  left: 0;
  top: 0;
  width: 2.25rem;
  height: 2.25rem;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 700;
  color: #fff;
  background: var(--color-accent);
  border-radius: 50%;
}
.svc-step:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 1.125rem;
  top: 2.5rem;
  bottom: 0;
  width: 2px;
  background: var(--color-border);
}
.svc-step h4 { font-family: var(--font-display); color: var(--color-primary); margin: .2rem 0 .5rem; }
.svc-step p  { color: var(--color-text-muted); line-height: 1.7; margin: 0 0 .5rem; }

/* ─── NOTE / DISCLAIMER ──────────────────────────────────────── */
.svc-note {
  margin: 2rem 0 0;
  padding: 1.25rem 1.5rem;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 8px);
  font-size: .85rem;
  line-height: 1.65;
  color: var(--color-text-muted);
}
.svc-note p { margin: 0 0 .85rem; }
.svc-note p:last-child { margin-bottom: 0; }
.svc-note strong { color: var(--color-primary); }

/* ─── BOOKING TERMS & DISCLAIMER ─────────────────────────────── */
.svc-terms {
  margin: 1rem 0 0;
  padding: 1.75rem;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-md, 8px);
}
.svc-terms-lede {
  margin: 0;
  font-size: .9rem;
  line-height: 1.65;
  color: var(--color-text);
}
.svc-terms-list {
  margin: 1.5rem 0 0;
  padding: 1.5rem 0 0;
  border-top: 1px solid var(--color-border);
  display: grid;
  gap: 1.4rem;
}
.svc-term dt {
  margin: 0 0 .35rem;
  font-family: var(--font-display);
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-accent);
}
.svc-term dd {
  margin: 0;
  font-size: .85rem;
  line-height: 1.65;
  color: var(--color-text-muted);
}

/* ─── INLINE PRICE STRIP (maintenance, simple rates) ─────────── */
.svc-callprice {
  display: inline-flex;
  align-items: baseline;
  gap: .5rem;
  margin: .5rem 0 1.5rem;
  padding: .85rem 1.4rem;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: 999px;
}
.svc-callprice b { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-accent); }
.svc-callprice span { font-size: .85rem; color: var(--color-text-muted); }
