/* ============================================================
   planregister.de — Core Design System
   Colors: Earth #1A1F16 / Sage #7C9A6E / Amber #D4A843
   Fonts:  Fraunces (Display) / DM Sans (Body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
  /* ─── Colors ─────────────────────────────── */
  --earth:        #1A1F16;
  --earth-90:     #2A3024;
  --earth-80:     #3A4234;
  --earth-70:     #4D5748;
  --earth-50:     #8A917E;
  --earth-30:     #B8BDB0;
  --earth-20:     #D0D4CA;
  --earth-10:     #E8EAE4;
  --earth-05:     #F4F5F2;
  --earth-02:     #FAFAF9;

  --sage:         #7C9A6E;
  --sage-light:   #A3BF96;
  --sage-pale:    #D4E5CD;
  --sage-wash:    #EDF4EA;
  --sage-dark:    #5A7A4E;

  --amber:        #D4A843;
  --amber-light:  #E8C96E;
  --amber-pale:   #F5E6B8;
  --amber-wash:   #FBF4E0;
  --amber-dark:   #B8912E;

  --success:      #4CAF50;
  --warning:      #FF9800;
  --error:        #E53935;
  --info:         #5B8DEF;

  --white:        #FFFFFF;
  --bg:           #FAFAF9;
  --border:       #E2E4DE;
  --border-light: #EEEFEB;

  /* ─── Typography ─────────────────────────── */
  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'DM Sans', -apple-system, sans-serif;
  --font-mono:    'IBM Plex Mono', 'SF Mono', monospace;

  /* ─── Spacing ────────────────────────────── */
  --space-xs:  4px;
  --space-sm:  8px;
  --space-md:  16px;
  --space-lg:  24px;
  --space-xl:  32px;
  --space-2xl: 48px;
  --space-3xl: 64px;
  --space-4xl: 96px;

  /* ─── Radius ─────────────────────────────── */
  --radius-sm:  6px;
  --radius-md:  10px;
  --radius-lg:  16px;
  --radius-xl:  24px;
  --radius-full: 9999px;

  /* ─── Shadows ────────────────────────────── */
  --shadow-sm:  0 1px 2px rgba(26,31,22,0.06);
  --shadow-md:  0 4px 12px rgba(26,31,22,0.08);
  --shadow-lg:  0 8px 24px rgba(26,31,22,0.10);
  --shadow-xl:  0 16px 48px rgba(26,31,22,0.12);

  /* ─── Transitions ────────────────────────── */
  --ease:       cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:   cubic-bezier(0, 0, 0.2, 1);
  --duration:   200ms;
  --duration-md: 300ms;
  --duration-lg: 500ms;
}

/* ─── Reset ──────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  color: var(--earth);
  background: var(--bg);
  line-height: 1.6;
  min-height: 100vh;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

h1 { font-size: clamp(1.8rem, 4vw, 2.4rem); }
h2 { font-size: clamp(1.4rem, 3vw, 1.8rem); }
h3 { font-size: clamp(1.1rem, 2vw, 1.3rem); }

a { color: var(--sage-dark); text-decoration: none; transition: color var(--duration) var(--ease); }
a:hover { color: var(--sage); }

img { max-width: 100%; display: block; }

/* ─── Utility ────────────────────────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 var(--space-lg); }
.container-sm { max-width: 800px; margin: 0 auto; padding: 0 var(--space-lg); }
.container-xs { max-width: 560px; margin: 0 auto; padding: 0 var(--space-lg); }

.text-sage  { color: var(--sage); }
.text-amber { color: var(--amber); }
.text-earth { color: var(--earth); }
.text-muted { color: var(--earth-50); }
.text-sm    { font-size: 0.875rem; }
.text-xs    { font-size: 0.75rem; }
.text-mono  { font-family: var(--font-mono); }

.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); border: 0;
}

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 500; font-size: 0.9rem;
  padding: 10px 20px; border-radius: var(--radius-md); border: none;
  cursor: pointer; transition: all var(--duration) var(--ease);
  text-decoration: none; line-height: 1.4;
}
.btn:active { transform: scale(0.97); }

.btn-sage {
  background: var(--sage); color: var(--white);
}
.btn-sage:hover { background: var(--sage-dark); color: var(--white); }

.btn-amber {
  background: var(--amber); color: var(--earth);
}
.btn-amber:hover { background: var(--amber-dark); }

.btn-earth {
  background: var(--earth); color: var(--white);
}
.btn-earth:hover { background: var(--earth-90); color: var(--white); }

.btn-outline {
  background: transparent; border: 1.5px solid var(--border);
  color: var(--earth);
}
.btn-outline:hover { border-color: var(--sage); color: var(--sage); background: var(--sage-wash); }

.btn-ghost {
  background: transparent; color: var(--earth-50);
  padding: 8px 12px;
}
.btn-ghost:hover { color: var(--earth); background: var(--earth-05); }

.btn-sm { font-size: 0.8rem; padding: 7px 14px; }
.btn-lg { font-size: 1rem; padding: 14px 28px; }
.btn-block { width: 100%; justify-content: center; }

.btn:disabled, .btn.loading {
  opacity: 0.6; cursor: not-allowed; pointer-events: none;
}

/* ─── Badges ─────────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 0.7rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.05em; padding: 3px 10px;
  border-radius: var(--radius-full);
}
.badge-sage    { background: var(--sage-wash); color: var(--sage-dark); }
.badge-amber   { background: var(--amber-wash); color: var(--amber-dark); }
.badge-success { background: #E8F5E9; color: #2E7D32; }
.badge-warning { background: #FFF3E0; color: #E65100; }
.badge-error   { background: #FFEBEE; color: #C62828; }
.badge-muted   { background: var(--earth-10); color: var(--earth-50); }

.badge-dot {
  width: 6px; height: 6px; border-radius: 50%;
  display: inline-block;
}
.badge-dot-green  { background: var(--success); }
.badge-dot-amber  { background: var(--amber); }
.badge-dot-red    { background: var(--error); }
.badge-dot-muted  { background: var(--earth-30); }

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.section-card {
  background: var(--white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
}

.section-card-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-light);
}

.section-card-title {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 500;
  display: flex; align-items: center; gap: 8px;
}

/* ─── Inputs ─────────────────────────────────────────────────────────────── */
.input-group { margin-bottom: var(--space-md); }
.input-label {
  display: block; font-size: 0.8rem; font-weight: 500;
  color: var(--earth-70); margin-bottom: 6px;
}
.input {
  width: 100%; padding: 10px 14px; font-size: 0.9rem;
  font-family: var(--font-body);
  border: 1.5px solid var(--border); border-radius: var(--radius-md);
  background: var(--white); color: var(--earth);
  transition: border-color var(--duration) var(--ease);
  outline: none;
}
.input:focus { border-color: var(--sage); box-shadow: 0 0 0 3px var(--sage-wash); }
.input::placeholder { color: var(--earth-30); }

select.input {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234D5748' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
  padding-right: 36px;
}

/* ─── Tables ─────────────────────────────────────────────────────────────── */
.data-table {
  width: 100%; border-collapse: collapse;
  font-size: 0.85rem;
}
.data-table th {
  text-align: left; font-weight: 600; font-size: 0.7rem;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--earth-50); padding: 10px 14px;
  border-bottom: 2px solid var(--border);
}
.data-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-light);
  vertical-align: middle;
}
.data-table tr { transition: background var(--duration) var(--ease); }
.data-table tr:hover { background: var(--earth-02); }
.data-table tr.clickable { cursor: pointer; }

/* ─── Skeleton Loader ────────────────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, var(--earth-10) 25%, var(--earth-05) 50%, var(--earth-10) 75%);
  background-size: 200% 100%;
  animation: skeleton-pulse 1.5s ease-in-out infinite;
  border-radius: var(--radius-md);
}
@keyframes skeleton-pulse {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ─── Empty State ────────────────────────────────────────────────────────── */
.empty-state {
  text-align: center; padding: var(--space-3xl) var(--space-lg);
}
.empty-state-icon { font-size: 3rem; margin-bottom: var(--space-md); opacity: 0.5; }
.empty-state h3 { margin-bottom: var(--space-sm); }
.empty-state p { color: var(--earth-50); max-width: 400px; margin: 0 auto; }

/* ─── Pagination ─────────────────────────────────────────────────────────── */
.pagination {
  display: flex; justify-content: center; align-items: center;
  gap: var(--space-sm); margin-top: var(--space-xl);
}
.pagination-btn {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--white); cursor: pointer;
  font-size: 0.8rem; color: var(--earth);
  transition: all var(--duration) var(--ease);
}
.pagination-btn:hover:not(:disabled) { border-color: var(--sage); color: var(--sage); }
.pagination-btn.active { background: var(--sage); color: var(--white); border-color: var(--sage); }
.pagination-btn:disabled { opacity: 0.4; cursor: default; }
.pagination-info { font-size: 0.8rem; color: var(--earth-50); margin: 0 var(--space-sm); }

/* ─── Toasts ─────────────────────────────────────────────────────────────── */
.toast-container {
  position: fixed; top: var(--space-lg); right: var(--space-lg);
  z-index: 10000; display: flex; flex-direction: column; gap: var(--space-sm);
}
.toast {
  padding: 12px 20px; border-radius: var(--radius-md);
  font-size: 0.85rem; font-weight: 500;
  box-shadow: var(--shadow-lg);
  animation: toast-in 0.3s var(--ease-out);
  max-width: 400px;
}
.toast-success { background: var(--success); color: var(--white); }
.toast-error   { background: var(--error); color: var(--white); }
.toast-warning { background: var(--warning); color: var(--white); }
.toast-info    { background: var(--info); color: var(--white); }

@keyframes toast-in {
  from { opacity: 0; transform: translateX(100px); }
  to   { opacity: 1; transform: translateX(0); }
}
