:root {
  --bg: #faf9f7;
  --text: #1a1a1a;
  --accent: #2d5a4a;
  --accent-hover: #3d7a64;
  --muted: #6b7280;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, -apple-system, "Segoe UI", sans-serif; color: var(--text); background: var(--bg); }

.wrap { max-width: 42rem; margin: 0 auto; padding: 1rem 1.5rem; min-height: 100vh; }
.header { border-bottom: 1px solid #e5e7eb; background: #fff; margin: 0 -1.5rem 1.5rem; padding: 1.5rem 1.5rem; }
.header h1 { margin: 0; font-size: 1.5rem; font-weight: 600; }
.header .sub { margin: 0.25rem 0 0; font-size: 0.9375rem; color: var(--muted); }

.main { padding-bottom: 2rem; }

.section-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.section-card h2 { margin: 0 0 1rem; font-size: 1.125rem; font-weight: 600; }

.input-field {
  width: 100%;
  padding: 0.625rem 1rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1rem;
  background: #fff;
}
.input-field:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}
.input-field::placeholder { color: #9ca3af; }

.grid { display: grid; gap: 0.75rem; }
.grid-2 { grid-template-columns: 1fr 1fr; }
.grid .full { grid-column: 1 / -1; }
@media (max-width: 640px) { .grid-2 { grid-template-columns: 1fr; } }

.photo-upload-row { display: flex; align-items: flex-start; gap: 1rem; flex-wrap: wrap; }
.input-photo { font-size: 0.875rem; }
.foto-preview { flex-shrink: 0; }
.foto-preview-img { width: 90px; height: 120px; object-fit: cover; border-radius: 4px; border: 1px solid #e5e7eb; }

.block { margin-bottom: 1rem; padding: 1rem; background: #f9fafb; border-radius: 0.5rem; border: 1px solid #f3f4f6; }
.block .grid { margin-bottom: 0.5rem; }
.link-remove { background: none; border: none; color: #dc2626; cursor: pointer; font-size: 0.875rem; padding: 0.25rem 0; }
.link-remove:hover { text-decoration: underline; }

.flex { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.flex.head { margin-bottom: 1rem; }
.btn-secondary { padding: 0.5rem 1rem; border: 1px solid #d1d5db; border-radius: 0.5rem; background: #fff; font-weight: 500; color: #374151; cursor: pointer; }
.btn-secondary:hover { background: #f9fafb; }
.btn-sm { font-size: 0.875rem; }

.sprachen-list .row { display: flex; gap: 0.5rem; align-items: center; margin-bottom: 0.5rem; }
.sprachen-list .flex1 { flex: 1; }
.sprachen-list .w-niveau { width: 8rem; }
.label { display: block; font-size: 0.875rem; font-weight: 500; color: #374151; margin-top: 1rem; margin-bottom: 0.25rem; }

.btn-primary {
  padding: 0.625rem 1.25rem;
  border-radius: 0.5rem;
  background: var(--accent);
  color: #fff;
  font-weight: 500;
  border: none;
  cursor: pointer;
  font-size: 1rem;
}
.btn-primary:hover { background: var(--accent-hover); }
.btn-primary:disabled { opacity: 0.7; cursor: not-allowed; }

.muted { font-size: 0.875rem; color: var(--muted); margin-bottom: 1rem; }
.message { font-size: 0.875rem; margin-bottom: 1rem; }
.message.ok { color: #15803d; }
.message.error { color: #dc2626; }
