*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--navy: #1A2E5A;--navy-deep: #0F1C3A;--navy-mid: #253F7A;--gold: #C49A2E;--gold-light: #E8C253;--gold-faint: #FDF6E3;--white: #FFFFFF;--surface: #F7F8FC;--border: rgba(26,46,90,.12);--border-strong: rgba(26,46,90,.25);--text-primary: #0F1C3A;--text-secondary: #4A5A7A;--text-muted: #8A96B0;--success: #1B7A4A;--success-bg: #E8F7EF;--warning: #A05C00;--warning-bg: #FEF3E2;--danger: #B32323;--danger-bg: #FDECEC;--info: #1A5FA8;--info-bg: #EBF3FD;--sidebar-w: 224px;--header-h: 56px;--font-serif: "Libre Baskerville", serif;--font-sans: "DM Sans", sans-serif}body{font-family:var(--font-sans);background:var(--surface);color:var(--text-primary);font-size:14px;line-height:1.5}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar{height:var(--header-h);background:var(--navy-deep);border-bottom:2px solid var(--gold);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0;z-index:10}.topbar-logo-mark{width:32px;height:32px;background:var(--gold);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:15px;font-weight:700;color:var(--navy-deep);flex-shrink:0}.topbar-logo-text{font-family:var(--font-serif);font-size:15px;color:#fff;font-weight:700}.topbar-logo-sub{font-size:10px;color:var(--gold-light);letter-spacing:.12em;text-transform:uppercase}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:16px}.topbar-alert{font-size:11px;font-weight:600;background:var(--gold);color:var(--navy-deep);padding:2px 9px;border-radius:20px}.user-chip{display:flex;align-items:center;gap:8px}.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--navy-mid);border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--gold-light)}.user-name{font-size:12px;color:#fffc}.main-wrap{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--navy);flex-shrink:0;display:flex;flex-direction:column;padding:16px 0;overflow-y:auto;gap:2px}.nav-section{padding:8px 16px 4px;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#ffffff59;font-weight:500}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;margin:0 8px;border-radius:8px;cursor:pointer;font-size:13px;color:#ffffffb3;text-decoration:none;transition:all .15s}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:var(--gold);color:var(--navy-deep);font-weight:600}.nav-item.active .nav-badge{background:var(--navy-deep);color:#fff}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:10px;min-width:16px;text-align:center}.nav-icon{width:16px;height:16px;flex-shrink:0}.content{flex:1;overflow-y:auto;padding:24px;background:var(--surface)}.card{background:var(--white);border:.5px solid var(--border);border-radius:10px;overflow:hidden}.card-header{padding:14px 18px;border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:13px;font-weight:600;color:var(--text-primary)}.card-body{padding:16px 18px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.page-title{font-family:var(--font-serif);font-size:20px;font-weight:700;color:var(--navy-deep);line-height:1.2}.page-subtitle{font-size:12px;color:var(--text-muted);margin-top:3px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.stat-card{background:var(--white);border:.5px solid var(--border);border-top:3px solid var(--gold);border-radius:10px;padding:16px}.stat-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px}.stat-value{font-size:26px;font-weight:600;color:var(--navy-deep);line-height:1}.stat-trend{font-size:11px;margin-top:4px;color:var(--success)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;border:none;font-family:var(--font-sans);transition:all .15s;text-decoration:none}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy-mid)}.btn-gold{background:var(--gold);color:var(--navy-deep)}.btn-gold:hover{background:var(--gold-light)}.btn-ghost{background:transparent;color:var(--text-secondary);border:.5px solid var(--border-strong)}.btn-ghost:hover{background:var(--white)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:5px 10px;font-size:11px}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;white-space:nowrap}.badge-partner{background:#ebf3fd;color:#1a5fa8}.badge-manager{background:#fef3e2;color:#a05c00}.badge-staff{background:#e8f7ef;color:#1b7a4a}.badge-active{background:var(--success-bg);color:var(--success)}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-overdue{background:var(--danger-bg);color:var(--danger)}.badge-sent{background:var(--info-bg);color:var(--info)}.badge-new{background:#f3eefb;color:#6b35c5}.badge-complete{background:var(--success-bg);color:var(--success)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:500;padding:10px 14px;border-bottom:.5px solid var(--border);background:var(--surface);white-space:nowrap}td{padding:11px 14px;border-bottom:.5px solid var(--border);color:var(--text-primary);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#1a2e5a05}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}.form-input{width:100%;border:.5px solid var(--border-strong);border-radius:8px;padding:8px 12px;font-size:13px;font-family:var(--font-sans);background:var(--surface);color:var(--text-primary);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--navy);background:var(--white)}.filter-bar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.filter-bar .form-input{margin-bottom:0}.filter-bar input{flex:1;min-width:180px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.mb-14{margin-bottom:14px}.mb-20{margin-bottom:20px}.notif-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:.5px solid var(--border)}.notif-item:last-child{border-bottom:none}.notif-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.notif-body{flex:1}.notif-title{font-size:12px;font-weight:500;color:var(--text-primary)}.notif-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.notif-date{font-size:11px;color:var(--text-muted);white-space:nowrap}.progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:4px}.progress-fill{height:100%;border-radius:2px;background:var(--navy)}.progress-fill.warn{background:var(--gold)}.progress-fill.danger{background:var(--danger)}.tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:500;background:var(--surface);border:.5px solid var(--border);color:var(--text-secondary);margin-right:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a143280;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--white);border-radius:12px;padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #0003}.modal-title{font-family:var(--font-serif);font-size:17px;font-weight:700;color:var(--navy-deep);margin-bottom:18px;display:flex;align-items:center;justify-content:space-between}.modal-close{cursor:pointer;color:var(--text-muted);font-size:20px;line-height:1}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.wa-layout{display:grid;grid-template-columns:256px 1fr;gap:12px;height:500px}.wa-list{background:var(--white);border:.5px solid var(--border);border-radius:10px;overflow-y:auto;display:flex;flex-direction:column}.wa-list-header{padding:12px 14px;border-bottom:.5px solid var(--border);font-size:12px;font-weight:600;background:var(--surface);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.wa-thread{padding:11px 14px;border-bottom:.5px solid var(--border);cursor:pointer;transition:background .1s}.wa-thread:hover{background:var(--surface)}.wa-thread.active{background:#ebf3fd;border-left:2px solid var(--navy)}.wa-thread-name{font-size:12px;font-weight:500}.wa-thread-preview{font-size:11px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.wa-thread-time{font-size:10px;color:var(--text-muted);float:right}.wa-unread-dot{display:inline-block;width:7px;height:7px;background:var(--gold);border-radius:50%;margin-right:5px}.wa-chat{background:var(--white);border:.5px solid var(--border);border-radius:10px;display:flex;flex-direction:column;overflow:hidden}.wa-chat-header{padding:12px 16px;border-bottom:.5px solid var(--border);background:var(--navy-deep);display:flex;align-items:center;gap:10px}.wa-chat-name{font-size:13px;font-weight:600;color:#fff}.wa-chat-sub{font-size:10px;color:#fff9}.wa-assignee{margin-left:auto;font-size:10px;color:var(--gold-light)}.wa-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:#f0f2f5}.msg{max-width:68%;padding:8px 12px;border-radius:12px;font-size:12px;line-height:1.5}.msg-client{background:#fff;color:var(--text-primary);align-self:flex-start;border-bottom-left-radius:2px;box-shadow:0 1px 2px #0000000f}.msg-staff{background:var(--navy);color:#fff;align-self:flex-end;border-bottom-right-radius:2px}.msg-time{font-size:10px;opacity:.6;margin-top:3px;text-align:right}.wa-compose{padding:12px 14px;border-top:.5px solid var(--border);display:flex;gap:8px;align-items:center}.wa-compose input{flex:1;border:.5px solid var(--border-strong);border-radius:20px;padding:8px 14px;font-size:12px;font-family:var(--font-sans);outline:none;background:var(--surface)}.wa-compose input:focus{border-color:var(--navy)}.wa-send-btn{width:34px;height:34px;background:var(--navy);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wa-send-btn:hover{background:var(--navy-mid)}.wa-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px}.tree-node{border-radius:8px;padding:10px 14px;font-size:12px;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}.tree-partner{background:#ebf3fd;border:.5px solid #B5D4F4;color:#0c447c;font-weight:600}.tree-manager{background:#fef3e2;border:.5px solid #FAC775;color:#633806;margin-left:20px}.tree-staff{background:var(--surface);border:.5px solid var(--border);color:var(--text-secondary);margin-left:40px}.tree-count{font-size:10px;opacity:.7}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy-deep)}.login-card{background:var(--white);border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-logo{text-align:center;margin-bottom:32px}.login-logo-mark{width:52px;height:52px;background:var(--gold);border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--navy-deep);margin-bottom:12px}.login-title{font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--navy-deep)}.login-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.login-success{text-align:center;padding:20px;background:var(--success-bg);border-radius:10px;color:var(--success);font-size:14px;line-height:1.6}.info-box{padding:10px 14px;border-radius:8px;font-size:11px;margin-top:12px}.info-box.info{background:var(--info-bg);border:.5px solid #B5D4F4;color:var(--info)}.info-box.warning{background:var(--warning-bg);border:.5px solid #FAC775;color:var(--warning)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-wrap{display:flex;align-items:center;justify-content:center;padding:40px}.empty-state{text-align:center;padding:40px;color:var(--text-muted)}.empty-state p{font-size:13px;margin-top:8px}
