/* ================================================================
   AGLAR UI v2 — Modern Premium Redesign
   Załadowany po style.css — nadpisuje wyłącznie visual styles.
   Aby cofnąć: usuń <link> do tego pliku w index.html
   ================================================================ */

/* ============================================================
   CSS VARIABLES — Dark theme (default)
   ============================================================ */
:root {
  --primary:           #e94560;
  --primary-dark:      #c23152;
  --primary-rgb:       233, 69, 96;
  --primary-glow:      rgba(233, 69, 96, 0.15);

  /* Surfaces — głębszy, bardziej neutralny dark */
  --bg-dark:           #08080d;
  --bg-card:           #10101a;
  --bg-surface:        #13131e;
  --bg-input:          #1a1a27;
  --bg-main:           #08080d;
  --bg-secondary:      rgba(255,255,255,0.03);
  --bg-hover:          rgba(255,255,255,0.04);
  --hover-overlay:     rgba(255,255,255,0.04);

  /* Text */
  --text:              #eeeef3;
  --text-secondary:    #7e88a5;
  --text-muted:        #424760;

  /* Border */
  --border:            #1c1c2a;

  /* Status */
  --success:           #10d87e;
  --warning:           #f59e0b;
  --danger:            #ef4444;
  --info:              #3b82f6;

  /* Shadows */
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.5);
  --shadow:      0 4px 20px rgba(0,0,0,0.55), 0 1px 4px rgba(0,0,0,0.3);
  --shadow-lg:   0 12px 40px rgba(0,0,0,0.7), 0 4px 12px rgba(0,0,0,0.4);
  --shadow-glow: 0 0 24px rgba(233, 69, 96, 0.18);

  /* Radius */
  --radius:    14px;
  --radius-sm: 10px;
  --radius-xs:  7px;

  /* Transitions */
  --t:      all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --t-fast: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);

  /* Signature */
  --sig-stroke:    #fff;
  --sig-baseline:  rgba(255,255,255,0.06);
  --sig-canvas-bg: rgba(255,255,255,0.02);
  --sig-hint-color:rgba(255,255,255,0.18);
}

/* ============================================================
   CSS VARIABLES — Light theme
   ============================================================ */
[data-theme="light"] {
  --primary:        #d63050;
  --primary-dark:   #b02440;
  --primary-rgb:    214, 48, 80;
  --primary-glow:   rgba(214, 48, 80, 0.1);

  --bg-dark:        #f0f2f7;
  --bg-card:        #ffffff;
  --bg-surface:     #f7f8fb;
  --bg-input:       #ffffff;
  --bg-main:        #f0f2f7;
  --bg-secondary:   rgba(0,0,0,0.025);
  --bg-hover:       rgba(0,0,0,0.03);
  --hover-overlay:  rgba(0,0,0,0.03);

  --text:           #0d0f18;
  --text-secondary: #4a5368;
  --text-muted:     #8896aa;

  --border:         #e4e7ef;

  --success:        #059669;
  --warning:        #d97706;
  --danger:         #dc2626;
  --info:           #2563eb;

  --shadow-sm:  0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --shadow:     0 4px 16px rgba(0,0,0,0.09), 0 2px 6px rgba(0,0,0,0.05);
  --shadow-lg:  0 16px 48px rgba(0,0,0,0.14), 0 4px 12px rgba(0,0,0,0.07);
  --shadow-glow:0 0 20px rgba(214, 48, 80, 0.08);

  --sig-stroke:    #111;
  --sig-baseline:  rgba(0,0,0,0.08);
  --sig-canvas-bg: rgba(0,0,0,0.01);
  --sig-hint-color:rgba(0,0,0,0.25);
}

/* ============================================================
   BASE
   ============================================================ */
* { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body {
  background: var(--bg-dark);
  color: var(--text);
  letter-spacing: -0.01em;
}

/* Scrollbar */
::-webkit-scrollbar       { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* ============================================================
   HEADER
   ============================================================ */
.app-header {
  border-bottom: 1px solid var(--border);
}

/* Dark header — frosted glass */
:root .app-header {
  background: rgba(10, 10, 16, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

[data-theme="light"] .app-header {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 1px 0 var(--border);
}

.header-left h2 {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.025em;
}

/* ============================================================
   BOTTOM NAV
   ============================================================ */
:root .bottom-nav {
  background: rgba(10, 10, 16, 0.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid var(--border);
}

[data-theme="light"] .bottom-nav {
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid var(--border);
  box-shadow: 0 -1px 0 var(--border);
}

.nav-btn {
  border-radius: 10px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: var(--t-fast);
}

.nav-btn i { font-size: 18px; transition: var(--t-fast); }

.nav-btn.active { color: var(--primary); }
.nav-btn.active i {
  filter: drop-shadow(0 0 5px rgba(233, 69, 96, 0.5));
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  border-radius: var(--radius-sm);
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: var(--t-fast);
  position: relative;
  overflow: hidden;
}

.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: transparent;
  transition: background 0.15s;
  pointer-events: none;
}
.btn:active::after { background: rgba(255,255,255,0.12); }

.btn-primary {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff;
  box-shadow: 0 2px 10px rgba(233,69,96,0.28);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #f0566f 0%, var(--primary) 100%);
  box-shadow: 0 4px 18px rgba(233,69,96,0.4);
  transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); box-shadow: none; }

.btn-success {
  background: linear-gradient(135deg, var(--success) 0%, #0aad68 100%);
  color: #fff;
  box-shadow: 0 2px 10px rgba(16,216,126,0.22);
}
.btn-success:hover {
  box-shadow: 0 4px 18px rgba(16,216,126,0.32);
  transform: translateY(-1px);
}
.btn-success:active { transform: translateY(0); }

.btn-warning {
  background: linear-gradient(135deg, var(--warning) 0%, #c97d06 100%);
  color: #fff;
}

.btn-danger {
  background: linear-gradient(135deg, var(--danger) 0%, #c41a1a 100%);
  color: #fff;
  box-shadow: 0 2px 10px rgba(239,68,68,0.22);
}
.btn-danger:hover {
  box-shadow: 0 4px 18px rgba(239,68,68,0.32);
  transform: translateY(-1px);
}
.btn-danger:active { transform: translateY(0); }

.btn-info {
  background: linear-gradient(135deg, var(--info) 0%, #1d4ed8 100%);
  color: #fff;
}

.btn-outline {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-secondary);
}
.btn-outline:hover {
  border-color: rgba(233,69,96,0.4);
  color: var(--primary);
  background: var(--primary-glow);
}

.btn-icon {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn-icon:hover {
  color: var(--primary);
  background: var(--primary-glow);
  border-color: rgba(233,69,96,0.3);
}

.btn-sm { padding: 6px 12px; font-size: 12px; font-weight: 600; }

/* ============================================================
   FORMS & INPUTS
   ============================================================ */
.form-group label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 7px;
}

.form-group input,
.form-group select,
.form-group textarea {
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 14px;
  transition: var(--t-fast);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-glow);
  outline: none;
}

.protocol-field input[type="text"],
.protocol-field input[type="number"],
.protocol-field textarea {
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}

.protocol-field input:focus,
.protocol-field textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-glow);
  outline: none;
}

.error-message {
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.25);
  border-radius: var(--radius-sm);
  color: var(--danger);
}

/* ============================================================
   CARDS — GENERAL
   ============================================================ */
.detail-section,
.settings-section {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

.detail-section h4 {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-muted);
}

/* ============================================================
   JOB CARDS
   ============================================================ */

/* --- Lista kart: większy odstęp między kartami --- */
.jobs-list { gap: 8px; }
@media (min-width: 901px) { .jobs-list { gap: 6px; } }

.job-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
  padding: 11px 15px;
}

.job-card:hover {
  box-shadow: var(--shadow);
  border-color: rgba(233,69,96,0.2);
  transform: translateY(-1px);
}

.job-card:active { transform: translateY(0); box-shadow: var(--shadow-sm); }

/* --- Numer zlecenia (badge przed tytułem, np. "640/26") --- */
.job-num {
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  color: var(--primary);
  background: rgba(233, 69, 96, 0.1);
  border: 1px solid rgba(233, 69, 96, 0.3);
  border-radius: 6px;
  padding: 2px 9px;
  margin-right: 9px;
  letter-spacing: 0.03em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  vertical-align: middle;
  line-height: 1.5;
}
[data-theme="light"] .job-num {
  color: var(--primary);
  background: rgba(214, 48, 80, 0.09);
  border-color: rgba(214, 48, 80, 0.28);
}

/* --- Tytuł zlecenia --- */
.job-card-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}

/* --- Nazwa klienta — najważniejszy element w row2 --- */
.jc-client {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  letter-spacing: -0.01em;
}

/* --- Adres — dyskretniejszy --- */
.jc-addr {
  font-size: 11.5px;
  color: var(--text-secondary);
}

/* --- Opis zlecenia — ważny, ale nie dominujący --- */
.job-card-desc {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.45;
  color: var(--text-secondary);
  background: rgba(255, 82, 82, 0.07);
  border-left-color: #ff5252;
  margin: 6px 0 4px;
  padding: 6px 10px;
}
[data-theme="light"] .job-card-desc {
  color: #c0392b;
  background: rgba(255, 82, 82, 0.06);
}

/* --- Urządzenie --- */
.jc-device-row {
  font-size: 12.5px;
  padding: 4px 9px;
  margin: 4px 0 2px;
}

/* --- Chipsy row2 — lekko większe --- */
.jc-chip { font-size: 12px; }

/* --- Footer — czytelniejszy --- */
.job-card-footer {
  font-size: 11px;
  gap: 5px 12px;
  margin-top: 6px;
  padding-top: 6px;
}

.job-card-footer span { font-size: 11px; }

/* --- Badge typu zlecenia --- */
.job-type-badge {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 8px;
  font-weight: 700;
}

/* --- Status badge --- */
.job-status {
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 3px 8px !important;
  border-radius: 6px !important;
  letter-spacing: 0.03em;
}

/* Desktop: tighter but readable */
@media (min-width: 901px) {
  .job-card { padding: 10px 15px; }
  .job-card-desc { font-size: 11.5px; }
}

/* --- Serwisant jako pill (bardziej wyróżniony) --- */
.jc-tech-pill {
  background: rgba(233, 69, 96, 0.1);
  border: 1px solid rgba(233, 69, 96, 0.28);
  border-radius: 20px;
  padding: 2px 9px;
  font-size: 12px !important;
}
.jc-tech.jc-tech-pill { color: var(--primary) !important; }
.jc-tech.jc-tech-pill i { color: var(--primary) !important; }
.jc-notech.jc-tech-pill {
  background: rgba(245, 158, 11, 0.1);
  border-color: rgba(245, 158, 11, 0.25);
  color: var(--warning) !important;
}

/* --- Notatka na karcie --- */
.job-card-note {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  padding: 5px 10px;
  margin: 4px 0 2px;
  background: rgba(139, 92, 246, 0.07);
  border-left: 3px solid #8b5cf6;
  border-radius: 0 6px 6px 0;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.4;
}
.job-card-note i {
  color: #8b5cf6;
  font-size: 11px;
  margin-top: 2px;
  flex-shrink: 0;
}
.job-card-note span { flex: 1; min-width: 0; }
.jc-note-author {
  font-size: 10px;
  font-weight: 700;
  color: #8b5cf6;
  white-space: nowrap;
  opacity: 0.8;
  flex-shrink: 0;
}
[data-theme="light"] .job-card-note {
  background: rgba(139, 92, 246, 0.05);
  color: #4c1d95;
}

/* ============================================================
   CLIENT CARDS
   ============================================================ */
.client-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: var(--t);
}

.client-card:hover {
  border-color: rgba(233,69,96,0.3);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}

.client-card-icon {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  border-radius: var(--radius-sm);
}

/* ============================================================
   USER CARDS
   ============================================================ */
.user-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.user-card:hover {
  box-shadow: var(--shadow);
  border-color: rgba(233,69,96,0.2);
}

.user-role-badge { border-radius: var(--radius-xs); }
.role-admin {
  background: rgba(233,69,96,0.12);
  color: var(--primary);
  border: 1px solid rgba(233,69,96,0.2);
}
.role-serwisant {
  background: rgba(59,130,246,0.12);
  color: var(--info);
  border: 1px solid rgba(59,130,246,0.2);
}

/* ============================================================
   KPI TILES
   ============================================================ */
.kpi-tile {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.kpi-tile:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.kpi-tile.kpi-active {
  border-color: var(--primary);
  background: rgba(233,69,96,0.07);
  box-shadow: 0 0 0 1px rgba(233,69,96,0.15), var(--shadow-sm);
}

.kpi-count { font-size: 20px; font-weight: 800; }
.kpi-label { font-size: 9px; font-weight: 700; letter-spacing: 0.05em; }

/* ============================================================
   FILTER TABS
   ============================================================ */
.filter-tab {
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  transition: var(--t-fast);
}
.filter-tab:hover {
  border-color: rgba(233,69,96,0.35);
  color: var(--text);
  background: var(--bg-surface);
}
.filter-tab.active {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: #fff;
  border-color: transparent;
  box-shadow: 0 2px 10px rgba(233,69,96,0.3);
}

/* ============================================================
   MENU TILES
   ============================================================ */
.menu-tile {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.menu-tile:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: rgba(233,69,96,0.3);
}
.menu-tile:active { transform: translateY(0); }
.menu-tile-icon { border-radius: var(--radius-sm); }

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay {
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.modal-content {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  animation: modalIn 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes modalIn {
  from { opacity: 0; transform: scale(0.96) translateY(10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.modal-header h3 {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.025em;
}

/* ============================================================
   TOAST
   ============================================================ */
.toast {
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  box-shadow: var(--shadow);
  backdrop-filter: blur(8px);
}

/* ============================================================
   NAV MORE PANEL
   ============================================================ */
.nav-more-panel {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);
  box-shadow: var(--shadow-lg);
}

[data-theme="light"] .nav-more-panel {
  box-shadow: 0 -4px 32px rgba(0,0,0,0.1);
}

.nav-more-item {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-weight: 600;
  transition: var(--t-fast);
}
.nav-more-item:hover, .nav-more-item:active {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  border-color: transparent;
  color: #fff;
}

/* ============================================================
   STATUS BADGES
   ============================================================ */
.job-status {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 6px;
  padding: 2px 7px;
}

/* ============================================================
   PROPOSAL TABS
   ============================================================ */
.proposal-tab {
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  transition: var(--t-fast);
}
.proposal-tab.active {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  border-color: transparent;
  box-shadow: 0 2px 10px rgba(233,69,96,0.25);
}

/* ============================================================
   PROPOSAL CARDS & SUMMARY
   ============================================================ */
.proposal-summary {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

/* ============================================================
   KANBAN
   ============================================================ */
.kanban-column {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.kanban-column-header {
  background: var(--bg-card);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.kanban-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.kanban-card:hover { box-shadow: var(--shadow); transform: translateY(-1px); }
.kanban-card:active { transform: translateY(0); cursor: grabbing; }

/* ============================================================
   REPORTS
   ============================================================ */
.report-table th {
  background: var(--bg-surface);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}
.report-table tr:hover td { background: var(--hover-overlay); }

.stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}
.stat-number { font-size: 26px; font-weight: 800; }

.tech-report-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.period-btn { background: var(--bg-surface); color: var(--text-secondary); }
.period-btn.active {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: #fff;
}

.progress-bar { background: var(--bg-surface); border-radius: 6px; }
.progress-fill { border-radius: 6px; }

/* ============================================================
   DAILY WORKLOAD
   ============================================================ */
.daily-workload-bar {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.daily-workload-header { background: var(--bg-surface); }
.workload-tech-row:hover { background: rgba(233,69,96,0.06); }
.workload-job-mini:hover { background: rgba(233,69,96,0.1); }

/* ============================================================
   GPS CARDS
   ============================================================ */
.gps-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.gps-card:hover { background: var(--bg-surface); box-shadow: var(--shadow); }

.svc-map-view {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

/* ============================================================
   CHAT
   ============================================================ */
.chat-container {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.chat-message.sent {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
}
.chat-message.received {
  background: var(--bg-surface);
  border: 1px solid var(--border);
}
.chat-input input {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}
.chat-input input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-glow);
}
.chat-photo-btn {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}

/* ============================================================
   GLOBAL SEARCH
   ============================================================ */
.global-search-dropdown {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* ============================================================
   PROTOCOL
   ============================================================ */
.protocol-section {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.protocol-section-title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.protocol-info-card {
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}
.btn-protocol-submit {
  border-radius: var(--radius-sm) !important;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  box-shadow: 0 4px 18px rgba(233,69,96,0.32) !important;
  font-weight: 700 !important;
}

/* ============================================================
   NOTIFICATIONS
   ============================================================ */
.notification-item {
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}
.notification-item:hover { background: var(--hover-overlay); }
.notification-unread {
  background: rgba(59,130,246,0.04);
  border-left: 2px solid var(--primary);
}
.notification-icon {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: 50%;
}

/* ============================================================
   NOTES
   ============================================================ */
.note-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.note-item:hover { box-shadow: var(--shadow); }

/* ============================================================
   REMINDERS
   ============================================================ */
.reminder-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  transition: var(--t-fast);
}
.reminder-card:hover { box-shadow: var(--shadow); }

/* ============================================================
   DEVICE CARDS
   ============================================================ */
.device-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}
.device-card:hover { border-color: var(--info); box-shadow: var(--shadow-sm); }

/* ============================================================
   SIGNATURE
   ============================================================ */
.signature-canvas {
  border: 2px dashed rgba(233,69,96,0.3);
  border-radius: var(--radius-sm);
  transition: border-color 0.2s;
}
.signature-canvas-wrap::before {
  content: 'Podpisz się tutaj palcem lub myszką';
  font-size: 12px;
  color: var(--sig-hint-color);
}

/* ============================================================
   LOGIN SCREEN
   ============================================================ */
:root .login-container {
  background: radial-gradient(ellipse at 50% 0%, rgba(233,69,96,0.07) 0%, var(--bg-dark) 65%);
}
[data-theme="light"] .login-container {
  background: radial-gradient(ellipse at 50% 0%, rgba(214,48,80,0.05) 0%, var(--bg-dark) 65%);
}
.login-logo h1 {
  font-weight: 800;
  letter-spacing: 7px;
}
.lock-user-info {
  background: rgba(233,69,96,0.08);
  border: 1px solid rgba(233,69,96,0.2);
  border-radius: var(--radius-sm);
}

/* ============================================================
   PAGE TRANSITION ANIMATION
   ============================================================ */
.page.active {
  animation: pageFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes pageFadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   CLIENT SUGGESTIONS
   ============================================================ */
.client-suggestions {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg);
}
.client-suggestion-item:hover { background: var(--bg-surface); }

/* ============================================================
   DEVICE PICKER
   ============================================================ */
.device-picker-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}
.device-picker-item:hover {
  border-color: rgba(233,69,96,0.35);
  background: var(--bg-surface);
}
.device-picker-item.device-picker-selected {
  border-color: var(--success);
  background: rgba(16,216,126,0.07);
}

/* ============================================================
   EMPTY & LOADING STATES
   ============================================================ */
.empty-state { color: var(--text-muted); }
.empty-state i { opacity: 0.25; }

/* ============================================================
   GLOBAL SEARCH INPUT (inside header)
   ============================================================ */
#global-search-input {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 20px;
  transition: var(--t-fast);
}
#global-search-input:focus {
  border-color: rgba(233,69,96,0.4);
  box-shadow: 0 0 0 3px var(--primary-glow);
  outline: none;
}

/* ============================================================
   FOCUS RING — accessibility
   ============================================================ */
:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* ============================================================
   LIGHT THEME — specific shadow & surface overrides
   ============================================================ */
[data-theme="light"] .job-card { box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
[data-theme="light"] .client-card { box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
[data-theme="light"] .detail-section,
[data-theme="light"] .settings-section { box-shadow: 0 1px 4px rgba(0,0,0,0.05); }
[data-theme="light"] .modal-content { box-shadow: 0 20px 60px rgba(0,0,0,0.16); }
[data-theme="light"] .btn-primary { box-shadow: 0 2px 8px rgba(214,48,80,0.22); }
[data-theme="light"] .btn-success { box-shadow: 0 2px 8px rgba(5,150,105,0.18); }
[data-theme="light"] .global-search-dropdown { box-shadow: 0 8px 32px rgba(0,0,0,0.12); }
[data-theme="light"] .filter-tab.active { box-shadow: 0 2px 8px rgba(214,48,80,0.22); }
[data-theme="light"] .role-admin { background: rgba(214,48,80,0.08); }
[data-theme="light"] .role-serwisant { background: rgba(37,99,235,0.08); }

/* Light status badges */
[data-theme="light"] .status-nowe { background: rgba(37,99,235,0.1); color: #1d4ed8; }
[data-theme="light"] .status-przydzielone { background: rgba(217,119,6,0.1); color: #b45309; }
[data-theme="light"] .status-w_trakcie { background: rgba(217,119,6,0.1); color: #b45309; }
[data-theme="light"] .status-w_drodze { background: rgba(124,58,237,0.1); color: #7c3aed; }
[data-theme="light"] .status-zakonczone_protokol { background: rgba(5,150,105,0.1); color: #047857; }
[data-theme="light"] .status-zakonczone { background: rgba(217,119,6,0.1); color: #b45309; }
[data-theme="light"] .status-anulowane { background: rgba(220,38,38,0.1); color: #b91c1c; }
[data-theme="light"] .status-zewnetrzna { background: rgba(220,38,38,0.1); color: #c2410c; }

/* Light job card hover */
[data-theme="light"] .job-card:hover {
  border-color: rgba(214,48,80,0.2);
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}

/* Light nav more */
[data-theme="light"] .nav-more-panel { box-shadow: 0 -4px 32px rgba(0,0,0,0.1); }
[data-theme="light"] .nav-more-item { background: var(--bg-surface); }

/* Light workload hover */
[data-theme="light"] .workload-tech-row:hover { background: rgba(214,48,80,0.05); }
[data-theme="light"] .workload-job-mini:hover { background: rgba(214,48,80,0.07); }

/* Light chat */
[data-theme="light"] .chat-message.received { background: var(--bg-surface); }

/* ============================================================
   SMALL RESPONSIVE TWEAKS
   ============================================================ */
@media (max-width: 400px) {
  .nav-btn span { font-size: 8px; }
  .nav-btn i { font-size: 17px; }
}

@media (min-width: 901px) {
  .job-card { border-radius: var(--radius-sm); }
}
