@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";:root{--pri:#0f766e;--pri-dark:#0d6359;--pri-light:#ccfbf1;--pri-xlight:#f0fdfa;--accent:#1e40af;--green:#059669;--green-bg:#ecfdf5;--red:#dc2626;--red-bg:#fef2f2;--yellow:#d97706;--yellow-bg:#fffbeb;--blue:#2563eb;--blue-bg:#eff6ff;--text:#111827;--text2:#374151;--muted:#6b7280;--muted2:#9ca3af;--border:#e5e7eb;--border2:#f3f4f6;--bg:#f9fafb;--white:#fff;--sidebar-w:230px;--header-h:56px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;line-height:1.5}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--white);border-right:1px solid var(--border);z-index:10;flex-direction:column;flex-shrink:0;display:flex}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:18px 16px 14px;display:flex}.sidebar-logo-icon{background:var(--pri);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:800;display:flex}.sidebar-logo-text{color:var(--text);letter-spacing:.02em;font-size:18px;font-weight:800;line-height:1.1}.sidebar-logo-sub{color:var(--muted);font-size:10px;font-weight:500}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-group{margin-bottom:2px}.nav-label{color:var(--muted2);text-transform:uppercase;letter-spacing:.06em;padding:12px 16px 4px;font-size:10px;font-weight:600}.nav-item{cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none;border-left:2px solid #0000;align-items:center;gap:10px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .12s;display:flex}.nav-item:hover{background:var(--pri-xlight);color:var(--pri)}.nav-item.active{background:var(--pri-xlight);color:var(--pri);border-left-color:var(--pri);font-weight:600}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.nav-live{letter-spacing:.05em;color:var(--green);background:var(--green-bg);text-transform:uppercase;border-radius:6px;margin-left:auto;padding:2px 5px;font-size:8px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);padding:12px 16px}.user-row{background:var(--bg);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:flex}.user-avatar{background:var(--pri);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex}.user-name{color:var(--text);font-size:12px;font-weight:600}.user-role{color:var(--muted);font-size:10px}.main-area{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.topbar{height:var(--header-h);background:linear-gradient(90deg,var(--white) 0%,#0f766e08 100%);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.topbar-title{color:var(--text);font-size:15px;font-weight:700}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-accent{background:linear-gradient(90deg,var(--pri),transparent 60%);flex-shrink:0;height:2px}.content{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden auto}.content-watermark{color:var(--pri);opacity:.04;pointer-events:none;z-index:0;letter-spacing:.1em;font-size:120px;font-weight:800;position:absolute;bottom:18px;left:50%;transform:translate(-50%)}.demo-pill{letter-spacing:.06em;color:var(--green);background:var(--green-bg);border:1px solid #a7f3d0;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:10px;font-weight:700;display:inline-flex}.demo-pill:before{content:"";background:var(--green);border-radius:50%;width:6px;height:6px;animation:1.6s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.demo-banner{background:var(--yellow-bg);color:#92400e;z-index:1;border-bottom:1px solid #fde68a;align-items:center;gap:10px;padding:8px 24px;font-size:12px;display:flex}.demo-banner .demo-pill{color:var(--yellow);background:#fef3c7;border-color:#fde68a}.demo-banner .demo-pill:before{background:var(--yellow)}.lang-switch{border:1px solid var(--border);border-radius:7px;display:inline-flex;overflow:hidden}.lang-switch button{background:var(--white);color:var(--muted);cursor:pointer;border:none;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:700;transition:all .12s}.lang-switch button.active{background:var(--pri);color:#fff}.page{z-index:1;flex:1;width:100%;padding:24px;position:relative}.page-title{color:var(--text);font-size:18px;font-weight:800}.page-sub{color:var(--muted);margin-bottom:18px;font-size:12px}.card{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.card-title{color:var(--text);font-size:13px;font-weight:700}.card-body{padding:16px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:16px}.stat-label{color:var(--muted2);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.stat-value{color:var(--text);margin:4px 0;font-size:26px;font-weight:800}.table{border-collapse:collapse;width:100%}.table th{color:var(--muted2);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border);background:var(--bg);padding:8px 12px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--border2);padding:10px 12px;font-size:13px}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--bg)}.badge{border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-yellow{background:var(--yellow-bg);color:var(--yellow)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-gray{background:var(--bg);color:var(--muted);border:1px solid var(--border)}.badge-pri{background:var(--pri-light);color:var(--pri)}.btn{cursor:pointer;border:none;border-radius:7px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--pri);color:#fff}.btn-primary:hover{background:var(--pri-dark)}.btn-outline{color:var(--pri);border:1.5px solid var(--pri);background:0 0}.btn-outline:hover{background:var(--pri-xlight)}.btn-ghost{color:var(--muted);background:0 0}.btn-ghost:hover{background:var(--bg)}.btn-sm{padding:5px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.list-panel{border-right:1px solid var(--border);background:var(--white);flex-direction:column;flex-shrink:0;width:330px;display:flex}.list-header{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 16px;display:flex}.list-search{background:var(--bg);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:7px 12px;display:flex}.list-search input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.list-body{flex:1;overflow-y:auto}.list-item{cursor:pointer;border-bottom:1px solid var(--border2);align-items:center;gap:12px;padding:12px 16px;transition:background .1s;display:flex}.list-item:hover{background:var(--bg)}.list-item.active{background:var(--pri-xlight);border-left:2px solid var(--pri)}.list-avatar{background:var(--pri-light);width:38px;height:38px;color:var(--pri);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.list-item-info{flex:1;min-width:0}.list-item-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.list-item-sub{color:var(--muted);margin-top:2px;font-size:11px}.list-item-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.list-item-date{color:var(--muted2);font-size:10px}.detail-panel{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.fields-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.field label{color:var(--muted2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:10px;font-weight:600;display:block}.field span{color:var(--text);font-size:13px;font-weight:600}.day-grid-wrap{border:1px solid var(--border);background:var(--white);border-radius:10px;overflow-x:auto}.day-grid{border-collapse:collapse;table-layout:fixed;width:100%;font-size:12px}.day-grid th{text-align:center;color:var(--muted);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;padding:6px 2px;font-size:10px;font-weight:700}.day-grid td{text-align:center;border-bottom:1px solid var(--border2);border-right:1px solid var(--border2);padding:0}.day-grid .day-weekend{background:#fef3c7}.day-grid .day-holiday{background:#dbeafe}.day-cell{text-align:center;width:100%;color:var(--text);background:0 0;border:none;outline:none;padding:7px 2px;font-family:DM Mono,monospace;font-size:12px}.day-cell:focus{background:var(--pri-xlight);outline:2px solid var(--pri);outline-offset:-2px}.day-cell.absence{color:var(--red);text-transform:lowercase;font-family:DM Sans,sans-serif;font-weight:700}.day-grid .summary-row td{background:var(--bg);border-top:2px solid var(--border);padding:6px 4px;font-size:12px;font-weight:700}.finance-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;display:grid}.finance-item{background:var(--bg);border-radius:8px;justify-content:space-between;align-items:center;padding:9px 12px;font-size:12px;display:flex}.finance-item label{color:var(--muted);font-weight:500}.finance-item .value{color:var(--text);font-family:DM Mono,monospace;font-weight:700}.finance-item.total{background:var(--pri-xlight);border:1px solid var(--pri-light)}.finance-item.total .value{color:var(--pri);font-size:14px}.legend{flex-wrap:wrap;gap:8px 18px;display:flex}.legend-item{color:var(--muted);align-items:center;gap:6px;font-size:11px;display:flex}.legend-code{color:var(--red);font-family:DM Mono,monospace;font-weight:700}.import-screen{z-index:1;flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.import-stepper{justify-content:center;align-items:center;gap:0;display:flex}.import-step{color:var(--muted2);align-items:center;gap:8px;padding:8px 20px;font-size:13px;font-weight:500;display:flex;position:relative}.import-step:not(:last-child):after{content:"";background:var(--border);width:16px;height:1px;position:absolute;top:50%;right:-8px}.import-step-num{border:2px solid var(--border);width:26px;height:26px;color:var(--muted2);background:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.import-step.active{color:var(--pri);font-weight:700}.import-step.active .import-step-num{border-color:var(--pri);color:#fff;background:var(--pri)}.import-step.done{color:var(--green)}.import-step.done .import-step-num{border-color:var(--green);color:#fff;background:var(--green)}.import-content{width:100%;max-width:920px;margin:0 auto}.import-dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--white);border-radius:16px;padding:48px 32px;transition:all .2s}.import-dropzone:hover,.import-dropzone.drag-over{border-color:var(--pri);background:var(--pri-xlight)}.import-dropzone-icon{margin-bottom:12px;font-size:3rem}.import-dropzone-text{color:var(--text);margin-bottom:4px;font-size:15px;font-weight:600}.import-dropzone-sub{color:var(--muted2);font-size:12px}.import-progress-bar{background:var(--border2);border-radius:4px;height:8px;margin-bottom:16px;overflow:hidden}.import-progress-fill{background:linear-gradient(90deg,var(--pri),var(--green));border-radius:4px;height:100%;transition:width .3s}.import-done-icon{background:var(--green-bg);width:80px;height:80px;color:var(--green);border-radius:50%;justify-content:center;align-items:center;margin:0 auto;font-size:36px;font-weight:800;animation:.4s cubic-bezier(.175,.885,.32,1.275) popIn;display:flex}@keyframes popIn{0%{transform:scale(0)}to{transform:scale(1)}}.source-preview{color:#333;background:#fffff8;border:2px solid #999;border-radius:4px;padding:14px;font-family:Courier New,monospace}.source-label{text-align:center;letter-spacing:2px;margin-bottom:6px;font-size:14px;font-weight:700;display:block}.source-meta{color:#555;border-bottom:1px solid #ccc;flex-wrap:wrap;gap:14px;margin-bottom:10px;padding-bottom:8px;font-size:10px;display:flex}.source-meta b{color:#333}.source-table{border-collapse:collapse;width:100%}.source-table th{text-align:center;background:#e8e8d8;border:1px solid #aaa;padding:4px 6px;font-size:10px;font-weight:700}.source-table td{text-align:center;border:1px solid #bbb;padding:3px 6px;font-size:11px}.source-name{white-space:nowrap;background:#f0f0e8;font-weight:600;text-align:left!important}.source-num{font-family:DM Mono,Courier New,monospace}.source-total td{background:#fed;border-top:2px double #666;font-weight:700}.mono{font-family:DM Mono,monospace}.toast{z-index:2000;border-left:3px solid var(--green);background:#fff;border-radius:8px;align-items:center;gap:10px;padding:12px 16px;font-size:13px;animation:.2s slideIn;display:flex;position:fixed;top:16px;right:16px;box-shadow:0 4px 16px #0000001f}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted2)}
