/**
 * serve.lazare.ai — component layer + page styles.
 * Depends on design-tokens.css (imported first). Every value reads var(--bru-*).
 */

/* ── Base ─────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  background: var(--bru-canvas);
  color: var(--bru-text-primary);
  font-family: var(--bru-font-sans);
  font-size: var(--bru-text-base);
  line-height: var(--bru-leading-relaxed);
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Fixed structural grid background — the academic-brutalist signature. */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(var(--bru-ink) 1px, transparent 1px),
    linear-gradient(90deg, var(--bru-ink) 1px, transparent 1px);
  background-size: var(--bru-grid-size) var(--bru-grid-size);
  opacity: 0.04;
  pointer-events: none;
  z-index: -1;
}

a { color: var(--bru-action); text-underline-offset: 2px; }

h1, .bru-h1 { font-size: var(--bru-text-4xl); font-weight: var(--bru-font-bold);
  line-height: var(--bru-leading-tight); letter-spacing: var(--bru-tracking-tight);
  color: var(--bru-ink); margin: 0 0 var(--bru-space-4); }
h2, .bru-h2 { font-size: var(--bru-text-2xl); font-weight: var(--bru-font-semibold);
  line-height: var(--bru-leading-snug); color: var(--bru-ink); margin: 0 0 var(--bru-space-3); }
h3, .bru-h3 { font-size: var(--bru-text-xl); font-weight: var(--bru-font-semibold);
  color: var(--bru-ink); margin: 0 0 var(--bru-space-2); }

code { font-family: var(--bru-font-mono); font-size: 0.95em; }

.bru-prose { max-width: var(--bru-prose-max); }

.bru-label {
  font-size: var(--bru-text-xs); font-weight: var(--bru-font-semibold);
  text-transform: uppercase; letter-spacing: var(--bru-tracking-label);
  color: var(--bru-text-muted);
}

.bru-rule { border: 0; border-top: var(--bru-border-width) solid var(--bru-border); margin: var(--bru-space-8) 0; }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.bru-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--bru-space-2);
  font-family: var(--bru-font-sans); font-size: var(--bru-text-sm); font-weight: var(--bru-font-semibold);
  padding: var(--bru-space-2) var(--bru-space-4);
  border: var(--bru-border-width-2) solid var(--bru-ink);
  border-radius: var(--bru-radius-md);
  background: var(--bru-canvas); color: var(--bru-ink);
  box-shadow: var(--bru-shadow-brutal-sm);
  cursor: pointer; text-decoration: none;
  transition: transform var(--bru-duration-fast) var(--bru-ease-default),
              box-shadow var(--bru-duration-fast) var(--bru-ease-default),
              background-color var(--bru-duration-default) var(--bru-ease-default);
}
.bru-btn:active { transform: translate(var(--bru-press-translation), var(--bru-press-translation)); box-shadow: none; }
.bru-btn:focus-visible { outline: var(--bru-border-width-2) solid var(--bru-action); outline-offset: 2px; }
.bru-btn:disabled { opacity: 0.5; cursor: not-allowed; box-shadow: none; }

@media (hover: hover) and (pointer: fine) {
  .bru-btn:hover { transform: translate(0, var(--bru-hover-lift)); box-shadow: var(--bru-shadow-brutal); }
}

.bru-btn--action { background: var(--bru-action); color: var(--bru-button-primary-text); border-color: var(--bru-ink); }
.bru-btn--cta { background: var(--bru-action); color: var(--bru-button-primary-text); }
.bru-btn--ghost { background: transparent; box-shadow: var(--bru-shadow-brutal-xs); }
@media (hover: hover) and (pointer: fine) {
  .bru-btn--ghost:hover { background: var(--bru-warning-10); }
}
.bru-btn--critical { background: var(--bru-critical); color: var(--bru-button-primary-text); border-color: var(--bru-ink); }

/* Dense controls (toolbars / frame bar) — opt out of lift/press. */
.bru-btn--dense {
  padding: 0 var(--bru-space-3); height: 30px; box-shadow: none; border-width: var(--bru-border-width);
}
.bru-btn--dense:hover { transform: none; box-shadow: none; }
@media (hover: hover) and (pointer: fine) {
  .bru-btn--dense:hover { background: var(--bru-ink-05); }
  .bru-btn--dense.bru-btn--action:hover { background: var(--bru-action); }
}

/* ── Cards / notes ────────────────────────────────────────────────────── */
.bru-card {
  border: var(--bru-border-width) solid var(--bru-border);
  background: var(--bru-panel);
  box-shadow: var(--bru-shadow-brutal-sm);
  padding: var(--bru-space-4);
}
.bru-note--error   { border: var(--bru-border-width) solid var(--bru-error);   color: var(--bru-error);   background: var(--bru-panel); padding: var(--bru-space-4); box-shadow: var(--bru-shadow-brutal-sm); }
.bru-note--success { border: var(--bru-border-width) solid var(--bru-success); color: var(--bru-success); background: var(--bru-panel); padding: var(--bru-space-4); box-shadow: var(--bru-shadow-brutal-sm); }

/* ── Forms ────────────────────────────────────────────────────────────── */
.bru-input {
  width: 100%;
  border: var(--bru-border-width) solid var(--bru-ink);
  background: #fff;
  padding: var(--bru-space-2) var(--bru-space-3);
  font-size: var(--bru-text-sm); color: var(--bru-ink);
  box-shadow: var(--bru-shadow-brutal-xs);
  border-radius: var(--bru-radius-sm);
  font-family: var(--bru-font-sans);
}
.bru-input:focus-visible { outline: var(--bru-border-width-2) solid var(--bru-action); outline-offset: 1px; }
.bru-field { display: flex; flex-direction: column; gap: var(--bru-space-1); }
.bru-field > label {
  font-size: var(--bru-text-xs); font-weight: var(--bru-font-semibold);
  text-transform: uppercase; letter-spacing: var(--bru-tracking-wide); color: var(--bru-ink-70);
}

/* ── Status / badges ──────────────────────────────────────────────────── */
.bru-status { font-size: var(--bru-text-sm); font-weight: var(--bru-font-medium); color: var(--bru-ink-70); }
.bru-badge {
  display: inline-block; padding: 0 var(--bru-space-2);
  font-size: var(--bru-text-xs); font-weight: var(--bru-font-semibold);
  text-transform: uppercase; letter-spacing: var(--bru-tracking-wide);
  border: var(--bru-border-width) solid currentColor; border-radius: var(--bru-radius-sm);
}
.bru-badge--active { color: var(--bru-action); }
.bru-badge--review { color: var(--bru-warning); }
.bru-badge--draft  { color: var(--bru-ink-70); }

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

/* ═══════════════════════════ Page chrome ═══════════════════════════════ */
.site-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--bru-space-4) var(--bru-space-6);
  border-bottom: var(--bru-border-width-2) solid var(--bru-ink);
  background: var(--bru-canvas);
}
.brand { font-family: var(--bru-font-mono); font-weight: var(--bru-font-bold);
  font-size: var(--bru-text-lg); color: var(--bru-ink); text-decoration: none; letter-spacing: var(--bru-tracking-tight); }
.brand-dim { color: var(--bru-ink-40); }

.site-main { flex: 1 0 auto; width: 100%; max-width: 64rem; margin: 0 auto; padding: var(--bru-space-8) var(--bru-space-6); }

.site-footer {
  flex-shrink: 0;
  display: flex; flex-wrap: wrap; gap: var(--bru-space-3) var(--bru-space-6); align-items: baseline;
  padding: var(--bru-space-6);
  border-top: var(--bru-border-width-2) solid var(--bru-ink);
  font-size: var(--bru-text-sm);
}
.footer-brand { font-family: var(--bru-font-mono); font-weight: var(--bru-font-semibold); }
.footer-dim { color: var(--bru-ink-60); }

/* IHP flash messages (renderFlashMessages → .alert / .alert-success / .alert-danger) */
.alert {
  border: var(--bru-border-width) solid var(--bru-ink);
  background: var(--bru-panel);
  box-shadow: var(--bru-shadow-brutal-sm);
  padding: var(--bru-space-3) var(--bru-space-4);
  margin-bottom: var(--bru-space-6);
  font-weight: var(--bru-font-medium);
}
.alert-success { border-color: var(--bru-success); color: var(--bru-success); }
.alert-danger, .alert-error { border-color: var(--bru-error); color: var(--bru-error); }

/* ═══════════════════════════ Landing ══════════════════════════════════ */
.hero { margin-bottom: var(--bru-space-10); }
.hero-eyebrow { margin: 0 0 var(--bru-space-3); }
.hero-title { font-size: var(--bru-text-5xl); font-weight: var(--bru-font-extrabold);
  letter-spacing: var(--bru-tracking-tightest); line-height: var(--bru-leading-tight); margin-bottom: var(--bru-space-4); }
.hero-mark { color: var(--bru-accent); }
.hero-sub { font-family: var(--bru-font-serif); font-size: var(--bru-text-xl); color: var(--bru-ink-70); margin: 0; }

@media (min-width: 48rem) { .hero-title { font-size: var(--bru-text-6xl); } }

.paste { margin-bottom: var(--bru-space-12); }
.paste-field { gap: var(--bru-space-2); }
.dropzone { position: relative; }
.dropzone.is-dragover .paste-area { outline: var(--bru-border-width-2) dashed var(--bru-action); background: var(--bru-action-05); }
.paste-area {
  min-height: 16rem; resize: vertical; font-family: var(--bru-font-mono);
  font-size: var(--bru-text-sm); line-height: var(--bru-leading-normal);
  box-shadow: var(--bru-shadow-brutal-sm); border-width: var(--bru-border-width-2);
  border-radius: var(--bru-radius-md);
}
.dropzone-hint { margin: var(--bru-space-2) 0 0; font-size: var(--bru-text-sm); color: var(--bru-ink-60); }
.paste-meta { display: flex; justify-content: space-between; margin-top: var(--bru-space-2); }
.paste-actions { display: flex; flex-wrap: wrap; align-items: center; gap: var(--bru-space-4); margin-top: var(--bru-space-5); }
.paste-submit { font-size: var(--bru-text-base); padding: var(--bru-space-3) var(--bru-space-6); }
.paste-note { color: var(--bru-ink-60); }

.how { max-width: var(--bru-prose-max); }
.how-steps { list-style: none; margin: var(--bru-space-4) 0; padding: 0; display: grid; gap: var(--bru-space-3); }
.how-steps strong { color: var(--bru-ink); }
.how-foot { margin-top: var(--bru-space-4); }

/* ═══════════════════════════ Framed share view ════════════════════════ */
.frame-body { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }
.frame { display: flex; flex-direction: column; height: 100vh; }
.frame-bar {
  display: flex; align-items: center; gap: var(--bru-space-2);
  padding: var(--bru-space-2) var(--bru-space-3);
  border-bottom: var(--bru-border-width-2) solid var(--bru-ink);
  background: var(--bru-canvas);
  flex-wrap: wrap;
}
.frame-brand { font-family: var(--bru-font-mono); font-weight: var(--bru-font-bold); color: var(--bru-ink); text-decoration: none; }
.frame-id { font-family: var(--bru-font-mono); font-size: var(--bru-text-sm); color: var(--bru-ink-60); }
.frame-spacer { flex: 1 1 auto; }
.frame-report { color: var(--bru-accent); }
.frame-embed { flex: 1 1 auto; width: 100%; border: 0; background: #fff; }

/* ═══════════════════════════ Manage ═══════════════════════════════════ */
.manage-head { margin-bottom: var(--bru-space-8); }
.manage-status { display: flex; align-items: center; gap: var(--bru-space-2); }
.manage-block { margin-bottom: var(--bru-space-8); }
.copyrow { display: grid; grid-template-columns: 1fr auto; gap: var(--bru-space-2); align-items: center; }
.copyrow .bru-input { font-family: var(--bru-font-mono); }
.manage-preview { width: 100%; height: 24rem; border: var(--bru-border-width-2) solid var(--bru-ink);
  box-shadow: var(--bru-shadow-brutal-sm); background: #fff; }
.edit-form { display: flex; flex-direction: column; gap: var(--bru-space-3); }
.keep-btn { font-size: var(--bru-text-base); padding: var(--bru-space-3) var(--bru-space-6); }
.manage-danger h2 { color: var(--bru-critical); }

/* ═══════════════════════════ Report ═══════════════════════════════════ */
.report-card { margin: var(--bru-space-6) 0; }
.report-card p { margin: var(--bru-space-1) 0; }
.report-hash { word-break: break-all; }
