:root{
  --bg:#f4f5f7; --panel:#fff; --ink:#1f2430; --muted:#7b8190; --line:#e6e8ee;
  --sidebar:#1b2030; --sidebar-ink:#c9cedb; --sidebar-on:#fff; --accent:#2f6df6;
  --ok:#43a047; --danger:#e53935; --radius:10px;
  --row-h:15px; /* высота слота 15 минут */
  --time-w:56px; --col-w:140px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:14px}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ===== Login ===== */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#1b2030}
.login-card{background:#fff;padding:32px;border-radius:16px;width:340px;box-shadow:0 20px 60px rgba(0,0,0,.35);display:flex;flex-direction:column;gap:14px}
.login-logo{font-size:20px;font-weight:700;text-align:center}
.login-logo span{color:var(--accent)}
.login-card h1{font-size:15px;font-weight:500;color:var(--muted);margin:0 0 6px;text-align:center}
.login-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.login-card input{padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:15px}
.login-card button{margin-top:6px;padding:11px;background:var(--accent);color:#fff;border:0;border-radius:8px;font-size:15px;font-weight:600}
.login-error{background:#fde8e8;color:#c0392b;padding:9px 12px;border-radius:8px;font-size:13px;text-align:center}

/* ===== App shell ===== */
.app{display:flex;height:100vh;overflow:hidden}
.sidebar{width:220px;flex:0 0 220px;background:var(--sidebar);color:var(--sidebar-ink);display:flex;flex-direction:column;padding:14px 0}
.brand{font-weight:700;font-size:17px;padding:4px 18px 14px;color:#fff}
.brand span{color:#6fa0ff}
.nav{display:flex;flex-direction:column;gap:2px;padding:6px 10px;overflow-y:auto}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--sidebar-ink);font-size:14px}
.nav a span{width:18px;text-align:center}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav a.on{background:var(--accent);color:#fff}
.nav-sec{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#5b6478;padding:14px 14px 6px}
.user-box{margin-top:auto;padding:14px 18px;border-top:1px solid rgba(255,255,255,.08);text-align:center}

/* ===== Аватарки ===== */
.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;object-fit:cover;background:#e7ecf5;color:var(--accent);font-weight:700;overflow:hidden;flex:0 0 auto;vertical-align:middle}
.avatar-lg{width:54px;height:54px;font-size:20px}
.avatar-sm{width:34px;height:34px;font-size:14px}
.avatar-btn{position:relative;display:inline-block;background:none;border:0;padding:0;margin:0 auto 8px;cursor:pointer}
.avatar-btn .avatar-lg{border:2px solid rgba(255,255,255,.18)}
.avatar-edit{position:absolute;right:-2px;bottom:-2px;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;border:2px solid var(--sidebar)}
.emp-avatar{cursor:default}
td .emp-avatar.editable{cursor:pointer}
td .emp-avatar.editable:hover{outline:2px solid var(--accent);outline-offset:1px}
.user-name{font-weight:600;color:#fff}
.user-role{font-size:12px;color:var(--muted)}
.logout{display:inline-block;margin-top:8px;font-size:13px;color:#6fa0ff}

/* Селектор заведения под логотипом */
.side-venue{padding:2px 12px 8px;margin:0 6px}
.side-venue:empty{display:none}
.side-venue .venue-sel{width:100%;min-width:0;background:#262c3e;color:#fff;border-color:#36405a;font-size:13px;font-weight:600;padding:9px 10px}
.side-venue .ro-badge:not([hidden]){display:inline-block;margin-top:8px}

.main{flex:1;overflow:auto;padding:22px 26px}
.main-full{padding:0;display:flex;flex-direction:column;overflow:hidden}

/* mini calendar */
.mini-cal{padding:4px 12px 8px;margin:0 6px 4px}
.mc-head{display:flex;justify-content:space-between;align-items:center;color:#fff;font-size:13px;margin-bottom:6px}
.mc-head button{background:none;border:0;color:var(--sidebar-ink);font-size:15px;padding:2px 6px;border-radius:6px}
.mc-head button:hover{background:rgba(255,255,255,.08)}
.mc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.mc-grid .dow{font-size:10px;color:#5b6478;text-align:center;padding:2px 0}
.mc-grid .day{font-size:11px;text-align:center;padding:4px 0;border-radius:6px;color:var(--sidebar-ink);cursor:pointer}
.mc-grid .day:hover{background:rgba(255,255,255,.1)}
.mc-grid .day.today{outline:1px solid #6fa0ff}
.mc-grid .day.sel{background:var(--accent);color:#fff}
.mc-grid .day.empty{visibility:hidden}

/* ===== Buttons / common ===== */
.btn{border:1px solid var(--line);background:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500}
.btn:hover{background:#f6f7f9}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:#2861e0}
.btn-danger{background:#fff;color:var(--danger);border-color:#f1c6c6}
.btn-danger:hover{background:#fdeaea}
.btn-light{background:#fff}
.btn-icon{padding:8px 12px;font-size:16px;line-height:1}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}
.page-head h1{font-size:20px;margin:0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}

/* ===== Journal top ===== */
.journal{display:flex;flex-direction:column;height:100%}
.journal-top{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-bottom:1px solid var(--line);background:#fff;gap:12px;flex-wrap:wrap}
.jt-left,.jt-right{display:flex;align-items:center;gap:8px}
.jt-date{font-size:16px;font-weight:600;margin-left:6px}
.date-pick{border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:13px}
.venue-sel{border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:14px;font-weight:500;min-width:200px}
.ro-badge{background:#fff3cd;color:#8a6d00;border:1px solid #ffe08a;padding:4px 10px;border-radius:20px;font-size:12px}

/* Масштаб журнала */
.zoom{display:flex;align-items:center;gap:6px}
.zoom-cap{font-size:12px;color:var(--muted)}
.zoom-level{font-size:12px;color:var(--muted);min-width:30px;text-align:center;font-variant-numeric:tabular-nums}
.zoom-range{width:120px;accent-color:var(--accent);cursor:pointer}
.btn-icon:disabled{opacity:.4;cursor:default}

/* ===== Grid ===== */
.grid-wrap{flex:1;overflow:auto;position:relative;background:#fff}
.grid-loading{padding:40px;color:var(--muted)}
.grid{position:relative;display:grid}
.grid-corner{position:sticky;top:0;left:0;z-index:6;background:#fff;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}

/* header row (groups + objects) */
.ghead{position:sticky;top:0;z-index:5;background:#fbfcfe;border-bottom:1px solid var(--line);display:flex}
.ghead-main{display:flex;flex-direction:column;flex:0 0 auto}
.ghead-groups{display:flex}
.ghead-group{border-right:2px solid var(--line);border-left:0;text-align:center;font-weight:700;font-size:12px;color:#fff;padding:5px 4px;text-transform:uppercase;letter-spacing:.3px}
.ghead-objs{display:flex}
.gobj{flex:0 0 var(--col-w);width:var(--col-w);text-align:center;font-size:12px;font-weight:600;color:var(--ink);padding:6px 4px;border-right:1px solid var(--line);background:#fbfcfe;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gobj.gsep{border-right:2px solid #cfd4e0}

.kind-bowling{background:#3f6fd1}
.kind-vip{background:#9b51e0}
.kind-restaurant{background:#e08a2f}

/* body */
.gbody{display:flex;position:relative}
.cols-area{display:flex;flex:0 0 auto}
.time-col{position:sticky;left:0;z-index:4;background:#fff;border-right:1px solid var(--line);flex:0 0 var(--time-w);width:var(--time-w)}
.time-cell{height:var(--row-h);font-size:10px;color:var(--muted);text-align:right;padding-right:6px;position:relative}
.time-cell.hour{border-top:1px solid var(--line)}
.time-cell.hour::after{content:attr(data-h);position:absolute;right:6px;top:-6px;background:#fff;padding:0 2px}

.col{flex:0 0 var(--col-w);width:var(--col-w);position:relative;border-right:1px solid var(--line)}
.col.gsep{border-right:2px solid #cfd4e0}
.slot{height:var(--row-h);border-top:1px dotted #eef0f4}
.slot.hour{border-top:1px solid var(--line)}
/* нерабочие часы — серые, без курсора-указателя */
.slot.off{background:repeating-linear-gradient(135deg,#eceef2,#eceef2 6px,#e4e7ec 6px,#e4e7ec 12px)}
.col:hover .slot{cursor:pointer}
.col:hover .slot.off{cursor:not-allowed}

/* booking card — две горизонтальные части: верх (время+статус), низ (данные+цвет записи) */
.bk{position:absolute;left:2px;right:2px;border-radius:6px;overflow:hidden;font-size:11px;line-height:1.2;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.18);border:1px solid rgba(0,0,0,.14);display:flex;flex-direction:column}
.bk:hover{filter:brightness(1.03);z-index:3}
.bk-top{flex:0 0 auto;font-weight:700;font-size:11px;text-align:center;padding:1px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk-bot{flex:1 1 auto;padding:2px 5px;overflow:hidden;min-height:0}
.bk-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk-phone{opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk-prepay{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk-comment{opacity:.8;white-space:normal;overflow-wrap:anywhere;word-break:break-word;font-style:italic}
.bk.ro{cursor:default}
/* ручки растягивания брони */
.bk-rs{position:absolute;left:0;right:0;height:8px;cursor:ns-resize;z-index:4}
.bk-rs-top{top:0}
.bk-rs-bot{bottom:0}
.bk:hover .bk-rs{background:rgba(0,0,0,.18)}
#confirmText{white-space:pre-line;font-size:14px;line-height:1.5}

/* выбор времени списками */
.time-pick{display:flex;align-items:center;gap:4px}
.time-pick select{padding:9px 6px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;color:var(--ink);background:#fff}

/* кастомный выбор цвета записи со свотчем у каждого пункта */
.color-picker{position:relative}
.cp-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:14px;color:var(--ink);text-align:left}
.cp-trigger:disabled{opacity:.6}
.cp-sw{width:18px;height:18px;border-radius:4px;border:1px solid rgba(0,0,0,.2);flex:0 0 auto;display:inline-block}
.cp-name{flex:1}
.cp-caret{color:var(--muted);font-size:12px}
.cp-list{position:absolute;left:0;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.14);z-index:10;max-height:220px;overflow:auto;padding:4px}
.cp-list[hidden]{display:none}
.cp-opt{display:flex;align-items:center;gap:8px;width:100%;padding:7px 9px;border:0;background:none;font-size:14px;color:var(--ink);text-align:left;border-radius:6px;cursor:pointer}
.cp-opt:hover{background:#f0f4ff}

/* статус-кнопки в модалке брони */
.status-btns{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:2px}
.st-btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:8px 10px;font-size:13px;color:var(--ink);font-weight:500;text-align:center}
.st-btn:hover{background:#f6f7f9}
.st-btn.on{background:var(--st-light);border-color:rgba(0,0,0,.2);font-weight:700;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.st-btn:disabled{opacity:.6;cursor:default}

/* ===== Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(15,20,30,.5);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal-overlay[hidden]{display:none}
.modal{background:#fff;border-radius:14px;width:520px;max-width:100%;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line)}
.modal-head h2{font-size:17px;margin:0}
.modal-close{background:none;border:0;font-size:24px;color:var(--muted);line-height:1}
.modal-body{padding:18px 20px;overflow:auto;display:flex;flex-direction:column;gap:14px}
.modal-body label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted);font-weight:500}
.modal-body input,.modal-body select,.modal-body textarea{padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;color:var(--ink)}
.m-row{display:flex;gap:12px}
.m-row label{flex:1}
.m-row label.grow{flex:1}
.m-place{font-size:16px;font-weight:700;background:#f0f4ff;color:var(--accent);padding:10px 14px;border-radius:8px}
.m-place small{display:block;color:var(--muted);font-weight:500;font-size:12px;margin-top:2px}
.m-meta{font-size:12px;color:var(--muted);border-top:1px dashed var(--line);padding-top:10px}
.modal-foot{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--line)}
.modal-foot .spacer{flex:1}
.color-sel{}
.color-opt-row{display:flex;align-items:center;gap:8px}
.suggest{position:relative;background:#fff;border:1px solid var(--line);border-radius:8px;margin-top:2px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:5;max-height:200px;overflow:auto}
.suggest div{padding:8px 11px;cursor:pointer;font-size:13px;color:var(--ink)}
.suggest div:hover{background:#f0f4ff}
.suggest small{color:var(--muted)}

/* ===== Tables (clients, employees) ===== */
.table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.table th,.table td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px}
.table th{background:#fafbfc;color:var(--muted);font-weight:600;font-size:12px}
.table th.sortable{cursor:pointer;user-select:none}
.table th.sortable:hover{color:var(--ink)}
.sort-ind{font-size:10px;color:var(--accent)}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background:#fafbff}
.row-actions{display:flex;gap:6px}
.tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;background:#eef1f6;color:#555}
.tag.admin{background:#e7f0ff;color:#2861e0}
.tag.off{background:#fde8e8;color:#c0392b}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar input,.toolbar select{padding:8px 12px;border:1px solid var(--line);border-radius:8px;font-size:13px}
.search{min-width:240px}

/* analytics */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.stat .v{font-size:26px;font-weight:700}
.stat .l{color:var(--muted);font-size:13px;margin-top:4px}
.bar-wrap{background:#eef1f6;border-radius:6px;height:10px;overflow:hidden}
.bar{height:100%;background:var(--accent)}

/* profile */
.profile-grid{display:grid;grid-template-columns:300px 1fr;gap:18px}
@media(max-width:780px){.profile-grid{grid-template-columns:1fr}}
.empty{color:var(--muted);padding:30px;text-align:center}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1f2430;color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;z-index:100;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.toast.err{background:#c0392b}
