body,html,#root{background:#f0f4f8}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;padding-top:5rem}.login-page .header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.login-page .header-logo{max-width:50px}.login-page .header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin:0}.login-card{background:#fff;padding:2rem 2.5rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;text-align:center;max-width:450px;width:100%}.login-card h2{margin:0 0 .5rem;color:#2c3e50;font-size:1.75rem;font-weight:600}.login-card p{margin-bottom:2rem;color:#64748b}.login-form #pin{text-align:center}.login-form .primary{background:#3498db;color:#fff;border:none;border-radius:6px;padding:.75rem 1.25rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .05s ease}.login-form .primary:hover{background:#2980b9}.login-form .primary:active{transform:translateY(1px)}.login-form .primary:disabled{opacity:.6;cursor:not-allowed}.login-card .link{background:transparent;border:none;color:#3498db;padding:0;cursor:pointer;font-size:.95rem}.login-card .link:hover{text-decoration:underline}.login-form input[type=email],.login-form input[type=password],.login-form input[type=text],.login-form input[type=number]{width:100%;padding:.75rem .9rem;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:.75rem;font-size:.95rem;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.login-form input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd59}.login-form input.valid{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e33}.login-form input.invalid{border-color:#ef4444;box-shadow:0 0 0 3px #ef444433}.login-form input.warning{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.strength-meter{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin:6px 0 10px}.strength-meter .bar{height:100%;transition:width .25s ease,background .25s ease}.strength-meter--segments{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:6px 0 10px}.strength-meter--segments .segment{height:8px;border-radius:999px;background:#e5e7eb;transition:background-color .2s ease}.strength-meter--segments.strength-1 .segment:nth-child(-n+1){background:#f97316}.strength-meter--segments.strength-2 .segment:nth-child(-n+2){background:#f59e0b}.strength-meter--segments.strength-3 .segment:nth-child(-n+3){background:#84cc16}.strength-meter--segments.strength-4 .segment:nth-child(-n+4){background:#22c55e}.login-form .field{text-align:left;margin-bottom:.75rem}.login-form .label{display:block;font-size:.9rem;color:#334155;margin-bottom:.35rem;font-weight:600}.login-form .hint{font-size:.85rem;color:#64748b;margin:6px 0 10px}.login-form .error{color:#b00020}.criteria{text-align:left;list-style:none;padding:0;margin:6px 0 10px}.criteria li{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#64748b}.criteria li:before{content:"•";color:#cbd5e1}.criteria li.valid{color:#16a34a}.criteria li.valid:before{content:"✓";color:#16a34a}.criteria li.invalid{color:#ef4444}.criteria li.invalid:before{content:"✗";color:#ef4444}.toggle-link{display:inline-block;margin-top:4px;font-size:.85rem;color:#3498db;cursor:pointer}.toggle-link:hover{text-decoration:underline}.toggle-row{text-align:right;margin-top:4px}.small-hint{font-size:.85rem;color:#64748b;margin:6px 0 10px}.small-hint.error{color:#b00020}.input-with-toggle{position:relative}.login-form .has-toggle{padding-right:2.25rem}.input-with-toggle .input-toggle-btn{position:absolute;top:50%;right:10px;transform:translateY(-70%);background:transparent;border:none;padding:0;width:24px;height:24px;line-height:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b}.input-with-toggle .input-toggle-btn svg{display:block}.input-with-toggle .input-toggle-btn:hover{color:#1f2937}body{font-family:Arial,sans-serif;padding:1rem;background:#f0f4f8;max-width:1200px;margin:0 auto;padding:20px}h1{color:#2c3e50;font-size:2rem;margin-bottom:20px;text-align:center;font-weight:600}.tabs{display:flex;gap:1rem;margin-bottom:1.5rem;justify-content:flex-start}.tab{padding:.75rem 1.5rem;background:#fff;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:500;color:#2c3e50;box-shadow:0 2px 4px #0000000d}.tab:hover{background:#3498db;color:#fff}.tab.active,.tab.admin-active{background:#2980b9;color:#fff}.tab.admin-active:hover{background:#3498db}.section{display:none}.section.active{display:block}.card{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1rem;box-shadow:0 4px 6px #0000001a}table{width:100%;border-collapse:collapse;margin-top:1rem}th,td{text-align:left;padding:.75rem;border-bottom:1px solid #edf2f7}th{color:#2c3e50;font-weight:600;background:#e2e8f0;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;padding-right:25px}th.sort-asc:after{content:"↑";position:absolute;right:8px;color:#2980b9}th.sort-desc:after{content:"↓";position:absolute;right:8px;color:#2980b9}.stats{display:flex;gap:1.5rem;margin-top:1rem}.stat{flex:1;background:#fff;border-radius:8px;padding:1.5rem;text-align:center;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease}input{padding:.75rem;width:100%;margin-bottom:1rem;box-sizing:border-box;border:2px solid #e2e8f0;border-radius:6px;transition:all .3s ease;font-size:.95rem}input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.header-logo{max-width:50px;height:auto;display:block;margin:0}.file-row{cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #e2e8f0}.row-dark{background-color:#e2e8f0}.file-row:hover{background-color:#cbd5e1!important}.file-details{display:none;background:#f8fafc;padding:1.5rem;border-top:1px solid #e2e8f0;border-bottom:2px solid #e2e8f0;width:100%}.file-details td{padding:0}.file-row:last-child{border-bottom:none}.file-details:last-child{border-bottom:none}.file-row+.file-row{border-top:1px solid #e2e8f0}.file-analytics{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:1rem;width:100%}.analytics-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.analytics-card h3{margin:0 0 1rem;color:#2c3e50;font-size:1.1rem;position:relative;z-index:1}.activity-list{list-style:none;padding:0;margin:0}.activity-item{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center;padding:10px 0;border-bottom:1px solid #eee}.activity-description{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.activity-status{padding:.25rem .5rem;border-radius:4px;text-align:center;font-size:.8rem;font-weight:500;white-space:nowrap}.activity-time{color:#666;text-align:right;white-space:nowrap}.activity-item:last-child{border-bottom:none}.status-success{background:#dcfce7;color:#166534}.status-1fa{background:#fef3c7;color:#92400e}.trend-container{display:flex;flex-direction:column;align-items:center;margin-top:1rem}.trend-chart{display:flex;justify-content:flex-start;height:140px;padding:10px;gap:4px;background:#f8fafc;border-radius:4px;position:relative}.trend-bar{width:100%;transition:height .3s ease-out}.trend-bar:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.trend-bar.info{background:#3b82f6}.trend-bar.success{background:#22c55e}.trend-bar.warning{background:#eab308}.trend-bar.blocked{background:#ef4444}.trend-bar-stack{position:relative;display:flex;flex-direction:column;justify-content:flex-end;width:100%}.chart-tooltip{position:fixed;background:#2c3e50;color:#fff;padding:8px 12px;border-radius:4px;font-size:.85rem;white-space:pre-line;z-index:1001;box-shadow:0 2px 8px #00000026;text-align:left;min-width:120px;pointer-events:none;opacity:0;transition:opacity .2s;transform:translate(-50%,-100%);margin-top:-10px}.trend-legend{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1.5rem;padding-top:1rem;font-size:.85rem;color:#6b7280}.trend-legend>div{display:flex;align-items:center}.trend-bar-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;flex:1}.trend-legend-color{width:12px;height:12px;border-radius:2px;margin-right:8px;display:inline-block;background:#3b82f6}.trend-legend-color.success{background:#22c55e}.trend-legend-color.blocked{background:#ef4444}.trend-legend-color.info{background:#3b82f6}.trend-legend-color.warning{background:#f39c12}.expand-icon{display:inline-block;text-align:center;transition:transform .2s ease;font-weight:700;-webkit-user-select:none;user-select:none}.expand-icon.expanded{transform:rotate(90deg)}.document-link{color:#3498db;text-decoration:none;cursor:pointer}.access-management{padding:1rem 0}.access-management .activity-item{grid-template-columns:1fr auto}.access-management .activity-description{white-space:normal;overflow:visible;text-overflow:clip}.access-list{margin-bottom:1rem}.access-list h4{margin:0 0 .5rem;color:#2c3e50;font-size:.9rem}.access-controls{display:flex;align-items:center;gap:.5rem}.access-type{padding:.25rem .5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.85rem;background:#fff;color:#2c3e50;cursor:pointer}.access-type[value="1fa"]{background:#fef3c7;color:#92400e;border-color:#fbbf24}.access-type[value="2fa"]{background:#dcfce7;color:#166534;border-color:#22c55e}.remove-access{background:#fee2e2;color:#991b1b;border:none;border-radius:4px;width:24px;height:24px;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-access:hover{background:#fecaca}.add-access{display:flex;gap:.5rem;margin-top:1rem}.access-input{flex:1;height:36px;padding:0 .5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.9rem;box-sizing:border-box}.add-access-btn{background:#3498db;color:#fff;height:36px;border:none;border-radius:4px;padding:0 1rem;cursor:pointer;font-size:.9rem;transition:all .2s ease;box-sizing:border-box}.add-access-btn:hover{background:#2980b9}.layered-access{padding:1rem 0}.layered-item{display:flex;align-items:center;gap:1rem}.page-range,.column-name{min-width:100px;color:#2c3e50;font-weight:500}.layered-input{flex:1;padding:.5rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.9rem;background:#fff}.layered-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db1a}.layered-input:hover{border-color:#3498db}.no-access-message{color:#64748b;font-size:.9rem;font-style:italic}.user-info{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:1rem}.user-email{color:#2c3e50;font-size:.9rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;text-decoration:underline dotted #b6bbc4 1px;transition:color .2s}.user-email:hover{color:#2980b9}.user-plan{color:#64748b;font-size:.85rem}.logout-btn{background:none;border:none;color:#64748b;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.logout-btn:hover{color:#2c3e50;background:#f1f5f9}.logout-icon{width:20px;height:20px;fill:currentColor}.footer{margin-top:3rem;padding-top:2rem;border-top:1px solid #e2e8f0;text-align:center}.footer-links{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem}.footer-link{color:#64748b;text-decoration:none;font-size:.9rem;transition:color .2s ease}.footer-link:hover{color:#2c3e50}.copyright{color:#94a3b8;font-size:.8rem}.header{display:flex;align-items:center;gap:1rem;margin-bottom:20px}.search-container{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.search-container input[type=text]{flex:1;min-width:200px}.search-container input[type=text],.search-container input[type=date]{height:42px;margin-bottom:0}.search-container select{width:150px;height:42px;box-sizing:border-box;padding:0 .75rem;border:2px solid #e2e8f0;border-radius:6px;background:#fff;color:#2c3e50;font-size:.95rem;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;transition:all .2s ease}.search-container select:hover{border-color:#3498db}.search-container select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;background-color:#fff}.search-container select option{padding:.5rem;font-size:.95rem}.date-range{display:flex;gap:.5rem;align-items:center}.date-range span{color:#64748b;font-size:.9rem}.account-modal{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#2c3e5026;z-index:1000;align-items:center;justify-content:center}.account-modal.active{display:flex}.account-content{background:#fff;border-radius:10px;box-shadow:0 8px 32px #2c3e502e;padding:2rem 2.5rem;min-width:350px;max-width:95vw;max-height:90vh;overflow-y:auto;position:relative}.account-content h2{margin-top:0;color:#2c3e50;font-size:1.5rem;font-weight:600}.account-section{margin-bottom:2rem}.account-section label{display:block;margin-bottom:.5rem;color:#64748b;font-size:.95rem;font-weight:500}.account-section input[type=text],.account-section input[type=email],.account-section input[type=password]{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.account-section input:focus{border-color:#3498db;outline:none}.account-section .account-btn{background:#3498db;color:#fff;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:1rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.account-section .account-btn:hover{background:#2980b9}.account-section .account-btn.btn-delete{background:#b00020}.account-section .account-btn.btn-delete:hover{background:#8e001a}.account-section .account-btn.btn-signout{background:#ef4444}.account-section .account-btn.btn-signout:hover{background:#dc2626}.hc-checkbox{width:18px;height:18px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-color:#fff;border:2px solid #e2e8f0;border-radius:4px;display:inline-block;position:relative;cursor:pointer;vertical-align:middle;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}.hc-checkbox:hover{border-color:#b9c6d6}.hc-checkbox:focus{outline:none;box-shadow:0 0 0 3px #3498db26}.hc-checkbox:checked{background-color:#b00020;border-color:#b00020}.hc-checkbox:checked:after{content:"";position:absolute;left:50%;top:50%;width:7px;height:12px;border:solid #ffffff;border-width:0 2px 2px 0;transform:translate(-50%,-60%) rotate(45deg)}.close-account-modal{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;transition:color .2s}.close-account-modal:hover{color:#2c3e50}.account-section select{width:100%;height:42px;padding:0 2.5rem 0 .75rem;border:2px solid #e2e8f0;border-radius:6px;background:#fff;color:#2c3e50;font-size:1rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232c3e50' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1em;transition:all .2s ease;line-height:1;margin-bottom:1rem}.account-section select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;background-color:#fff}.account-section select option{padding:.5rem;font-size:1rem}.status-blocked{background:#fee2e2;color:#991b1b}.status-warning{background:#fef3c7;color:#92400e}.action-success{background:#dcfce7;color:#166534;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.action-warning{background:#fef3c7;color:#92400e;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.action-blocked{background:#fee2e2;color:#991b1b;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.portal-container{max-width:1200px;margin:0 auto;padding:20px}@keyframes flash-success{0%{background-color:#dcfce7}to{background-color:#fff}}.layered-input.flash-success{animation:flash-success 1s ease-out}.date-management-panel{grid-column:span 2}.account-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.account-modal.active{opacity:1;visibility:visible}.account-content{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:90%;max-width:500px;position:relative}.close-account-modal{position:absolute;top:10px;right:15px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#888}.account-section{margin-bottom:1.5rem;border-bottom:1px solid #eee;padding-bottom:1.5rem}.account-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.account-section label{display:block;font-weight:700;margin-bottom:.5rem;color:#333}.account-section input,.account-section select{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.account-section input[readonly]{background-color:#f4f4f4;cursor:not-allowed}.account-btn{background-color:#007bff;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;margin-top:.5rem;transition:background-color .3s}.account-btn:hover{background-color:#0056b3}.date-management-content{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:end;margin-top:1rem}.date-input-group{display:flex;flex-direction:column;gap:.5rem}.date-input{padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px;background-color:#f8f9fa;color:#495057}.update-dates-btn{grid-column:2 / 3;justify-self:end;padding:8px 16px;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.update-dates-btn:hover{background-color:#2980b9}.update-dates-btn:disabled{background-color:#ccc;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:1.75rem;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;width:90%;max-width:400px;text-align:center}.modal-content h2{margin-top:0;font-size:1.25rem;font-weight:600;color:#2c3e50}.modal-content p{color:#666;line-height:1.6;margin-bottom:1rem}.highlight-info{display:block;background-color:#f0f8ff;border:1px solid #b0e0e6;padding:10px;border-radius:5px;margin:10px 0;font-weight:700;color:#333}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.btn{padding:.6rem 1.2rem;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;letter-spacing:.025em;transition:all .2s ease}.btn-secondary{background-color:transparent;color:#4a5568;border-color:#cbd5e1}.btn-secondary:hover{background-color:#edf2f7;border-color:#a0aec0;transform:translateY(-1px)}.btn-primary{background-color:#2980b9;color:#fff;border-color:#2980b9}.btn-primary:hover{background-color:#3498db;border-color:#3498db;transform:translateY(-1px)}.skeleton{animation:pulse 1.5s infinite}.skeleton .skeleton-text,.skeleton .skeleton-icon{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-icon{width:20px;height:20px;background-color:#e0e0e0;border-radius:50%;margin:0 auto}.skeleton-text{height:20px;background-color:#e0e0e0;border-radius:4px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.search-container{display:flex;gap:16px;margin-bottom:20px;align-items:center}.search-container input[type=text]{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}th{text-align:left;padding:12px;border-bottom:2px solid #ddd;cursor:pointer;-webkit-user-select:none;user-select:none}th:hover{background-color:#f5f5f5}td{padding:12px;border-bottom:1px solid #f0f0f0}.file-row{cursor:pointer;transition:background-color .2s}.file-row:hover{background-color:#f5f5f5}.row-light{background-color:#fff}.row-dark{background-color:#f9f9f9}.expand-icon{position:relative;display:inline-block;width:16px;height:16px;cursor:pointer}.expand-icon:before,.expand-icon:after{content:"";position:absolute;background-color:#333;transition:all .3s ease-in-out}.expand-icon:after{left:3px;top:7px;width:10px;height:2px}.expand-icon:before{left:7px;top:3px;width:2px;height:10px}.expand-icon.expanded:before{transform:rotate(90deg);opacity:0}.file-details{display:none;background-color:#f9f9f9}.file-details.active{display:table-row}.error-cell{padding:20px;text-align:center}.error{color:#dc3545;padding:12px;text-align:center;background-color:#f8d7da;border-radius:4px;margin:0}.filter-tag-container{padding:.5rem 0 1rem}.filter-tag{display:inline-flex;align-items:center;font-weight:500;font-size:.9rem}.close-tag-btn{margin-left:.5rem;background-color:#e2e8f0;border:1px solid #cbd5e1;color:#2c3e50;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .2s ease}.close-tag-btn:hover{background-color:#cbd5e1}.file-analytics .skeleton-card{background-color:#f0f0f0;border-radius:8px;height:200px;animation:files-tab-pulse 1.5s infinite ease-in-out}@keyframes files-tab-pulse{0%{background-color:#f0f0f0}50%{background-color:#e0e0e0}to{background-color:#f0f0f0}}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;font-size:.875rem;color:#4a5568}.pagination-info,.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-controls{gap:1rem}.pagination-container button{background-color:transparent;border:1px solid #cbd5e0;border-radius:4px;padding:.2rem .8rem;cursor:pointer;transition:background-color .2s;font-weight:500;box-sizing:border-box;font-size:inherit;font-family:inherit}.pagination-container button:hover:not(:disabled){background-color:#f7fafc}.pagination-container button:disabled{cursor:not-allowed;opacity:.5}.page-input-group{display:flex;align-items:center;gap:.5rem}.page-input{width:4rem;height:1.5rem;padding:.2rem .5rem;text-align:center;border:1px solid #cbd5e0;border-radius:4px;align-self:center;box-sizing:border-box;font-size:inherit;font-family:inherit}.pagination-info select{padding:.2rem .3rem;border:1px solid #cbd5e0;border-radius:4px;font-size:inherit;font-family:inherit}.item-count{color:#718096}.skeleton-text{background-color:#f0f0f0;border-radius:4px;animation:pulse 1.5s infinite ease-in-out;height:1em}.skeleton-description{width:40%}.skeleton-status{width:20%}.skeleton-time{width:30%}@keyframes pulse{0%{background-color:#f0f0f0}50%{background-color:#e0e0e0}to{background-color:#f0f0f0}}.skeleton-text,.skeleton-input,.skeleton-button,.trend-bar-stack-skeleton{background-color:#f0f0f0;border-radius:4px;animation:pulse 1.5s infinite ease-in-out}.trend-chart-container-skeleton{padding:20px}.trend-chart-skeleton{display:flex;justify-content:space-around;align-items:flex-end;height:120px;border-bottom:1px solid #eee;margin-bottom:1rem}.trend-bar-wrapper-skeleton{flex:1;display:flex;justify-content:center;align-items:flex-end}.trend-bar-stack-skeleton{width:50%}.trend-legend-skeleton{display:flex;justify-content:center;gap:1rem;margin-top:10px}.activity-item-skeleton{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #eee}.skeleton-description{width:70%;height:1em}.skeleton-action{width:20%;height:1em}.add-access-skeleton{display:flex;gap:10px;margin-top:1rem}.skeleton-input{flex-grow:1;height:38px}.skeleton-button{width:100px;height:38px}.skeleton-layered-input{flex-grow:1;height:1em}.date-management-skeleton{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.date-input-skeleton{display:flex;flex-direction:column;gap:.5rem}.user-type-tabs{display:flex;gap:1rem;margin-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.user-tab{padding:.75rem 1.5rem;cursor:pointer;transition:all .3s ease;font-weight:500;color:#64748b;border-bottom:2px solid transparent;margin-bottom:-2px}.user-tab:hover{color:#3498db}.user-tab.active{color:#2980b9;border-bottom-color:#2980b9}.user-table{display:none}.user-table.active{display:block}.status-active{background:#dcfce7;color:#166534;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.status-inactive{background:#fef3c7;color:#92400e;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.status-banned{background:#fee2e2;color:#991b1b;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500}.account-btn:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.table-container{overflow-x:auto;width:100%;border-radius:8px;box-shadow:0 4px 6px #0000001a;background:#fff}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.75rem 1rem;border-bottom:1px solid #edf2f7;vertical-align:middle;font-size:.9rem;color:#000}th{font-weight:600;background:#e2e8f0;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}th:hover{background:#cbd5e1}tbody tr:nth-of-type(2n){background-color:#e2e8f0}tbody tr:hover{background-color:#cbd5e1!important}.truncate-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}td.action-cell{text-align:center}.action-badge{padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:500;white-space:nowrap;display:inline-block}.action-success{background:#dcfce7;color:#000}.action-warning{background:#fef3c7;color:#000}.action-blocked{background:#fee2e2;color:#000}.document-link{color:#3498db;text-decoration:none;font-weight:500;cursor:pointer}.document-link:hover{text-decoration:underline}@media (max-width: 768px){.truncate-text{max-width:100px}th,td{padding:6px}}.stats{display:flex;gap:1.5rem}.stat{flex:1;background:#fff;border-radius:8px;padding:1.5rem;text-align:center;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease;cursor:pointer}.stat:hover{transform:translateY(-5px)}.stat h2{margin:0;font-size:2rem;color:#2980b9;font-weight:600}.stat p{margin:.5rem 0 0;color:#64748b;font-weight:500}.stat.active,.stat.active h2{background:#2980b9!important;color:#fff!important}.stat.active p{color:#e0eaff!important}.filter-banner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#e2e8f0;border-bottom:1px solid #cbd5e1;border-radius:8px 8px 0 0;margin:-1.5rem -1.5rem 1.5rem}.filter-banner span{font-weight:500;color:#2c3e50}.clear-filter-btn{background:#3498db;color:#fff;border:none;border-radius:6px;padding:.4rem .8rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.clear-filter-btn:hover{background-color:#2980b9}.filter-tag-container{padding:10px 20px;background-color:#f9f9f9;border-bottom:1px solid #ddd;display:flex;align-items:center}.filter-tag{background-color:#e0e0e0;border-radius:15px;padding:5px 12px;font-size:14px;display:inline-flex;align-items:center;font-weight:500}.close-tag-btn{background:none;border:none;cursor:pointer;margin-left:8px;font-size:18px;line-height:1;padding:0;color:#555}.close-tag-btn:hover{color:#000}.search-container{display:flex;gap:16px;margin-bottom:20px;align-items:center;flex-wrap:wrap}.search-container input[type=text]{flex:1;min-width:200px;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.date-range{display:flex;gap:8px;align-items:center}.date-range input[type=date]{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.search-container select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff}.download-button{background:#3498db;color:#fff;border:none;border-radius:6px;padding:10px;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px}.download-button:hover{background-color:#2980b9}.download-button:active{background-color:#1f5f99}.download-button:focus{outline:2px solid #3498db;outline-offset:2px}.offline-header{background-color:#ff4d4f;color:#fff;text-align:center;padding:10px;position:fixed;top:0;width:100%;z-index:1000}.offline-banner{background-color:#ff4d4d!important;color:#fff!important;text-align:center!important;padding:10px!important;position:fixed!important;top:0!important;left:0!important;width:100%!important;z-index:9999!important;display:block!important}body.offline{margin-top:40px}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{background-color:#f0f4f8;min-height:100vh}
