:root {
  --bg:#f0f2f8; --surface:#ffffff; --surface2:#f5f6fa; --surface3:#eceef6;
  --border:#dde1f0; --border2:#c8cde3;
  --accent:#5b52e8; --accent-light:#ede9ff;
  --accent2:#e85b7a; --accent3:#22c55e;
  --text:#1a1a2e; --text2:#4a4a6a; --muted:#8888aa;
  --created:#5b52e8; --assigned:#f59e0b; --sent_to_supply: #207a7f;
  --returned_to_executor: #20417f; --completed:#22c55e; --closed: #8a8a8a;
  --shadow:0 2px 12px rgba(91,82,232,.10);
  --shadow2:0 4px 24px rgba(91,82,232,.13);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Onest',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;}

/* subtle grid */
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(91,82,232,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(91,82,232,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0;}

/* LOGIN */
#login-screen{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8eaf6 0%,#f0f2f8 60%,#fce4ec 100%);}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:44px;width:410px;box-shadow:var(--shadow2);animation:slideUp .5s ease;}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.login-logo{font-family:'Unbounded',sans-serif;font-size:24px;font-weight:900;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px;}
.login-sub{color:var(--muted);font-size:13px;margin-bottom:26px;}
.field{margin-bottom:13px;}
.field-label{font-size:11px;color:var(--muted);margin-bottom:5px;letter-spacing:.6px;text-transform:uppercase;}
input[type=text],input[type=password]{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:11px;padding:11px 14px;color:var(--text);font-family:'Onest',sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;}
input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(91,82,232,.1);}
.btn{width:100%;background:linear-gradient(135deg,var(--accent),#8b5cf6);border:none;border-radius:11px;padding:13px;color:#fff;font-family:'Unbounded',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s,box-shadow .2s;margin-top:8px;box-shadow:0 4px 14px rgba(91,82,232,.3);}
.btn:hover{opacity:.93;transform:translateY(-1px);box-shadow:0 6px 20px rgba(91,82,232,.35);}
.btn:active{transform:none;}
.btn.secondary{background:var(--surface2);border:1.5px solid var(--border);color:var(--text2);box-shadow:none;}
.btn.secondary:hover{border-color:var(--accent);color:var(--accent);}
.btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 14px rgba(239,68,68,.25);}
.btn.success{background:linear-gradient(135deg,var(--accent3),#16a34a);box-shadow:0 4px 14px rgba(34,197,94,.25);}
.btn.sm{width:auto;padding:8px 16px;font-size:11px;margin-top:0;box-shadow:none;}
.btn.xs{width:auto;padding:5px 11px;font-size:11px;margin-top:0;box-shadow:none;}
.btn.ghost{background:none;border:1.5px solid var(--border);color:var(--text2);box-shadow:none;}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);}
.login-hints{margin-top:16px;display:flex;flex-direction:column;gap:6px;}
.hint-row{background:var(--surface2);border:1px solid var(--border);border-radius:9px;padding:8px 12px;font-size:12px;color:var(--text2);display:flex;align-items:center;justify-content:space-between;}
.hint-row code{color:var(--accent);font-size:11px;font-weight:600;}
.role-pill{padding:2px 9px;border-radius:20px;font-size:10px;font-weight:700;font-family:'Unbounded',sans-serif;}
.rp-admin{background:rgba(232,91,122,.1);color:var(--accent2);}
.rp-staff{background:rgba(245,158,11,.1);color:#d97706;}
.rp-exec{background:rgba(91,82,232,.1);color:var(--accent);}
.validation-error{color:#ef4444;font-size:12px;margin-top:5px;}

/* APP */
#app{display:none;position:relative;z-index:1;}

/* TOPNAV */
.topnav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 32px;height:62px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 8px rgba(91,82,232,.07);}
.nav-logo{font-family:'Unbounded',sans-serif;font-size:17px;font-weight:900;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.nav-right{display:flex;align-items:center;gap:14px;}
.nav-user{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text2);}
.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Unbounded',sans-serif;font-size:12px;font-weight:700;color:#fff;}
.av-admin{background:linear-gradient(135deg,var(--accent2),#c0392b);}
.av-staff{background:linear-gradient(135deg,#f59e0b,#fbbf24);}
.av-exec{background:linear-gradient(135deg,var(--accent),#8b5cf6);}
.logout-btn{background:none;border:1.5px solid var(--border);color:var(--muted);font-size:12px;font-family:'Onest',sans-serif;padding:6px 13px;border-radius:9px;cursor:pointer;transition:all .2s;}
.logout-btn:hover{border-color:var(--accent);color:var(--accent);}

/* NOTIF BELL */
.notif-bell{position:relative;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);transition:all .2s;color:var(--muted);font-size:16px;}
.notif-bell:hover{border-color:var(--accent);color:var(--accent);}
.notif-badge{position:absolute;top:-3px;right:-3px;background:var(--accent2);color:#fff;border-radius:50%;width:17px;height:17px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff;display:none;}
.notif-badge.show{display:flex;}

/* NOTIF DROPDOWN */
.notif-dropdown{position:absolute;top:54px;right:32px;z-index:200;background:var(--surface);border:1.5px solid var(--border);border-radius:16px;width:340px;box-shadow:var(--shadow2);display:none;}
.notif-dropdown.open{display:block;animation:slideUp .2s ease;}
.notif-drop-header{padding:14px 16px 10px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.notif-drop-title{font-family:'Unbounded',sans-serif;font-size:13px;font-weight:700;}
.notif-clear{font-size:11px;color:var(--muted);cursor:pointer;}
.notif-clear:hover{color:var(--accent);}
.notif-list{max-height:280px;overflow-y:auto;}
.notif-item{padding:11px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text2);display:flex;gap:10px;align-items:flex-start;transition:background .15s;}
.notif-item:hover{background:var(--surface2);}
.notif-item:last-child{border-bottom:none;}
.notif-item.unread{background:var(--accent-light);}
.notif-icon{font-size:18px;flex-shrink:0;}
.notif-text{flex:1;}
.notif-time{font-size:11px;color:var(--muted);margin-top:2px;}
.notif-empty{padding:28px;text-align:center;color:var(--muted);font-size:13px;}

/* TABS */
.tabs{display:flex;gap:4px;padding:18px 32px 0;background:var(--surface);border-bottom:1px solid var(--border);}
.tab{background:none;border:none;font-family:'Onest',sans-serif;font-size:13px;font-weight:500;color:var(--muted);padding:9px 18px;cursor:pointer;transition:all .2s;border-bottom:2.5px solid transparent;margin-bottom:-1px;}
.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;}
.tab:hover{color:var(--text);}

/* CONTENT */
.content{padding:26px 32px;max-width:1280px;margin:0 auto;}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:26px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow2);}
.stat-num{font-family:'Unbounded',sans-serif;font-size:30px;font-weight:900;}
.stat-label{font-size:12px;color:var(--muted);margin-top:2px;}
.stat-dot{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:25px;}

/* SECTION TITLE */
.section-title{font-family:'Unbounded',sans-serif;font-size:13px;font-weight:700;margin-bottom:13px;
  margin-top: 15px;display:flex;align-items:center;gap:10px;color:var(--text);}
.section-title span{color:var(--muted);font-size:11px;font-weight:400;font-family:'Onest',sans-serif;}

/* FORM */
.add-form,.staff-new-form{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:22px;box-shadow:var(--shadow);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:13px;}
.form-field{display:flex;flex-direction:column;gap:5px;margin-bottom: 10px;}
.form-field label{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.3px;}
.form-field input,.form-field select,.form-field textarea{background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:10px 13px;color:var(--text);font-family:'Onest',sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;}
.form-field select option{background:var(--surface);}
.form-field textarea{resize:vertical;min-height:76px;}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(91,82,232,.08);}
.form-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:4px;}
.btn-outline{background:none;border:1.5px solid var(--border);border-radius:10px;padding:10px 18px;color:var(--muted);font-family:'Onest',sans-serif;font-size:13px;cursor:pointer;transition:all .2s;}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);}

/* FILTER */
.filter-row{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.filter-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:6px 15px;font-size:12px;font-family:'Onest',sans-serif;color:var(--muted);cursor:pointer;transition:all .2s;font-weight:500;}
.filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-light);font-weight:600;}
.filter-btn:hover{color:var(--text);}

/* TASKS */
.tasks-list{display:flex;flex-direction:column;gap:10px;}
.task-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:15px 18px;display:flex;align-items:center;gap:13px;transition:border-color .2s,transform .15s,box-shadow .2s;animation:fadeIn .3s ease;box-shadow:var(--shadow);}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.task-card:hover{border-color:var(--accent);transform:translateX(2px);box-shadow:var(--shadow2);}
.task-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.task-body{flex:1;min-width:0;}
.task-title{font-weight:600;font-size:14px;color:var(--text);}
.task-meta{font-size:12px;color:var(--muted);margin-top:3px;display:flex;gap:13px;flex-wrap:wrap;}
.task-actions{display:flex;gap:8px;flex-shrink:0;align-items:center;}
.status-badge{padding:4px 11px;border-radius:20px;font-size:10px;font-weight:700;font-family:'Unbounded',sans-serif;white-space:nowrap;}
.badge-created{background:rgba(91,82,232,.1);color:var(--created);}
.badge-assigned{background:rgba(245,158,11,.1);color:var(--assigned);}
.badge-sent_to_supply{background: rgb(20 156 158 / 0.15);color:var(--sent_to_supply);}
.badge-returned_to_executor{background: rgb(119 129 172 / 0.1);color:var(--returned_to_executor);}
.badge-completed{background:rgba(34,197,94,.1);color:var(--completed);}
.badge-closed{background: rgb(87 85 85 / 0.1);color:var(--closed);}

/* USERS TABLE */
.users-table{width:100%;border-collapse:separate;border-spacing:0 8px;}
.users-table th{font-size:11px;color:var(--muted);text-align:left;padding:0 15px 6px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;}
.users-table td{background:var(--surface);padding:13px 15px;font-size:13px;box-shadow:var(--shadow);}
.users-table td:first-child{border-radius:11px 0 0 11px;}
.users-table td:last-child{border-radius:0 11px 11px 0;}

/* USER HEADER */
.user-header{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:22px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);}
.user-avatar-big{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Unbounded',sans-serif;font-size:20px;font-weight:900;color:#fff;}
.user-name{font-family:'Unbounded',sans-serif;font-size:17px;font-weight:700;}
.user-role-text{font-size:12px;color:var(--muted);margin-top:3px;}

/* HINT BOX */
.hint-box{background:var(--accent-light);border:1.5px dashed rgba(91,82,232,.3);border-radius:12px;padding:13px 17px;font-size:12px;color:var(--text2);margin-bottom:20px;line-height:1.6;}
.hint-box strong{color:var(--accent);}

/* COMMENT SECTION */
.comments-section{margin-top:16px;border-top:1px solid var(--border);padding-top:14px;}
.comments-title{font-size:12px;font-weight:700;color:var(--text2);margin-bottom:10px;font-family:'Unbounded',sans-serif;}
.comment-item{background:var(--surface2);border-radius:10px;padding:10px 13px;margin-bottom:8px;font-size:13px;}
.comment-author{font-weight:600;color:var(--text);font-size:12px;}
.comment-role{font-size:10px;color:var(--muted);margin-left:6px;}
.comment-time{font-size:11px;color:var(--muted);float:right;}
.comment-text{margin-top:4px;color:var(--text2);line-height:1.5;}
.comment-input-row{display:flex;gap:8px;margin-top:10px;}
.comment-input-row input{flex:1;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:9px 12px;color:var(--text);font-family:'Onest',sans-serif;font-size:13px;outline:none;}
.comment-input-row input:focus{border-color:var(--accent);}
.comment-send{background:var(--accent);border:none;border-radius:9px;color:#fff;padding:9px 16px;cursor:pointer;font-size:13px;font-family:'Onest',sans-serif;transition:opacity .2s;}
.comment-send:hover{opacity:.85;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(30,20,60,.35);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--surface);border:1.5px solid var(--border);border-radius:22px;padding:28px;width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 48px rgba(91,82,232,.18);animation:slideUp .3s ease;}
.modal-title{font-family:'Unbounded',sans-serif;font-size:15px;font-weight:700;margin-bottom:16px;color:var(--text);}
.modal-btns{display:flex;gap:10px;margin-top:16px;}
.modal-btns .btn{margin-top:0;}

/* REPORTS */
.report-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:22px;}
.report-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--shadow);}
.report-card-title{font-size:12px;color:var(--muted);margin-bottom:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;}
.report-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px;}
.report-row:last-child{border-bottom:none;}
.report-val{font-weight:700;font-family:'Unbounded',sans-serif;font-size:14px;}
.history-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:13px 16px;margin-bottom:8px;display:flex;align-items:flex-start;gap:12px;box-shadow:var(--shadow);}
.history-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.history-body{flex:1;}
.history-title{font-size:13px;font-weight:600;}
.history-meta{font-size:12px;color:var(--muted);margin-top:2px;}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;z-index:999;background:var(--surface);border:1.5px solid var(--accent);border-radius:13px;padding:12px 20px;font-size:13px;color:var(--text);box-shadow:var(--shadow2);transform:translateY(80px);opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);pointer-events:none;max-width:300px;}
.toast.show{transform:none;opacity:1;}

.empty-state{text-align:center;padding:52px 20px;color:var(--muted);font-size:14px;}
.empty-icon{font-size:42px;margin-bottom:10px;}

@media(max-width:640px){
  .stats-row,.report-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .content{padding:14px;}
  .topnav,.tabs{padding-left:14px;padding-right:14px;}
  .modal{width:calc(100vw - 24px);}
  .notif-dropdown{width:calc(100vw - 24px);right:12px;}
}

.alert {
  padding: 20px 25px;
  border-radius: 20px;
  font-size: 12px;
  font-family: 'Unbounded', sans-serif;
  white-space: nowrap;
  margin-bottom: 20px;
  color: #353542;
}

.success {
  background: #52e86f30;
}

.danger {
  background: #e8525230;
}

.task-modal{

  display:none;

  position:fixed;

  inset:0;

  background:rgba(0,0,0,.45);

  z-index:9999;

  overflow:auto;

}

.task-modal.show{

  display:block;

}

.task-modal-content{

  width:900px;

  max-width:95%;

  background:#fff;

  margin:40px auto;

  border-radius:12px;

  padding:30px;

  position:relative;

}

.close-btn{
  position:absolute;
  top:20px;
  right:20px;
  font-size:24px;
  background:none;
  border:none;
  cursor:pointer;
}

.task-link{
  cursor:pointer;
  color:#2563eb;
  font-weight:600;
}

.task-link:hover{
  text-decoration:underline;
}


.modal-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:20px;
}

.info-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
  margin-bottom:25px;
}

.info-grid small{
  display:block;
  color:#888;
  margin-bottom:5px;
  font-size:13px;
}

.description-box{
  background:#f6f7fb;
  padding:18px;
  border-radius:12px;
  line-height:1.6;
}

.modal-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:30px;
}

.photo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:15px;
  margin-top:15px;
}

.photo-grid img{
  width:100%;
  border-radius:12px;
}

.comment-item{
  background:#fff;
  border:1px solid #ececec;
  padding:15px;
  border-radius:12px;
  margin-bottom:12px;
}

.comment-item strong{
  display:block;
  margin-bottom:4px;
}

.task-modal.open {
  display: block;
}

.task-modal {
  display: none;
  position: fixed;
  inset: 0;

  background: rgba(0, 0, 0, 0.5);

  justify-content: center;
  align-items: center;

  padding: 20px; /* отступы от краёв экрана */
  box-sizing: border-box;

  opacity: 0;
  transition: opacity .2s ease;

  z-index: 1050;
}

.task-modal.open {
  display: flex;
  opacity: 1;
}

.task-modal-content {
  width: min(900px, 100%);
  max-height: calc(100vh - 40px);

  overflow-y: auto;

  background: #fff;
  border-radius: 12px;

  transform: scale(.95);
  opacity: 0;

  transition: transform .2s ease, opacity .2s ease;
}

.task-modal.open .task-modal-content {
  transform: scale(1);
  opacity: 1;
}

input:disabled,
textarea:disabled,
select:disabled {
  background: #f8fafc;
  /*color: #6b7280;*/
  border: 1px solid #d1d5db;
  box-shadow: none;
  cursor: auto;
  opacity: 1;
}