/* Style — spójny ze Script: kompaktowe kafelki, zielony „Dodaj”, nagłówki dni (desktop), badge dnia (mobile), autocomplete pod polem */

/* --- Layout globalny --- */
body { font-family: Arial, sans-serif; background:#f2f2f2; margin:0; padding:0; }
h1 { text-align:center; margin:20px 0 10px; }

/* --- Nawigacja --- */
.calendar-nav { text-align:center; margin-bottom:10px; }
.calendar-nav button { font-size:18px; padding:5px 10px; margin:0 10px; cursor:pointer; }

/* --- Siatka kalendarza --- */
.calendar { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; padding:10px; }
.day { background:#fff; border-radius:8px; padding:8px; display:flex; flex-direction:column; justify-content:flex-start; min-height:150px; border:1px solid #ddd; }
.day h3 { font-size:14px; margin:2px 0 8px; }

/* Puste kratki (desktop zostają, mobile ukryte) */
.empty-day { padding:0!important; border:none!important; min-height:0!important; height:0!important; overflow:hidden; }
@media (max-width:600px){ .empty-day{ display:none!important; } }

/* Pasek nazw dni (desktop) – generowany jako 7 komórek .day-name */
.day-name { text-align:center; font-weight:700; color:#333; padding:4px 0; border-bottom:1px solid #ddd; }
@media (max-width:600px){ .day-name{ display:none; } }

/* Badge dnia przy dacie (mobile) */
@media (max-width:600px){ .dow-badge{ font-weight:700; color:#555; margin-left:6px; letter-spacing:.5px; } }

/* --- Przycisk Dodaj na dole kafelka --- */
.add-btn{ background:#b9e6c9; color:#1b402a; border:1px solid #98d5b2; padding:8px 10px; border-radius:8px; cursor:pointer; margin-top:auto; }
.add-btn:hover{ filter:brightness(.95); }

/* --- Kafelek wizyty (kompaktowy) --- */
.appt{ background:#fff; border:1px solid #ddd; border-radius:10px; padding:8px 10px; margin:8px 0; box-shadow:0 1px 2px rgba(0,0,0,.04); font-size:12px; }
/* wiersz 1: lewo godzina+klientka, prawo czas trwania */
.appt-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:13px; font-weight:600; }
.appt-left{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.appt-right{ white-space:nowrap; color:#444; }
/* wiersz 2: kwoty */
.appt-meta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:6px; font-size:12px; color:#333; }
/* wiersz 3: akcje */
.appt-actions{ margin-top:8px; display:flex; gap:8px; }
.btn{ padding:4px 8px; border:1px solid #cfcfcf; border-radius:6px; background:#f6f6f6; cursor:pointer; font-size:12px; }
.btn-edit{ background:#eef3ff; border-color:#d8e3ff; }
.btn-del{ background:#f9eeee; border-color:#f1caca; }
.btn:hover{ filter:brightness(.97); }

/* --- Dashboard --- */
.dashboard{ margin:20px; background:#fff; padding:15px; border-radius:10px; border:1px solid #ddd; }
.dashboard h2{ margin-top:0; }
.summary{ display:grid; grid-template-columns:repeat(4,1fr); gap:15px; margin-top:15px; }
.card{ background:#f8f8f8; padding:15px; border-radius:8px; text-align:center; font-size:16px; font-weight:bold; border:1px solid #ddd; }
.chart-container{ margin-top:30px; }

/* --- Modal --- */
.modal{ display:none; position:fixed; z-index:10; left:0; top:0; width:100%; height:100%; background:rgba(0,0,0,.5); justify-content:center; align-items:center; }
.modal-content{ background:#fff; padding:20px; border-radius:10px; width:320px; }
.modal-content label{ display:block; margin:8px 0 3px; }
.modal-content input{ width:100%; padding:5px; box-sizing:border-box; }

/* --- Autocomplete (pole Klientka) — dropdown przyklejony do inputa */
.ac-wrap { position: relative; }
.autocomplete{
  position: absolute; left: 0; right: 0; top: calc(100% + 6px);
  background:#fff; border:1px solid #ddd; border-radius:8px;
  box-shadow:0 6px 20px rgba(0,0,0,.08); max-height:220px; overflow:auto;
  z-index:50; display:none;
}
.autocomplete-item{ padding:8px 10px; cursor:pointer; font-size:14px; }
.autocomplete-item:hover, .autocomplete-item.active{ background:#eef3ff; }

/* --- Responsywność --- */
@media (max-width:1024px){ .calendar{ grid-template-columns:repeat(4,1fr); } .summary{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){
  .calendar{ grid-template-columns:1fr; }
  .summary{ grid-template-columns:1fr; }
  .modal-content{ width:90%; }
  .appt{ padding:8px; border-radius:8px; }
  .appt-top{ font-size:13px; }
  .appt-meta{ font-size:12px; gap:10px; }
  .btn{ padding:4px 10px; }
}
/* tryb uproszczony – jedna linia na wizytę */
.appt--compact{
  padding:6px 8px; margin:4px 0;
  border-radius:8px; border:1px dashed #ddd; background:#fff;
  font-size:12px; display:flex; justify-content:space-between; gap:8px;
}
.appt--compact .lc{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.appt--compact .rc{ white-space:nowrap; color:#444; }

/* drobne: style przycisków w nav (żeby pasowały do reszty) */
.calendar-nav button{ font-size:14px; padding:6px 10px; margin:0; cursor:pointer; border:1px solid #d7d7d7; background:#fff; border-radius:8px; }


/* Status/toast bar */
.status {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 16px;
  max-width: 90vw;
  background: #222;
  color: #fff;
  padding: 10px 14px;
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  opacity: 0;
  transition: opacity .25s ease;
  z-index: 9999;
  font-size: 14px;
}
.status.error { background: #b00020; }
.status.success { background: #1b5e20; }
.status.info { background: #333; }
