*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  background: var(--ap-bg);
  color: var(--ap-text);
  font-family: var(--ap-font-body);
  font-size: var(--ap-fs-md);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1,h2,h3,h4 { font-family: var(--ap-font-head); line-height: 1.18; margin: 0 0 .35em; font-weight: 700; letter-spacing: -0.01em; }
p { margin: 0 0 .8em; }
a { color: var(--ap-primary); text-decoration: none; }
img { max-width: 100%; display: block; }
::selection { background: color-mix(in srgb, var(--ap-primary) 28%, transparent); }

.ap-root { min-height: 100vh; display: flex; flex-direction: column; background: var(--ap-bg); color: var(--ap-text); }

/* Scrollbars */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--ap-text-mute) 45%, transparent); border-radius: 99px; border: 2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-thumb:hover { background: var(--ap-text-mute); background-clip: padding-box; }

/* ---- Buttons ---- */
.ap-btn {
  --bg: var(--ap-surface); --fg: var(--ap-text);
  appearance: none; border: 1px solid var(--ap-border); background: var(--bg); color: var(--fg);
  font: inherit; font-weight: 600; font-size: var(--ap-fs-sm);
  padding: 9px 15px; border-radius: 999px; cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px; line-height: 1;
  transition: transform .15s var(--ap-ease), box-shadow .2s var(--ap-ease), background .2s var(--ap-ease), border-color .2s var(--ap-ease);
  white-space: nowrap;
}
.ap-btn:hover { transform: translateY(-1px); box-shadow: var(--ap-shadow-sm); }
.ap-btn:active { transform: translateY(0); }
.ap-btn:focus-visible { outline: none; box-shadow: var(--ap-ring); }
.ap-btn svg { width: 16px; height: 16px; }
.ap-btn--primary { --bg: var(--ap-primary); --fg: var(--ap-on-primary); border-color: transparent; box-shadow: 0 6px 18px color-mix(in srgb, var(--ap-primary) 35%, transparent); }
.ap-btn--primary:hover { box-shadow: 0 10px 26px color-mix(in srgb, var(--ap-primary) 45%, transparent); }
.ap-btn--ghost { --bg: transparent; border-color: transparent; }
.ap-btn--ghost:hover { background: var(--ap-bg-soft); }
.ap-btn--soft { --bg: color-mix(in srgb, var(--ap-primary) 12%, var(--ap-surface)); --fg: var(--ap-primary); border-color: transparent; }
.ap-btn--sm { padding: 6px 11px; font-size: var(--ap-fs-xs); }
.ap-btn--icon { padding: 8px; border-radius: 50%; }
.ap-btn--danger { --fg: var(--ap-warn); }
.ap-btn[disabled] { opacity: .5; pointer-events: none; }

/* ---- Form controls ---- */
.ap-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.ap-label { font-size: var(--ap-fs-xs); font-weight: 700; color: var(--ap-text-soft); text-transform: uppercase; letter-spacing: .04em; }
.ap-input, .ap-select, .ap-textarea {
  width: 100%; font: inherit; font-size: var(--ap-fs-sm); color: var(--ap-text);
  background: var(--ap-surface); border: 1px solid var(--ap-border); border-radius: var(--ap-radius-sm);
  padding: 9px 11px; transition: border-color .15s, box-shadow .15s;
}
.ap-input:focus, .ap-select:focus, .ap-textarea:focus { outline: none; border-color: var(--ap-primary); box-shadow: var(--ap-ring); }
.ap-textarea { resize: vertical; min-height: 72px; font-family: ui-monospace, "Cascadia Code", Consolas, monospace; }
.ap-input-color { width: 38px; height: 34px; padding: 2px; border-radius: 8px; cursor: pointer; border: 1px solid var(--ap-border); background: var(--ap-surface); }

/* ---- Chips & badges ---- */
.ap-chip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: 999px; font-size: var(--ap-fs-xs); font-weight: 600; background: var(--ap-bg-soft); color: var(--ap-text-soft); border: 1px solid transparent; cursor: pointer; transition: all .15s var(--ap-ease); }
.ap-chip:hover { border-color: var(--ap-border); }
.ap-chip[aria-pressed="true"], .ap-chip.is-active { background: color-mix(in srgb, var(--ap-primary) 16%, var(--ap-surface)); color: var(--ap-primary); }
.ap-chip[disabled] { opacity: .4; pointer-events: none; }
.ap-chip svg { width: 15px; height: 15px; flex: none; }

/* Keep inline icons from stretching inside flex rows */
.ap-stat__delta svg, .ap-colpill svg, .ap-tabedit > svg, .ap-consent-list svg, .ap-footer__meta svg { flex: none; }
.ap-stat__delta svg { width: 16px; height: 16px; }
.ap-colpill svg { width: 16px; height: 16px; }

/* ---- Utility ---- */
.ap-card { background: var(--ap-surface); border: 1px solid var(--ap-border); border-radius: var(--ap-radius); box-shadow: var(--ap-shadow-sm); }
.ap-muted { color: var(--ap-text-mute); }
.ap-sr { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.ap-row { display: flex; align-items: center; gap: 10px; }
.ap-spread { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.ap-hidden { display: none !important; }

@keyframes ap-fade-up { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes ap-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes ap-pop { 0% { transform: scale(.96); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
@keyframes ap-spin { to { transform: rotate(360deg); } }
.ap-spinner { width: 22px; height: 22px; border-radius: 50%; border: 3px solid var(--ap-bg-soft); border-top-color: var(--ap-primary); animation: ap-spin .8s linear infinite; }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
