/* === base: typography, forms, links === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--ducky-font-body);
  margin: 0 auto;
  padding: 0 var(--ducky-space-lg);
  line-height: 1.5;
  background: var(--ducky-color-bg);
  color: var(--ducky-color-text);
  -webkit-font-smoothing: antialiased;
}

body.layout-public,
body.layout-admin {
  margin: 0;
  padding: 0;
  max-width: none;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--ducky-font-heading);
  color: var(--ducky-color-textStrong);
  font-weight: 600;
  margin-bottom: 0.5em;
}

h1 { font-size: 1.35rem; margin: 0 0 var(--ducky-space-lg); }
h2 { font-size: 1.1rem; margin: 0 0 var(--ducky-space-sm); }

p { margin-bottom: 1em; }

label { display: block; margin: var(--ducky-space-md) 0 var(--ducky-space-xs); }

input, textarea, select {
  width: 100%;
  padding: var(--ducky-space-sm);
  box-sizing: border-box;
  border: 1px solid var(--ducky-color-border);
  border-radius: var(--ducky-radius-md);
  background: var(--ducky-color-surface);
  color: var(--ducky-color-text);
}

/* Button variants live in 08-design-system.css (.btn, .ducky-btn) */
button[type="submit"]:not(.ducky-btn--ghost):not(.btn-ghost):not(.btn-secondary) {
  background: var(--ducky-color-accent);
  color: var(--ducky-color-accentOn);
  border-color: var(--ducky-color-accent);
}

code {
  background: var(--ducky-color-codeBg);
  padding: 0.1em 0.35em;
  border-radius: var(--ducky-radius-sm);
  font-size: 0.9em;
}

a { color: var(--ducky-color-accent); }

.muted, .hint { color: var(--ducky-color-textMuted); font-size: 0.95rem; }
.hint { font-size: 0.9rem; }

section { margin: var(--ducky-space-lg) 0; }
ul { padding-left: 1.25rem; margin: var(--ducky-space-xs) 0; }

.bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ducky-space-lg);
  flex-wrap: wrap;
}

.public-content nav { margin-top: var(--ducky-space-lg); font-size: 0.9rem; }

.layout-not-found {
  max-width: 28rem;
  margin: 4rem auto;
  text-align: center;
  padding: 2rem var(--ducky-space-lg);
}

.layout-not-found .not-found-code {
  font-size: 3rem;
  font-weight: 700;
  margin: 0 0 var(--ducky-space-sm);
  color: var(--ducky-color-textMuted);
  line-height: 1;
}

.layout-not-found h1 { font-size: 1.35rem; margin: 0 0 var(--ducky-space-md); }

#app-content[aria-busy="true"] {
  opacity: 0.55;
  pointer-events: none;
  transition: opacity 0.15s ease;
}
