/* ============================================================
   TADWERA DESIGN SYSTEM — layout.css
   Spacing · Radius · Borders · Shadows · Motion · Layout
   ============================================================ */

:root {
  /* ── Spacing Scale — 4px base ───────────────────────────── */
  --space-0:  0px;
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;

  /* ── Radius Scale ───────────────────────────────────────── */
  --radius-none:  0px;
  --radius-xs:    2px;
  --radius-sm:    4px;
  --radius-md:    6px;
  --radius-lg:    8px;
  --radius-xl:    12px;
  --radius-2xl:   16px;
  --radius-full:  9999px;

  /* ── Border ─────────────────────────────────────────────── */
  --border-width:       1px;
  --border-width-thick: 2px;

  /* ── Shadows — opacity from semantic overlay channel (theme-aware) ─ */
  --shadow-xs: 0 1px 2px hsl(var(--bg-overlay) / 0.04);
  --shadow-sm: 0 1px 3px hsl(var(--bg-overlay) / 0.06), 0 1px 2px hsl(var(--bg-overlay) / 0.04);
  --shadow-md: 0 4px 6px hsl(var(--bg-overlay) / 0.06), 0 2px 4px hsl(var(--bg-overlay) / 0.04);
  --shadow-lg: 0 10px 24px hsl(var(--bg-overlay) / 0.08), 0 4px 8px hsl(var(--bg-overlay) / 0.05);
  --shadow-xl: 0 20px 40px hsl(var(--bg-overlay) / 0.12), 0 8px 16px hsl(var(--bg-overlay) / 0.06);

  /* ── Motion ─────────────────────────────────────────────── */
  --duration-fast:    100ms;
  --duration-normal:  150ms;
  --duration-slow:    200ms;
  --duration-slower:  300ms;
  --ease-default:     cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in:          cubic-bezier(0.4, 0, 1, 1);
  --ease-out:         cubic-bezier(0, 0, 0.2, 1);
  --ease-spring:      cubic-bezier(0.34, 1.56, 0.64, 1);

  /* ── Layout ─────────────────────────────────────────────── */
  --max-width-docs:    1280px;
  --max-width-content: 960px;
  --max-width-narrow:  720px;
  --sidebar-width:     260px;
  --header-height:     56px;

  /* ── Z-Index Scale ──────────────────────────────────────── */
  --z-below:    -1;
  --z-base:      0;
  --z-raised:   10;
  --z-dropdown: 100;
  --z-sticky:   200;
  --z-overlay:  300;
  --z-modal:    400;
  --z-toast:    500;
}

/* ── Focus Ring — global accessible style ─────────────────── */
:focus-visible {
  outline: 2px solid hsl(var(--focus-ring));
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ── Selection ────────────────────────────────────────────── */
::selection {
  background: hsl(var(--bg-selection));
  color: hsl(var(--foreground));
}

/* ── Scrollbar ────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: hsl(var(--border));
  border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover { background: hsl(var(--border-strong)); }

/* ── Layout Utilities ─────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-width-docs);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.content-container {
  max-width: var(--max-width-content);
}

/* ── Divider ──────────────────────────────────────────────── */
hr {
  border: none;
  border-top: var(--border-width) solid hsl(var(--border-muted));
  margin: 0;
}

/* ── Docs Layout ──────────────────────────────────────────── */
.docs-layout {
  display: flex;
  min-height: 100vh;
  padding-top: var(--header-height);
}

.docs-sidebar {
  position: fixed;
  top: var(--header-height);
  left: 0;
  width: var(--sidebar-width);
  height: calc(100vh - var(--header-height));
  overflow-y: auto;
  border-right: var(--border-width) solid hsl(var(--border-muted));
  background: hsl(var(--bg-dash-sidebar));
  padding: var(--space-6) 0;
  z-index: var(--z-sticky);
  transition: transform var(--duration-normal) var(--ease-default);
}

[dir="rtl"] .docs-sidebar {
  left: auto;
  right: 0;
  border-right: none;
  border-left: var(--border-width) solid hsl(var(--border-muted));
}

.docs-main {
  flex: 1;
  margin-left: var(--sidebar-width);
  min-width: 0;
  padding: var(--space-12) var(--space-8);
}

[dir="rtl"] .docs-main {
  margin-left: 0;
  margin-right: var(--sidebar-width);
}

/* ── Section spacing ──────────────────────────────────────── */
.section { margin-bottom: var(--space-16); }
.section + .section { padding-top: var(--space-12); border-top: var(--border-width) solid hsl(var(--border-muted)); }

/* ── Grid utilities ───────────────────────────────────────── */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }

@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .docs-sidebar {
    transform: translateX(-100%);
    z-index: var(--z-modal);
  }
  [dir="rtl"] .docs-sidebar { transform: translateX(100%); }
  .docs-sidebar.open { transform: translateX(0); }
  .docs-main { margin-left: 0 !important; margin-right: 0 !important; padding: var(--space-6) var(--space-4); }
}

@media (max-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}

/* ── Landing pricing rows (pricing.html) ─────────────────── */
.pricing-rows {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}
.pricing-row--3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.pricing-row--2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-top: 1.5rem;
}
@media (max-width: 960px) {
  .pricing-row--3,
  .pricing-row--2 {
    grid-template-columns: 1fr;
  }
}
