/* === ZL Production – design system === */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root{
  --red:#d32f2f;
  --red-dark:#b71c1c;
  --green:#2b8f6b;
  --green-dark:#1f7a53;
  --navy:#1a1f2e;
  --topbar-bg:#e9edf5;
  --bg:#f1f4f9;
  --card:#ffffff;
  --border:#e2e8f0;
  --text:#1e293b;
  --text-muted:#64748b;
  --radius:8px;
  --shadow:0 1px 4px rgba(0,0,0,.10),0 4px 16px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
body{font-family:'Inter',Arial,sans-serif;background:var(--bg);margin:0;padding:0;color:var(--text)}

/* ── Topbar ── */
.topbar{background:var(--topbar-bg);position:sticky;top:0;z-index:100;box-shadow:0 1px 6px rgba(15,23,42,.12);border-bottom:1px solid #d7deeb}
.topbar-inner{display:flex;align-items:center;gap:14px;padding:0 20px;height:56px}
.topbar-logo{height:30px;width:auto;flex-shrink:0}
.topbar-title{font-size:14px;font-weight:600;color:#334155;flex:1}
.topbar-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.topbar-user{font-size:12px;color:#475569;padding:0 4px}

/* ── Page body ── */
.page-body{padding:14px 20px}

table{border-collapse:collapse;width:100%;background:var(--card)}
td,th{border:1px solid var(--border);padding:5px 6px;vertical-align:top;font-size:12px;height:auto}
th{background:#f8fafc;color:var(--text-muted);font-weight:600}
input,select{width:100%;font-size:11px;margin-bottom:2px;border:1px solid var(--border);border-radius:4px;padding:3px 5px;font-family:inherit}
input:focus,select:focus{outline:2px solid var(--red);border-color:transparent}

.cell{min-width:90px}
.nakládka{background:#98d8ff}
.vykládka{background:#ffc56d}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:4px;padding:7px 14px;border-radius:var(--radius);border:none;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;text-decoration:none;transition:background .15s;white-space:nowrap;line-height:1.3}
.btn.primary{background:var(--green);color:#fff}
.btn.primary:hover{background:var(--green-dark)}
.btn.danger{background:var(--red);color:#fff}
.btn.danger:hover{background:var(--red-dark)}
.btn.ghost{background:#f8fafc;color:#334155;border:1px solid #d6deea}
.btn.ghost:hover{background:#eef2f8}
.btn.ghost.active{background:#d32f2f;color:#fff;border-color:#d32f2f}
.btn.pill{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:12px}
.btn.pill:hover,.btn.pill.active{background:var(--red);color:#fff;border-color:var(--red)}
.btn.small{padding:4px 10px;font-size:12px}

/* ── Week switcher ── */
.week-switcher{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}

/* ── Main layout ── */
.main-content{display:flex;gap:14px;flex-wrap:nowrap;align-items:flex-start}
.main-content .ramps{flex:0 0 52%;min-width:0;max-width:52%}
.main-content .ramps table{width:100%;table-layout:fixed}
.main-content .smeny{flex:1;min-width:0;position:sticky;top:70px;align-self:flex-start}
.actions-cell{white-space:nowrap;width:1%}

/* ── Smeny scroll ── */
.main-content .smeny .smeny-scroll{max-height:calc(100vh - 80px);overflow-y:auto;border-radius:var(--radius);box-shadow:var(--shadow);border:none;background:var(--card)}
.main-content .smeny thead th{position:sticky;top:0;z-index:3;background:#f8fafc}

/* ── Day blocks ── */
.day-block{margin:0;padding:6px 0;border-top:3px solid var(--border)}
.day-block:first-child{border-top:none}
.day-header{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin:0 0 6px 0;flex-wrap:wrap}
.day-title{font-weight:700;margin:0;font-size:14px;color:var(--text);display:flex;align-items:baseline;gap:6px}
.day-title small{font-size:12px;color:var(--text-muted);font-weight:600}
.driver-of-day{display:inline-flex;align-items:center;gap:6px;border:1px solid #d7deeb;background:#f8fafc;border-radius:6px;padding:4px 8px;font-size:12px;color:#334155;line-height:1.1}
.driver-of-day span{text-transform:lowercase;color:#475569}
.driver-of-day .driver-name{font-size:12px;color:#0f172a}
.driver-of-day .driver-name.empty{color:#94a3b8;font-weight:600}
.driver-of-day.driver-of-day-edit{padding:3px 6px;gap:8px}
.driver-of-day.driver-of-day-edit input{margin:0;min-width:160px;width:220px;max-width:100%;font-size:12px;padding:3px 6px}
.block-table th,.block-table td{border:1px solid var(--border);padding:6px;vertical-align:top;font-size:12px}
.block-table{width:100%;border-collapse:collapse}
.block-table thead th{background:#f8fafc;color:var(--text-muted);font-weight:600}
.slot-row{width:120px}
.day-block + .day-block{border-top:3px solid var(--border)}

/* ── Slot cells ── */
.cell .slot{padding:4px 6px;box-sizing:border-box;display:flex;flex-direction:column;gap:4px;font-size:13px;line-height:1.1;overflow:visible;min-height:auto}
.cell .slot .slot-type{font-weight:700;text-align:center;padding-bottom:2px;font-size:13px;color:#222}
.cell .slot .slot-name{font-size:11px;color:var(--text-muted);margin:0;text-transform:uppercase;letter-spacing:.4px}
.cell .slot .slot-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;align-items:start}
.cell .slot .slot-left,.cell .slot .slot-right{display:flex;flex-direction:column;gap:3px}
.cell .slot .slot-action{font-weight:600}
.cell .slot .slot-cargo,.cell .slot .slot-helpers{font-size:12px;color:var(--text)}
.cell .slot .slot-action,
.cell .slot .slot-cargo,
.cell .slot .slot-helpers,
.cell .slot .slot-left .slot-name{font-size:1.4em;line-height:1.1;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}
.cell .slot.empty{opacity:.55}
.cell .slot.edit{background:transparent}
.cell .slot.edit input,.cell .slot.edit select{font-size:13px;padding:4px;height:auto}

/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy)}
.login-card{background:var(--card);border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.3);padding:40px 36px;width:100%;max-width:360px;text-align:center}
.login-logo{height:44px;margin-bottom:28px}
.login-card h2{font-size:17px;font-weight:700;margin:0 0 24px 0;color:var(--text)}
.login-card input[type=password],.login-card input[type=email]{width:100%;padding:10px 14px;font-size:14px;border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;margin-bottom:14px;color:var(--text)}
.login-card input[type=password]:focus,.login-card input[type=email]:focus{outline:2px solid var(--red);border-color:transparent}
.login-card .btn-login{width:100%;padding:11px;font-size:15px;font-weight:600;background:var(--red);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-family:inherit;transition:background .15s}
.login-card .btn-login:hover{background:var(--red-dark)}
.login-error{color:var(--red);font-size:13px;margin-top:10px}

/* ── User management ── */
.users-page{max-width:1400px;margin:0 auto}
.users-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:16px;align-items:start}
.card{background:var(--card);border-radius:12px;box-shadow:var(--shadow);padding:18px}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.card-header h1,.card-header h2{margin:0;color:var(--text)}
.card-header h1{font-size:22px}
.card-header h2{font-size:18px}
.users-list{display:flex;flex-direction:column;gap:12px}
.user-row{border:1px solid var(--border);border-radius:10px;padding:14px;background:#fbfcff}
.user-main{margin-bottom:12px}
.user-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.user-meta{font-size:12px;color:var(--text-muted)}
.role-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600}
.role-badge.admin{background:#e2e8f0;color:#334155}
.role-badge.superadmin{background:#fee2e2;color:#b91c1c}
.role-badge.current{background:#dcfce7;color:#166534}
.user-controls{display:flex;align-items:end;gap:10px;flex-wrap:wrap}
.inline-field{display:flex;flex-direction:column;gap:5px;min-width:150px}
.inline-field.grow{flex:1;min-width:220px}
.inline-field span,.inline-check span{font-size:12px;color:var(--text-muted)}
.inline-check{display:flex;align-items:center;gap:8px;padding-bottom:8px}
.inline-check input{width:auto;margin:0}
.user-form{display:flex;flex-direction:column;gap:8px}
.user-form label{font-size:12px;color:var(--text-muted);font-weight:600}
.users-message{min-height:20px;font-size:13px;margin-bottom:12px;color:var(--text-muted)}
.users-message.success{color:#166534}
.users-message.error{color:#b91c1c}
.empty-state{padding:18px;border:1px dashed var(--border);border-radius:10px;color:var(--text-muted);background:#fbfcff}

@media (max-width: 960px){
  .users-grid{grid-template-columns:1fr}
  .user-controls{align-items:stretch}
}
