*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Arial,sans-serif;background:#f0f2f5;color:#1a1a2e}.app-header{background:#1a1a2e;color:#fff;padding:14px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.app-header-title{font-size:20px;font-weight:700;letter-spacing:1px;line-height:1.2}.app-header-subtitle{font-size:12px;color:#aab;letter-spacing:1px;text-transform:uppercase}.btn-logout{padding:8px 18px;background:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;white-space:nowrap}.home-content{padding:24px 16px}.section-label{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.nav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:28px}@media(max-width:768px){.nav-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.nav-grid{grid-template-columns:1fr}}.nav-card{background:#fff;border-radius:12px;padding:18px 20px;cursor:pointer;box-shadow:0 2px 8px #00000012;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:row;align-items:center;gap:16px}.nav-card:hover{box-shadow:0 8px 24px #00000021;transform:translateY(-3px)}.nav-card-icon{font-size:32px;flex-shrink:0}.nav-card-text{display:flex;flex-direction:column;gap:3px}.nav-card-title{font-size:15px;font-weight:700}.nav-card-desc{font-size:12px;color:#888}.screen{padding:24px 16px;width:100%}.screen-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid #e8ecf0;flex-wrap:wrap}.screen-header h2{margin:0;font-size:22px;font-weight:700;color:#1a1a2e;padding-left:14px;border-left:4px solid #4361ee;line-height:1.2}.btn-back{padding:8px 14px;background:#f0f2f5;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:14px;white-space:nowrap}.btn-back:hover{background:#e2e6ea}.btn-primary{flex:1;padding:10px 16px;background:#4361ee;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-primary:hover{background:#3451d1}.btn-cancel{padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.btn-edit{padding:6px 12px;background:#e8f0fe;color:#4361ee;border:1px solid #c5d4f8;border-radius:5px;cursor:pointer;font-size:13px}.btn-edit:hover{background:#d0e0fd}.btn-delete{padding:6px 12px;background:#fde8e8;color:#dc3545;border:1px solid #f5c6cb;border-radius:5px;cursor:pointer;font-size:13px}.btn-delete:hover{background:#fbd0d0}.btn-delete:disabled{opacity:.4;cursor:not-allowed}.btn-delete:disabled:hover{background:#fde8e8}.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.col-1{grid-column:span 1}.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-9{grid-column:span 9}.col-10{grid-column:span 10}.col-11{grid-column:span 11}.col-12{grid-column:span 12}.form-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:20px;margin-bottom:24px;box-shadow:0 1px 4px #0000000f}.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:13px;font-weight:500;color:#555}.form-field input,.form-field select{padding:9px 10px;border:1px solid #d0d0d0;border-radius:6px;font-size:14px;width:100%;background:#fff}.form-field input:focus,.form-field select:focus{outline:none;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1a}.form-section-title{grid-column:span 12;font-size:12px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.5px;padding-top:6px;border-top:1px solid #f0f0f0;margin-top:2px}.form-actions{grid-column:span 12;display:flex;gap:10px;margin-top:4px}.checkbox-group{grid-column:span 12;display:flex;flex-wrap:wrap;gap:14px 24px;align-items:center;padding:4px 0}.checkbox-group label{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer}.days-group{grid-column:span 12;display:flex;flex-wrap:wrap;gap:10px}.days-group label{display:flex;align-items:center;gap:5px;font-size:14px;cursor:pointer;background:#f8f9fa;border:1px solid #ddd;border-radius:6px;padding:5px 10px}.days-group input[type=checkbox]:checked+span{color:#4361ee;font-weight:600}.card-list{display:flex;flex-direction:column;gap:10px}.list-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;box-shadow:0 1px 3px #0000000d}.list-card-info .title{font-weight:600;font-size:15px}.list-card-info .subtitle{font-size:13px;color:#777;margin-top:3px}.list-card-actions{display:flex;gap:8px;flex-shrink:0}.field-hint{font-size:12px;color:#dc3545;margin-top:3px}.back-page{padding:16px}@media(max-width:640px){.form-grid{grid-template-columns:1fr}.form-grid>*{grid-column:1 / -1}.form-actions{flex-direction:column}.btn-primary{flex:none;width:100%}.list-card{flex-direction:column;align-items:flex-start}.list-card-actions{width:100%}.btn-edit,.btn-delete{flex:1;text-align:center}.screen{padding:12px}.app-header{padding:12px 16px}.home-content{padding:16px 12px}.nav-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}}.login-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e 60%,#0f3460);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.login-brand{text-align:center;margin-bottom:32px}.login-brand-name{font-size:32px;font-weight:800;color:#fff;letter-spacing:1px;line-height:1.1;margin-top:16px}.login-brand-tagline{font-size:13px;color:#7b9eff;letter-spacing:2px;text-transform:uppercase;margin-top:6px}.login-card{background:#fff;border-radius:16px;padding:36px 32px;width:100%;max-width:380px;box-shadow:0 20px 60px #0006,inset 0 1px #fffc}.login-card-title{font-size:20px;font-weight:700;color:#1a1a2e;margin:0 0 6px}.login-card-subtitle{font-size:13px;color:#888;margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:16px}.login-input{padding:10px 12px;border:1.5px solid #d0d0d0;border-radius:8px;font-size:14px;width:100%;box-sizing:border-box;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#fff}.login-input:focus{border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1f}.login-error{padding:10px 12px;background:#fde8e8;border:1px solid #f5c6cb;border-radius:8px;color:#dc3545;font-size:13px}.login-submit-btn{padding:12px;background:#4361ee;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;margin-top:4px;transition:background .2s,transform .1s;position:relative;overflow:hidden;font-family:inherit;width:100%}.login-submit-btn:hover:not(:disabled){background:#3451d1}.login-submit-btn:active:not(:disabled){transform:scale(.98)}.login-submit-btn:disabled{background:#a0aee0;cursor:not-allowed}@keyframes loginShimmer{0%{transform:translate(-150%)}to{transform:translate(250%)}}.login-submit-btn--loading:after{content:"";position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);animation:loginShimmer 1.3s infinite}.upload-type-pills{display:flex;flex-wrap:wrap;gap:8px}.upload-type-pill{padding:6px 18px;border:1.5px solid #d0d4e8;border-radius:20px;background:#fff;color:#555;font-size:13px;font-weight:500;cursor:pointer;transition:border-color .18s,color .18s,background .18s;font-family:inherit}.upload-type-pill:hover:not(:disabled){border-color:#4361ee;color:#4361ee;background:#f0f3ff}.upload-type-pill--active{background:#4361ee;border-color:#4361ee;color:#fff}.upload-type-pill--active:hover:not(:disabled){background:#3451d1;border-color:#3451d1}.upload-type-pill:disabled{opacity:.5;cursor:not-allowed}.upload-dropzone{border:2px dashed #c5cde8;border-radius:12px;padding:36px 20px 28px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;background:#f8f9fe;position:relative}.upload-dropzone:hover{border-color:#4361ee;background:#f0f3ff}.upload-dropzone--active{border-color:#4361ee;background:#e8edff;transform:scale(1.01)}.upload-dropzone-icon{display:block;width:40px;height:40px;margin:0 auto 12px;color:#4361ee;opacity:.65;transition:opacity .2s,transform .2s}.upload-dropzone:hover .upload-dropzone-icon,.upload-dropzone--active .upload-dropzone-icon{opacity:1;transform:translateY(-3px)}.upload-dropzone-text{font-size:14px;font-weight:600;color:#2a2a3e;margin-bottom:4px}.upload-dropzone-hint{font-size:12px;color:#999}.upload-selected-file{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:6px 14px;background:#e8edff;border-radius:20px;font-size:13px;color:#3451d1;font-weight:500;max-width:100%;overflow:hidden}.upload-selected-file span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress-wrap{margin:4px 0}.upload-progress-track{width:100%;height:8px;background:#e8ecf4;border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#4361ee,#7b9eff);border-radius:4px;transition:width .5s ease;position:relative;overflow:hidden}@keyframes progressShimmer{0%{transform:translate(-150%)}to{transform:translate(250%)}}.upload-progress-fill:after{content:"";position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:progressShimmer 1.4s infinite}.upload-progress-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px}.upload-progress-status{font-size:12px;color:#666}.upload-progress-pct{font-size:12px;font-weight:700;color:#4361ee}.upload-message{padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;margin-top:14px}.upload-message--success{background:#edfaf3;border:1px solid #b7e8cf;color:#1a7a4a}.upload-message--error{background:#fde8e8;border:1px solid #f5c6cb;color:#dc3545}.dv-section-label{font-size:11px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}.dv-file-picker{background:#fff;border:1.5px solid #e0e4f0;border-radius:10px;overflow:hidden;margin-bottom:20px}.dv-file-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #e0e4f0;background:#f8f9fe}.dv-file-search-icon{color:#aaa;flex-shrink:0}.dv-file-search input{border:none;outline:none;font-size:13px;background:transparent;width:100%;color:#1a1a2e;font-family:inherit}.dv-file-search input::placeholder{color:#bbb}.dv-file-list{max-height:200px;overflow-y:auto}.dv-file-list::-webkit-scrollbar{width:4px}.dv-file-list::-webkit-scrollbar-track{background:#f0f2f5}.dv-file-list::-webkit-scrollbar-thumb{background:#c5cde8;border-radius:2px}.dv-file-row{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid #f0f2f5}.dv-file-row:last-child{border-bottom:none}.dv-file-row:hover,.dv-file-row--active{background:#f0f3ff}.dv-file-row-icon{color:#4361ee;flex-shrink:0;opacity:.7}.dv-file-row--active .dv-file-row-icon{opacity:1}.dv-file-row-info{flex:1;min-width:0}.dv-file-row-name{font-size:13px;font-weight:500;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dv-file-row--active .dv-file-row-name{font-weight:700;color:#4361ee}.dv-file-row-date{font-size:11px;color:#999;margin-top:1px}.dv-file-row-check{color:#4361ee;flex-shrink:0}.dv-file-empty{padding:20px;text-align:center;color:#bbb;font-size:13px;font-style:italic}.dv-empty-files{padding:28px;text-align:center;color:#aaa;font-size:14px;font-style:italic;background:#f8f9fe;border:1.5px dashed #d0d4e8;border-radius:10px;margin-bottom:20px}.dv-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px;padding:12px 16px;background:#fff;border:1px solid #e0e4f0;border-radius:10px}.dv-toolbar-sheets{display:flex;gap:6px;flex-wrap:wrap;flex:1;min-width:0}.dv-toolbar-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.dv-badge{font-size:12px;color:#666;background:#f0f2f5;border-radius:6px;padding:4px 10px;white-space:nowrap}.dv-loading{padding:24px;text-align:center;color:#4361ee;font-size:14px;font-weight:500}.dv-warnings{padding:10px 14px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin-bottom:12px;color:#856404;font-size:13px}.dv-warnings ul{margin:6px 0 0;padding-left:20px}.dv-process-result{background:#f8f9fe;border:1px solid #e0e4f0;border-radius:8px;padding:16px;overflow-x:auto;font-size:12px;margin-top:16px;margin-bottom:16px}.dv-table-wrap{border:1px solid #e0e4f0;border-radius:10px;overflow:hidden;width:100%}.dv-table-scroll{overflow-x:auto;width:100%;max-height:65vh}.dv-pagination{padding:10px 16px;border-top:1px solid #e0e4f0;background:#f8f9fe;display:flex;justify-content:center;align-items:center;gap:12px;font-size:13px;color:#555}.dv-pagination button{padding:5px 12px;background:#fff;border:1px solid #d0d4e8;border-radius:6px;cursor:pointer;font-size:13px;font-family:inherit;transition:background .15s,border-color .15s}.dv-pagination button:hover:not(:disabled){background:#f0f3ff;border-color:#4361ee;color:#4361ee}.dv-pagination button:disabled{opacity:.4;cursor:not-allowed}.dv-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center}.dv-modal{background:#fff;border-radius:12px;width:80vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d}.dv-modal-header{padding:16px 20px;border-bottom:1px solid #e0e4f0;display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:700;color:#1a1a2e;flex-shrink:0}.dv-modal-actions{display:flex;gap:8px}.dv-modal-pre{margin:0;padding:16px;overflow-y:auto;font-size:12px;font-family:monospace;flex:1;background:#f8f9fe}
