*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-card: #1c2128;--bg-input: #0d1117;--bg-hover: #292e36;--border: #30363d;--border-light: #484f58;--text-primary: #f0f6fc;--text-secondary: #c9d1d9;--text-muted: #8b949e;--accent: #f59e0b;--accent-hover: #d97706;--accent-bg: rgba(245, 158, 11, .12);--success: #3fb950;--success-bg: rgba(63, 185, 80, .12);--danger: #f85149;--danger-bg: rgba(248, 81, 73, .12);--warning: #d29922;--warning-bg: rgba(210, 153, 34, .12);--info: #58a6ff;--info-bg: rgba(88, 166, 255, .12);--purple: #bc8cff;--purple-bg: rgba(188, 140, 255, .12);--radius: 8px;--radius-lg: 12px;--shadow: 0 2px 8px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--transition: all .2s ease;--sb-width: 230px}html{font-size:14px;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;line-height:1.5}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}.app{display:flex;min-height:100vh}.sidebar{width:var(--sb-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:199}.sidebar-overlay.show{display:block}.sidebar-header{padding:14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}.sidebar-logo{width:34px;height:34px;background:var(--accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:15px;color:#000;flex-shrink:0}.sidebar-brand h1{font-size:15px;color:var(--accent);font-weight:800;letter-spacing:-.5px}.sidebar-brand p{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.sidebar-nav{flex:1;padding:6px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--radius);cursor:pointer;color:var(--text-secondary);transition:var(--transition);font-weight:500;font-size:12.5px;margin-bottom:1px;border:1px solid transparent;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-bg);color:var(--accent);border-color:#f59e0b33}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:9px;padding:2px 6px;border-radius:10px;font-weight:700}.sidebar-footer{padding:14px;border-top:1px solid var(--border);flex-shrink:0}.main{flex:1;margin-left:var(--sb-width);min-height:100vh;display:flex;flex-direction:column}.topbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;gap:8px;min-height:48px}.topbar h2{font-size:16px;font-weight:700;display:flex;align-items:center;gap:6px;white-space:nowrap}.topbar-date{font-size:10px;color:var(--text-muted);white-space:nowrap}.menu-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:4px;border-radius:var(--radius);transition:var(--transition)}.menu-btn:hover{background:var(--bg-hover)}.menu-btn svg{width:22px;height:22px}.content{padding:16px;flex:1}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg-secondary);border-top:1px solid var(--border);padding:5px 4px env(safe-area-inset-bottom,6px)}.mobile-nav-inner{display:flex;justify-content:space-around}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 6px;border-radius:var(--radius);cursor:pointer;color:var(--text-muted);font-size:9px;font-weight:600;transition:var(--transition);flex:1;text-align:center;-webkit-user-select:none;user-select:none}.mobile-nav-item:hover{color:var(--text-primary)}.mobile-nav-item.active{color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);font-size:12.5px;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit}.btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn:active{opacity:.8}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#000;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#f8514940}.btn-danger:hover{background:var(--danger);color:#fff}.btn-success{background:var(--success-bg);color:var(--success);border-color:#3fb95040}.btn-success:hover{background:var(--success);color:#fff}.btn-info{background:var(--info-bg);color:var(--info);border-color:#58a6ff40}.btn-info:hover{background:var(--info);color:#fff}.btn-sm{padding:5px 10px;font-size:11px}.btn-xs{padding:3px 7px;font-size:10px}.btn-lg{padding:11px 20px;font-size:14px}.form-group{margin-bottom:12px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 11px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:13px;font-family:inherit;transition:var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f59e0b1f}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b949e' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:32px}.form-textarea{resize:vertical;min-height:80px;line-height:1.6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.money-input-wrap{position:relative;display:flex;align-items:center}.money-input-wrap .prefix{position:absolute;left:11px;font-size:12px;font-weight:700;color:var(--text-muted);pointer-events:none;z-index:1}.money-input-wrap .form-input{padding-left:30px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:12px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);gap:8px}.card-header h3{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}.card-body{padding:14px}.card-body.no-pad{padding:0}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;white-space:nowrap}.badge-success{background:var(--success-bg);color:var(--success)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-default{background:var(--bg-tertiary);color:var(--text-muted)}.badge-accent{background:var(--accent-bg);color:var(--accent)}.modal-overlay{position:fixed;inset:0;z-index:1000;background:#000000bf;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s ease;box-shadow:var(--shadow-lg)}.modal-lg{max-width:700px}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h3{font-size:14px;font-weight:700}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius);transition:var(--transition);display:flex}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-close svg{width:18px;height:18px}.modal-body{padding:16px;overflow-y:auto;flex:1}.modal-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}.toast-container{position:fixed;bottom:80px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:6px;pointer-events:none}.toast{padding:10px 14px;border-radius:var(--radius);font-size:12px;font-weight:600;box-shadow:var(--shadow-lg);animation:slideInRight .25s ease;max-width:280px}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-success{background:#238636;color:#fff}.toast-error{background:#b91c1c;color:#fff}.toast-info{background:#1d4ed8;color:#fff}.toast-warning{background:#b45309;color:#fff}.progress-bar{height:5px;background:var(--bg-tertiary);border-radius:999px;overflow:hidden}.progress-bar .fill{height:100%;border-radius:999px;transition:width .4s ease}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;font-size:12px;min-width:500px}.table th{background:var(--bg-tertiary);color:var(--text-muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;font-weight:700}.table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-hover)}.table .actions{display:flex;gap:4px;align-items:center;justify-content:flex-end}.list-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);transition:var(--transition)}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--bg-hover)}.empty-state{text-align:center;padding:40px 16px;color:var(--text-muted)}.empty-state .empty-icon{font-size:40px;margin-bottom:12px;opacity:.6}.empty-state p{font-size:12px;margin-bottom:12px}.filter-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.filter-row .form-input,.filter-row .form-select{width:auto}.search-box{display:flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:6px 11px;flex:1;min-width:160px}.search-box svg{width:15px;height:15px;color:var(--text-muted);flex-shrink:0}.search-box input{background:none;border:none;outline:none;color:var(--text-primary);font-size:12px;width:100%;font-family:inherit}.search-box input::placeholder{color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}.stat-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:8px}.stat-value{font-size:20px;font-weight:800;letter-spacing:-.5px;line-height:1.1;margin-bottom:2px}.stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-change{font-size:10px;font-weight:600}.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.tab-bar{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:4px;margin-bottom:14px;overflow-x:auto}.tab-item{padding:6px 12px;border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;white-space:nowrap;color:var(--text-muted);transition:var(--transition);flex-shrink:0}.tab-item:hover{color:var(--text-primary)}.tab-item.active{background:var(--accent);color:#000}.mobile-card-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;margin-bottom:10px}.mc-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px}.mc-title{font-size:14px;font-weight:700;line-height:1.3}.mc-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.mc-label{font-size:10px;color:var(--text-muted)}.mc-value{font-size:12px;font-weight:600}.mc-actions{display:flex;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px;margin-top:8px}.photo-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb .del-btn{position:absolute;top:3px;right:3px;background:#f85149d9;color:#fff;border:none;cursor:pointer;border-radius:50%;width:18px;height:18px;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:700}.photo-upload-zone{display:flex;align-items:center;justify-content:center;width:100%;padding:16px;background:var(--bg-tertiary);border:1px dashed var(--border-light);border-radius:var(--radius);cursor:pointer;font-size:12px;color:var(--text-muted);transition:var(--transition)}.photo-upload-zone:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.rab-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}.rab-summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px}.rab-summary-card .lbl{font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.rab-summary-card .val{font-size:15px;font-weight:800;letter-spacing:-.5px;line-height:1.2;margin-bottom:4px}.variance-bar{height:4px;background:var(--bg-tertiary);border-radius:999px;overflow:hidden;margin-top:4px}.variance-bar .fill{height:100%;border-radius:999px;transition:width .4s ease}.rab-cat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:8px;overflow:hidden}.rab-cat-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:var(--transition);border-bottom:1px solid transparent}.rab-cat-head:hover{background:var(--bg-hover)}.rab-cat-head h4{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;flex:1;min-width:0}.rab-cat-head .ct{font-size:11px;font-weight:700;color:var(--accent)}.rab-item{border-top:1px solid var(--border)}.rab-item-head{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:var(--transition)}.rab-item-head:hover{background:var(--bg-hover)}.rab-item-num{width:22px;height:22px;border-radius:4px;background:var(--bg-tertiary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--text-muted);flex-shrink:0}.rab-item-info{flex:1;min-width:0}.rab-item-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rab-item-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}.rab-item-meta span{font-size:10px;color:var(--text-muted)}.rab-item-price{text-align:right;flex-shrink:0}.rab-item-price .up{font-size:12px;font-weight:700;color:var(--accent)}.rab-item-price .tot{font-size:10px;color:var(--text-muted)}.rab-item-actions{display:flex;gap:4px;flex-shrink:0}.rab-ahs{padding:12px;background:var(--bg-primary);border-top:1px solid var(--border)}.ahs-section{margin-bottom:10px}.ahs-section-head{font-size:10px;font-weight:700;padding:5px 8px;border-radius:var(--radius);margin-bottom:4px}.ahs-bahan{background:var(--info-bg);color:var(--info)}.ahs-upah{background:var(--success-bg);color:var(--success)}.ahs-alat{background:var(--purple-bg);color:var(--purple)}.ahs-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4px;padding:4px 8px;font-size:10px;border-bottom:1px solid var(--border)}.ahs-row:last-child{border-bottom:none}.ahs-row .name{color:var(--text-secondary)}.ahs-row .koef,.ahs-row .hrg{color:var(--text-muted);text-align:right}.ahs-row .sub{font-weight:700;color:var(--accent);text-align:right}.ahs-total{display:flex;align-items:center;justify-content:space-between;padding:8px;margin-top:6px;background:var(--accent-bg);border:1px solid rgba(245,158,11,.2);border-radius:var(--radius)}.ahs-total .label{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase}.ahs-total .value{font-size:13px;font-weight:800;color:var(--accent)}.ahs-comparison{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.ahs-comp-card{padding:10px;border-radius:var(--radius)}.ahs-comp-card .lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.ahs-comp-card .val{font-size:14px;font-weight:800;margin-top:4px}.comp-list{margin-bottom:8px}.comp-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:var(--radius);background:var(--bg-primary);margin-bottom:3px;border:1px solid var(--border)}.ci-type{width:22px;height:22px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}.ci-name{flex:1;font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ci-detail{font-size:10px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.ci-sub{font-size:11px;font-weight:700;color:var(--accent);white-space:nowrap;flex-shrink:0}.ci-del{background:none;border:none;color:var(--danger);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;flex-shrink:0;transition:var(--transition)}.ci-del:hover{color:#fff;background:var(--danger);border-radius:4px}.preset-grid{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:4px}.preset-btn{padding:4px 8px;border-radius:var(--radius);background:var(--bg-tertiary);border:1px solid var(--border);font-size:10px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-family:inherit}.preset-btn:hover{background:var(--accent-bg);color:var(--accent);border-color:#f59e0b4d}.stock-indicator{display:flex;align-items:center;gap:4px;font-size:10px}.stock-dot{width:8px;height:8px;border-radius:50%}.worker-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:12px}.worker-avatar{width:42px;height:42px;border-radius:50%;background:var(--accent-bg);border:2px solid rgba(245,158,11,.3);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.worker-info{flex:1;min-width:0}.worker-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.worker-role{font-size:10px;color:var(--accent);font-weight:600}.worker-meta{font-size:10px;color:var(--text-muted);margin-top:2px}.worker-actions{display:flex;gap:4px;flex-shrink:0}.invoice-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;margin-bottom:10px}.inv-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px}.inv-number{font-size:11px;color:var(--text-muted);margin-top:2px}.inv-amount{font-size:18px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.inv-meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}.inv-meta-item{font-size:10px;color:var(--text-muted)}.inv-meta-item span{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);margin-top:1px}.inv-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.doc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:var(--transition)}.doc-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow)}.doc-thumb{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--bg-tertiary);display:block}.doc-thumb-placeholder{width:100%;aspect-ratio:4/3;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:32px}.doc-info{padding:8px}.doc-name{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-meta{font-size:9px;color:var(--text-muted);margin-top:2px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-info{color:var(--info)}.text-right{text-align:right}.text-center{text-align:center}.fw-700{font-weight:700}.fw-600{font-weight:600}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin:14px 0 6px}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0}.menu-btn{display:flex}.mobile-nav{display:block}.content{padding:10px 10px 76px}.stats-grid{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr}.rab-summary{grid-template-columns:repeat(2,1fr)}.form-row,.form-row-3{grid-template-columns:1fr}.ahs-row{grid-template-columns:1.5fr 1fr 1fr;gap:3px}.ahs-row .hrg{display:none}.ahs-comparison{grid-template-columns:1fr 1fr}.table{min-width:420px}.modal{max-height:95vh}.toast-container{bottom:85px;left:16px;right:16px;align-items:stretch}.toast{max-width:100%;text-align:center}.doc-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media(max-width:400px){.rab-summary,.stats-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:16px}}.attendance-grid{display:grid;grid-template-columns:1fr;gap:8px}.att-buttons{display:flex;gap:4px;flex-shrink:0}.att-btn{width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-family:inherit}.att-btn:hover{border-color:var(--border-light);color:var(--text-primary)}.att-btn.present{background:var(--success-bg);color:var(--success);border-color:#3fb95066}.att-btn.half{background:var(--warning-bg);color:var(--warning);border-color:#d2992266}.att-btn.absent{background:var(--danger-bg);color:var(--danger);border-color:#f8514966}.att-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;margin-bottom:12px}.att-sum-item{text-align:center}.att-sum-val{font-size:22px;font-weight:800;line-height:1}.att-sum-lbl{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;border-radius:var(--radius);animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;margin-bottom:10px}.skeleton-h{height:14px;margin-bottom:8px;border-radius:4px}.skeleton-p{height:10px;margin-bottom:6px;border-radius:4px}.skeleton-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}.sk-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}.confirm-overlay{position:fixed;inset:0;z-index:2000;background:#000c;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.confirm-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;max-width:340px;width:100%;text-align:center;animation:slideUp .2s ease;box-shadow:var(--shadow-lg)}.confirm-icon{font-size:40px;margin-bottom:12px}.confirm-title{font-size:15px;font-weight:700;margin-bottom:6px}.confirm-msg{font-size:12px;color:var(--text-muted);margin-bottom:20px;line-height:1.6}.confirm-actions{display:flex;gap:8px;justify-content:center}.lightbox{position:fixed;inset:0;z-index:3000;background:#000000eb;display:flex;align-items:center;justify-content:center;padding:16px;cursor:zoom-out;animation:fadeIn .2s ease}.lightbox img{max-width:100%;max-height:90vh;border-radius:var(--radius);object-fit:contain}.lightbox-close{position:absolute;top:16px;right:16px;background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.lightbox-close:hover{background:#ffffff4d}.doc-type-chip{padding:4px 12px;border-radius:999px;font-size:10px;font-weight:700;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none}.doc-type-chip:hover{color:var(--text-primary);border-color:var(--border-light)}.doc-type-chip.active{background:var(--accent);color:#000;border-color:var(--accent)}.shortcut-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.shortcut-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 8px;cursor:pointer;text-align:center;transition:var(--transition);-webkit-user-select:none;user-select:none}.shortcut-btn:hover{border-color:var(--accent);background:var(--accent-bg);transform:translateY(-2px)}.shortcut-btn .sb-icon{font-size:22px;margin-bottom:4px}.shortcut-btn .sb-label{font-size:10px;color:var(--text-muted);font-weight:600}.worker-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}@media(max-width:768px){.shortcut-grid{grid-template-columns:repeat(4,1fr)}.skeleton-stats{grid-template-columns:repeat(2,1fr)}.att-summary,.worker-stats{grid-template-columns:repeat(3,1fr)}}
