:root{--bg:#f5f7f8;--surface:#fff;--surface-2:#eef2f3;--border:#d8e0e2;--text:#16242b;--text-muted:#5e7079;--primary:#0f6e6e;--primary-600:#0b5757;--primary-050:#e3f1f1;--accent:#b8862f;--danger:#b3261e;--success:#1f7a4d;--warning:#9a6700;--radius:10px;--shadow:0 1px 2px rgba(16,36,43,.06),0 6px 20px rgba(16,36,43,.06);--sidebar-w:244px}*{box-sizing:border-box}body,html{padding:0;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0 0 .4em;font-weight:650;letter-spacing:-.01em}h1{font-size:22px}h2{font-size:18px}h3{font-size:15px}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:#0c2a30;color:#cfe3e3;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:16px 12px;gap:4px;z-index:30}.brand{display:flex;align-items:center;gap:10px;padding:6px 10px 16px}.brand .logo{width:32px;height:32px;object-fit:contain;display:block}.brand b{color:#fff;font-size:15px;letter-spacing:.02em}.brand small{display:block;color:#7fa3a3;font-size:11px}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:#bcd6d6;font-weight:500;cursor:pointer}.nav-link:hover{background:hsla(0,0%,100%,.06);text-decoration:none;color:#fff}.nav-link.active{background:var(--primary);color:#fff}.nav-section{color:#5c8585;font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 4px}.nav-ico{width:18px;text-align:center;opacity:.9}.main{margin-left:var(--sidebar-w);flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{height:58px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.search{flex:1 1;max-width:480px}.content,.search input{width:100%}.content{padding:22px;max-width:1280px}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;cursor:pointer;font-size:13.5px}.btn:hover{background:var(--surface-2);text-decoration:none}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-600)}.btn.ghost{border-color:transparent;background:transparent}.btn.danger{color:var(--danger);border-color:#e8c9c7}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.sm{padding:5px 10px;font-size:12.5px}input,select,textarea{font:inherit;padding:8px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-050);border-color:var(--primary)}.btn:focus-visible,.tab:focus-visible,[role=button]:focus-visible,a:focus-visible,tr[tabindex]:focus-visible{outline:2px solid var(--primary);outline-offset:2px}label{display:block;font-size:12.5px;font-weight:600;color:var(--text-muted);margin-bottom:5px}.field{margin-bottom:14px}.grid2{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card .card-h{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card .card-b{padding:16px}.kpis{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px;margin-bottom:18px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}.kpi .k-label{color:var(--text-muted);font-size:12px;font-weight:600}.kpi .k-value{font-size:23px;font-weight:750;margin-top:6px;letter-spacing:-.02em}.kpi .k-sub{color:var(--text-muted);font-size:11.5px;margin-top:2px}.panels{display:grid;grid-template-columns:1.4fr 1fr;grid-gap:16px;gap:16px}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:10px 14px}td,th{border-bottom:1px solid var(--border)}td{padding:11px 14px}tbody tr:hover{background:var(--surface-2)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:650;background:var(--surface-2);color:var(--text-muted)}.badge.green{background:#e2f3ea;color:var(--success)}.badge.amber{background:#fbf0d9;color:var(--warning)}.badge.red{background:#fbe4e2;color:var(--danger)}.badge.blue{background:var(--primary-050);color:var(--primary-600)}.badge.grey{background:var(--surface-2);color:var(--text-muted)}.page-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.page-h .sub{color:var(--text-muted);font-size:13px}.modal-overlay{position:fixed;inset:0;background:rgba(12,42,48,.4);display:grid;place-items:center;z-index:50;padding:20px}.modal{background:var(--surface);border-radius:14px;width:100%;max-width:560px;max-height:88vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}.modal-h{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-b{padding:20px}.modal-f{padding:14px 20px;border-top:1px solid var(--border);justify-content:flex-end}.modal-f,.toasts{display:flex;gap:10px}.toasts{position:fixed;bottom:20px;right:20px;flex-direction:column;z-index:60}.toast{background:var(--text);color:#fff;padding:11px 16px;border-radius:10px;box-shadow:var(--shadow);font-size:13.5px;min-width:240px}.toast.err{background:var(--danger)}.toast.ok{background:var(--success)}.row{gap:10px}.row,.spread{display:flex;align-items:center}.spread{justify-content:space-between}.empty,.muted{color:var(--text-muted)}.empty{text-align:center;padding:48px 20px}.empty .em-ico{display:flex;justify-content:center;opacity:.45}.nav-ico{justify-content:center}.nav-ico,.qa .qa-ico{display:inline-flex;align-items:center}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px;flex-wrap:wrap}.tab{padding:9px 14px;cursor:pointer;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.qa{display:flex;flex-direction:column;gap:6px;align-items:flex-start;padding:14px;border:1px solid var(--border);border-radius:10px;cursor:pointer;background:var(--surface)}.qa:hover{border-color:var(--primary);background:var(--primary-050)}.qa .qa-ico{font-size:18px}.qa b{font-size:13.5px}.auth-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0c2a30,#0f6e6e);padding:20px}.auth-card{background:var(--surface);border-radius:16px;box-shadow:0 24px 70px rgba(0,0,0,.3);width:100%;max-width:420px;padding:32px}.menu-btn,.search-icon-btn,.sidebar-footer,.sidebar-scrim,.topbar-logo{display:none}.sidebar nav{flex:1 1 auto;overflow-y:auto;min-height:0}@media (max-width:980px){.kpis{grid-template-columns:repeat(2,1fr)}.grid2,.panels{grid-template-columns:1fr}.quick-actions{grid-template-columns:1fr 1fr}}@media (max-width:680px){.sidebar{transform:translateX(-100%);transition:transform .2s ease;box-shadow:0 0 40px rgba(0,0,0,.35);padding-left:max(12px,env(safe-area-inset-left))}.sidebar.open{transform:none}.main{margin-left:0;min-width:0}.sidebar-scrim{display:block;position:fixed;inset:0;background:rgba(8,24,28,.5);z-index:29}.menu-btn{display:inline-flex;padding:8px 12px;font-size:18px}.topbar-logo{display:inline-flex;align-items:center;margin-right:auto}.topbar-logo img{object-fit:contain}.sidebar-footer{display:flex;flex-direction:column;gap:10px;margin-top:auto;padding:12px 6px 4px;border-top:1px solid hsla(0,0%,100%,.12)}.sf-user{display:flex;align-items:center;gap:10px;padding:0 6px}.sf-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700;flex:none}.sf-meta b{color:#fff;font-size:13px;display:block}.sf-meta small{color:#7fa3a3;font-size:11px;word-break:break-all}.sf-signout{color:#cfe3e3;justify-content:center;border:1px solid hsla(0,0%,100%,.18)}.topbar{gap:8px;padding:0 max(14px,env(safe-area-inset-right)) 0 14px}.search{display:none}.search-icon-btn{display:inline-flex;font-size:16px;padding:8px 12px}.topbar-user{display:none}.page-h{flex-direction:column;align-items:flex-start;gap:12px}.page-h .row{width:100%;flex-wrap:wrap}.kpis{grid-template-columns:1fr 1fr;gap:10px}.content{padding:16px 16px max(16px,env(safe-area-inset-bottom))}input,select,textarea{font-size:16px}.btn{min-height:40px}.btn.sm{min-height:34px}table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.modal-overlay{padding:0}.modal{max-width:100%;width:100%;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0;display:flex;flex-direction:column}.modal-f,.modal-h{flex:none}.modal-b{flex:1 1 auto;overflow:auto}.toasts{left:12px;right:12px;bottom:max(12px,env(safe-area-inset-bottom))}.toast{min-width:0}.auth-card{padding:24px}}@media (max-width:420px){.kpis,.quick-actions{grid-template-columns:1fr}}.cal-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.cal-title{font-size:18px;font-weight:700;min-width:180px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface)}.cal-dow{background:var(--surface-2);padding:8px 10px;font-size:12px;font-weight:700;color:var(--text-muted);text-align:left}.cal-cell,.cal-dow{border-bottom:1px solid var(--border)}.cal-cell{min-height:104px;border-right:1px solid var(--border);padding:6px;cursor:pointer;position:relative;display:flex;flex-direction:column;gap:4px}.cal-cell:nth-child(7n){border-right:none}.cal-cell.out{background:var(--surface-2)}.cal-cell:hover{background:var(--primary-050)}.cal-daynum{font-size:12.5px;font-weight:600;color:var(--text-muted)}.cal-cell.today .cal-daynum{background:var(--primary);color:#fff;width:22px;height:22px;border-radius:50%;display:grid;place-items:center}.cal-ev{font-size:11.5px;line-height:1.3;padding:2px 6px;border-radius:6px;color:#fff;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid rgba(0,0,0,.18)}.cal-ev:hover{filter:brightness(.94)}.cal-more{font-size:11px;color:var(--text-muted);font-weight:600;padding:0 4px}.cal-k-court_date{background:#b3261e}.cal-k-deadline{background:#b8862f}.cal-k-consultation{background:#2563a8}.cal-k-meeting{background:#0f6e6e}.cal-k-reminder{background:#5e7079}.cal-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;font-size:12px;color:var(--text-muted)}.cal-legend .dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}.agenda-row{display:flex;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);align-items:flex-start;cursor:pointer}.agenda-row:hover{background:var(--surface-2)}.agenda-date{min-width:64px;text-align:center}.agenda-date .d{font-size:20px;font-weight:800;line-height:1}.agenda-date .m{font-size:11px;text-transform:uppercase;color:var(--text-muted)}@media (max-width:680px){.cal-cell{min-height:72px}.cal-ev{font-size:10.5px}}.unread-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--primary);margin-right:7px;vertical-align:middle}.dropzone{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;padding:18px;border:1.5px dashed var(--border);border-radius:var(--radius);cursor:pointer;background:var(--surface-2);transition:border-color .15s,background .15s}.dropzone.drag,.dropzone:hover{border-color:var(--primary);background:rgba(15,110,110,.06)}.detail-list{display:grid;grid-template-columns:1fr;grid-gap:8px;gap:8px;margin:0}.detail-list>div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);padding-bottom:6px}.detail-list dt{color:var(--text-muted);font-size:13px;margin:0}.detail-list dd{margin:0;font-weight:600;text-align:right}.board{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;align-items:flex-start}.board-col{min-width:240px;flex:1 1;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:8px}.board-col-h{font-weight:700;font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;padding:2px 2px 6px}.board-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.board-card:hover{border-color:var(--primary);box-shadow:0 1px 4px rgba(0,0,0,.08)}.board-card-t{font-weight:600;font-size:13.5px}.chip-set{display:flex;flex-wrap:wrap;gap:6px}.chip{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:999px;padding:4px 11px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s}.chip:hover{border-color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.avatar-sm{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;font-size:10.5px;font-weight:700;flex:none}.thread-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px;padding:16px}.thread-card .card-b,.thread-card .card-h{padding:12px 14px}.thread{display:flex;flex-direction:column;gap:10px;max-height:55vh;overflow-y:auto;padding:4px}.bubble{max-width:78%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--surface)}.bubble.in{align-self:flex-start;border-bottom-left-radius:4px}.bubble.out{align-self:flex-end;background:var(--primary-050);border-color:var(--primary-050);border-bottom-right-radius:4px}