/**
 * Design System Objects - Layout Patterns
 * ITCSS Layer 4: OOCSS/CUBE CSS Composition Layer
 * Reusable layout patterns without visual styling
 * @version 1.0.0
 */

/* =========================================================================
   CONTAINER
   Max-width wrapper with padding
   ========================================================================= */

.container {
  width: 100%;
  max-width: var(--container-max-width, var(--size-max-content));
  margin-inline: auto;
  padding-inline: var(--container-padding, var(--spacing-md));
}

.container--sm {
  --container-max-width: 640px;
}

.container--md {
  --container-max-width: 768px;
}

.container--lg {
  --container-max-width: 1024px;
}

.container--xl {
  --container-max-width: 1280px;
}

/* =========================================================================
   STACK
   Vertical flow with consistent gap
   ========================================================================= */

.stack {
  display: flex;
  flex-direction: column;
  gap: var(--stack-gap, var(--spacing-md));
}

.stack--xs { --stack-gap: var(--spacing-xs); }
.stack--sm { --stack-gap: var(--spacing-sm); }
.stack--md { --stack-gap: var(--spacing-md); }
.stack--lg { --stack-gap: var(--spacing-lg); }
.stack--xl { --stack-gap: var(--spacing-xl); }

/* Recursive stack - apply to all children */
.stack-recursive > * + * {
  margin-top: var(--stack-gap, var(--spacing-md));
}

/* =========================================================================
   CLUSTER
   Horizontal grouping with wrapping
   ========================================================================= */

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cluster-gap, var(--spacing-sm));
  align-items: var(--cluster-align, center);
  justify-content: var(--cluster-justify, flex-start);
}

.cluster--center {
  --cluster-justify: center;
}

.cluster--between {
  --cluster-justify: space-between;
}

.cluster--end {
  --cluster-justify: flex-end;
}

/* =========================================================================
   SIDEBAR
   Content with fixed-width sidebar
   ========================================================================= */

.sidebar-layout {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sidebar-gap, var(--spacing-lg));
}

.sidebar-layout > :first-child {
  flex-basis: var(--sidebar-width, 280px);
  flex-grow: 1;
}

.sidebar-layout > :last-child {
  flex-basis: 0;
  flex-grow: 999;
  min-width: var(--sidebar-content-min, 50%);
}

/* Flip sidebar to right */
.sidebar-layout--flip {
  flex-direction: row-reverse;
}

/* =========================================================================
   GRID
   Auto-fit responsive grid
   ========================================================================= */

.grid {
  display: grid;
  gap: var(--grid-gap, var(--spacing-md));
  grid-template-columns: repeat(
    auto-fit,
    minmax(var(--grid-min, 250px), 1fr)
  );
}

.grid--2 { --grid-min: 300px; }
.grid--3 { --grid-min: 250px; }
.grid--4 { --grid-min: 200px; }

/* Fixed column grids */
.grid-cols-2 {
  grid-template-columns: repeat(2, 1fr);
}

.grid-cols-3 {
  grid-template-columns: repeat(3, 1fr);
}

.grid-cols-4 {
  grid-template-columns: repeat(4, 1fr);
}

/* Responsive: stack on mobile */
@media (max-width: 640px) {
  .grid-cols-2,
  .grid-cols-3,
  .grid-cols-4 {
    grid-template-columns: 1fr;
  }
}

/* =========================================================================
   CENTER
   Centered content with optional intrinsic width
   ========================================================================= */

.center {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.center--intrinsic {
  align-items: center;
}

.center--intrinsic > * {
  width: auto;
}

/* =========================================================================
   COVER
   Full viewport height with centered content
   ========================================================================= */

.cover {
  display: flex;
  flex-direction: column;
  min-height: var(--cover-min-height, 100vh);
  padding: var(--cover-padding, var(--spacing-md));
}

.cover > :first-child:not(.cover__center) {
  margin-top: 0;
}

.cover > :last-child:not(.cover__center) {
  margin-bottom: 0;
}

.cover > .cover__center {
  margin-block: auto;
}

/* =========================================================================
   SWITCHER
   Horizontal until it wraps, then vertical
   ========================================================================= */

.switcher {
  display: flex;
  flex-wrap: wrap;
  gap: var(--switcher-gap, var(--spacing-md));
}

.switcher > * {
  flex-grow: 1;
  flex-basis: calc((var(--switcher-threshold, 30rem) - 100%) * 999);
}

/* =========================================================================
   MEDIA OBJECT
   Image + content side by side
   ========================================================================= */

.media {
  display: flex;
  gap: var(--media-gap, var(--spacing-md));
  align-items: var(--media-align, flex-start);
}

.media__image {
  flex-shrink: 0;
}

.media__body {
  flex: 1;
  min-width: 0; /* Prevent text overflow */
}

.media--center {
  --media-align: center;
}

.media--flip {
  flex-direction: row-reverse;
}

/* =========================================================================
   FRAME
   Aspect ratio container
   ========================================================================= */

.frame {
  aspect-ratio: var(--frame-ratio, 16 / 9);
  overflow: hidden;
}

.frame > img,
.frame > video,
.frame > iframe {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.frame--1-1 { --frame-ratio: 1 / 1; }
.frame--4-3 { --frame-ratio: 4 / 3; }
.frame--16-9 { --frame-ratio: 16 / 9; }
.frame--21-9 { --frame-ratio: 21 / 9; }

/* =========================================================================
   REEL
   Horizontal scrolling container
   ========================================================================= */

.reel {
  display: flex;
  gap: var(--reel-gap, var(--spacing-md));
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}

.reel > * {
  flex: 0 0 var(--reel-item-width, auto);
  scroll-snap-align: start;
}

.reel::-webkit-scrollbar {
  height: 8px;
}

.reel::-webkit-scrollbar-thumb {
  background-color: var(--color-border-strong);
  border-radius: var(--radius-full);
}

/* =========================================================================
   IMPOSTER
   Overlay/modal positioning
   ========================================================================= */

.imposter {
  position: var(--imposter-position, fixed);
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-md);
}

.imposter[hidden] {
  display: none;
}

.imposter__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgb(0 0 0 / 50%);
  z-index: -1;
}

/* =========================================================================
   ICON
   Inline icon sizing
   ========================================================================= */

.icon {
  display: inline-flex;
  width: var(--icon-size, 1em);
  height: var(--icon-size, 1em);
  vertical-align: middle;
}

.icon--sm { --icon-size: var(--size-icon-sm); }
.icon--md { --icon-size: var(--size-icon-md); }
.icon--lg { --icon-size: var(--size-icon-lg); }
.icon--xl { --icon-size: var(--size-icon-xl); }

/* =========================================================================
   WRAPPER
   Breakout from container for full-width sections
   ========================================================================= */

.wrapper {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding-inline: var(--spacing-md);
}

.wrapper > .container {
  padding-inline: 0;
}

/* =========================================================================
   REGION
   Section spacing
   ========================================================================= */

.region {
  padding-block: var(--region-space, var(--spacing-xxl));
}

.region--sm { --region-space: var(--spacing-lg); }
.region--lg { --region-space: calc(var(--spacing-xxl) * 1.5); }

/* =========================================================================
   FLOW (Alternative to Stack using margins)
   For prose content where gap doesn't apply
   ========================================================================= */

.flow > * + * {
  margin-top: var(--flow-space, 1em);
}

.flow--tight { --flow-space: 0.5em; }
.flow--loose { --flow-space: 1.5em; }

/* =========================================================================
   VISUALLY HIDDEN
   Accessible hiding
   ========================================================================= */

.visually-hidden,
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Allow focus for skip links */
.visually-hidden--focusable:focus,
.visually-hidden--focusable:active {
  position: static !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: normal !important;
}

/* =========================================================================
   CONTAINER QUERIES
   Enable container query on layout elements
   ========================================================================= */

.container-query {
  container-type: inline-size;
}

/* Stack to grid at container breakpoint */
@container (min-width: 640px) {
  .cq-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
  }
}

@container (min-width: 768px) {
  .cq-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
  }
}
