:root {
  color-scheme: light;
  --md-background: #f8fafc;
  --md-surface: #ffffff;
  --md-text: #0f172a;
  --md-muted: #475569;
  --md-accent: #2563eb;
  --md-on-accent: #ffffff;
  --md-border: rgba(15, 23, 42, 0.12);
  --md-accent-soft: rgba(37, 99, 235, 0.12);
  --md-status-bg: #dcfce7;
  --md-status-text: #166534;
  --md-status-error-bg: #fee2e2;
  --md-status-error-text: #7f1d1d;
  --radius: 20px;
  --shadow: 0 20px 50px rgba(15, 23, 42, 0.15);
  font-family: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  justify-content: center;
  background: var(--md-background);
  color: var(--md-text);
  padding: clamp(16px, 4vw, 48px);
}

.viewer-shell {
  width: min(960px, 100%);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.viewer-status {
  border-radius: 16px;
  border: 1px solid transparent;
  padding: 14px 18px;
  font-size: 0.95rem;
  background: var(--md-status-bg);
  color: var(--md-status-text);
  box-shadow: var(--shadow);
}

.viewer-status.viewer-status--error {
  background: var(--md-status-error-bg);
  color: var(--md-status-error-text);
  border-color: rgba(239, 68, 68, 0.25);
}

.viewer-banner {
  padding: 16px 20px;
  border-radius: 18px;
  background: var(--md-accent-soft);
  color: var(--md-text);
  font-size: 1rem;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: baseline;
  box-shadow: var(--shadow);
  border: 1px solid var(--md-border);
}

.viewer-banner a {
  color: var(--md-accent);
  font-weight: 600;
}

.viewer-canvas {
  position: relative;
  border-radius: var(--radius);
  border: 1px solid var(--md-border);
  background: var(--md-surface);
  box-shadow: var(--shadow);
  padding: clamp(24px, 4vw, 40px);
  min-height: 360px;
}

.viewer-footer {
  text-align: center;
  font-size: 0.85rem;
  color: var(--md-muted);
}

.viewer-footer p {
  margin: 0;
}
