/* ============================================================
   UI.css — component styles used across preview + ui_kit
   ============================================================ */

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  letter-spacing: 0;
  padding: 10px 16px; border-radius: var(--r-2);
  border: 1px solid transparent; cursor: pointer; user-select: none;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
  text-decoration: none;
}
.btn:active:not(:disabled){ transform: translateY(1px); }
.btn:disabled{ opacity: 0.45; cursor: not-allowed; }

.btn-primary { background: var(--brand); color: var(--brand-ink); }
.btn-primary:hover{ background: var(--brand-hi); }
.btn-primary:active:not(:disabled){ background: var(--brand-lo); }

.btn-secondary { background: var(--bg-2); color: var(--fg); border-color: var(--line-hi); }
.btn-secondary:hover{ background: var(--bg-3); border-color: var(--fg-3); }

.btn-ghost { background: transparent; color: var(--fg); border-color: transparent; padding-inline: 8px; }
.btn-ghost:hover{ color: var(--brand-hi); background: var(--brand-tint); }

.btn-sm{ font-size: 13px; padding: 6px 12px; }
.btn-icon{ padding: 8px; background: var(--bg-2); color: var(--fg-1); border-color: var(--line); }
.btn-icon:hover{ color: var(--fg); border-color: var(--line-hi); }

/* Card */
.card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  padding: 20px;
  transition: border-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.card:hover { border-color: var(--line-hi); }
.card.hover-lift:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); border-color: var(--line-hi); }
.card.accent-top { border-top: 2px solid var(--brand); }

/* Input */
.field {
  width: 100%;
  background: var(--bg-1);
  border: 1px solid var(--line);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: 14px;
  padding: 10px 14px;
  border-radius: var(--r-2);
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.field::placeholder { color: var(--fg-3); }
.field:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-ring); }
.field-mono { font-family: var(--font-mono); font-size: 13px; }

.label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: block;
  margin-bottom: 6px;
}

/* Badges / status */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11px;
  padding: 3px 8px; border-radius: var(--r-1);
  background: var(--bg-2); color: var(--fg-1);
  border: 1px solid var(--line);
}
.badge.ok    { color: var(--ok);    border-color: rgba(46,204,113,0.3);  background: rgba(46,204,113,0.08); }
.badge.warn  { color: var(--warn);  border-color: rgba(245,166,35,0.3);  background: rgba(245,166,35,0.08); }
.badge.err   { color: var(--err);   border-color: rgba(255,93,93,0.3);   background: rgba(255,93,93,0.08); }
.badge.brand { color: var(--brand-hi); border-color: rgba(0,120,255,0.35); background: var(--brand-tint); }

.dot { width:8px; height:8px; border-radius:50%; background:currentColor; }

/* Code block window */
.code-window {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  overflow: hidden;
  font-family: var(--font-mono);
  font-size: 13px;
}
.code-window .cw-bar {
  display:flex; align-items:center; gap:8px;
  padding: 10px 14px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  color: var(--fg-2);
}
.code-window .cw-bar .dots { display:flex; gap:6px; }
.code-window .cw-bar .dots i { width:10px; height:10px; border-radius:50%; background:var(--line-hi); }
.code-window .cw-bar .file { font-size: 12px; margin-left: 8px; }
.code-window pre { margin: 0; padding: 16px 18px; color: var(--fg); line-height: 1.7; overflow:auto; }

/* Syntax spans */
.sy-k{ color: var(--syn-keyword); } .sy-s{ color: var(--syn-string); } .sy-n{ color: var(--syn-number); }
.sy-f{ color: var(--syn-func); } .sy-c{ color: var(--syn-comment); } .sy-t{ color: var(--syn-tag); }

/* Link with arrow */
.link-arrow {
  color: var(--brand);
  font-family: var(--font-sans); font-weight: 500;
  display: inline-flex; align-items: center; gap: 6px;
  transition: gap var(--dur-fast) var(--ease-out);
}
.link-arrow:hover { gap: 10px; color: var(--brand-hi); }

/* Section markers */
.section-marker {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--fg-2); text-transform: uppercase; letter-spacing: 0.1em;
}
.section-marker::before {
  content:"";
  width: 8px; height: 8px;
  background: var(--brand);
  display:inline-block;
}
.section-marker .num { color: var(--fg-3); }

/* Divider */
.hr { height:1px; background: var(--line); border:0; margin: 24px 0; }
