/**
 * CMS page composition — locked layout system for all themed storefront pages.
 * Loaded after cms_section_system.css on tenant_base.
 *
 * Spacing rhythm (tight → medium → large), document flow:
 *   --frs-composition-tight:  clamp(0.75rem, 2vw, 1rem)
 *   --frs-composition-medium: clamp(1.25rem, 3vw, 1.75rem)
 *   --frs-composition-large:  clamp(2rem, 4vw, 2.75rem)
 *
 * Inner CMS sections override builder-root vertical section padding (no giant dead zones).
 */

:root {
  --frs-composition-tight: clamp(0.75rem, 2vw, 1rem);
  --frs-composition-medium: clamp(1.25rem, 3vw, 1.75rem);
  --frs-composition-large: clamp(2rem, 4vw, 2.75rem);
  --frs-content-max: min(1200px, 94vw);
  /* Global spacing governor: cap vertical section padding to kill “dead zone” blocks */
  --frs-section-pad-y-cap: min(var(--frs-space-section-y, 80px), 5.5rem);
}

/* Full-bleed main: sections own horizontal rails via .section-inner */
.frs-page-wrapper--shell {
  max-width: none;
  width: 100%;
  margin: 0 auto;
  padding: 0 0 var(--frs-composition-large);
  box-sizing: border-box;
}

.frs-page-wrapper--shell.frs-page-wrapper--friendly-wide {
  max-width: none;
}

/* Inner CMS: content starts near top of viewport — no extra top vacuum */
.tenant-page-sections.frs-inner-cms {
  margin-top: 0;
  padding-top: 0;
}

/* ---- Standard inner hero (CMS masthead + catalog/rentals alignment) ---- */

.frs-page-hero__inner {
  max-width: var(--frs-content-max);
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

.frs-page-hero--inner {
  position: relative;
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--tenant-primary-color, #2563eb) 6%, #f8fafc) 0%,
    #ffffff 55%,
    #f8fafc 100%
  );
}

.frs-page-hero--inner::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(
    180deg,
    var(--tenant-primary-color, #2563eb),
    color-mix(in srgb, var(--tenant-primary-color, #2563eb) 35%, transparent)
  );
  opacity: 0.85;
  border-radius: 0 2px 2px 0;
  pointer-events: none;
}

.frs-cms-masthead.frs-page-hero--inner {
  padding: var(--frs-composition-medium) clamp(1rem, 4vw, 1.75rem)
    var(--frs-composition-medium);
}

.frs-cms-masthead__inner {
  max-width: var(--frs-content-max);
  margin: 0 auto;
}

.frs-cms-masthead__crumb {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #64748b;
  margin-bottom: var(--frs-composition-tight);
  letter-spacing: 0.02em;
}

.frs-cms-masthead__crumb a {
  color: var(--tenant-primary-color, #2563eb);
  text-decoration: none;
}

.frs-cms-masthead__crumb a:hover {
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.frs-cms-masthead__sep {
  margin: 0 0.35rem;
  opacity: 0.45;
}

.frs-cms-masthead__here {
  color: #475569;
}

.frs-cms-masthead__title {
  margin: 0;
  font-size: clamp(1.65rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: #0f172a;
}

.frs-cms-masthead__lead {
  margin: 0.65rem 0 0;
  font-size: clamp(0.95rem, 1.2vw, 1.05rem);
  line-height: 1.55;
  color: #475569;
  max-width: 52ch;
}

.frs-cms-masthead__lead--mute {
  color: #64748b;
  font-size: 0.9rem;
}

/* Inner builder canvas: tighter default section Y than homepage */
.tenant-page-sections.frs-inner-cms .frs-section-canvas.builder-root {
  --frs-space-section-y: clamp(2.25rem, 4vw, 3rem);
  --frs-space-section-y-lg: clamp(2.75rem, 4.5vw, 3.5rem);
  --frs-space-section-y-tight: clamp(1.5rem, 3vw, 2rem);
  --frs-space-section-y-large: clamp(3rem, 5vw, 3.75rem);
}

.frs-section-canvas.builder-root .section.section--content:not(.section--hero):not(.ui-hero):not(.section--booking-hero),
.tenant-page-sections.frs-inner-cms .frs-section-canvas.builder-root .section.section--content:not(.section--hero) {
  padding-top: min(var(--frs-space-section-y, 80px), 5.5rem);
  padding-bottom: min(var(--frs-space-section-y, 80px), 5.5rem);
}

/* First block: handoff from masthead — avoid double padding lump */
.tenant-page-sections.frs-inner-cms
  .builder-root
  > .section-edit-wrapper:first-child
  .frs-block-surface-foreground
  > section.section:first-of-type:not(.section--hero):not(.section--booking-hero):not([class*="booking-hero"]) {
  padding-top: clamp(1.75rem, 3.5vw, 2.75rem);
}

.tenant-page-sections.frs-inner-cms .builder-root > .section-edit-wrapper + .section-edit-wrapper {
  margin-top: 0;
}

/* ---- Catalog / category list & detail: same shell + hero as CMS ---- */

.frs-catalog-shell,
.frs-catlist-shell,
.frs-cat-shell {
  max-width: var(--frs-content-max);
  margin: 0 auto;
  padding: var(--frs-composition-tight) clamp(14px, 3vw, 20px)
    var(--frs-composition-large);
  box-sizing: border-box;
}

.frs-catalog-page-hero.frs-page-hero--inner {
  padding: var(--frs-composition-medium) clamp(1rem, 4vw, 1.5rem);
  margin: 0 calc(-1 * clamp(14px, 3vw, 20px)) var(--frs-composition-medium);
  border-radius: 0;
}

.frs-catalog-page-hero .frs-catlist-header,
.frs-catalog-page-hero .frs-cat-header {
  margin-bottom: 0;
}

.frs-catalog-shell .frs-btn-primary,
.frs-cat-shell .frs-btn-primary,
.frs-catalog-shell .frs-btn-main {
  background: var(--tenant-primary-color, #16a34a);
  border-color: var(--tenant-primary-color, #16a34a);
  box-shadow: 0 10px 28px
    color-mix(in srgb, var(--tenant-primary-color, #16a34a) 35%, transparent);
}

.frs-catalog-shell .frs-cat-link,
.frs-cat-shell .frs-btn-primary.frs-btn-add {
  background: var(--tenant-primary-color, #16a34a);
}

/* Category detail breadcrumb inside hero */
.frs-catalog-page-hero .frs-cat-breadcrumb {
  margin-bottom: var(--frs-composition-tight);
}

/* ---- Rentals SaaS page ---- */

.frs-page-rentals {
  max-width: var(--frs-content-max);
  margin: var(--frs-composition-tight) auto var(--frs-composition-large);
  padding: 0 clamp(14px, 3vw, 20px);
  box-sizing: border-box;
}

.frs-rentals-hero-wrap.frs-catalog-page-hero.frs-page-hero--inner {
  padding: var(--frs-composition-medium);
  margin: 0 calc(-1 * clamp(14px, 3vw, 20px)) var(--frs-composition-medium);
}

.frs-rentals-hero-inner {
  max-width: none;
}

/* ---- Closing CTA band (sparse inner pages) ---- */

.frs-page-closing-band {
  margin: var(--frs-composition-large) auto 0;
  padding: var(--frs-composition-large) clamp(1rem, 4vw, 1.5rem);
  background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
  color: #f1f5f9;
  border-radius: var(--frs-radius-lg, 16px);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.2);
}

.frs-page-closing-band__inner {
  max-width: var(--frs-content-max);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--frs-composition-medium);
}

.frs-page-closing-band__title {
  margin: 0;
  font-size: clamp(1.25rem, 2.2vw, 1.5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
}

.frs-page-closing-band__lead {
  margin: 0.5rem 0 0;
  max-width: 48ch;
  font-size: 0.975rem;
  line-height: 1.55;
  color: #cbd5e1;
}

.frs-page-closing-band__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.frs-page-closing-band__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.25rem;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.9rem;
  text-decoration: none;
  transition: filter 0.15s ease, transform 0.1s ease;
}

.frs-page-closing-band__cta--primary {
  background: var(--tenant-primary-color, #2563eb);
  color: #fff;
  box-shadow: 0 12px 32px
    color-mix(in srgb, var(--tenant-primary-color, #2563eb) 45%, transparent);
}

.frs-page-closing-band__cta--ghost {
  background: transparent;
  color: #e2e8f0;
  border: 2px solid rgba(226, 232, 240, 0.35);
}

.frs-page-closing-band__cta:hover {
  filter: brightness(1.06);
}

@media (max-width: 640px) {
  .frs-page-closing-band__inner {
    flex-direction: column;
    align-items: stretch;
  }

  .frs-page-closing-band__actions {
    justify-content: stretch;
  }

  .frs-page-closing-band__cta {
    flex: 1;
    justify-content: center;
  }
}

/* Empty / onboarding cards */
.frs-cms-empty {
  max-width: min(640px, 92vw);
  margin: var(--frs-composition-large) auto;
  padding: 0 clamp(0.75rem, 3vw, 1rem);
}

.frs-cms-empty__card {
  background: linear-gradient(145deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 20px;
  padding: clamp(1.35rem, 3vw, 1.75rem) clamp(1.25rem, 3vw, 1.85rem);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.frs-cms-empty__title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.25rem, 2.2vw, 1.45rem);
  font-weight: 800;
  color: #0f172a;
  letter-spacing: -0.02em;
}

.frs-cms-empty__body {
  margin: 0 0 1.25rem;
  color: #475569;
  line-height: 1.62;
  font-size: 1rem;
}

.frs-cms-empty__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 1.35rem;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.95rem;
  text-decoration: none;
  background: var(--tenant-primary-color, #2563eb);
  color: #fff;
  box-shadow: 0 10px 28px
    color-mix(in srgb, var(--tenant-primary-color, #2563eb) 35%, transparent);
}

.frs-cms-empty__cta:hover {
  filter: brightness(1.05);
}
