/* Psyn UI docs site — site-only styles layered on top of psyn-ui.css */

.site-nav {
  position: sticky;
  top: 0;
  z-index: var(--psy-z-sticky);
  backdrop-filter: blur(8px);
  background: color-mix(in srgb, var(--psy-color-surface-1) 86%, transparent);
}
.site-wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-weight: var(--psy-weight-bold);
  font-size: var(--psy-text-lg);
  letter-spacing: -0.02em;
}
.site-wordmark .dot { color: var(--psy-color-accent); }

.site-main { min-height: 70vh; }
.site-section { padding-block: var(--psy-space-8); }
.site-section + .site-section { border-top: 1px solid var(--psy-color-border); }

.eyebrow {
  font-family: var(--psy-font-mono);
  font-size: var(--psy-text-sm);
  color: var(--psy-color-accent);
  letter-spacing: 0.04em;
  margin-bottom: var(--psy-space-3);
}

.hero {
  padding-block: clamp(48px, 12vw, 120px);
}
.hero h1 {
  font-size: clamp(36px, 7vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  max-width: 16ch;
}
.hero p.lead {
  margin-top: var(--psy-space-4);
  font-size: var(--psy-text-lg);
  color: var(--psy-color-text-muted);
  max-width: 52ch;
}
.hero-actions { margin-top: var(--psy-space-6); display: flex; gap: var(--psy-space-3); flex-wrap: wrap; }

.feature-num {
  font-family: var(--psy-font-mono);
  font-size: var(--psy-text-sm);
  color: var(--psy-color-text-faint);
}

/* swatches */
.swatch-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--psy-space-3); }
.swatch {
  border: 1px solid var(--psy-color-border);
  border-radius: var(--psy-radius-md);
  overflow: hidden;
  font-size: var(--psy-text-xs);
}
.swatch .chip { height: 64px; }
.swatch .meta { padding: 8px 10px; background: var(--psy-color-surface-1); }
.swatch .meta b { display: block; font-weight: var(--psy-weight-medium); }
.swatch .meta code { background: none; border: none; padding: 0; color: var(--psy-color-text-muted); }

/* type specimen */
.type-row { display: flex; align-items: baseline; gap: var(--psy-space-4); padding-block: var(--psy-space-2); border-bottom: 1px solid var(--psy-color-border); }
.type-row .tag { font-family: var(--psy-font-mono); font-size: var(--psy-text-xs); color: var(--psy-color-text-faint); min-width: 56px; }

/* example + code panel */
.example {
  border: 1px solid var(--psy-color-border);
  border-radius: var(--psy-radius-lg);
  overflow: hidden;
  margin-bottom: var(--psy-space-5);
}
.example-preview { padding: var(--psy-space-5); display: flex; flex-wrap: wrap; gap: var(--psy-space-3); align-items: center; }
.example-code { position: relative; border-top: 1px solid var(--psy-color-border); }
.example-code pre { margin: 0; border: 0; border-radius: 0; background: var(--psy-color-bg); }
.copy-btn {
  position: absolute; top: 8px; right: 8px;
  font-family: var(--psy-font-mono); font-size: var(--psy-text-xs);
  padding: 4px 9px; border-radius: var(--psy-radius-sm);
  background: var(--psy-color-surface-2); border: 1px solid var(--psy-color-border-strong);
  color: var(--psy-color-text-muted);
}
.copy-btn:hover { color: var(--psy-color-text); }

/* icon gallery */
.gallery-toolbar { display: flex; gap: var(--psy-space-3); align-items: center; flex-wrap: wrap; margin-bottom: var(--psy-space-5); }
.icon-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: var(--psy-space-2); }
.icon-cell {
  display: flex; flex-direction: column; align-items: center; gap: var(--psy-space-2);
  padding: var(--psy-space-4) var(--psy-space-2);
  border: 1px solid var(--psy-color-border);
  border-radius: var(--psy-radius-md);
  background: var(--psy-color-surface-1);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s, transform 0.12s;
}
.icon-cell:hover { border-color: var(--psy-color-accent); background: var(--psy-color-surface-2); transform: translateY(-1px); }
.icon-cell svg { width: 26px; height: 26px; color: var(--psy-color-text); }
.icon-cell .nm { font-size: 10px; color: var(--psy-color-text-muted); text-align: center; word-break: break-word; line-height: 1.3; }
.icon-cell.copied { border-color: var(--psy-color-green); }
.gallery-count { font-size: var(--psy-text-sm); color: var(--psy-color-text-muted); margin-left: auto; }

.toast {
  position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--psy-color-surface-3); color: var(--psy-color-text);
  border: 1px solid var(--psy-color-border-strong); border-radius: var(--psy-radius-md);
  padding: 10px 16px; font-size: var(--psy-text-sm); box-shadow: var(--psy-shadow-lg);
  opacity: 0; pointer-events: none; transition: opacity 0.2s, transform 0.2s; z-index: var(--psy-z-tooltip);
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

.site-footer {
  border-top: 1px solid var(--psy-color-border);
  padding-block: var(--psy-space-6);
  color: var(--psy-color-text-muted);
  font-size: var(--psy-text-sm);
}
.site-footer a { color: var(--psy-color-text-muted); }
.site-footer a:hover { color: var(--psy-color-text); }
