/* =========================================================
   page.css · primitivas de conteúdo para o guia
   ========================================================= */

/* ---- Page header ---- */
.ph { margin-bottom: var(--sp-10); }
.ph .eyebrow { color: var(--accent-base); }
.ph .title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(4.4rem, 6vw, 7.2rem);
  letter-spacing: -0.025em;
  line-height: 1.02;
  margin: 0 0 var(--sp-5);
}
.ph .lede {
  font-size: var(--t-xl);
  line-height: 1.45;
  color: var(--fg-2);
  max-width: 70ch;
}

/* ---- Section ---- */
.sec { margin-bottom: var(--sp-12); }
.sec-h {
  display: flex; align-items: baseline; gap: var(--sp-4);
  border-bottom: 1px solid var(--border);
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-7);
}
.sec-h .num {
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.sec-h .name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--t-3xl);
  letter-spacing: -0.015em;
  margin: 0;
}

/* ---- Do / Don't ---- */
.dodont { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); margin: var(--sp-6) 0; }
@media (max-width: 768px) { .dodont { grid-template-columns: 1fr; } }
.dodont .col {
  border: 1px solid var(--border);
  border-radius: var(--r-2);
  padding: var(--sp-5) var(--sp-6);
  background: var(--n-paper);
}
.dodont .col h4 {
  font-family: var(--font-mono);
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0 0 var(--sp-3);
}
.dodont .do h4 { color: var(--sem-success); }
.dodont .dont h4 { color: var(--sem-danger); }
.dodont ul { margin: 0; padding-left: var(--sp-5); }
.dodont li { font-size: var(--t-sm); line-height: 1.6; color: var(--fg-2); margin-bottom: var(--sp-2); }
.dodont .col.do { border-left: 3px solid var(--sem-success); }
.dodont .col.dont { border-left: 3px solid var(--sem-danger); }

/* ---- Code ---- */
.code {
  background: var(--n-ink);
  color: #E8E8EC;
  border-radius: var(--r-2);
  padding: var(--sp-5) var(--sp-6);
  font-family: var(--font-mono);
  font-size: 1.3rem;
  line-height: 1.6;
  overflow-x: auto;
  margin: var(--sp-4) 0;
}
.code .com { color: #6E6E74; }
.code .kw  { color: #66CFC1; }
.code .str { color: #E8E8EC; }
.code .var { color: #FFE39F; }

/* ---- Spec table ---- */
.spec { width: 100%; border-collapse: collapse; margin: var(--sp-5) 0; font-size: var(--t-sm); }
.spec th, .spec td {
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.spec th {
  font-family: var(--font-mono);
  font-size: 1.15rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: 500;
}
.spec td.mono, .spec td .mono { font-family: var(--font-mono); color: var(--fg-2); font-size: 1.3rem; }
.spec tr:hover td { background: var(--n-bone); }

/* ---- Callout ---- */
.callout {
  border-left: 3px solid var(--accent-base);
  background: var(--accent-wash);
  padding: var(--sp-4) var(--sp-5);
  border-radius: 0 var(--r-2) var(--r-2) 0;
  margin: var(--sp-5) 0;
  font-size: var(--t-sm);
  color: var(--fg);
}
.callout strong { font-family: var(--font-mono); font-size: 1.2rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-pressed); display: block; margin-bottom: var(--sp-1); }

/* ---- Checklist ---- */
.check { list-style: none; padding: 0; margin: var(--sp-4) 0; }
.check li {
  position: relative;
  padding-left: var(--sp-7);
  margin-bottom: var(--sp-3);
  font-size: var(--t-sm);
  line-height: 1.55;
  color: var(--fg-2);
}
.check li::before {
  content: '✓';
  position: absolute;
  left: 0; top: 0;
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent-base); color: white;
  border-radius: var(--r-1);
  font-size: 1.4rem; font-weight: 700;
}

/* ---- Swatch grid ---- */
.swg { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--sp-4); margin: var(--sp-5) 0; }
.sw {
  border: 1px solid var(--border);
  border-radius: var(--r-2);
  overflow: hidden;
  background: var(--n-paper);
}
.sw .chip { aspect-ratio: 4/3; }
.sw .meta { padding: var(--sp-3) var(--sp-4); font-size: 1.3rem; }
.sw .meta b { display: block; font-weight: 600; color: var(--fg); }
.sw .meta span { font-family: var(--font-mono); color: var(--fg-2); }
.sw .meta em { display: block; font-style: normal; color: var(--fg-3); margin-top: 2px; font-size: 1.2rem; }

/* ---- Demo box (renders an example component) ---- */
.demo {
  border: 1px dashed var(--border);
  border-radius: var(--r-2);
  padding: var(--sp-7) var(--sp-6);
  margin: var(--sp-5) 0;
  background: var(--n-bone);
  display: flex; flex-wrap: wrap; gap: var(--sp-4); align-items: center;
}
.demo[data-stack="vertical"] { flex-direction: column; align-items: stretch; }
.demo > * { margin: 0; }

/* ---- Buttons (used inside demos) ---- */
.btn-primary, .btn-secondary, .btn-outline, .btn-link, .btn-destructive {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  font-weight: 500;
  border-radius: var(--r-1);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--d-base) var(--ease), border-color var(--d-base) var(--ease);
}
.btn-primary { background: var(--brand-ink); color: white; }
.btn-primary:hover { background: var(--n-char); }
.btn-secondary { background: var(--accent-base); color: white; }
.btn-secondary:hover { background: var(--accent-hover); }
.btn-outline { background: transparent; color: var(--brand-ink); border-color: var(--brand-ink); }
.btn-outline:hover { background: var(--n-bone); }
.btn-link { padding: 0; background: transparent; color: var(--accent-base); border: 0; }
.btn-link:hover { color: var(--accent-hover); }
.btn-destructive { background: var(--sem-danger); color: white; }
.btn-destructive:hover { background: #8C2D20; }
.btn-sm { padding: var(--sp-2) var(--sp-4); font-size: var(--t-xs); }
.btn-lg { padding: var(--sp-4) var(--sp-6); font-size: var(--t-base); }

/* ---- Index grid (chapter overview) ---- */
.ix-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); margin: var(--sp-6) 0; }
@media (max-width: 900px) { .ix-grid { grid-template-columns: 1fr; } }
.ix-card {
  display: block;
  border: 1px solid var(--border);
  border-radius: var(--r-2);
  padding: var(--sp-5) var(--sp-6);
  text-decoration: none;
  color: var(--fg);
  background: var(--n-paper);
  transition: border-color var(--d-base) var(--ease), transform var(--d-base) var(--ease);
}
.ix-card:hover { border-color: var(--brand-ink); transform: translateY(-2px); }
.ix-card .num { font-family: var(--font-mono); font-size: 1.1rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-base); }
.ix-card h4 { font-family: var(--font-display); font-weight: 600; font-size: var(--t-xl); margin: var(--sp-2) 0 var(--sp-2); letter-spacing: -0.01em; }
.ix-card p { font-size: var(--t-sm); color: var(--fg-2); margin: 0; line-height: 1.55; }
