:root{--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #dbeafe;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--sidebar: #0f172a;--sidebar-muted: #94a3b8;--radius: 12px;--shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .04);--shadow-lg: 0 10px 30px rgba(15, 23, 42, .12);font-family:Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0}a{color:inherit;text-decoration:none}.btn{border:none;border-radius:8px;padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-link{background:none;color:var(--primary);padding:4px 8px}.btn-link:hover{text-decoration:underline}.btn-danger-ghost{background:none;color:var(--danger);border:1px solid transparent;padding:6px 10px}.btn-danger-ghost:hover{background:#fee2e2}.btn-block{width:100%;padding:12px}.btn.sm{padding:5px 10px;font-size:13px}.btn.btn-lg{padding:14px 28px;font-size:16px}.btn-success-ghost{background:none;color:var(--success);border:1px solid transparent;padding:6px 10px}.btn-success-ghost:hover{background:#dcfce7}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1e3a8a,#2563eb,#3b82f6)}.login-card{background:var(--surface);width:100%;max-width:400px;border-radius:16px;padding:36px 32px;box-shadow:var(--shadow-lg)}.login-brand{text-align:center;margin-bottom:28px}.login-brand h1{font-size:22px;margin-top:14px}.login-brand p{color:var(--muted);margin:4px 0 0;font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600}.login-form input{padding:11px 14px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit}.login-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.login-demo{margin-top:22px;padding-top:18px;border-top:1px solid var(--border);text-align:center;font-size:13px;color:var(--muted)}.login-demo code{display:block;margin:6px 0;background:var(--bg);padding:6px;border-radius:6px;color:var(--text)}.alert{background:#fee2e2;color:var(--danger);padding:10px 12px;border-radius:8px;font-size:14px}.layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--sidebar);color:#fff;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:30}.brand{display:flex;align-items:center;gap:12px;padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-logo{width:40px;height:40px;background:var(--primary);border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:20px;color:#fff;flex-shrink:0}.brand-logo.lg{width:56px;height:56px;font-size:28px;margin:0 auto}.brand-logo-img{width:40px;height:40px;border-radius:10px;object-fit:cover;flex-shrink:0;background:#fff}.brand-logo-img.lg{width:64px;height:64px;margin:0 auto;display:block}.brand-name{font-weight:700;font-size:15px}.brand-tag{font-size:12px;color:var(--sidebar-muted)}.nav{flex:1;padding:14px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.nav-group{margin-bottom:10px}.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--sidebar-muted);padding:10px 14px 6px;opacity:.7}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:8px;color:var(--sidebar-muted);font-size:14px;font-weight:500;transition:all .15s ease}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:var(--primary);color:#fff}.nav-icon{font-size:18px}.sidebar-footer{display:flex;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);text-decoration:none;color:inherit;transition:background .15s}a.sidebar-footer:hover{background:#ffffff0f}.avatar.lg{width:60px;height:60px;font-size:22px}.account-info{display:flex;align-items:center;gap:16px}.account-name{font-size:17px;font-weight:700}.login-foot{text-align:center;font-size:13px;color:var(--muted);margin-top:18px}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.user-meta{overflow:hidden}.user-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:var(--sidebar-muted)}.main{flex:1;min-width:0;margin-left:260px;display:flex;flex-direction:column;overflow-x:hidden}.topbar{height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 28px;position:sticky;top:0;z-index:20}.hamburger{display:none;background:none;border:none;font-size:22px;cursor:pointer}.page-title{font-size:19px;font-weight:700;flex:1}.topbar-right{display:flex;align-items:center;gap:14px}.hello{color:var(--muted);font-size:14px}.content{padding:28px}.backdrop{display:none}.stack{display:flex;flex-direction:column;gap:22px;max-width:1100px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}.card-head h3{font-size:17px}.tag{display:inline-block;background:var(--bg);color:var(--muted);padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.tag-agenda{background:#fef3c7;color:var(--warning)}.tag-kebijakan{background:#ede9fe;color:#7c3aed}.tag-pengumuman{background:var(--primary-light);color:var(--primary-dark)}.empty{color:var(--muted);text-align:center;padding:24px}.empty.sm{padding:12px;font-size:13px}.toolbar{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap}.search{flex:1;min-width:200px}.toolbar input,.toolbar select,.inline-form input,.inline-form select,.inline-form textarea{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit}.toolbar input:focus,.toolbar select:focus{outline:none;border-color:var(--primary)}.inline-form{display:flex;flex-direction:column;gap:10px;background:var(--bg);padding:16px;border-radius:10px;margin-bottom:18px}.inline-form textarea{resize:vertical;font-family:inherit}.inline-form .form-row{display:flex;gap:10px}.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:end}.welcome-banner{background:linear-gradient(135deg,var(--primary) 0%,#3b82f6 100%);color:#fff;padding:26px 28px;border-radius:var(--radius)}.welcome-banner h2{font-size:22px}.welcome-banner p{margin:6px 0 0;opacity:.9}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(205px,1fr));gap:16px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);overflow:hidden}.stat-card>div{min-width:0}.stat-icon{font-size:28px;flex-shrink:0}.stat-value{font-size:24px;font-weight:800;line-height:1.1;overflow-wrap:anywhere}.stat-label{color:var(--muted);font-size:13px;margin-top:4px}.announce-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.announce-item{display:flex;gap:12px;padding:16px;border:1px solid var(--border);border-radius:10px}.announce-item:hover{border-color:var(--primary)}.announce-main{flex:1}.announce-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.pin{font-size:12px;color:var(--warning);font-weight:600}.announce-date{font-size:12px;color:var(--muted);margin-left:auto}.announce-main h4{font-size:16px;margin-bottom:6px}.announce-main p{margin:0;color:var(--muted);line-height:1.5;font-size:14px}.announce-author{font-size:12px;color:var(--muted);font-style:italic;display:block;margin-top:8px}.people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}.person-card{border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center;transition:all .15s ease}.person-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.person-avatar{width:56px;height:56px;margin:0 auto 12px;border-radius:50%;background:var(--primary-light);color:var(--primary-dark);display:grid;place-items:center;font-weight:700;font-size:20px}.person-card h4{font-size:16px}.person-position{color:var(--muted);font-size:13px;margin:4px 0 10px}.person-contact{margin-top:14px;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.person-contact a:hover{color:var(--primary)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:10px 12px;border-bottom:2px solid var(--border)}.data-table td{padding:13px 12px;border-bottom:1px solid var(--border);font-size:14px}.data-table tbody tr:hover{background:var(--bg)}.doc-title{display:flex;align-items:center;gap:10px;font-weight:600}.doc-icon{font-size:18px}.row-actions{display:flex;gap:6px;justify-content:flex-end}.board{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.board-col{background:var(--bg);border-radius:12px;padding:14px}.board-col-head{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:14px;margin-bottom:12px;padding:0 4px}.count{background:var(--surface);color:var(--muted);border-radius:999px;padding:2px 9px;font-size:12px}.board-col-body{display:flex;flex-direction:column;gap:10px;min-height:60px}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:13px;box-shadow:var(--shadow)}.task-top{display:flex;justify-content:space-between;align-items:center}.task-title{font-weight:600;font-size:14px;margin:8px 0}.task-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.task-actions{display:flex;gap:6px;margin-top:10px}.x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1}.x:hover{color:var(--danger)}.prio{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.prio-tinggi{background:#fee2e2;color:var(--danger)}.prio-sedang{background:#fef3c7;color:var(--warning)}.prio-rendah{background:#dcfce7;color:var(--success)}.muted{color:var(--muted)}.muted.sm,.sm.muted{font-size:13px}.tag-hadir,.status-disetujui{background:#dcfce7;color:var(--success)}.tag-terlambat,.status-menunggu{background:#fef3c7;color:var(--warning)}.tag-izin{background:var(--primary-light);color:var(--primary-dark)}.status-ditolak{background:#fee2e2;color:var(--danger)}.field{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--muted)}.clock-card{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.clock-status{display:flex;align-items:center;gap:18px}.clock-times{display:flex;align-items:center;gap:20px}.clock-times>div{display:flex;flex-direction:column}.clock-times strong{font-size:18px}.balance-card{display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap}.balance-box{background:linear-gradient(135deg,var(--primary) 0%,#3b82f6 100%);color:#fff;border-radius:12px;padding:18px 26px;text-align:center;min-width:150px}.balance-num{font-size:38px;font-weight:800;line-height:1}.balance-label{font-size:13px;opacity:.9;margin-top:6px}.leave-form{flex:1;min-width:280px;margin-bottom:0}.leave-form label,.inline-form label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600}.tabs{display:flex;gap:6px;background:var(--bg);padding:4px;border-radius:8px}.tab{border:none;background:none;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:grid;place-items:center;z-index:50;padding:20px}.modal{background:var(--surface);border-radius:14px;padding:24px;width:100%;max-width:440px;box-shadow:var(--shadow-lg)}.payslip-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--border);padding-bottom:14px}.payslip-company{font-size:18px;font-weight:800}.payslip-emp{margin:14px 0;font-size:15px}.payslip-table{width:100%;border-collapse:collapse;margin-bottom:18px}.payslip-table td{padding:8px 0;font-size:14px}.payslip-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}.payslip-table .minus{color:var(--danger)}.payslip-table .subtotal td{border-top:1px solid var(--border);font-weight:700}.payslip-table .grandtotal td{border-top:2px solid var(--text);font-weight:800;font-size:16px;padding-top:12px}.report-actions{display:flex;gap:8px;align-self:center;margin-left:auto}.report-doc-head{margin-bottom:12px}.report-doc-head h3{font-size:18px}.data-table tr.report-bold td{font-weight:800;border-top:1px solid var(--border)}@media print{.sidebar,.topbar,.modal-backdrop>.modal>.btn,.no-print{display:none!important}.main{margin-left:0!important}.printable{box-shadow:none!important;border:none!important}}.unit-switch{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:600;background:var(--surface);cursor:pointer;font-family:inherit;max-width:160px}.unit-badge{background:var(--primary-light);color:var(--primary-dark);padding:7px 14px;border-radius:8px;font-size:13px;font-weight:700}.stat-value.sm{font-size:18px}.pos{color:var(--success)}.neg{color:var(--danger)}.right{text-align:right}.center{text-align:center}.small{font-size:12px;color:var(--muted)}.cell-select{padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit;background:var(--surface)}.cell-select.full{width:100%;margin-top:8px}.tag.clickable{cursor:pointer;border:none;font-family:inherit}.sm-tag{margin-left:6px;font-size:10px}.unit-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.unit-card{border:1px solid var(--border);border-top:4px solid var(--primary);border-radius:12px;padding:16px}.unit-card-head{font-weight:700;font-size:15px;margin-bottom:12px;display:flex;align-items:center;gap:8px}.unit-emoji{font-size:20px}.unit-metric{display:flex;justify-content:space-between;font-size:13px;padding:5px 0;color:var(--muted)}.unit-metric strong{color:var(--text)}.unit-metric.total{border-top:1px solid var(--border);margin-top:6px;padding-top:10px;font-weight:700}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}.mini-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}.mini-row:last-child{border-bottom:none}.mini-title{font-weight:600;font-size:14px}.mini-sub{font-size:12px;color:var(--muted)}.progress-wrap{display:flex;align-items:center;gap:10px;min-width:140px}.progress-bar{flex:1;height:8px;background:var(--bg);border-radius:999px;overflow:hidden}.progress-bar span{display:block;height:100%;background:var(--primary);border-radius:999px}.progress-pct{font-size:12px;font-weight:700;color:var(--muted);min-width:34px;text-align:right}.range{width:100%;margin-top:10px;accent-color:var(--primary)}.tabs-lg{display:inline-flex}.tabs-lg .tab{padding:9px 18px;font-size:14px}.matrix-wrap{overflow-x:auto}.matrix th{white-space:nowrap}.matrix th.rot{font-size:12px}.matrix input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.role-name-edit{cursor:pointer}.role-name-edit:hover{color:var(--primary);text-decoration:underline}.matrix th.rot .col-x{margin-left:4px;vertical-align:middle}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.project-card{border:1px solid var(--border);border-radius:12px;padding:16px}.project-card:hover{box-shadow:var(--shadow)}.project-top{display:flex;align-items:center;gap:8px;margin-bottom:10px}.project-top .x{margin-left:auto}.project-card h4{font-size:15px;margin-bottom:10px}.project-meta{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted);margin-bottom:12px}.row-warn{background:#fffbeb}.stock-low{color:var(--danger);font-weight:700}.person-tags{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:6px}.loc-note{font-size:12px;color:var(--muted)}.demo-more{font-size:11px;color:var(--muted);margin-top:10px;line-height:1.5}.forbidden{text-align:center;padding:50px 24px;max-width:460px;margin:40px auto}.forbidden-icon{font-size:48px;margin-bottom:12px}.forbidden h2{margin-bottom:10px}.forbidden p{color:var(--muted);margin-bottom:20px}.chart-donut{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:center}.donut-total-label{font-size:11px;fill:var(--muted)}.donut-total-value{font-size:13px;font-weight:800;fill:var(--text)}.chart-legend{display:flex;flex-direction:column;gap:8px;flex:1;min-width:160px}.legend-row{display:flex;align-items:center;gap:8px;font-size:13px}.legend-row.inline{display:inline-flex}.legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.legend-label{color:var(--muted)}.legend-val{margin-left:auto;font-weight:700;font-variant-numeric:tabular-nums}.chart-bars{padding-top:8px}.bars-area{display:flex;align-items:flex-end;justify-content:space-around;gap:12px;height:180px;border-bottom:2px solid var(--border)}.bar-group{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;height:100%;justify-content:flex-end}.bar-group .bars{display:flex;align-items:flex-end;gap:6px;height:100%}.bar-wrap{display:flex;align-items:flex-end;height:100%}.bar{width:26px;border-radius:6px 6px 0 0;min-height:3px;transition:height .3s ease}.bar-label{font-size:13px;font-weight:600;color:var(--muted)}.bars-legend{display:flex;gap:18px;justify-content:center;margin-top:14px;font-size:13px;color:var(--muted)}.tabs-wrap{flex-wrap:wrap}.report-title{font-size:18px;margin-bottom:2px}.report-table{width:100%;border-collapse:collapse;margin-top:14px}.report-table td{padding:9px 6px;font-size:14px}.report-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}.report-table .report-head td{font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.04em;color:var(--muted);border-bottom:2px solid var(--border);padding-top:16px}.report-table .report-subtotal td{border-top:1px solid var(--border);font-weight:700}.report-table .report-total td{border-top:2px solid var(--text);border-bottom:3px double var(--text);font-weight:800;font-size:15px;padding:12px 6px}.balance-check{margin-top:16px;text-align:center;padding:10px;border-radius:8px;font-weight:700;font-size:14px}.balance-check.ok{background:#dcfce7;color:var(--success)}.balance-check.bad{background:#fee2e2;color:var(--danger)}.vendor-card{border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px;text-align:left}.vendor-card:hover{box-shadow:var(--shadow)}.vendor-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.vendor-top h4{font-size:15px}.vendor-tags{display:flex;gap:6px;flex-wrap:wrap}.vendor-products{font-size:13px}.vendor-contact{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--muted)}.vendor-contact a:hover{color:var(--primary)}.vendor-note{font-size:13px;color:var(--muted);background:var(--bg);padding:8px 10px;border-radius:8px}.vendor-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px}.btn-wa{background:#25d366;color:#fff;text-decoration:none}.btn-wa:hover{background:#1ebe5b}.stars{color:#d1d5db;font-size:17px;white-space:nowrap}.star.on{color:#f59e0b}.star.click{cursor:pointer}.chip-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:999px;font-size:13px;font-weight:600;cursor:pointer}.chip-toggle.on{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark)}.chip-toggle input{margin:0;accent-color:var(--primary)}.chip-toggle.inline-check{background:var(--bg)}.form-inline-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}.board-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;align-items:flex-start}.kanban-col{background:var(--bg);border-radius:12px;padding:10px;min-width:250px;width:250px;flex-shrink:0;border:2px solid transparent;transition:border-color .15s,background .15s}.kanban-col.drag-over{border-color:var(--primary);background:var(--primary-light)}.kanban-col-head{display:flex;align-items:center;gap:8px;padding:4px 6px 10px}.col-title{font-weight:700;font-size:14px;cursor:pointer;flex:1}.col-title:hover{color:var(--primary)}.kanban-col-head .count{background:var(--surface);color:var(--muted);border-radius:999px;padding:1px 9px;font-size:12px}.col-x{background:none;border:none;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:0 4px}.col-x:hover{color:var(--danger)}.kanban-col-body{display:flex;flex-direction:column;gap:8px;min-height:20px}.add-card{width:100%;margin-top:8px;background:none;border:1px dashed var(--border);border-radius:8px;padding:8px;color:var(--muted);font-size:13px;cursor:pointer;font-family:inherit}.add-card:hover{border-color:var(--primary);color:var(--primary);background:var(--surface)}.kard{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:11px;box-shadow:var(--shadow);cursor:grab}.kard:hover{border-color:var(--primary)}.kard:active{cursor:grabbing}.kard-top{display:flex;align-items:center;gap:6px;margin-bottom:8px}.kard-title{font-weight:600;font-size:13.5px;line-height:1.35}.kard-meta{display:flex;flex-direction:column;gap:4px;margin-top:8px;font-size:12px;color:var(--muted)}.kard-meta .overdue,td.overdue{color:var(--danger);font-weight:700}.bell{position:relative;background:none;border:none;font-size:20px;cursor:pointer;padding:4px 6px;line-height:1}.bell-badge{position:absolute;top:-2px;right:-4px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:999px;display:grid;place-items:center;padding:0 4px}.notif-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.notif-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-left-width:4px;border-radius:10px;cursor:pointer;transition:background .15s}.notif-item:hover{background:var(--bg)}.notif-item.sev-danger{border-left-color:var(--danger)}.notif-item.sev-warning{border-left-color:var(--warning)}.notif-item.sev-info{border-left-color:var(--primary)}.notif-dot{font-size:12px}.notif-main{flex:1}.notif-top{display:flex;align-items:center;gap:8px}.notif-title{font-weight:600;font-size:14px}.notif-detail{font-size:13px;color:var(--muted);margin-top:3px}.notif-go{font-size:22px;color:var(--muted)}.settings-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:16px}.settings-box{border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center}.settings-box .settings-emoji{font-size:32px;margin-bottom:8px}.settings-box h4{margin-bottom:6px}.settings-box p{margin-bottom:14px;min-height:36px}.settings-box.danger-box{border-color:#fecaca;background:#fff5f5}.kpi-list{display:flex;flex-direction:column;gap:18px}.kpi-item{border:1px solid var(--border);border-radius:12px;padding:16px}.kpi-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.kpi-unit{font-weight:700;display:flex;align-items:center;gap:8px}.kpi-pct{font-size:20px;font-weight:800}.progress-bar.lg{height:12px}.kpi-figures{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-size:13px;color:var(--muted);flex-wrap:wrap;gap:8px}.kpi-target{display:inline-flex;align-items:center;gap:6px}.kpi-target input{width:130px;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit}.kpi-total{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:2px solid var(--border);font-size:14px;flex-wrap:wrap;gap:8px}.tier-gold{background:#fef3c7;color:#b45309}.tier-silver{background:#e2e8f0;color:#475569}.tier-bronze{background:#fae8d8;color:#9a5b2c}.qline-head,.qline{display:grid;grid-template-columns:1fr 70px 120px 130px 28px;gap:8px;align-items:center}.qline-head{font-size:12px;color:var(--muted);font-weight:600;margin:6px 0}.qline{margin-bottom:6px}.qline input{padding:8px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:inherit}.qline-sub{font-size:13px;text-align:right;font-variant-numeric:tabular-nums}.qtotal-row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;background:var(--bg);padding:10px 14px;border-radius:8px;margin:10px 0;font-size:13px;color:var(--muted)}.qtotal-row strong{font-size:16px;color:var(--text)}.remind-card{border:1px solid var(--warning);background:#fffbeb}.remind-list{display:flex;flex-direction:column;gap:10px}.remind-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap}.unit-banner{display:flex;align-items:center;gap:18px;color:#fff;padding:24px 28px;border-radius:var(--radius)}.unit-banner-icon{font-size:44px}.unit-banner h2{font-size:24px}.unit-banner p{margin:4px 0 0;opacity:.92;font-size:14px}.shortcut-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}.shortcut-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;border:1px solid var(--border);border-radius:12px;text-align:center;font-size:14px;font-weight:600;color:var(--text);transition:all .15s ease}.shortcut-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px);color:var(--primary)}.shortcut-icon{font-size:30px}.sj-sign{display:flex;justify-content:space-around;gap:20px;margin-top:24px;text-align:center}.sj-sign-label{font-size:13px;color:var(--muted);margin-bottom:40px}.sj-sign-name{border-top:1px solid var(--text);padding-top:4px;font-size:13px}.logo-row{display:flex;align-items:center;gap:18px;margin-bottom:18px;flex-wrap:wrap}.logo-preview{width:72px;height:72px;border-radius:14px;object-fit:cover;border:1px solid var(--border)}.logo-placeholder{width:72px;height:72px;border-radius:14px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:32px;font-weight:800}.doc-brand{display:flex;align-items:center;gap:12px}.doc-logo{width:46px;height:46px;object-fit:contain;border-radius:8px;background:#fff}.quota-row{display:inline-flex;align-items:center;gap:6px}.quota-input{width:56px;padding:3px 6px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit}.proj-profit{font-weight:700}.proj-profit.pos{color:var(--success)}.proj-profit.neg{color:var(--danger)}.geo-section{margin-top:18px;padding-top:16px;border-top:1px dashed var(--border)}.geo-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:4px}.geo-head h4{margin:0}.doc-textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:14px;line-height:1.55;resize:vertical}.doc-modal{max-width:640px;width:100%}.doc-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.doc-title-input{font-size:16px;font-weight:700;padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-family:inherit}.doc-meta{display:flex;align-items:center;gap:6px;margin-bottom:14px}.doc-view{white-space:pre-wrap;line-height:1.6;background:var(--surface-2, #f8fafc);border:1px solid var(--border);border-radius:8px;padding:14px 16px;min-height:120px;max-height:55vh;overflow:auto}.doc-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}.cal-legend{display:flex;align-items:center;gap:16px;margin-bottom:12px;font-size:13px;color:var(--muted);flex-wrap:wrap}.cal-legend span{display:inline-flex;align-items:center;gap:6px}.cal-legend i.cal-cell{width:16px;height:16px;border-radius:4px;display:inline-block}.cal-legend i.occ{background:var(--primary)}.cal-legend i.free{background:#e5e7eb}.cal-scroll{overflow-x:auto}.cal-table{border-collapse:collapse}.cal-table th,.cal-table td{border:1px solid var(--border)}.cal-table th.cal-day{width:26px;min-width:26px;text-align:center;font-size:11px;padding:4px 0;color:var(--muted);font-weight:600}.cal-table th.cal-day.sun{color:var(--danger)}.cal-room{min-width:130px;padding:6px 10px;text-align:left;position:sticky;left:0;background:var(--surface, #fff);z-index:1}.cal-cell-td{width:26px;height:34px;padding:0;cursor:default}.cal-cell-td.free{background:#f3f4f6}.cal-cell-td.occ{background:var(--primary);cursor:pointer}.cal-cell-td.occ:hover{opacity:.85}.chat-list{height:56vh;min-height:320px;overflow-y:auto;padding:8px 4px;display:flex;flex-direction:column;gap:4px;background:var(--surface-2, #f8fafc);border:1px solid var(--border);border-radius:10px}.chat-day{text-align:center;font-size:11px;color:var(--muted);margin:10px 0 6px}.chat-row{display:flex;align-items:flex-end;gap:8px;margin:2px 6px}.chat-row.mine{flex-direction:row-reverse}.chat-avatar{width:30px;height:30px;border-radius:50%;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.chat-bubble{max-width:72%;background:#fff;border:1px solid var(--border);border-radius:12px;padding:7px 11px;box-shadow:0 1px 1px #0000000a}.chat-row.mine .chat-bubble{background:var(--primary);color:#fff;border-color:var(--primary)}.chat-name{font-size:11px;font-weight:700;color:var(--primary);margin-bottom:2px}.chat-text{font-size:14px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.chat-time{font-size:10px;opacity:.7;text-align:right;margin-top:2px;display:flex;align-items:center;justify-content:flex-end;gap:4px}.chat-del{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:13px;line-height:1;padding:0}.chat-del:hover{opacity:1}.chat-input{display:flex;gap:8px;margin-top:12px}.chat-input input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:999px;font-family:inherit;font-size:14px}.acct-status{display:flex;justify-content:center;margin:8px 0 6px}*{scrollbar-width:thin;scrollbar-color:#c7cdd6 transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c7cdd6;border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#9aa4b2;background-clip:padding-box}::-webkit-scrollbar-corner{background:transparent}@media (max-width: 900px){.board,.grid-2{grid-template-columns:1fr}}@media (max-width: 560px){.page-title{display:none}}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.main{margin-left:0}.hamburger{display:block}.hello{display:none}.backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:25}.content{padding:16px}.topbar{padding:0 14px;gap:10px}.page-title{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-right{gap:8px}.unit-switch{max-width:132px}.welcome-banner h2{font-size:19px}.welcome-banner p{font-size:13px}}
