/* ============ THEME VARIABLES ============ */
:root{
  --bg:#F4F6FA;--surface:#fff;--surface2:#F7F8FA;--border:rgba(0,0,0,0.1);--border2:rgba(0,0,0,0.18);
  --txt:#1A1A1A;--txt2:#666;--txt3:#999;
  --navy:#0D2545;--copper:#B87333;--copper-light:#E8A96A;
  --sb-active:rgba(184,115,51,0.2);
  --badge-part-bg:#E6EEF9;--badge-part-c:#0C447C;
  --badge-full-bg:#E8F5EE;--badge-full-c:#1A6A40;
  --badge-dev-bg:#FEF0E6;--badge-dev-c:#7A4A10;
  --badge-prep-bg:#FFF9E6;--badge-prep-c:#7A6010;
  --badge-set-bg:#F0E8F6;--badge-set-c:#5A2A8A;
  --pr-bg:#F4F6FA;--pr-c:#888;--pu-bg:#FEF0E6;--pu-c:#7A4A10;
  --pw-bg:#E6EEF9;--pw-c:#0C447C;--px-bg:#E8F5EE;--px-c:#1A6A40;
  --pdf-bg:#FCEAEA;--pdf-c:#791F1F;--xls-bg:#E8F5EE;--xls-c:#1A6A40;--doc-bg:#E6EEF9;--doc-c:#0C447C;
  --link-c:#1A5FA8;--inp-bg:#F7F8FA;
  --ok-bg:#E8F5EE;--ok-c:#1A6A40;
  --warn-bg:#FFF4E5;--warn-c:#8A4B0A;
  --danger-bg:#FCEAEA;--danger-c:#791F1F;
  --icon-c:#5B6472;--icon-c-hover:#1A1A1A;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
[data-theme=dark]{
  --bg:#111827;--surface:#1F2937;--surface2:#161F2B;--border:rgba(255,255,255,0.1);--border2:rgba(255,255,255,0.18);
  --txt:#F3F4F6;--txt2:#9CA3AF;--txt3:#6B7280;
  --badge-part-bg:#1E3A5F;--badge-part-c:#93C5FD;--badge-full-bg:#14432A;--badge-full-c:#6EE7B7;
  --badge-dev-bg:#431C07;--badge-dev-c:#FCA97A;--badge-prep-bg:#3D3408;--badge-prep-c:#FDE68A;--badge-set-bg:#2D1B4E;--badge-set-c:#C4B5FD;
  --pr-bg:#1F2937;--pr-c:#9CA3AF;--pu-bg:#431C07;--pu-c:#FCA97A;--pw-bg:#1E3A5F;--pw-c:#93C5FD;--px-bg:#14432A;--px-c:#6EE7B7;
  --pdf-bg:#3B1212;--pdf-c:#FCA5A5;--xls-bg:#14432A;--xls-c:#6EE7B7;--doc-bg:#1E3A5F;--doc-c:#93C5FD;
  --link-c:#60A5FA;--inp-bg:#111827;
  --ok-bg:#14432A;--ok-c:#6EE7B7;
  --warn-bg:#3D3408;--warn-c:#FDE68A;
  --danger-bg:#3B1212;--danger-c:#FCA5A5;
  --icon-c:#D1D5DB;--icon-c-hover:#F9FAFB;
}

/* ============ RESET / BASE ============ */
*{box-sizing:border-box;margin:0;padding:0;}
html,body{font-family:var(--font-sans);background:var(--bg);color:var(--txt);}
body{min-height:100vh;}
a{color:inherit;}
input,select,textarea,button{font-family:var(--font-sans);}

.layout{display:flex;min-height:100vh;background:var(--bg);}

/* ============ SIDEBAR ============ */
.sb{width:210px;flex-shrink:0;background:var(--navy);display:flex;flex-direction:column;min-height:100vh;}
.sb-logo{padding:18px 16px 14px;border-bottom:0.5px solid rgba(255,255,255,0.1);display:flex;align-items:center;gap:9px;}
.sb-li{width:34px;height:34px;background:var(--copper);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:17px;overflow:hidden;}
.sb-li img{width:100%;height:100%;object-fit:cover;display:block;}
.sb-li.no-bg{background:transparent;}
.sb-lt{color:#fff;font-size:14px;font-weight:500;}
.sb-ls{color:rgba(255,255,255,0.45);font-size:10px;}
.sb-nav{padding:14px 9px;flex:1;}
.nl{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,0.3);padding:13px 9px 6px;}
.ni{display:flex;align-items:center;gap:9px;padding:8px 9px;border-radius:8px;color:rgba(255,255,255,0.6);font-size:12.5px;cursor:pointer;margin-bottom:2px;}
.ni:hover{background:var(--sb-active);color:var(--copper-light);}
.ni.act{background:var(--sb-active);color:var(--copper-light);}
.ni i{font-size:16px;}
.sb-footer{padding:12px 11px;border-top:0.5px solid rgba(255,255,255,0.1);display:flex;flex-direction:column;gap:9px;}
.sb-usr{display:flex;align-items:center;gap:9px;}
.av{width:30px;height:30px;border-radius:50%;background:var(--copper);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:#fff;flex-shrink:0;}
.un{color:#fff;font-size:12.5px;font-weight:500;}
.ur{color:rgba(255,255,255,0.4);font-size:10.5px;}
.sb-logout-btn{margin-left:auto;background:rgba(255,255,255,0.07);border:none;}
.sb-logout-btn i{color:rgba(255,255,255,0.55);}
.theme-switch{display:flex;background:rgba(255,255,255,0.07);border-radius:8px;padding:3px;gap:2px;}
.theme-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;border-radius:6px;cursor:pointer;color:rgba(255,255,255,0.45);font-size:9.5px;text-align:center;transition:background .15s,color .15s;}
.theme-opt i{font-size:14px;}
.theme-opt:hover{color:rgba(255,255,255,0.7);}
.theme-opt.active{background:var(--copper);color:#fff;}

/* ============ MAIN / PAGES ============ */
.main{flex:1;display:flex;flex-direction:column;min-width:0;}
.page{display:none;flex:1;flex-direction:column;}
.page.active{display:flex;}

/* ============ TOPBAR ============ */
.topbar{background:var(--surface);border-bottom:0.5px solid var(--border);padding:0 26px;height:56px;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.topbar-title{font-size:15px;font-weight:500;color:var(--txt);}
.bc{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--txt2);}
.bc a{color:var(--copper);text-decoration:none;cursor:pointer;}
.sp{flex:1;}

/* ============ BUTTONS ============ */
.bp{background:var(--navy);color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px;cursor:pointer;}
.bo{background:transparent;color:var(--txt2);border:0.5px solid var(--border2);border-radius:8px;padding:7px 13px;font-size:12.5px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;}
.bo:hover{background:var(--surface2);}
.bd{background:var(--pdf-bg);color:var(--pdf-c);border:0.5px solid var(--pdf-bg);border-radius:8px;padding:6px 13px;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;}
.bd-solid{background:#A32D2D;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;}
.bg{background:none;border:none;cursor:pointer;font-size:12.5px;color:var(--copper);display:inline-flex;align-items:center;gap:5px;}
.ib{width:25px;height:25px;border-radius:6px;border:0.5px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;}
.ib i{font-size:12.5px;color:var(--icon-c);}
.ib:hover i{color:var(--icon-c-hover);}
.actions-cell{display:flex;gap:4px;}

/* ============ CONTENT WRAPPER ============ */
.cnt{padding:22px 26px;overflow-y:auto;}
.flt{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;align-items:center;}

.sb-sys-monitor{display:flex;flex-direction:column;gap:8px;padding:10px 2px 2px;}
.sb-sys-meter-label{display:flex;justify-content:space-between;align-items:baseline;font-size:9.5px;color:rgba(255,255,255,0.45);margin-bottom:3px;text-transform:uppercase;letter-spacing:0.03em;}
.sb-sys-meter-label span{font-size:10px;color:rgba(255,255,255,0.6);text-transform:none;letter-spacing:0;}
.sb-sys-meter-bar{height:4px;border-radius:2px;background:rgba(255,255,255,0.1);overflow:hidden;}
.sb-sys-meter-fill{height:100%;border-radius:2px;background:var(--ok-c);transition:width .3s ease,background-color .3s ease;}
.sb-sys-meter-fill.sys-warn{background:var(--warn-c);}
.sb-sys-meter-fill.sys-critical{background:var(--danger-c);}
@media (max-width:600px){
  .sys-monitor-grid{grid-template-columns:1fr;gap:12px;}
}
.sw{position:relative;}
.sw i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--txt3);font-size:15px;}
.sw input{background:var(--surface);border:0.5px solid var(--border);border-radius:8px;padding:7px 12px 7px 32px;font-size:12.5px;color:var(--txt);width:260px;}
.sw.sw-full{flex:1;}
.sw.sw-full input{width:100%;}
.sel{background:var(--surface);border:0.5px solid var(--border);border-radius:8px;padding:7px 11px;font-size:12.5px;color:var(--txt2);}

/* ============ OBJECT CARDS GRID (main page) ============ */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.card{background:var(--surface);border-radius:12px;border:0.5px solid var(--border);overflow:hidden;cursor:pointer;}
.card:hover{border-color:var(--copper);}
.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;padding:11px 13px 9px;}
.card-addr{font-size:13.5px;font-weight:500;color:var(--txt);}
.badge{font-size:10.5px;font-weight:500;padding:3px 8px;border-radius:20px;white-space:nowrap;}
.b-part{background:var(--badge-part-bg);color:var(--badge-part-c);}
.b-full{background:var(--badge-full-bg);color:var(--badge-full-c);}
.b-dev{background:var(--badge-dev-bg);color:var(--badge-dev-c);}
.b-prep{background:var(--badge-prep-bg);color:var(--badge-prep-c);}
.b-set{background:var(--badge-set-bg);color:var(--badge-set-c);}
.card-img{width:100%;aspect-ratio:1/1;overflow:hidden;background:var(--surface2);}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;}
.card-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
.card-img-ph i{font-size:36px;color:var(--txt3);}
.card-meta{padding:11px 13px;display:flex;gap:13px;flex-wrap:wrap;align-items:center;}
.card-meta-stack{padding:11px 13px 14px;display:flex;flex-direction:column;gap:6px;}
.meta-row{font-size:11.5px;color:var(--txt2);display:flex;align-items:center;gap:5px;}
.meta-row .meta-v{font-weight:500;color:var(--txt);}
.meta{font-size:11.5px;color:var(--txt2);display:flex;align-items:center;gap:4px;}
.meta-v{font-weight:500;color:var(--txt);}
.meta-fill{font-weight:500;color:var(--copper);}
.meta-fill.full{color:var(--badge-full-c);}
.meta-fill.zero{color:var(--txt3);font-weight:400;}
.card-footer{padding:8px 13px;border-top:0.5px solid var(--border);display:flex;gap:11px;}
.tag{font-size:10.5px;color:var(--txt2);display:flex;align-items:center;gap:3px;}
.pgn{margin-top:24px;display:flex;justify-content:center;gap:6px;}
.pg{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12.5px;cursor:pointer;border:0.5px solid var(--border);color:var(--txt2);background:var(--surface);}
.pg.a{background:var(--navy);color:#fff;border-color:var(--navy);}

/* ============ GENERIC SECTION / CARD CONTAINER ============ */
.sec{background:var(--surface);border-radius:12px;border:0.5px solid var(--border);margin-bottom:14px;overflow:hidden;}
.sh{padding:12px 16px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.st{font-size:13.5px;font-weight:500;color:var(--txt);display:flex;align-items:center;gap:7px;}
.st i{font-size:15px;color:var(--copper);}
.sb2{padding:14px 16px;}
.stat-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:500;padding:4px 11px;border-radius:20px;background:var(--badge-part-bg);color:var(--badge-part-c);}

/* ============ OBJECT CARD PAGE LAYOUT ============ */
.obj-layout{display:grid;grid-template-columns:1fr 280px;gap:18px;padding:22px 26px;}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.gphoto{border-radius:8px;overflow:hidden;aspect-ratio:1/1;position:relative;background:var(--surface2);}
.gphoto img{width:100%;height:100%;object-fit:cover;}
.photo-del{position:absolute;top:4px;right:4px;width:19px;height:19px;background:rgba(121,31,31,0.85);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.photo-del i{font-size:10px;color:#fff;}
.photo-download{position:absolute;top:4px;right:27px;width:19px;height:19px;background:rgba(0,0,0,0.55);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.photo-download i{font-size:10px;color:#fff;}
.photo-add{border:1.5px dashed var(--border2);background:var(--surface2);border-radius:8px;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.photo-add i{font-size:20px;color:var(--txt3);}

.fields{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.pwd-gen-row{display:flex;gap:6px;align-items:center;}
.pwd-gen-row input{flex:1;font-family:'SF Mono','Consolas',monospace;letter-spacing:0.02em;}
.pwd-gen-row .ib{flex-shrink:0;background:var(--surface2);border-radius:7px;width:32px;height:32px;justify-content:center;}
.field label{font-size:10.5px;color:var(--txt2);display:block;margin-bottom:4px;}
.field input,.field select,.field textarea{width:100%;background:var(--inp-bg);border:0.5px solid var(--border);border-radius:8px;padding:7px 9px;font-size:12.5px;color:var(--txt);}
.field textarea{width:100%;background:var(--inp-bg);border:0.5px solid var(--border);border-radius:8px;padding:7px 9px;font-size:12.5px;color:var(--txt);min-height:42px;resize:none;overflow:hidden;line-height:1.5;}
.ff{grid-column:1/-1;}
.field-readonly{background:var(--surface2);border:0.5px solid var(--border);border-radius:8px;padding:7px 9px;font-size:12.5px;color:var(--txt);font-weight:500;display:flex;align-items:center;}

.tbl-wrap{overflow-x:auto;}
.tbl-hint{font-size:11px;color:var(--txt2);padding:10px 16px 0;display:flex;align-items:center;gap:6px;}
.tbl-hint i{color:var(--copper);font-size:13px;}
.tbl{width:100%;border-collapse:collapse;font-size:12.5px;}
.tbl th{text-align:left;font-size:10.5px;font-weight:500;color:var(--txt2);padding:0 8px 9px;border-bottom:0.5px solid var(--border);white-space:nowrap;}
.tbl td{padding:2px 2px;border-bottom:0.5px solid var(--border);color:var(--txt);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.rn{width:26px;height:26px;background:var(--surface2);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--navy);margin:6px 0 6px 6px;cursor:text;border:1px solid transparent;}
.rn:hover{border-color:var(--border);}
.rn:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 2px rgba(184,115,51,0.15);background:var(--surface);}
[data-theme=dark] .rn{color:var(--copper-light);}
.te{color:var(--txt3);font-style:italic;}
.chk{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border2);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.chk i{opacity:0;font-size:12px;color:#fff;transition:opacity .12s ease;}
.chk.on{background:var(--copper);border-color:var(--copper);}
.chk.on i{opacity:1;}
.chk-cell{display:flex;justify-content:center;}
.tcell{display:block;width:100%;padding:8px 6px;border-radius:6px;border:1px solid transparent;background:transparent;color:inherit;font-size:inherit;font-family:inherit;cursor:text;min-height:34px;}
.tcell:hover{background:var(--surface2);border-color:var(--border);}
.tcell:focus{outline:none;background:var(--surface);border-color:var(--copper);box-shadow:0 0 0 2px rgba(184,115,51,0.15);}

.docs{display:flex;flex-direction:column;gap:8px;}
.doc{display:flex;align-items:center;gap:10px;padding:9px 11px;background:var(--surface2);border-radius:8px;border:0.5px solid var(--border);}
.dico{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.dico.p{background:var(--pdf-bg);} .dico.p i{color:var(--pdf-c);}
.dico.x{background:var(--xls-bg);} .dico.x i{color:var(--xls-c);}

/* ============ READ-ONLY MODE (право "только читать" на объект) ============ */
/* Каскадно отключает интерактивность всех полей/чекбоксов/кнопок внутри
   карточки объекта, кроме элементов с классом .ro-allow (например, кнопка
   скачивания документа остаётся активной — её доступность регулируется
   отдельно правом "download", не общим readonly-режимом). */
.obj-readonly .tcell,
.obj-readonly .rn{cursor:default;pointer-events:none;}
.obj-readonly .tcell:hover,
.obj-readonly .rn:hover{background:transparent;border-color:transparent;}
.obj-readonly .chk{cursor:default;pointer-events:none;opacity:0.7;}
.obj-readonly .photo-add{cursor:default;pointer-events:none;opacity:0.4;}
.obj-readonly .photo-del{display:none;}
.obj-readonly .ib:not(.ro-allow){cursor:default;pointer-events:none;opacity:0.35;}
.obj-readonly .ib:not(.ro-allow):hover{background:transparent;}
.dico.d{background:var(--doc-bg);} .dico.d i{color:var(--doc-c);}
.dn{font-size:12.5px;font-weight:500;color:var(--txt);flex:1;}
.ds{font-size:10.5px;color:var(--txt2);}

.links{display:flex;flex-direction:column;gap:8px;}
.lk{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--link-c);}
.lk-t{flex:1;}

.rcard{background:var(--surface);border-radius:12px;border:0.5px solid var(--border);margin-bottom:14px;overflow:hidden;}
.rcard-h{padding:11px 15px;background:var(--navy);}
.rcard-ht{color:#fff;font-size:12.5px;font-weight:500;}
.rcard-b{padding:13px 15px;}
.kv{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:0.5px solid var(--border);font-size:12.5px;}
.kv:last-child{border-bottom:none;}
.kl{color:var(--txt2);}
.kv2{font-weight:500;color:var(--txt);}
.kva{color:var(--copper);font-weight:500;}
.acc-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:0.5px solid var(--border);font-size:11.5px;}
.acc-row:last-child{border-bottom:none;}
.acc-u{flex:1;color:var(--txt);font-weight:500;}
.pb{padding:2px 7px;border-radius:20px;font-size:10.5px;font-weight:500;}
.pr{background:var(--pr-bg);color:var(--pr-c);}
.pu{background:var(--pu-bg);color:var(--pu-c);}
.pw{background:var(--pw-bg);color:var(--pw-c);}
.px{background:var(--px-bg);color:var(--px-c);}
.fill-bar{width:100%;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;margin-top:8px;}
.fill-bar-f{height:100%;background:var(--copper);}

/* ============ CONTACTS TABLE PAGE ============ */
.ct{width:100%;border-collapse:collapse;font-size:12.5px;}
.ct th{text-align:left;font-size:10.5px;font-weight:500;color:var(--txt2);padding:0 11px 9px;border-bottom:0.5px solid var(--border);white-space:nowrap;}
.ct td{padding:10px 11px;border-bottom:0.5px solid var(--border);color:var(--txt);vertical-align:middle;}
.ct tr:last-child td{border-bottom:none;}
.ct tr:hover td{background:var(--surface2);}
.cat-ico{width:28px;height:28px;border-radius:7px;background:var(--surface2);display:inline-flex;align-items:center;justify-content:center;border:0.5px solid var(--border);}
.cat-ico i{font-size:14px;color:var(--icon-c);}
.card-chip{font-size:10.5px;padding:2px 7px;border-radius:12px;background:var(--badge-part-bg);color:var(--badge-part-c);white-space:nowrap;}
.card-chip.global{background:var(--surface2);color:var(--txt2);}
.soc-link{color:var(--link-c);font-size:11.5px;display:flex;align-items:center;gap:3px;cursor:pointer;}
.contact-link{color:var(--link-c);cursor:pointer;text-decoration:none;}
.row-editing{background:var(--surface2);}
.edit-cell-input{width:100%;background:var(--inp-bg);border:1px solid var(--copper);border-radius:6px;padding:5px 8px;font-size:12px;color:var(--txt);font-family:inherit;}
.edit-cell-input:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 2px rgba(184,115,51,0.15);}
.edit-save i{color:var(--ok-c) !important;}
.edit-cancel i{color:var(--danger-c) !important;}
.contact-link:hover{text-decoration:underline;}
.copied-flash{color:var(--ok-c) !important;}

/* ============ PERMISSIONS PAGE ============ */
.perm-tbl-wrap{overflow:auto;max-height:70vh;}
.perm-tbl{border-collapse:collapse;font-size:12px;white-space:nowrap;}
.perm-tbl th,.perm-tbl td{padding:9px 10px;border-bottom:0.5px solid var(--border);border-right:0.5px solid var(--border);}
.perm-tbl th{background:var(--surface2);font-weight:500;color:var(--txt2);font-size:10.5px;text-align:center;position:sticky;top:0;z-index:2;}
.perm-tbl td:first-child,.perm-tbl th:first-child{position:sticky;left:0;background:var(--surface);z-index:1;text-align:left;font-weight:500;color:var(--txt);min-width:170px;}
.perm-tbl th:first-child{background:var(--surface2);z-index:3;}
.perm-tbl tr.default-row td{background:var(--surface2);font-style:italic;color:var(--txt2);}
.perm-tbl tr.default-row td:first-child{background:var(--surface2);}
.perm-select{background:var(--inp-bg);border:0.5px solid var(--border);border-radius:6px;padding:4px 6px;font-size:11px;color:var(--txt);width:128px;}

.gp-tbl-wrap{overflow:auto;}
.gp-tbl{width:100%;border-collapse:collapse;font-size:12.5px;}
.gp-tbl th{text-align:center;font-size:10.5px;font-weight:500;color:var(--txt2);padding:9px 10px;border-bottom:0.5px solid var(--border);}
.gp-tbl th:first-child{text-align:left;}
.gp-tbl td{padding:9px 10px;border-bottom:0.5px solid var(--border);text-align:center;}
.gp-tbl td:first-child{text-align:left;font-weight:500;color:var(--txt);}
.gp-tbl tr:last-child td{border-bottom:none;}
.gp-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border2);background:var(--surface);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;}
.gp-check i{opacity:0;font-size:12px;color:#fff;transition:opacity .12s ease;}
.gp-check.on{background:var(--copper);border-color:var(--copper);}
.gp-check.on i{opacity:1;}

/* ============ USERS PAGE ============ */
.user-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:0.5px solid var(--border);}
.user-row:last-child{border-bottom:none;}
.user-row-info{flex:1;}
.user-row-name{font-size:13px;font-weight:500;color:var(--txt);}
.user-row-login{font-size:11px;color:var(--txt2);}
.role-badge{font-size:10.5px;font-weight:500;padding:3px 10px;border-radius:20px;}
.role-admin{background:var(--badge-set-bg);color:var(--badge-set-c);}
.role-staff{background:var(--surface2);color:var(--txt2);}

/* ============ LOGS PAGE ============ */
.log-row{display:flex;align-items:flex-start;gap:10px;padding:9px 16px;border-bottom:0.5px solid var(--border);font-size:12px;font-family:'SF Mono','Consolas',monospace;}

.docker-log-viewer{background:#0D1117;border-radius:0 0 12px 12px;max-height:420px;overflow-y:auto;padding:10px 0;}
.docker-log-line{font-family:'SF Mono','Consolas',monospace;font-size:11.5px;line-height:1.6;color:#C9D1D9;padding:1px 16px;white-space:pre-wrap;word-break:break-all;}
.docker-log-line.docker-log-stderr{color:#FF7B72;}
.log-row:last-child{border-bottom:none;}
.log-time{color:var(--txt3);white-space:nowrap;font-size:11px;}
.log-user{color:var(--copper);font-weight:500;white-space:nowrap;}
.log-action{color:var(--txt);flex:1;}
.log-action b{font-weight:600;}
.log-icon{width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;}
.li-create{background:var(--ok-bg);color:var(--ok-c);}
.li-delete{background:var(--danger-bg);color:var(--danger-c);}
.li-edit{background:var(--badge-part-bg);color:var(--badge-part-c);}
.li-auth{background:var(--surface2);color:var(--txt2);}
.li-file{background:var(--badge-dev-bg);color:var(--badge-dev-c);}
.li-warning{background:var(--warn-bg);color:var(--warn-c);}

/* ============ LOGIN PAGE ============ */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy);position:relative;overflow:hidden;}
.login-screen::before{content:'';position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(184,115,51,0.15),transparent 70%);top:-200px;right:-150px;}
.login-box{background:var(--surface);border-radius:16px;padding:36px 36px 28px;width:380px;position:relative;z-index:1;box-shadow:0 20px 60px rgba(0,0,0,0.3);}
.login-logo{display:flex;align-items:center;gap:11px;margin-bottom:26px;justify-content:center;}
.login-logo .sb-li{width:42px;height:42px;font-size:20px;}
.login-logo-text{font-size:18px;font-weight:600;color:var(--txt);}
.login-title{font-size:14px;color:var(--txt2);text-align:center;margin-bottom:24px;}
.login-field{margin-bottom:14px;}
.login-field label{font-size:11.5px;color:var(--txt2);display:block;margin-bottom:5px;font-weight:500;}
.login-field input{width:100%;background:var(--inp-bg);border:0.5px solid var(--border);border-radius:9px;padding:10px 12px;font-size:13px;color:var(--txt);}
.login-btn{width:100%;background:var(--navy);color:#fff;border:none;border-radius:9px;padding:11px;font-size:13.5px;font-weight:500;cursor:pointer;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:7px;}
.login-foot{text-align:center;font-size:11px;color:var(--txt3);margin-top:18px;}
.login-powered-by{text-align:center;font-size:9.5px;color:var(--txt3);opacity:0.6;margin-top:6px;letter-spacing:0.02em;}
.login-theme-toggle{position:absolute;top:20px;right:20px;z-index:2;width:220px;}
.login-theme-toggle .theme-opt{color:rgba(255,255,255,0.6);}
.login-theme-toggle .theme-opt:hover{color:rgba(255,255,255,0.85);}
.login-error{background:var(--danger-bg);color:var(--danger-c);border-radius:8px;padding:9px 12px;font-size:12px;display:none;align-items:center;gap:7px;margin-bottom:14px;}
.login-error.show{display:flex;}
.login-error i{flex-shrink:0;}
.login-lockout{background:var(--warn-bg);color:var(--warn-c);border-radius:8px;padding:9px 12px;font-size:12px;display:none;align-items:center;gap:7px;margin-bottom:14px;}
.login-lockout.show{display:flex;}
.login-lockout i{flex-shrink:0;}
.login-btn:disabled{opacity:0.5;cursor:not-allowed;}
.login-attempts{text-align:center;font-size:10.5px;color:var(--txt3);margin-top:8px;}

/* ============ OBJECT CARD: BOTTOM DANGER ZONE ============ */
.danger-zone{display:flex;justify-content:flex-end;gap:10px;padding:18px 26px 26px;}
.danger-zone-row{display:flex;justify-content:flex-end;gap:10px;padding:18px 26px 0;}

/* ============ MODALS ============ */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;align-items:center;justify-content:center;}
.overlay.open{display:flex;}
.modal{background:var(--surface);border-radius:14px;border:0.5px solid var(--border);width:500px;max-height:78vh;overflow:hidden;display:flex;flex-direction:column;}
.modal-sm{width:380px;}
.modal-h{background:var(--navy);padding:15px 18px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.modal-title{color:#fff;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;}
.modal-close{background:rgba(255,255,255,0.15);border:none;border-radius:6px;width:26px;height:26px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.modal-body{padding:15px 18px;overflow-y:auto;}
.modal-flt{display:flex;gap:8px;margin-bottom:13px;}
.modal-flt input{flex:1;background:var(--inp-bg);border:0.5px solid var(--border);border-radius:8px;padding:6px 11px;font-size:12.5px;color:var(--txt);}
.modal-flt select{background:var(--inp-bg);border:0.5px solid var(--border);border-radius:8px;padding:6px 11px;font-size:12.5px;color:var(--txt2);}
.mct-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:0.5px solid var(--border);}
.mct-item:last-child{border-bottom:none;}
.mct-ico{width:30px;height:30px;border-radius:7px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:0.5px solid var(--border);}
.mct-ico i{font-size:14px;color:var(--icon-c);}
.mct-info{flex:1;}
.mct-name{font-size:12.5px;font-weight:500;color:var(--txt);}
.mct-meta{font-size:10.5px;color:var(--txt2);}
.mct-phone{font-size:12.5px;color:var(--link-c);}
.modal-footer{padding:11px 18px;border-top:0.5px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0;}
.modal-hint{font-size:11.5px;color:var(--txt2);background:var(--surface2);border-radius:8px;padding:10px 12px;display:flex;gap:8px;align-items:flex-start;margin-top:8px;}
.modal-hint i{color:var(--copper);flex-shrink:0;margin-top:1px;}
.warn-icon{width:52px;height:52px;border-radius:50%;background:var(--danger-bg);color:var(--danger-c);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 14px;}
.warn-title{font-size:15px;font-weight:600;color:var(--txt);margin-bottom:8px;}
.warn-text{font-size:12.5px;color:var(--txt2);line-height:1.5;padding:0 8px;}

/* ============ EMPTY STATE ============ */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--txt3);}
.empty-state i{font-size:40px;margin-bottom:12px;opacity:0.5;}
.empty-state p{font-size:13px;}

/* ============ INLINE SVG ICONS (replaces webfont, no CDN dependency) ============ */
.icon-svg-wrap{line-height:0;}
.icon-svg-wrap svg{display:block;}

/* ============ MOBILE NAVIGATION (hamburger + slide-out sidebar) ============ */
.mobile-menu-btn{display:none;}
.sb-mobile-close{display:none;}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:150;}
.mobile-overlay.show{display:block;}

/* App-level helper: hides sidebar on the login page via class instead of inline style,
   so media queries below can still control sidebar display without !important fights. */
#app.on-login .sb{display:none;}

/* ============================================================
   BREAKPOINT 1: ~900px and narrower — tablet / half-screen window.
   Sidebar becomes a slide-out drawer, grid drops to 2 columns.
   ============================================================ */
@media (max-width: 900px){
  .sb{
    position:fixed;top:0;left:0;height:100vh;z-index:200;
    transform:translateX(-100%);transition:transform .2s ease;
    width:240px;
  }
  .sb.mobile-open{transform:translateX(0);}
  #app.on-login .sb{display:flex;transform:translateX(-100%);}

  .sb-mobile-close{display:flex;width:26px;height:26px;border-radius:6px;background:rgba(255,255,255,0.1);align-items:center;justify-content:center;cursor:pointer;margin-left:auto;flex-shrink:0;}
  .sb-mobile-close i{color:rgba(255,255,255,0.7);font-size:14px;}

  .mobile-menu-btn{display:flex;margin-right:4px;}

  .main{width:100%;}

  .grid{grid-template-columns:repeat(2,1fr);}

  .obj-layout{grid-template-columns:1fr;}

  .fields{grid-template-columns:1fr;}

  .cnt{padding:16px 14px;}
  .topbar{padding:0 14px;}
  .obj-layout{padding:14px;gap:14px;}

  .gp-tbl-wrap, .perm-tbl-wrap{overflow-x:auto;}

  .modal{width:92vw;max-width:480px;}
}

/* ============================================================
   BREAKPOINT 2: ~600px and narrower — phone.
   Single-column grid, stacked filters, full-screen modals, condensed tables.
   ============================================================ */
@media (max-width: 600px){
  .grid{grid-template-columns:1fr;}

  .flt{flex-direction:column;align-items:stretch;}
  .sw{width:100%;}
  .sw input{width:100%;}
  .sel{width:100%;}

  .topbar{flex-wrap:wrap;height:auto;padding:10px 14px;gap:8px;}
  .topbar .sp{flex-basis:100%;height:0;}
  .topbar-title, .topbar span{font-size:13.5px;}

  .card-img{aspect-ratio:16/10;}

  .obj-layout{padding:12px;}
  .danger-zone{flex-direction:column;padding:14px;}
  .danger-zone button{width:100%;justify-content:center;}

  .modal{width:100vw;height:100vh;max-height:100vh;border-radius:0;}
  .modal-sm{width:100vw;}

  .sec .sh{flex-direction:column;align-items:flex-start;gap:8px;}
  .sec .sh button{width:100%;justify-content:center;}

  /* Tables: allow horizontal scroll instead of squeezing columns unreadably */
  .tbl-wrap, .perm-tbl-wrap, .gp-tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .tbl, .ct, .perm-tbl, .gp-tbl{min-width:640px;}

  .user-row{flex-wrap:wrap;}
  .log-row{flex-wrap:wrap;gap:6px;}
  .log-action{flex-basis:100%;}

  .bc span, .bc a{font-size:12px;}

  .login-box{width:90vw;padding:28px 22px 22px;}
}

