/* ══════════════════════════════════════════════════════════════
   KLSV Single profile page
   Hero + gallery + summary sidebar + packages + mobile CTA
   ══════════════════════════════════════════════════════════════ */

.klsv-page--single {
  padding-block: var(--space-lg) calc(var(--mobile-cta-height) + var(--space-2xl));
}

.klsv-section--profile {
  padding-block: var(--space-lg);
}

.klsv-shell--profile {
  width: min(1080px, calc(100vw - var(--shell-gutter) * 2));
  margin-inline: auto;
}


/* ── Profile lead (H1 + intro) ────────────────────────────── */

.klsv-profile-lead {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
}
.klsv-profile-lead__title {
  font-size: var(--text-h1);
  letter-spacing: -0.02em;
}
.klsv-profile-lead__intro {
  color: var(--text-secondary);
  font-size: var(--text-lead);
  max-width: 60ch;
}


/* ── Main stage (gallery + summary + meta sidebar) ─────────── */

.klsv-profile-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  grid-template-areas:
    "media summary"
    "media sidebar";
  gap: var(--space-lg);
}
.klsv-profile-stage__media   { grid-area: media; }
.klsv-profile-stage__summary { grid-area: summary; }
.klsv-profile-stage__meta    { grid-area: sidebar; display: flex; flex-direction: column; gap: var(--space-md); }

.klsv-profile-stage__meta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs);
}

.klsv-meta-tile {
  padding: var(--space-md);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.klsv-meta-tile--accent {
  border-color: var(--accent-primary-bg);
  background: linear-gradient(135deg, var(--accent-primary-bg), transparent 80%), var(--bg-secondary);
}
.klsv-meta-tile strong {
  font-family: var(--font-display);
  font-size: 1.375rem;
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
}
.klsv-meta-tile span {
  font-size: var(--text-micro);
  color: var(--text-muted);
  letter-spacing: 0.02em;
}

.klsv-profile-stage__microcopy {
  color: var(--text-muted);
  font-size: var(--text-small);
  padding: var(--space-sm) var(--space-md);
  border-left: 2px solid var(--accent-primary);
  background: var(--bg-surface);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.klsv-profile-stage__microcopy p { margin: 0; }


/* ── Gallery ─────────────────────────────────────────────── */

.klsv-single-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.klsv-single-gallery__hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  aspect-ratio: 3 / 4;
  background: var(--bg-tertiary);
}
.klsv-single-gallery__hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.klsv-single-gallery__status {
  position: absolute;
  top: var(--space-sm);
  left: var(--space-sm);
  padding: 4px var(--space-xs);
  background: rgba(11, 11, 13, 0.72);
  color: var(--text-primary);
  border-radius: var(--radius-full);
  font-size: var(--text-micro);
  backdrop-filter: blur(8px);
}

.klsv-single-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-xs);
}
.klsv-single-gallery__thumb {
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: var(--bg-tertiary);
  cursor: pointer;
  border: 1px solid var(--border-color);
  transition:
    border-color var(--duration-fast) var(--ease-smooth),
    transform var(--duration-fast) var(--ease-smooth);
}
.klsv-single-gallery__thumb:hover {
  border-color: var(--accent-primary);
  transform: scale(1.02);
}
.klsv-single-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ── Summary card (price + CTAs, sticky on desktop) ────────── */

.klsv-single-summary-card {
  grid-area: summary;
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  position: sticky;
  top: calc(var(--header-height) + var(--space-md));
  align-self: start;
}

.klsv-single-summary-card__price {
  display: flex;
  align-items: baseline;
  gap: var(--space-xs);
}
.klsv-single-summary-card__price strong {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: var(--weight-medium);
  color: var(--accent-primary);
  letter-spacing: -0.01em;
}
.klsv-single-summary-card__price span {
  color: var(--text-muted);
  font-size: var(--text-small);
}

.klsv-single-summary-card__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}
.klsv-single-summary-card__actions .klsv-btn,
.klsv-single-summary-card__actions .klsv-button {
  width: 100%;
  min-height: 48px;
}


/* ── Overview grid (copy panel + facts panel) ─────────────── */

.klsv-profile-overview-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

.klsv-results-layout--profile {
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}


/* ── Package cards ────────────────────────────────────────── */

.klsv-package-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-sm);
}

.klsv-single-package-card {
  padding: var(--space-md);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.klsv-single-package-card h4 {
  font-size: var(--text-small);
  font-family: var(--font-ui);
  font-weight: var(--weight-semibold);
  color: var(--text-secondary);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  margin: 0;
}
.klsv-single-package-card strong {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--accent-primary);
  font-weight: var(--weight-medium);
}
.klsv-single-package-card small {
  color: var(--text-muted);
  font-size: var(--text-micro);
}


/* ── Related profiles ────────────────────────────────────── */

.klsv-related-profiles {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-top: var(--space-xl);
}
.klsv-related-profiles h2 {
  font-size: var(--text-h2);
}


/* ── Mobile fixed CTA bar ────────────────────────────────── */

.klsv-mobile-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  padding: var(--space-sm) var(--space-md);
  background: rgba(11, 11, 13, 0.96);
  border-top: 1px solid var(--border-color-strong);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  gap: var(--space-sm);
  align-items: center;
  justify-content: space-between;
}
.klsv-mobile-cta__summary {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.klsv-mobile-cta__eyebrow {
  font-size: var(--text-micro);
  color: var(--text-muted);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
}
.klsv-mobile-cta__summary strong {
  font-family: var(--font-display);
  font-size: var(--text-body);
  color: var(--accent-primary);
  font-weight: var(--weight-semibold);
}
.klsv-mobile-cta__meta {
  display: flex;
  gap: 6px;
  font-size: var(--text-micro);
  color: var(--text-muted);
}
.klsv-mobile-cta__actions {
  display: flex;
  gap: var(--space-xs);
  flex-shrink: 0;
}
.klsv-mobile-cta__actions .klsv-btn,
.klsv-mobile-cta__actions .klsv-button {
  min-height: 42px;
  padding-inline: var(--space-md);
}


/* ── Responsive ──────────────────────────────────────────── */

@media (max-width: 920px) {
  .klsv-profile-stage {
    grid-template-columns: 1fr;
    grid-template-areas:
      "media"
      "summary"
      "sidebar";
  }
  .klsv-single-summary-card {
    position: static;
  }
  .klsv-profile-overview-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .klsv-mobile-cta { display: flex; }
  .klsv-single-summary-card__actions { display: none; }
  .klsv-single-gallery__thumbs { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 420px) {
  .klsv-single-gallery__thumbs { grid-template-columns: repeat(3, 1fr); }
  .klsv-mobile-cta__meta { display: none; }
}
