/* Shared layout - theme files set CSS variables on .public-page.theme-* */

.public-page {
  margin: 0;
  min-height: 100dvh;
  font-family: var(--font-body, system-ui, sans-serif);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
}

.public-shell {
  max-width: 28rem;
  margin: 0 auto;
  padding: clamp(1.25rem, 4vw, 2.5rem) clamp(1rem, 4vw, 1.5rem);
  padding-bottom: max(2rem, env(safe-area-inset-bottom));
  padding-top: max(1.5rem, env(safe-area-inset-top));
}

.public-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 5vw, 2.25rem);
}

.public-title {
  margin: 0 0 0.5rem;
  font-family: var(--font-heading, var(--font-display, inherit));
  font-size: clamp(1.5rem, 5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--heading-color, var(--text));
}

.public-desc {
  margin: 0;
  font-size: clamp(0.95rem, 2.8vw, 1.05rem);
  line-height: 1.5;
  font-family: var(--font-description, var(--font-body, inherit));
  color: var(--description-color, var(--muted));
  max-width: 36ch;
  margin-inline: auto;
}

.public-links {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.public-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius, 0.75rem);
  font-size: 1rem;
  font-weight: 600;
  font-family: var(--font-links, var(--font-body, inherit));
  text-decoration: none;
  color: var(--link-text);
  background: var(--link-bg);
  border: 1px solid var(--link-border);
  box-shadow: var(--link-shadow);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.public-link:hover {
  transform: translateY(-2px);
  box-shadow: var(--link-shadow-hover);
  background: var(--link-bg-hover);
}

.public-link:active {
  transform: translateY(0);
}

.public-link:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 3px;
}

.public-admin-footer {
  position: fixed;
  z-index: 50;
  bottom: max(0.65rem, env(safe-area-inset-bottom));
  right: max(0.65rem, env(safe-area-inset-right));
  padding: 0.35rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-decoration: none;
  color: var(--muted);
  opacity: 0.75;
  border-radius: 0.35rem;
  transition: opacity 0.15s ease, color 0.15s ease, background 0.15s ease;
}

.public-admin-footer:hover {
  opacity: 1;
  color: var(--text);
  background: color-mix(in srgb, var(--text) 8%, transparent);
}

.public-admin-footer:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
  opacity: 1;
}
