/* ======================================================
   APP.CSS — STYLE GLOBALNE / LAYOUT / ELEMENTY BAZOWE
   ====================================================== */

/* Paleta (stała z briefu) */
:root {
  --color-bg: #f5f6fa;

  --color-cream-light: #f4eed5;
  --color-cream: #e8ebc1;
  --color-green-light: #b3c67d;
  --color-brown-light: #b48c6b;
  --color-brown-dark: #6b574b;

  --color-accent: #b3c67d;
  --color-accent-light: #c6d68a;
  --color-accent-hover: #a2b56a;

  --color-text: #333;
  --color-success: #4caf50;
  --color-danger: #c62828;

  /* Ujednolicone promienie, odstępy, cienie */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 14px;

  --gap-1: .5rem;
  --gap-2: .75rem;
  --gap-3: 1rem;
  --gap-4: 1.25rem;

  --shadow-1: 0 1px 3px rgba(0,0,0,.06);
  --shadow-2: 0 4px 12px rgba(0,0,0,.10);
  --shadow-3: 0 10px 30px rgba(0,0,0,.18);
}

/* Reset i bazowe */
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: "Segoe UI", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg);
  overflow-x: hidden;
}

/* Typografia */
h1, h2, h3, h4 { font-weight: 600; color: var(--color-text); margin-bottom: var(--gap-3); }

/* Linki */
a { color: var(--color-accent); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--color-accent-light); }

/* Layout aplikacji (zgodnie z obecnym main) */
.layout { display: flex; align-items: flex-start; min-height: 100vh; background: var(--color-bg); }
.main { flex: 1; margin-left: 150px; background: var(--color-bg); overflow-x: hidden; }

/* Dostępność */
:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--color-accent) 55%, white);
  outline-offset: 2px;
}
.sr-only{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}

/* ---------- IKONY (Lucide) ---------- */
/* Lucide generuje <svg class="lucide">… – zapewniamy rozmiar i wyrównanie */
.lucide { width: 18px; height: 18px; stroke-width: 1.75; flex: 0 0 auto; }
.btn .lucide, button .lucide { margin-right: .5rem; }
.btn.icon .lucide, button.icon .lucide { margin: 0; }

/* ---------- PRZYCISKI (global) ---------- */
button, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  background: var(--color-accent);
  color: #fff;
  border: 0;
  padding: .55rem 1.1rem;
  border-radius: 10px;
  font-size: .92rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  box-shadow: var(--shadow-1);
}
button:hover, .btn:hover { background: var(--color-accent-hover); transform: translateY(-1px); box-shadow: var(--shadow-2); }
button:active, .btn:active { transform: translateY(0); }

/* Wariants */
.btn.secondary { background: var(--color-brown-light); }
.btn.secondary:hover { background: var(--color-brown-dark); }
.btn.danger { background: var(--color-danger); }
.btn.danger:hover { background: #e53935; }

/* Ikonograficzny (okrągły/kwadratowy) – pod ikony Lucide */
.btn.icon, button.icon {
  width: 36px; height: 36px; padding: 0; border-radius: 10px;
  line-height: 1; font-size: 0; /* ukryj tekst, używamy samej ikony */
}
.btn.icon.--round { border-radius: 999px; }

/* Szklany / miękki styl – do filtrów i akcji */
.btn.--glass {
  background: color-mix(in srgb, #fff 70%, transparent);
  color: var(--color-brown-dark);
  box-shadow: 0 1px 2px rgba(0,0,0,.04), inset 0 1px 0 rgba(255,255,255,.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.btn.--glass:hover { background: color-mix(in srgb, #fff 85%, transparent); }

.btn.--soft {
  background: var(--color-cream);
  color: var(--color-brown-dark);
}
.btn.--ghost {
  background: #fff;
  color: var(--color-brown-dark);
  border: 1px solid #e6e6ea;
}

/* ---------- KARTY / PANELE ---------- */
.card, .soft-card, .glass-card {
  border-radius: var(--radius-lg);
  padding: var(--gap-3);
  background: #fff;
  box-shadow: var(--shadow-1);
}
.glass-card {
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.6);
}
.section-header {
  display:flex; align-items:center; justify-content:space-between; gap: var(--gap-2);
  margin: 0 0 var(--gap-3);
}
.section-header h1, .section-header h2 { margin: 0; display:flex; align-items:center; gap:.6rem; }

/* ---------- FORMULARZE ---------- */
.input, input[type="text"], input[type="number"], input[type="file"], input[type="email"],
textarea, select {
  width: 100%;
  border: 1px solid #dcdcdc;
  background: #fff;
  color: var(--color-text);
  border-radius: var(--radius-sm);
  padding: .55rem .7rem;
  font-size: .95rem;
  transition: border-color .15s ease, box-shadow .2s ease;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 18%, transparent);
  outline: none;
}
label span { display:block; font-weight:600; font-size:.9rem; margin-bottom:.35rem; color: var(--color-text); }

/* ---------- NARZĘDZIA / UTILS ---------- */
.grid-2 { display:grid; grid-template-columns: 1fr 1fr; gap: var(--gap-2) var(--gap-3); }
.row { display:flex; align-items:center; gap:.6rem; }
.row.between { justify-content: space-between; }
.row.end { justify-content: flex-end; }

.status-active { color: var(--color-success); font-weight: 600; }
.status-inactive { color: var(--color-danger); font-weight: 600; }

/* RWD */
@media (max-width: 768px) {
  .grid-2 { grid-template-columns: 1fr; }
}
