/* ==========================================================================
   REGINA LAFER · DESIGN SYSTEM
   docs.css — Estilo exclusivo da página de documentação navegável
   ========================================================================== */

/* overflow-x: clip evita rolagem horizontal SEM criar container de rolagem
   (diferente de hidden, que quebraria o position:sticky da barra lateral) */
.docs { display: grid; grid-template-columns: 280px minmax(0, 1fr); min-height: 100vh; overflow-x: clip; }

/* ---- Barra lateral ----------------------------------------------------- */
.docs-sidebar {
  position: sticky; top: 0; align-self: start; height: 100vh; overflow-y: auto;
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  padding: var(--space-6) var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-6);
  /* Barra de rolagem adaptada ao tema (Firefox) */
  scrollbar-width: thin;
  scrollbar-color: var(--color-border-strong) transparent;
}
/* Barra de rolagem adaptada ao tema (WebKit/Chromium) */
.docs-sidebar::-webkit-scrollbar { width: 10px; }
.docs-sidebar::-webkit-scrollbar-track { background: transparent; }
.docs-sidebar::-webkit-scrollbar-thumb {
  background: var(--color-border-strong);
  border-radius: var(--radius-full);
  border: 2px solid var(--color-surface);
}
.docs-sidebar::-webkit-scrollbar-thumb:hover { background: var(--color-text-subtle); }
.docs-brand { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-2); }
.docs-brand img { height: 42px; width: auto; max-width: 100%; }
.docs-brand__sub { font-size: var(--text-2xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--color-text-subtle); padding-left: 2px; }

.docs-nav { display: flex; flex-direction: column; gap: var(--space-1); }
.docs-nav__group { font-size: var(--text-2xs); text-transform: uppercase; letter-spacing: var(--tracking-wider); color: var(--color-text-subtle); margin: var(--space-4) var(--space-3) var(--space-1); font-weight: var(--weight-medium); }
.docs-nav a {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-md);
  color: var(--color-text-muted); font-size: var(--text-sm); font-weight: var(--weight-regular);
  transition: all var(--duration-fast) var(--ease-out);
}
.docs-nav a:hover { background: var(--color-surface-sunken); color: var(--color-text); text-decoration: none; }
.docs-nav a.is-active { background: var(--color-primary-subtle); color: var(--color-primary-active); font-weight: var(--weight-medium); }

/* ---- Conteúdo ---------------------------------------------------------- */
.docs-main { padding: var(--space-12) var(--space-16); max-width: 1080px; min-width: 0; }
.docs-main pre { max-width: 100%; overflow-x: auto; }
.docs-section { padding-block: var(--space-12); border-bottom: 1px solid var(--color-divider); scroll-margin-top: var(--space-8); }
.docs-section:first-of-type { padding-top: 0; }
.docs-section__head { margin-bottom: var(--space-8); }
.docs-section__head h2 { font-size: var(--text-3xl); margin-bottom: var(--space-2); }
.docs-section__head p { color: var(--color-text-muted); max-width: var(--measure); }

.docs-subtitle { font-size: var(--text-sm); font-weight: var(--weight-medium); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--color-text-muted); margin: var(--space-8) 0 var(--space-4); }

/* Cabeçalho fixo do conteúdo (toggle de tema) */
.docs-topbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-10); gap: var(--space-4); flex-wrap: wrap; }
.docs-topbar .eyebrow { margin-bottom: var(--space-1); }

/* Hero */
.docs-hero {
  background: linear-gradient(135deg, var(--blue-50), var(--sage-50));
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl); padding: var(--space-16);
  text-align: center; margin-bottom: var(--space-12); position: relative; overflow: hidden;
}
[data-theme="dark"] .docs-hero { background: linear-gradient(135deg, #0a1f3d, #112c2a); border-color: var(--color-border); }
.docs-hero__title { font-family: var(--font-display); font-size: var(--text-6xl); color: var(--color-primary); line-height: 1; margin-bottom: var(--space-2); }
.docs-hero__sub { font-size: var(--text-2xs); letter-spacing: 0.4em; text-transform: uppercase; color: var(--color-text-muted); margin-bottom: var(--space-6); }
.docs-hero__lead { font-size: var(--text-md); color: var(--color-text-muted); max-width: 52ch; margin: 0 auto; }
.docs-hero img { height: 240px; max-width: 100%; margin: 0 auto var(--space-6); }

/* ---- Blocos de demonstração ------------------------------------------- */
.demo {
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  overflow: hidden; margin-bottom: var(--space-6);
}
.demo__preview { padding: var(--space-8); background: var(--color-surface); display: flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; }
.demo__preview--col { flex-direction: column; align-items: stretch; }
.demo__preview--center { justify-content: center; }
.demo__label { font-size: var(--text-xs); color: var(--color-text-subtle); padding: var(--space-2) var(--space-4); background: var(--color-surface-sunken); border-top: 1px solid var(--color-divider); display: flex; justify-content: space-between; }

/* ---- Swatches de cor --------------------------------------------------- */
.swatch-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-4); }
.swatch { border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; background: var(--color-surface); cursor: pointer; transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out); }
.swatch:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.swatch__color { height: 76px; display: flex; align-items: flex-end; padding: var(--space-2); }
.swatch__meta { padding: var(--space-3); }
.swatch__name { font-size: var(--text-sm); font-weight: var(--weight-medium); }
.swatch__hex { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-muted); text-transform: uppercase; }
.swatch__role { font-size: var(--text-2xs); color: var(--color-text-subtle); margin-top: 2px; }

/* Escala de cor em faixa */
.scale-row { display: flex; border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--color-border); }
.scale-row__step { flex: 1; height: 64px; display: flex; align-items: flex-end; justify-content: center; padding-bottom: var(--space-1); font-size: var(--text-2xs); font-family: var(--font-mono); }

/* ---- Amostras tipográficas -------------------------------------------- */
.type-row { display: flex; align-items: baseline; gap: var(--space-6); padding: var(--space-4) 0; border-bottom: 1px solid var(--color-divider); flex-wrap: wrap; }
.type-row__meta { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-subtle); min-width: 140px; }
.type-row__sample { flex: 1; min-width: 0; }

/* ---- Tokens visuais (espaçamento/raio/sombra) ------------------------- */
.token-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--space-4); }
.token-card { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); background: var(--color-surface); }
.token-card__name { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-3); }
.space-bar { background: var(--color-primary); height: 16px; border-radius: var(--radius-xs); }
.radius-demo { height: 72px; background: var(--color-primary-subtle); border: 2px solid var(--color-primary); }
.shadow-demo { height: 72px; background: var(--color-surface); border-radius: var(--radius-md); }

/* ---- Tabela de uso / referência --------------------------------------- */
.ref-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.ref-table th, .ref-table td { padding: var(--space-3); text-align: left; border-bottom: 1px solid var(--color-divider); vertical-align: top; }
.ref-table th { color: var(--color-text-muted); font-weight: var(--weight-medium); }
.ref-table code { white-space: nowrap; }

/* ---- Toggle de tema ---------------------------------------------------- */
.theme-toggle { display: inline-flex; align-items: center; gap: var(--space-2); }

/* Botão fixo de tema (canto superior direito) — desktop e mobile.
   Redefine as variáveis internas do .ds-btn para que hover/active mantenham
   o contraste do ícone (texto sobre superfície), sem herdar o branco do tema primário. */
.docs-theme-fab {
  --_bg: var(--color-surface);
  --_fg: var(--color-text);
  --_bg-hover: var(--color-surface-sunken);
  --_bg-active: var(--color-border);
  position: fixed; top: var(--space-4); right: var(--space-4);
  z-index: var(--z-sticky); min-width: 44px; min-height: 44px;
  border: 1px solid var(--color-border-strong);
  box-shadow: var(--shadow-md);
}

/* Troca de ícone conforme o tema: lua no claro (vai p/ escuro), sol no escuro (vai p/ claro) */
.docs-theme-fab .icon-sun { display: none; }
[data-theme="dark"] .docs-theme-fab .icon-moon { display: none; }
[data-theme="dark"] .docs-theme-fab .icon-sun { display: block; }

/* Botão "voltar ao topo" (canto inferior direito) — desktop e mobile */
.docs-totop {
  position: fixed; bottom: var(--space-5); right: var(--space-5);
  z-index: var(--z-sticky); min-width: 44px; min-height: 44px;
  background: var(--color-primary); color: #fff;
  border: none; box-shadow: var(--shadow-lg);
  opacity: 0; transform: translateY(12px); pointer-events: none;
  transition: opacity var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
}
.docs-totop:hover { background: var(--color-primary-hover); color: #fff; }
.docs-totop.is-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }

/* ---- Cartões de princípios -------------------------------------------- */
.principle-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-4); }
.principle { padding: var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); }
.principle__icon { width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--color-primary-subtle); color: var(--color-primary); display: grid; place-items: center; margin-bottom: var(--space-3); }
.principle h4 { margin-bottom: var(--space-1); }
.principle p { font-size: var(--text-sm); color: var(--color-text-muted); }
.principle--avoid .principle__icon { background: var(--color-danger-subtle); color: var(--color-danger); }

/* ---- Cartões de template ---------------------------------------------- */
.template-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-6); }
.template-card__thumb { height: 180px; background: var(--color-surface-sunken); display: grid; place-items: center; color: var(--color-text-subtle); border-bottom: 1px solid var(--color-divider); }

/* ---- Vitrine de variações da marca ------------------------------------ */
.logo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-5); }
.logo-tile { border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; background: var(--color-surface); }
.logo-tile__stage { height: 180px; display: grid; place-items: center; padding: var(--space-6); }
.logo-tile__stage img { max-height: 120px; max-width: 100%; }
.logo-tile__stage--light { background: var(--neutral-50); }
.logo-tile__stage--white { background: #ffffff; }
.logo-tile__stage--blue  { background: var(--blue-500); }
.logo-tile__stage--dark  { background: #050d1a; }
.logo-tile__stage--check { background-color: #faf9f7; background-image: linear-gradient(45deg, #e7e3db 25%, transparent 25%), linear-gradient(-45deg, #e7e3db 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #e7e3db 75%), linear-gradient(-45deg, transparent 75%, #e7e3db 75%); background-size: 18px 18px; background-position: 0 0, 0 9px, 9px -9px, -9px 0; }
.logo-tile__meta { padding: var(--space-3) var(--space-4); border-top: 1px solid var(--color-divider); display: flex; justify-content: space-between; align-items: center; gap: var(--space-2); }
.logo-tile__meta strong { font-size: var(--text-sm); }
.logo-tile__meta .swatch__hex { font-size: var(--text-2xs); }

/* Clearspace / área de respiro */
.clearspace { display: inline-grid; place-items: center; padding: var(--space-8); background: var(--color-surface-sunken); border: 1px dashed var(--color-border-strong); border-radius: var(--radius-lg); position: relative; }
.clearspace img { height: 96px; outline: 1px dashed var(--color-primary); outline-offset: var(--space-6); }

/* Usos indevidos */
.misuse { border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; background: var(--color-surface); }
.misuse__stage { height: 130px; display: grid; place-items: center; padding: var(--space-4); background: var(--neutral-50); position: relative; }
.misuse__stage img { max-height: 84px; }
.misuse__tag { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); color: var(--color-danger); display: flex; gap: var(--space-1); align-items: center; border-top: 1px solid var(--color-divider); }

.copy-hint { position: fixed; bottom: var(--space-6); left: 50%; transform: translateX(-50%) translateY(20px); background: var(--neutral-900); color: #fff; padding: var(--space-3) var(--space-5); border-radius: var(--radius-full); font-size: var(--text-sm); opacity: 0; pointer-events: none; transition: all var(--duration-base) var(--ease-out); z-index: var(--z-toast); box-shadow: var(--shadow-lg); }
.copy-hint.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ---- Backdrop do menu mobile ------------------------------------------ */
.docs-backdrop { display: none; }

/* ---- Menu mobile ------------------------------------------------------- */
.docs-menu-btn { display: none; }

@media (max-width: 920px) {
  .docs { grid-template-columns: minmax(0, 1fr); }

  .docs-sidebar {
    position: fixed; left: 0; top: 0; bottom: 0; width: min(86vw, 300px);
    z-index: var(--z-modal); transform: translateX(-100%);
    transition: transform var(--duration-base) var(--ease-out);
    box-shadow: var(--shadow-xl);
  }
  .docs.menu-open .docs-sidebar { transform: translateX(0); }

  /* Fundo escurecido ao abrir o menu */
  .docs-backdrop {
    display: block; position: fixed; inset: 0; background: var(--color-overlay);
    opacity: 0; pointer-events: none; z-index: var(--z-overlay);
    transition: opacity var(--duration-base) var(--ease-out);
  }
  .docs.menu-open .docs-backdrop { opacity: 1; pointer-events: auto; }

  /* Espaço no topo para o botão de menu não cobrir o conteúdo */
  .docs-main { padding: var(--space-16) var(--space-5) var(--space-8); }

  /* Botão de menu em destaque (azul da marca + ícone hambúrguer branco) */
  .docs-menu-btn {
    display: inline-flex; position: fixed; top: var(--space-3); right: var(--space-3);
    z-index: var(--z-sticky); background: var(--color-primary); color: #fff;
    border: none; box-shadow: var(--shadow-lg);
    min-width: 44px; min-height: 44px;
  }
  .docs-menu-btn:hover { background: var(--color-primary-hover); color: #fff; }

  /* No mobile, o botão de tema desloca-se para a esquerda do botão de menu */
  .docs-theme-fab {
    top: var(--space-3);
    right: calc(var(--space-3) + 44px + var(--space-2));
  }

  .docs-hero { padding: var(--space-10) var(--space-5); }
  .docs-hero__title { font-size: var(--text-4xl); }
  .docs-hero img { height: 160px; }

  .docs-section__head h2 { font-size: var(--text-2xl); }
}

@media (max-width: 560px) {
  .docs-main { padding-inline: var(--space-4); }

  /* Amostras tipográficas: empilha e limita o tamanho do exemplo */
  .type-row { gap: var(--space-2); }
  .type-row__meta { min-width: 0; flex-basis: 100%; }
  .type-row__sample { font-size: var(--text-xl) !important; word-break: break-word; }

  /* Tabelas de referência: permite quebra dos tokens longos */
  .ref-table { font-size: var(--text-xs); }
  .ref-table th, .ref-table td { padding: var(--space-2); }
  .ref-table code { white-space: normal; word-break: break-word; }

  /* Demos com respiro menor */
  .demo__preview { padding: var(--space-5); gap: var(--space-3); }

  /* Escala de cores continua legível em telas estreitas */
  .scale-row__step { font-size: 9px; }

  .docs-hero__title { font-size: var(--text-3xl); }
  .docs-hero__lead { font-size: var(--text-base); }
}
