/* ============================================================================
 * 1MZ For Artists — Design System
 * 02-base.css — Reset, tipografia base, utilitários globais
 *
 * Aplica-se APENAS dentro de containers .rmbz-app para não tocar no resto
 * do tema do utilizador. Todas as regras estão namespaced com .rmbz-app.
 * ============================================================================ */

/* ─────────────────────────────────────────────────────────────────────────────
 * Container raiz — qualquer área do plugin (login, dashboard, modal, etc)
 * deve estar dentro de .rmbz-app.
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-app {
  font-family: var(--rmbz-font-body);
  font-size: var(--rmbz-text-base);
  line-height: var(--rmbz-leading-normal);
  color: var(--rmbz-text-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'cv11', 'ss01', 'ss03';  /* Geist stylistic sets */
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Box-sizing universal dentro de .rmbz-app
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-app,
.rmbz-app *,
.rmbz-app *::before,
.rmbz-app *::after {
  box-sizing: border-box;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Tipografia base
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-app h1,
.rmbz-app h2,
.rmbz-app h3,
.rmbz-app h4,
.rmbz-app h5,
.rmbz-app h6 {
  font-family: var(--rmbz-font-display);
  font-weight: var(--rmbz-weight-semibold);
  line-height: var(--rmbz-leading-tight);
  letter-spacing: var(--rmbz-tracking-tight);
  color: var(--rmbz-text-primary);
  margin: 0 0 var(--rmbz-space-4) 0;
  font-feature-settings: 'ss01', 'ss02';  /* Bricolage stylistic sets */
}

.rmbz-app h1 { font-size: var(--rmbz-text-3xl); font-weight: var(--rmbz-weight-bold); }
.rmbz-app h2 { font-size: var(--rmbz-text-2xl); }
.rmbz-app h3 { font-size: var(--rmbz-text-xl); }
.rmbz-app h4 { font-size: var(--rmbz-text-lg); }
.rmbz-app h5 { font-size: var(--rmbz-text-base); }
.rmbz-app h6 {
  font-size: var(--rmbz-text-xs);
  text-transform: uppercase;
  letter-spacing: var(--rmbz-tracking-wider);
  color: var(--rmbz-text-muted);
}

.rmbz-app p {
  margin: 0 0 var(--rmbz-space-4) 0;
  color: var(--rmbz-text-secondary);
}

.rmbz-app a {
  color: var(--rmbz-brand);
  text-decoration: none;
  transition: color var(--rmbz-duration-fast) var(--rmbz-ease-out);
}

.rmbz-app a:hover {
  color: var(--rmbz-brand-strong);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.rmbz-app strong { font-weight: var(--rmbz-weight-semibold); color: var(--rmbz-text-primary); }
.rmbz-app code,
.rmbz-app pre {
  font-family: var(--rmbz-font-mono);
  font-size: 0.9em;
}

.rmbz-app code {
  background: var(--rmbz-bg-elevated);
  padding: 0.15em 0.4em;
  border-radius: var(--rmbz-radius-xs);
  border: 1px solid var(--rmbz-border-subtle);
}

.rmbz-app hr {
  border: 0;
  border-top: 1px solid var(--rmbz-border-subtle);
  margin: var(--rmbz-space-8) 0;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Focus visible — anel dourado consistente em vez do outline do browser
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-app :focus-visible {
  outline: none;
  box-shadow: var(--rmbz-ring-brand);
  border-radius: var(--rmbz-radius-sm);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Selection — destacar com tom da marca
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-app ::selection {
  background: var(--rmbz-brand);
  color: var(--rmbz-text-on-brand);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Scrollbar — discreta mas visível, sintonizada com o tema
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-app * {
  scrollbar-width: thin;
  scrollbar-color: var(--rmbz-border-strong) transparent;
}

.rmbz-app *::-webkit-scrollbar          { width: 8px; height: 8px; }
.rmbz-app *::-webkit-scrollbar-track    { background: transparent; }
.rmbz-app *::-webkit-scrollbar-thumb    {
  background: var(--rmbz-border-strong);
  border-radius: var(--rmbz-radius-pill);
}
.rmbz-app *::-webkit-scrollbar-thumb:hover { background: var(--rmbz-text-muted); }

/* ─────────────────────────────────────────────────────────────────────────────
 * Container principal
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-container {
  max-width: var(--rmbz-container-lg);
  margin: var(--rmbz-space-10) auto;
  padding: var(--rmbz-space-8);
  background: var(--rmbz-bg-surface);
  border: 1px solid var(--rmbz-border-subtle);
  border-radius: var(--rmbz-radius-lg);
  box-shadow: var(--rmbz-shadow-md);
}

.rmbz-container--xl { max-width: var(--rmbz-container-xl); }
.rmbz-container--md { max-width: var(--rmbz-container-md); }
.rmbz-container--sm { max-width: var(--rmbz-container-sm); }

@media (max-width: 640px) {
  .rmbz-container {
    margin: var(--rmbz-space-4);
    padding: var(--rmbz-space-5);
    border-radius: var(--rmbz-radius-md);
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Utilitários de layout (poucos, intencionais — não é Tailwind)
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-stack    { display: flex; flex-direction: column; gap: var(--rmbz-space-4); }
.rmbz-stack-sm { display: flex; flex-direction: column; gap: var(--rmbz-space-2); }
.rmbz-stack-lg { display: flex; flex-direction: column; gap: var(--rmbz-space-6); }

/* O atributo HTML [hidden] tem que vencer SEMPRE qualquer display: flex/grid
 * dos utilitários. Sem !important, .rmbz-stack vence [hidden] por specificity
 * (0,1,0 > 0,0,1) — e elementos que deviam estar escondidos aparecem.
 * Sem namespace porque modais e outros componentes podem viver fora de .rmbz-app
 * (no body directamente). É seguro: [hidden] = "esconder" é o comportamento HTML. */
.rmbz-modal[hidden],
.rmbz-modal [hidden],
.rmbz-stack[hidden],
.rmbz-stack-sm[hidden],
.rmbz-stack-lg[hidden] { display: none !important; }

.rmbz-row    { display: flex; align-items: center; gap: var(--rmbz-space-4); }
.rmbz-row-sm { display: flex; align-items: center; gap: var(--rmbz-space-2); }
.rmbz-row-between { display: flex; align-items: center; justify-content: space-between; gap: var(--rmbz-space-4); }

.rmbz-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--rmbz-space-4); }
.rmbz-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--rmbz-space-4); }
.rmbz-grid-auto { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--rmbz-space-4); }

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

/* ─────────────────────────────────────────────────────────────────────────────
 * Utilitários tipográficos (nomeados, não atómicos)
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-text-muted     { color: var(--rmbz-text-muted); }
.rmbz-text-secondary { color: var(--rmbz-text-secondary); }
.rmbz-text-brand     { color: var(--rmbz-brand); }
.rmbz-text-success   { color: var(--rmbz-success); }
.rmbz-text-danger    { color: var(--rmbz-danger); }

.rmbz-text-mono      { font-family: var(--rmbz-font-mono); font-variant-numeric: tabular-nums; }
.rmbz-text-display   { font-family: var(--rmbz-font-display); }

.rmbz-text-xs   { font-size: var(--rmbz-text-xs); }
.rmbz-text-sm   { font-size: var(--rmbz-text-sm); }
.rmbz-text-lg   { font-size: var(--rmbz-text-lg); }

.rmbz-eyebrow {
  font-size: var(--rmbz-text-2xs);
  font-weight: var(--rmbz-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--rmbz-tracking-wider);
  color: var(--rmbz-text-muted);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * Hidden / sr-only
 * ───────────────────────────────────────────────────────────────────────── */

.rmbz-hidden { display: none !important; }

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