*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#F5F5F2;--surface:#FFFFFF;--surface-2:#F1EFE8;--text:#1F1F1D;--text-2:#5F5E5A;--text-3:#888780;--border:#E3E1DA;--border-2:#CFCCC2;--blue-50:#E6F1FB;--blue-400:#378ADD;--blue-600:#185FA5;--blue-800:#0C447C;--teal-400:#1D9E75;--amber-50:#FAEEDA;--amber-200:#FAC775;--amber-400:#BA7517;--amber-800:#633806;--green-50:#EAF3DE;--green-600:#3B6D11;--green-800:#27500A;--red-50:#FCEBEB;--red-800:#501313;--coral-400:#D85A30;--purple-50:#EEEDFE;--purple-600:#534AB7;--purple-800:#3C3489}html,body,#root{height:100%}body{font-family:Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.topbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px;flex-shrink:0;padding-top:env(safe-area-inset-top);box-sizing:content-box}.tb-icon-wrap{width:30px;height:30px;border-radius:8px;background:var(--blue-600);display:flex;align-items:center;justify-content:center}.tb-icon-wrap i{font-size:16px;color:#fff}.tb-name{font-size:14px;font-weight:500;margin-left:9px}.tb-sep{width:1px;height:20px;background:var(--border);margin:0 16px}.tb-sub{font-size:12px;color:var(--text-3)}.tb-right{margin-left:auto;display:flex;align-items:center;gap:12px}.menu-btn{display:none;background:transparent;border:none;cursor:pointer;color:var(--text-2);font-size:20px;padding:4px}.notif-dot{position:relative;cursor:pointer}.notif-dot i{font-size:19px;color:var(--text-2)}.notif-count{position:absolute;top:-3px;right:-4px;min-width:14px;height:14px;padding:0 3px;border-radius:8px;background:var(--coral-400);color:#fff;font-size:9px;font-weight:500;display:flex;align-items:center;justify-content:center}.tb-avatar{width:28px;height:28px;border-radius:50%;background:var(--blue-50);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--blue-800)}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:214px;background:var(--surface);border-right:1px solid var(--border);padding:18px 0;display:flex;flex-direction:column;gap:1px;flex-shrink:0;overflow-y:auto}.nav-section{font-size:10px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.09em;padding:14px 16px 6px;margin-top:4px}.nav-section:first-child{margin-top:0}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 16px;font-size:13px;color:var(--text-2);cursor:pointer;border-left:2px solid transparent;transition:all .12s;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--blue-50);color:var(--blue-800);border-left-color:var(--blue-600);font-weight:500}.nav-item i{font-size:15px;flex-shrink:0}.nav-pill{margin-left:auto;font-size:10px;font-weight:500;padding:2px 6px;border-radius:10px;background:var(--surface-2);color:var(--text-3)}.nav-pill.warn{background:var(--amber-50);color:var(--amber-800)}.nav-pill.purple{background:var(--purple-50);color:var(--purple-800)}.scrim{display:none;position:fixed;inset:0;background:#0006;z-index:25}.scrim.show{display:block}.content{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:18px;-webkit-overflow-scrolling:touch}.view{display:none;flex-direction:column;gap:18px}.view.active{display:flex}.ph h2{font-size:16px;font-weight:500}.ph p{font-size:12px;color:var(--text-3);margin-top:3px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 20px}.card-label{font-size:10px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.metric{background:var(--surface-2);border-radius:8px;padding:14px 16px}.metric-n{font-size:24px;font-weight:500;line-height:1;margin-bottom:4px}.metric-l{font-size:11px;color:var(--text-3)}.mn-blue{color:var(--blue-600)}.mn-amber{color:var(--amber-400)}.mn-teal{color:var(--teal-400)}.mn-purple{color:var(--purple-600)}.tbl{width:100%;border-collapse:collapse;font-size:12.5px;table-layout:fixed}.tbl th{text-align:left;font-size:10px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;padding:9px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.tbl td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:var(--surface-2);cursor:pointer}.sp{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:3px 9px;border-radius:20px;white-space:nowrap}.sp-pending{background:var(--amber-50);color:var(--amber-800)}.sp-confirmed{background:var(--blue-50);color:var(--blue-800)}.sp-done{background:var(--green-50);color:var(--green-800)}.sp-cancelled{background:var(--red-50);color:var(--red-800)}.sp-recorded{background:var(--purple-50);color:var(--purple-800)}.pdot{width:5px;height:5px;border-radius:50%;display:inline-block;flex-shrink:0}.pdot.high{background:var(--coral-400)}.pdot.normal{background:var(--amber-400)}.pdot.low{background:var(--teal-400)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}.full{grid-column:1/-1}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11px;font-weight:500;color:var(--text-2)}.req{color:var(--coral-400)}.field input,.field select,.field textarea{font-family:Roboto,sans-serif;font-size:13px;background:var(--surface);border:1px solid var(--border-2);border-radius:8px;padding:9px 11px;color:var(--text);outline:none;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue-400)}.field textarea{resize:vertical;min-height:68px}.pill-group{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}.epill{display:flex;align-items:center;gap:5px;padding:7px 11px;border:1px solid var(--border-2);border-radius:20px;font-size:12px;cursor:pointer;color:var(--text-2);transition:all .12s;-webkit-user-select:none;user-select:none}.epill i{font-size:13px}.epill.on{background:var(--blue-50);border-color:var(--blue-400);color:var(--blue-800);font-weight:500}.form-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:6px;margin-top:4px;border-top:1px solid var(--border);flex-wrap:wrap}.btn{font-family:Roboto,sans-serif;font-size:12.5px;font-weight:500;padding:9px 16px;border-radius:8px;cursor:pointer;transition:all .13s;display:inline-flex;align-items:center;gap:6px;border:none}.btn-primary{background:var(--blue-600);color:#fff}.btn-primary:hover{background:var(--blue-800)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border-2)}.btn-ghost:hover{background:var(--surface-2)}.filter-bar{display:flex;gap:8px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}.filter-bar input,.filter-bar select{font-family:Roboto,sans-serif;font-size:12px;padding:7px 10px;border:1px solid var(--border-2);border-radius:8px;background:var(--surface);color:var(--text);outline:none}.filter-bar input{flex:1;min-width:140px}.bar-list{display:flex;flex-direction:column;gap:9px}.bar-row{display:flex;align-items:center;gap:10px;font-size:12px}.bar-lbl{width:96px;color:var(--text-2);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{flex:1;height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;background:var(--blue-400);transition:width .5s}.bar-n{font-size:11px;color:var(--text-3);min-width:14px;text-align:right}.detail{position:fixed;top:0;right:0;width:340px;max-width:90vw;height:100%;background:var(--surface);border-left:1px solid var(--border);display:none;flex-direction:column;z-index:30;overflow-y:auto}.detail.open{display:flex}.detail-top{padding:18px;padding-top:calc(18px + env(safe-area-inset-top));border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.detail-id{font-size:10px;color:var(--text-3);margin-bottom:4px}.detail-type{font-size:14px;font-weight:500}.detail-who{font-size:12px;color:var(--text-2);margin-top:2px}.detail-body{padding:14px 18px;display:flex;flex-direction:column;gap:14px;flex:1}.dl{display:flex;flex-direction:column;gap:3px}.dl-label{font-size:10px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em}.dl-value{font-size:12.5px}.dl-note{font-size:12px;color:var(--text-2);font-style:italic}.status-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.sa-btn{font-size:11px;padding:5px 10px;border-radius:20px;border:1px solid var(--border-2);cursor:pointer;background:transparent;font-family:Roboto,sans-serif;color:var(--text-2);transition:all .12s}.sa-btn:hover{background:var(--blue-50);border-color:var(--blue-400);color:var(--blue-800)}.close-btn{background:transparent;border:none;cursor:pointer;color:var(--text-2);padding:4px;border-radius:6px;font-size:16px;display:flex}.close-btn:hover{color:var(--text);background:var(--surface-2)}.detail-danger{padding:14px 18px;border-top:1px solid var(--border);padding-bottom:calc(14px + env(safe-area-inset-bottom))}.btn-danger{width:100%;justify-content:center;background:transparent;color:var(--red-800);border:1px solid var(--border-2)}.btn-danger:hover{background:var(--red-50);border-color:var(--red-800)}.confirm-box{background:var(--red-50);border:1px solid var(--red-800);border-radius:8px;padding:12px 14px}.confirm-box p{font-size:12px;color:var(--red-800);margin-bottom:10px;line-height:1.5}.confirm-actions{display:flex;gap:8px}.confirm-actions .btn{flex:1;justify-content:center}.btn-confirm-del{background:var(--red-800);color:#fff}.btn-confirm-del:hover{background:#3a0d0d}.toast{display:none;position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border-2);border-radius:12px;padding:12px 16px;font-size:12.5px;z-index:40;max-width:90vw;box-shadow:0 4px 16px #0000001f}.toast.show{display:flex;align-items:center;gap:10px}.toast i{font-size:17px;flex-shrink:0}.empty{text-align:center;padding:40px 20px;color:var(--text-3);font-size:12.5px}.empty i{font-size:28px;display:block;margin-bottom:8px;opacity:.35}.notif-panel{position:fixed;top:64px;right:20px;width:290px;max-width:90vw;background:var(--surface);border:1px solid var(--border-2);border-radius:12px;z-index:35;display:none;flex-direction:column;overflow:hidden;box-shadow:0 4px 16px #0000001f}.notif-panel.open{display:flex}.notif-hd{padding:12px 14px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.notif-hd span{font-size:12.5px;font-weight:500}.notif-hd small{font-size:11px;color:var(--text-3)}.notif-list-wrap{max-height:300px;overflow-y:auto}.notif-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-2)}.notif-item.unread{border-left:2px solid var(--blue-600)}.ni-top{display:flex;align-items:center;gap:6px;margin-bottom:3px}.ni-icon{width:22px;height:22px;border-radius:50%;background:var(--blue-50);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ni-icon i{font-size:12px;color:var(--blue-600)}.ni-title{font-size:12px;font-weight:500}.ni-sub{font-size:11px;color:var(--text-3)}.sent-to{font-size:10.5px;color:var(--text-3);padding:8px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:5px}.sent-to i{font-size:12px;color:var(--teal-400)}.banner{display:flex;align-items:flex-start;gap:10px;background:var(--amber-50);border:1px solid var(--amber-200);border-radius:8px;padding:11px 14px;font-size:12px;color:var(--amber-800);line-height:1.5}.banner i{font-size:16px;flex-shrink:0;margin-top:1px}@media(max-width:720px){.menu-btn{display:block}.tb-sub,.tb-sep{display:none}.sidebar{position:fixed;top:0;left:0;height:100%;z-index:26;transform:translate(-100%);transition:transform .2s;padding-top:calc(18px + env(safe-area-inset-top))}.sidebar.open{transform:translate(0)}.metrics{grid-template-columns:repeat(2,1fr)}.content{padding:16px}.form-grid{grid-template-columns:1fr}.dash-grid{grid-template-columns:1fr!important}}
