/* ════════════════════════════════════════════════════════════
   shell.css — Capa 1: Layout base
   Solo usa variables de primitives.css. Cero hardcoded.
   ════════════════════════════════════════════════════════════ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  cursor: default;
}

html, body {
  height: 100%;
  overflow: hidden;
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  background: var(--color-bg);
  color: var(--color-text-soft);
}

#app {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Toolbar ─────────────────────────────────────────────── */

.toolbar {
  flex-shrink: 0;
  min-height: var(--lyt-band-min-height);
  display: flex;
  align-items: center;
  padding: 0 var(--space-lg);
  gap: var(--space-sm);
  background: var(--lyt-header-bg);
  color: var(--lyt-header-color);
  border-bottom: var(--lyt-header-border);
  user-select: none;
}

.toolbar--compact {
  min-height: 32px;
  padding: 0 var(--space-sm);
  font-size: var(--font-size-sm);
}

.toolbar--bottom {
  border-top: 1px solid var(--color-border);
  border-bottom: none;
  background: var(--color-surface-soft);
  color: var(--color-text-soft);
  min-height: 42px;
}

.toolbar__brand {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-xbold);
  color: inherit;
}

.toolbar__label {
  font-size: var(--toolbar-title-size);
  font-weight: var(--toolbar-title-weight);
  color: inherit;
  white-space: nowrap;
}

.toolbar__spacer { flex: 1; }

.toolbar__sep {
  width: 1px;
  height: 16px;
  background: var(--toolbar-sep-bg);
  flex-shrink: 0;
}

.toolbar select {
  color-scheme: light;
}
.toolbar select option {
  background: #fff;
  color: #222;
}
.toolbar select option:hover {
  background: linear-gradient(var(--color-accent), var(--color-accent));
  color: #fff;
}
.toolbar select option:checked {
  background: var(--color-accent);
  color: #fff;
}

/* ── Layout body ─────────────────────────────────────────── */

.lyt-body {
  flex: 1 1 0;
  min-height: 0;
  display: flex;
  overflow: hidden;
  outline: none;
}

.panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--color-surface-soft);
}

.panel--left {
  flex: 0 0 220px;
  min-width: 120px;
  background: var(--lyt-left-bg);
  color: var(--lyt-left-color);
  border-right: var(--lyt-left-border);
}

.panel--right {
  flex: 1 1 0;
  min-width: 0;
  background: var(--lyt-right-bg);
  color: var(--lyt-right-color);
}

.panel--top    { flex-shrink: 0; }
.panel--bottom { flex-shrink: 0; border-top: 1px solid var(--color-border); }

.panel-header {
  flex-shrink: 0;
  height: 32px;
  display: flex;
  align-items: center;
  padding: 0 var(--space-md);
  gap: var(--space-xs);
  background: var(--lyt-left-bg);
  color: var(--lyt-left-color);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  border-bottom: 1px solid rgba(0,0,0,.10);
}

/* ── Slot ────────────────────────────────────────────────── */

.slot {
  flex: 1 1 0;
  min-height: 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  outline: none;
}

.slot--scroll { overflow-y: auto; overflow-x: hidden; }
.slot--scroll::-webkit-scrollbar       { width: 4px; }
.slot--scroll::-webkit-scrollbar-track { background: var(--lyt-scroll-track); }
.slot--scroll::-webkit-scrollbar-thumb {
  background: var(--lyt-scroll-thumb);
  border-radius: var(--radius-base);
}

/* ── Resizer ─────────────────────────────────────────────── */

.resizer { flex-shrink: 0; transition: background var(--transition-base); }

.resizer--h {
  width: 5px;
  cursor: col-resize;
  background: var(--lyt-resizer-bg);
}

.resizer--v {
  height: 5px;
  cursor: row-resize;
  background: var(--lyt-resizer-bg);
}

.resizer--h:hover,
.resizer--v:hover { background: var(--lyt-resizer-bg-hover); }

.resizer--active { background: var(--lyt-resizer-bg-hover); opacity: .6; }
