/* ═══════════════════════════════════════════════════════════
   WAVBASE BASE CSS
   Reset, Layout-Utilities, Responsive Breakpoints.
   Importiert zusammen mit wavbase-tokens.css in jeder Seite.
   ═══════════════════════════════════════════════════════════ */

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

html {
  font-family: var(--k2-font-sans);
  font-size: 16px;
  line-height: var(--k2-leading-normal);
  color: hsl(var(--foreground));
  background: hsl(var(--background));
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  min-height: 100vh;
  overflow-x: hidden;
}

img, svg, video, canvas {
  display: block;
  max-width: 100%;
}

a {
  color: hsl(var(--gold));
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  color: inherit;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

/* ─── Typography Utilities ─── */
.k2-heading-1 { font-size: var(--k2-text-3xl); font-weight: var(--k2-weight-bold); letter-spacing: var(--k2-tracking-tight); line-height: var(--k2-leading-tight); }
.k2-heading-2 { font-size: var(--k2-text-2xl); font-weight: var(--k2-weight-semibold); letter-spacing: var(--k2-tracking-tight); line-height: var(--k2-leading-tight); }
.k2-heading-3 { font-size: var(--k2-text-xl); font-weight: var(--k2-weight-semibold); line-height: var(--k2-leading-snug); }
.k2-heading-4 { font-size: var(--k2-text-lg); font-weight: var(--k2-weight-medium); line-height: var(--k2-leading-snug); }
.k2-body      { font-size: var(--k2-text-base); line-height: var(--k2-leading-normal); }
.k2-small     { font-size: var(--k2-text-sm); line-height: var(--k2-leading-normal); }
.k2-caption   { font-size: var(--k2-text-xs); color: hsl(var(--muted-foreground)); }
.k2-mono      { font-family: var(--k2-font-mono); font-size: var(--k2-text-sm); }

/* ─── Layout: Container ─── */
.k2-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--k2-space-6);
}

.k2-container--narrow {
  max-width: 720px;
}

.k2-container--wide {
  max-width: 1440px;
}

/* ─── Page-Bändigung (alle Portal-Tabs) ─── */
/* Verhindert dass Inhalt auf Wide-Screens ausläuft. Padding skaliert flüssig. */
.page {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--content-pad);
  box-sizing: border-box;
}

/* ─── Layout: Portal Shell (Sidebar + Topbar + Content) ─── */
.k2-shell {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  grid-template-rows: var(--topbar-height) 1fr;
  min-height: 100vh;
}

.k2-topbar {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--k2-space-6);
  background: var(--sidebar-bg);
  border-bottom: 1px solid var(--sidebar-border);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  z-index: var(--k2-z-topbar);
}

.k2-sidebar {
  grid-column: 1;
  grid-row: 1 / -1;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--sidebar-border);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  padding: var(--k2-space-4);
  overflow-y: auto;
  z-index: var(--k2-z-sidebar);
  display: flex;
  flex-direction: column;
}

.k2-sidebar-logo {
  padding: var(--k2-space-4) var(--k2-space-2);
  margin-bottom: var(--k2-space-4);
  font-size: var(--k2-text-xl);
  font-weight: var(--k2-weight-bold);
  color: hsl(var(--gold));
  letter-spacing: var(--k2-tracking-tight);
}

.k2-sidebar-nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--k2-space-0-5);
}

.k2-sidebar-item {
  display: flex;
  align-items: center;
  gap: var(--k2-space-3);
  padding: var(--sb-item-padding);
  border-radius: var(--sb-item-radius);
  font-size: var(--sb-item-font);
  color: var(--sidebar-text);
  transition: background var(--k2-duration-fast) var(--k2-ease-out),
              color var(--k2-duration-fast) var(--k2-ease-out);
  width: 100%;
  text-align: left;
}

.k2-sidebar-item:hover {
  background: var(--sidebar-hover);
}

.k2-sidebar-item.active {
  color: var(--sidebar-text-active);
  background: var(--sidebar-active-bg);
}

.k2-sidebar-icon {
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}

.k2-sidebar-badge {
  margin-left: auto;
  font-size: var(--k2-text-2xs);
  font-weight: var(--k2-weight-semibold);
  background: hsl(var(--gold) / 0.15);
  color: hsl(var(--gold));
  padding: 1px 6px;
  border-radius: var(--k2-radius-full);
}

.k2-content {
  grid-column: 2;
  grid-row: 2;
  padding: var(--k2-space-6);
  overflow-y: auto;
}

/* ─── Flexbox Utilities ─── */
.k2-flex         { display: flex; }
.k2-flex-col     { display: flex; flex-direction: column; }
.k2-flex-center  { display: flex; align-items: center; justify-content: center; }
.k2-flex-between { display: flex; align-items: center; justify-content: space-between; }
.k2-flex-wrap    { flex-wrap: wrap; }
.k2-gap-1  { gap: var(--k2-space-1); }
.k2-gap-2  { gap: var(--k2-space-2); }
.k2-gap-3  { gap: var(--k2-space-3); }
.k2-gap-4  { gap: var(--k2-space-4); }
.k2-gap-6  { gap: var(--k2-space-6); }
.k2-gap-8  { gap: var(--k2-space-8); }

/* ─── Grid Utilities ─── */
.k2-grid      { display: grid; gap: var(--k2-space-4); }
.k2-grid-2    { grid-template-columns: repeat(2, 1fr); }
.k2-grid-3    { grid-template-columns: repeat(3, 1fr); }
.k2-grid-4    { grid-template-columns: repeat(4, 1fr); }
.k2-grid-auto { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

/* ─── Spacing Utilities ─── */
.k2-mt-2 { margin-top: var(--k2-space-2); }
.k2-mt-4 { margin-top: var(--k2-space-4); }
.k2-mt-6 { margin-top: var(--k2-space-6); }
.k2-mt-8 { margin-top: var(--k2-space-8); }
.k2-mb-2 { margin-bottom: var(--k2-space-2); }
.k2-mb-4 { margin-bottom: var(--k2-space-4); }
.k2-mb-6 { margin-bottom: var(--k2-space-6); }

/* ─── Buttons ─── */
.k2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--k2-space-2);
  height: var(--btn-height);
  padding: 0 var(--k2-space-4);
  border-radius: var(--btn-radius);
  font-size: var(--btn-font);
  font-weight: var(--btn-weight);
  transition: background var(--k2-duration-normal) var(--k2-ease-default),
              box-shadow var(--k2-duration-normal) var(--k2-ease-default),
              opacity var(--k2-duration-normal) var(--k2-ease-default);
  white-space: nowrap;
}

.k2-btn--primary {
  background: hsl(var(--gold));
  color: hsl(var(--gold-foreground));
  box-shadow: var(--k2-shadow-accent);
}
.k2-btn--primary:hover {
  background: var(--btn-gold-hover);
  box-shadow: var(--k2-shadow-accent-hover);
}

.k2-btn--secondary {
  background: hsl(var(--secondary));
  color: hsl(var(--secondary-foreground));
  border: 1px solid hsl(var(--border));
}
.k2-btn--secondary:hover {
  background: hsl(var(--muted));
}

.k2-btn--ghost {
  background: transparent;
  color: hsl(var(--foreground));
}
.k2-btn--ghost:hover {
  background: hsl(var(--muted) / 0.5);
}

.k2-btn--danger {
  background: hsl(var(--destructive));
  color: hsl(var(--destructive-foreground));
}
.k2-btn--danger:hover {
  opacity: 0.9;
}

.k2-btn--sm {
  height: var(--btn-height-sm);
  font-size: var(--btn-font-sm);
  padding: 0 var(--k2-space-3);
}

.k2-btn--lg {
  height: var(--btn-height-lg);
  padding: 0 var(--k2-space-6);
}

.k2-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* ─── Inputs ─── */
.k2-input {
  height: var(--input-height);
  width: 100%;
  padding: 0 var(--k2-space-3);
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  font-size: var(--input-font);
  color: hsl(var(--foreground));
  transition: border-color var(--k2-duration-normal) var(--k2-ease-default),
              box-shadow var(--k2-duration-normal) var(--k2-ease-default);
}

.k2-input:focus {
  outline: none;
  border-color: hsl(var(--gold) / 0.5);
  box-shadow: 0 0 0 2px hsl(var(--gold) / 0.1), 0 0 12px hsl(var(--gold) / 0.08);
}

.k2-input::placeholder {
  color: hsl(var(--muted-foreground));
}

.k2-textarea {
  width: 100%;
  min-height: 80px;
  padding: var(--k2-space-3);
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  font-size: var(--input-font);
  color: hsl(var(--foreground));
  resize: vertical;
}

.k2-textarea:focus {
  outline: none;
  border-color: hsl(var(--gold) / 0.5);
  box-shadow: 0 0 0 2px hsl(var(--gold) / 0.1);
}

.k2-label {
  display: block;
  font-size: var(--k2-text-sm);
  font-weight: var(--k2-weight-medium);
  color: hsl(var(--foreground));
  margin-bottom: var(--k2-space-1);
}

.k2-field-error {
  font-size: var(--k2-text-xs);
  color: hsl(var(--destructive));
  margin-top: var(--k2-space-1);
}

/* ─── Badges ─── */
.k2-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--badge-padding);
  border-radius: var(--badge-radius);
  font-size: var(--badge-font);
  font-weight: var(--badge-weight);
  background: hsl(var(--muted));
  color: hsl(var(--muted-foreground));
}
.k2-badge--gold    { background: hsl(var(--gold) / 0.15); color: hsl(var(--gold)); }
.k2-badge--success { background: hsl(var(--success) / 0.15); color: hsl(var(--success)); }
.k2-badge--error   { background: hsl(var(--destructive) / 0.15); color: hsl(var(--destructive)); }
.k2-badge--warning { background: hsl(var(--warning) / 0.15); color: hsl(var(--warning)); }
.k2-badge--info    { background: hsl(var(--info) / 0.15); color: hsl(var(--info)); }

/* ─── Cards ─── */
.k2-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  box-shadow: var(--card-shadow);
}

/* ─── Avatars ─── */
.k2-avatar {
  width: var(--avatar-size);
  height: var(--avatar-size);
  border-radius: var(--avatar-radius);
  object-fit: cover;
  background: hsl(var(--muted));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--avatar-font);
  font-weight: var(--avatar-weight);
  color: hsl(var(--muted-foreground));
  overflow: hidden;
}
.k2-avatar--sm { width: var(--avatar-size-sm); height: var(--avatar-size-sm); }
.k2-avatar--lg { width: var(--avatar-size-lg); height: var(--avatar-size-lg); }
.k2-avatar--xl { width: var(--avatar-size-xl); height: var(--avatar-size-xl); }

/* ─── Accessibility ─── */
.k2-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ─── Responsive ─── */
@media (max-width: 768px) {
  .k2-shell {
    grid-template-columns: 1fr;
  }
  .k2-sidebar {
    display: none;
  }
  .k2-topbar {
    grid-column: 1;
  }
  .k2-content {
    grid-column: 1;
    padding: var(--k2-space-4);
  }
  .k2-grid-2, .k2-grid-3, .k2-grid-4 {
    grid-template-columns: 1fr;
  }
  .k2-container {
    padding: 0 var(--k2-space-4);
  }
}

@media (max-width: 480px) {
  .k2-content {
    padding: var(--k2-space-3);
  }
  .k2-heading-1 { font-size: var(--k2-text-2xl); }
  .k2-heading-2 { font-size: var(--k2-text-xl); }
}
