:root{
  --bg:#f4f7f9; --card:#fff; --ink:#1e1e1e; --muted:#727272; --line:#e2e8ec;
  --brand:#0185bd; --brand-d:#0e668c; --accent:#00c3ff;
  --brand-grad:linear-gradient(180deg,#0185bd 0%,#0a5577 100%);
  --pre:#0185bd; --post:#b737e6;
  --ok:#15803d; --no:#cc0000; --danger:#cc0000;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Open Sans",Roboto,-apple-system,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:15px}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.5rem;margin:.2em 0 .6em}
h2{font-size:1.15rem;margin:1.4em 0 .5em}

/* top bar */
.topbar{display:flex;align-items:center;gap:1.5rem;background:var(--brand-grad);color:#fff;padding:1.1rem 1.2rem;box-shadow:0 2px 10px rgba(1,133,189,.18)}
.topbar a{color:#fff}
.topbar .brand{font-weight:700;font-size:1.05rem;display:flex;align-items:center;gap:.6rem}
.topbar .brand:hover{text-decoration:none}
.topbar .brand .logo-icon{height:34px;width:34px;border-radius:50%;background:#fff;flex:none}
.topbar .brand em{font-style:normal;font-weight:400;opacity:.85}
.topbar nav{display:flex;gap:1.1rem}
.topbar nav a{opacity:.92}
.topbar nav a:hover{opacity:1;text-decoration:none;border-bottom:2px solid #fff}
.topbar .user{margin-left:auto;display:flex;align-items:center;gap:.8rem;font-size:.9rem}
.topbar .logout{opacity:.85}

/* app shell: topbar fixed on top, full-height fixed sidebar, content scrolls */
html,body{height:100%}
body.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}
body.app .topbar{flex:none}

/* layout: sidebar (Юрлица) | content (Водители) */
.layout{display:flex;align-items:stretch;flex:1;min-height:0}
.sidebar{width:330px;flex:none;background:#fbfcfd;border-right:2px solid #cbd7de;
  padding:1rem .8rem;overflow-y:auto;
  box-shadow:3px 0 8px -5px rgba(0,0,0,.18)}
.btn-add-org{display:block;text-align:center;background:var(--brand);color:#fff;border-radius:8px;
  padding:.6rem;font-weight:600;font-size:.9rem;transition:background .15s,box-shadow .15s}
.btn-add-org:hover{background:var(--brand-d);text-decoration:none;box-shadow:0 3px 12px rgba(1,133,189,.28)}
.sidebar-label{display:flex;align-items:center;justify-content:space-between;
  margin:1rem .15rem .55rem;font-size:.72rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--brand-d)}
.sidebar-label span{background:#e3eef4;color:var(--brand-d);font-size:.72rem;font-weight:700;
  border-radius:20px;padding:.05rem .5rem;letter-spacing:0}

.org-list{display:flex;flex-direction:column;gap:.55rem}
.org-card{position:relative;background:#fff;border:1px solid #d7e0e6;border-radius:12px;
  box-shadow:0 1px 2px rgba(16,40,60,.04);
  transition:border-color .15s,background .15s,box-shadow .15s}
.org-card:hover{border-color:var(--brand);box-shadow:0 4px 14px rgba(1,133,189,.16);transform:translateY(-1px)}
.org-card.active{border-color:var(--brand);background:#f5fbfe;box-shadow:0 0 0 1px var(--brand),0 4px 14px rgba(1,133,189,.16)}
.org-card-main{display:block;padding:.7rem .8rem;color:var(--ink)}
.org-card-main:hover{text-decoration:none}
.org-card .org-name{display:block;font-weight:700;font-size:.92rem;line-height:1.3;color:#16323f;padding-right:2rem}
.org-edit{position:absolute;top:.5rem;right:.5rem;width:27px;height:27px;border-radius:7px;
  border:1px solid transparent;background:#eef4f8 center/15px 15px no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230185bd' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4 12.5-12.5z'/%3E%3C/svg%3E")}
.org-edit:hover{background-color:#dbeaf3;border-color:var(--brand);text-decoration:none}
.oc-line{display:flex;align-items:center;gap:.4rem;font-size:.77rem;color:var(--muted);margin-top:.3rem}
.oc-line::before{content:"";width:13px;height:13px;flex:none;background:center/contain no-repeat}
.oc-person::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23808a91' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E")}
.oc-phone::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23808a91' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E")}
.org-chip{display:inline-flex;align-items:center;gap:.4rem;margin-top:.6rem;
  background:#eaf6fb;color:var(--brand-d);border-radius:20px;padding:.2rem .6rem;font-size:.75rem}
.org-chip::before{content:"";width:13px;height:13px;flex:none;background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230185bd' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E")}
.org-chip b{color:var(--brand);font-weight:700}
.org-empty{color:var(--muted);font-size:.85rem;padding:.4rem}

/* search bar */
.search-bar{display:flex;gap:.5rem;margin:0 0 1.3rem;max-width:640px}
.search-bar input{flex:1;min-width:0;padding:.6rem .9rem;border:1px solid var(--line);
  border-radius:9px;font-size:.95rem;background:#fff}
.search-bar input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(1,133,189,.13)}
.search-bar button{flex:none}
.form-archive{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}

/* danger zone (удаление/архив) */
.danger-zone{margin-top:1.5rem;border:1px solid #f0c9c9;background:#fff7f7;
  border-radius:12px;padding:1rem 1.1rem;max-width:680px}
.danger-zone h3{margin:.1rem 0 .6rem;font-size:1rem;color:#b91c1c}
.danger-zone hr{border:none;border-top:1px solid #f0d4d4;margin:1rem 0}
.confirm-row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-top:.5rem}
.confirm-row .confirm-input{padding:.5rem .7rem;border:1px solid var(--line);border-radius:8px;
  font-size:.95rem;min-width:240px;flex:1}
.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:8px;
  padding:.5rem .9rem;font-size:.92rem;cursor:pointer;flex:none}
.btn-danger:hover{background:#9b1414}
.btn-danger:disabled{background:#e3a3a3;cursor:not-allowed}
.btn-danger:disabled:hover{background:#e3a3a3}

/* modal (карточка водителя) */
.modal-overlay{position:fixed;inset:0;background:rgba(16,40,60,.5);display:flex;
  align-items:center;justify-content:center;padding:2vh 1rem;z-index:50}
.modal-overlay[hidden]{display:none}
.modal{background:#fff;border-radius:14px;width:100%;max-width:760px;position:relative;
  padding:1.3rem 1.4rem;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:92vh;overflow-y:auto}
.modal-close{position:absolute;top:.5rem;right:.6rem;background:none;color:var(--muted);
  font-size:1.6rem;line-height:1;padding:.05rem .4rem;border-radius:8px}
.modal-close:hover{background:#eef2f5;color:var(--ink);box-shadow:none}
.modal-head{display:flex;align-items:center;gap:1rem;justify-content:space-between;
  padding-right:2rem;margin-bottom:.8rem;cursor:move;user-select:none}
.modal.dragging{cursor:grabbing;box-shadow:0 24px 70px rgba(0,0,0,.38)}
.modal .modal-form{border:none;padding:0;margin:0;max-width:none;background:none}
.modal-title{margin:0;font-size:1.25rem}
.modal-tabs{display:flex;gap:.3rem;border-bottom:2px solid var(--line);margin-bottom:1rem}
.modal-tab{background:none;color:var(--muted);border:none;border-bottom:2px solid transparent;
  border-radius:0;padding:.5rem .8rem;margin-bottom:-2px;font-size:.92rem;font-weight:600;cursor:pointer}
.modal-tab:hover{background:none;color:var(--ink);box-shadow:none}
.modal-tab.active{color:var(--brand);border-bottom-color:var(--brand)}
.modal-actions{margin-top:1rem;display:flex;gap:.5rem;flex-wrap:wrap}
body.modal-open{overflow:hidden}

.container{flex:1;min-width:0;max-width:1080px;margin:1.4rem auto;padding:0 1.2rem;overflow-y:auto}
.container.wide{max-width:none}

/* кнопка над списком водителей (в стиле «Добавить организацию», но не на всю ширину) */
.list-head{margin:.4rem 0 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.list-head .org-title{margin:0;font-size:1.3rem;text-align:right}
.btn-add-inline{display:inline-block;width:auto;padding:.55rem 1.1rem;flex:none}
.head-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.crumbs{color:var(--muted);font-size:.9rem;margin:0 0 .3rem}
.muted{color:var(--muted)}
.small{font-size:.82rem}
.nowrap{white-space:nowrap}
.muted-row td{opacity:.55}

/* cards */
.cards{display:flex;gap:1rem;flex-wrap:wrap;margin:1rem 0}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1rem 1.3rem;min-width:130px}
.card .num{font-size:1.9rem;font-weight:700}
.card .lbl{color:var(--muted);font-size:.85rem}
.card.danger .num{color:var(--no)}

/* tables */
table.grid{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}
table.grid th,table.grid td{padding:.55rem .7rem;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
table.grid th{background:#eef6fa;font-size:.8rem;text-transform:uppercase;letter-spacing:.02em;color:var(--brand-d)}
table.grid tr:last-child td{border-bottom:none}
/* компактная таблица */
.grid.compact th,.grid.compact td{padding:.32rem .55rem;font-size:.88rem}

/* настраиваемая таблица: перетаскивание и изменение ширины колонок */
.grid.colcustom{table-layout:fixed}
.grid.colcustom th{position:relative;cursor:grab;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:none}
.grid.colcustom td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.grid.colcustom th.dragging{opacity:.45}
.grid.colcustom th.drop-target{box-shadow:inset 3px 0 0 var(--brand)}
.grid.colcustom th[data-col="num"]{width:58px}
.grid.colcustom th[data-col="birth"]{width:130px}
.grid.colcustom th[data-col="sex"]{width:70px}
.grid.colcustom th[data-col="phone"]{width:150px}
.grid.colcustom th[data-col="pre"]{width:140px}
.grid.colcustom th[data-col="post"]{width:150px}
.col-resizer{position:absolute;top:0;right:0;bottom:0;width:7px;cursor:col-resize}
.col-resizer:hover{background:var(--brand)}

.flash{padding:.55rem .8rem;border-radius:8px;margin:.6rem 0;max-width:420px;font-size:.9rem}
.flash.ok{background:#dcfce7;color:#166534}
.flash.err{background:#fee2e2;color:#991b1b}
.ok{color:var(--ok);font-weight:600}
.no{color:var(--no);font-weight:700}
.tag{display:inline-block;background:#fef3c7;color:#92400e;font-size:.72rem;padding:.05rem .4rem;border-radius:6px}

/* meta line */
.meta{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;color:var(--ink);margin:.3rem 0 .6rem}
.meta span{font-size:.9rem;color:var(--muted)}

/* buttons */
.btn,button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:.5rem .9rem;font-size:.92rem;cursor:pointer;display:inline-block;transition:background .15s,box-shadow .15s}
.btn:hover,button:hover{background:var(--brand-d);text-decoration:none;box-shadow:0 3px 12px rgba(1,133,189,.28)}
.btn-link{background:none;color:var(--brand);padding:.4rem .5rem;border:1px solid var(--line);border-radius:8px}
.btn-link.danger{color:var(--danger);border-color:#f3c4c4}
.btn-link.small{padding:.15rem .45rem;font-size:.85rem}
.mini{display:inline-block;font-size:.78rem;padding:.12rem .45rem;border-radius:6px;margin-right:.25rem;color:#fff}
.mini:hover{text-decoration:none;opacity:.9}
.mini.pre{background:var(--pre)}
.mini.post{background:var(--post)}
form.inline{display:inline}

/* forms */
.form{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1.1rem;max-width:680px}
.form label{display:block;margin:.5rem 0;font-size:.85rem;color:var(--muted)}
.form input,.form select,.form textarea{width:100%;margin-top:.2rem;padding:.5rem .6rem;border:1px solid var(--line);border-radius:8px;font-size:.95rem;color:var(--ink);background:#fff}
.form .row{display:flex;gap:.8rem;flex-wrap:wrap}
.form .row label{flex:1;min-width:130px}
.form .row .field{flex:1;min-width:130px}
.form .field-label{display:block;margin:.5rem 0 .15rem;font-size:.85rem;color:var(--muted)}
.form .radio-row{display:flex;gap:.6rem;align-items:center;padding:.5rem 0}
.form .radio-row .radio{display:flex;align-items:center;gap:.4rem;margin:0;color:var(--ink);font-size:.95rem}
.form .radio-row .radio input{width:auto;margin:0}
.form .check{display:flex;align-items:center;gap:.5rem;color:var(--ink)}
.form .check input{width:auto;margin:0}
.form .actions{margin-top:.9rem;display:flex;gap:.7rem;align-items:center}
.form.exam{border-top:4px solid var(--line)}
.form.exam.pre{border-top-color:var(--pre)}
.form.exam.post{border-top-color:var(--post)}

.two-col{display:flex;gap:1.2rem;flex-wrap:wrap}
.two-col section{flex:1;min-width:320px}

details.block{margin:1.2rem 0;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:.4rem 1rem}
details.block summary{cursor:pointer;font-weight:600;padding:.5rem 0;color:var(--brand)}
details.block .form{border:none;padding:.4rem 0 1rem;max-width:none}

.filters{display:flex;gap:.8rem;flex-wrap:wrap;align-items:end;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:.9rem;margin:.8rem 0}
.filters label{font-size:.8rem;color:var(--muted);display:flex;flex-direction:column;gap:.2rem}
.filters input,.filters select{padding:.45rem .55rem;border:1px solid var(--line);border-radius:8px}

/* login */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#00c3ff 0%,#0185bd 45%,#0e668c 100%)}
.login-card{background:#fff;border-radius:16px;padding:2rem;width:330px;box-shadow:0 12px 40px rgba(0,0,0,.25)}
.login-card .login-logo{display:block;width:100%;max-width:170px;height:auto;margin:.2rem auto .6rem}
.login-card .sub{margin:.2rem 0 1.2rem;text-align:center;color:var(--muted);font-size:.9rem}
.login-card label{display:block;margin:.6rem 0;font-size:.85rem;color:var(--muted)}
.login-card input{width:100%;margin-top:.25rem;padding:.55rem .65rem;border:1px solid var(--line);border-radius:8px;font-size:1rem}
.login-card button{width:100%;margin-top:1rem;padding:.6rem}
.login-card .error{background:#fee2e2;color:#991b1b;padding:.5rem .7rem;border-radius:8px;font-size:.88rem}

@media (max-width:860px){
  body.app{display:block;height:auto;overflow:visible}
  .layout{flex-direction:column}
  .sidebar{width:auto;overflow:visible;border-right:none;border-bottom:1px solid var(--line);box-shadow:none}
  .container{overflow:visible}
  .org-list{flex-direction:row;flex-wrap:wrap}
  .org-card{flex:1 1 150px}
}
@media (max-width:640px){
  .topbar{flex-wrap:wrap;gap:.6rem 1rem}
  .container{margin:1rem auto}
  table.grid{display:block;overflow-x:auto;white-space:nowrap}
}
