html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}:root{--primary-color: #3498db;--primary-dark: #2980b9;--secondary-color: #e74c3c;--text-color: #333;--bg-color: #f5f5f5;--card-bg: #fff;--border-color: #ddd;--success-color: #2ecc71;--error-color: #e74c3c;--admin-sidebar-width: 250px;--admin-header-height: 60px}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:var(--text-color);background-color:var(--bg-color)}.app{min-height:100vh;display:flex;flex-direction:column}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(to bottom right,#f5f7fa,#e4e8f0);width:100%}.login-container,.register-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:linear-gradient(to bottom right,#f5f7fa,#e4e8f0)}.login-form-wrapper,.register-form-wrapper{background-color:var(--card-bg);border-radius:12px;box-shadow:0 8px 20px #00000026;padding:40px;width:100%;max-width:420px;text-align:center;transition:transform .3s,box-shadow .3s}.login-form-wrapper:hover,.register-form-wrapper:hover{transform:translateY(-5px);box-shadow:0 12px 25px #0000002e}.login-form-wrapper h2,.register-form-wrapper h2{margin-bottom:25px;text-align:center;color:var(--primary-color);font-size:28px;font-weight:600}.login-form-wrapper form,.register-form-wrapper form{width:100%;max-width:350px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center}.form-group{margin-bottom:20px;width:100%}.form-actions{width:100%;display:flex;flex-direction:column;gap:15px;margin-top:20px}@media (max-width: 576px){.form-actions{flex-direction:column}}.form-row{display:flex;gap:15px;margin-bottom:20px}.form-row .form-group{flex:1;margin-bottom:0}.login-form-wrapper label,.register-form-wrapper label{display:block;margin-bottom:8px;font-weight:500;color:#444;font-size:15px;text-align:left;width:100%}.login-form-wrapper input,.register-form-wrapper input,.login-form-wrapper select,.register-form-wrapper select{width:100%;padding:12px 15px;border:1px solid var(--border-color);border-radius:6px;font-size:16px;transition:border-color .3s,box-shadow .3s}.login-form-wrapper input:focus,.register-form-wrapper input:focus,.login-form-wrapper select:focus,.register-form-wrapper select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3498db33}.login-form-wrapper button,.register-form-wrapper button{width:100%;padding:14px;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.login-form-wrapper button:hover,.register-form-wrapper button:hover{background-color:var(--primary-dark);box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.login-form-wrapper button:active,.register-form-wrapper button:active{transform:translateY(0);box-shadow:0 2px 3px #0000001a}.login-form-wrapper button:disabled,.register-form-wrapper button:disabled{background-color:#ccc;cursor:not-allowed;box-shadow:none;transform:none}.error-message{color:var(--error-color);margin-bottom:20px;padding:12px;background-color:#e74c3c1a;border-radius:6px;text-align:center;font-size:14px;width:100%}.admin-login-button{margin-top:0;background-color:var(--secondary-color)!important;width:100%}.admin-login-button:hover{background-color:#c0392b!important;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.admin-login-button:active{transform:translateY(0);box-shadow:0 2px 3px #0000001a}.admin-login-button:disabled{background-color:#e0a59f!important;cursor:not-allowed;box-shadow:none;transform:none}@media (max-width: 576px){.admin-login-button{margin-top:0}}.auth-links{margin-top:25px;text-align:center;font-size:15px;width:100%}.auth-links a{color:var(--primary-color);text-decoration:none}.auth-links a:hover{text-decoration:underline}.dashboard-container{min-height:100vh;padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background-color:var(--card-bg);border-radius:8px;box-shadow:0 2px 5px #0000001a;margin-bottom:20px}.user-info{display:flex;align-items:center;gap:15px}.logout-button{width:auto;padding:8px 15px;background-color:var(--secondary-color)}.dashboard-content{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.dashboard-card{background-color:var(--card-bg);border-radius:8px;box-shadow:0 2px 5px #0000001a;padding:20px}.dashboard-card h2{margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid var(--border-color);color:var(--primary-color)}.profile-info p{margin-bottom:10px}.action-buttons{display:flex;flex-direction:column;gap:10px}.action-button{padding:10px}.admin-dashboard-container{display:flex;min-height:100vh}.admin-sidebar{width:var(--admin-sidebar-width);background-color:#2c3e50;color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh}.admin-sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.admin-panel-title{margin-bottom:10px;color:#fff9;font-weight:300;letter-spacing:.5px}.admin-user-info{display:flex;flex-direction:column;font-size:14px}.user-role{font-size:12px;opacity:.7}.admin-navigation{flex:1;padding:20px}.admin-navigation ul{list-style:none}.admin-navigation li{margin-bottom:10px}.admin-navigation a{color:#fff;text-decoration:none;padding:8px 0;display:block;transition:.3s}.admin-navigation a:hover{color:var(--primary-color)}.admin-navigation li.active a{color:var(--primary-color);font-weight:700}.admin-sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:10px}.back-to-app{color:#fff;text-decoration:none;font-size:14px;text-align:center;padding:8px}.back-to-app:hover{color:var(--primary-color)}.admin-content{flex:1;margin-left:var(--admin-sidebar-width);padding:20px}.admin-home-container{max-width:1200px;margin:0 auto}.admin-welcome{background-color:var(--card-bg);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 5px #0000001a}.admin-quick-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:20px}.stats-card{background-color:var(--card-bg);border-radius:8px;padding:20px;box-shadow:0 2px 5px #0000001a}.stats-card h3{margin-bottom:15px;color:var(--primary-color);border-bottom:1px solid var(--border-color);padding-bottom:10px}.stats-count{display:flex;align-items:center;gap:10px;font-size:18px}.stats-info p{margin-bottom:8px;font-size:14px}.admin-actions{background-color:var(--card-bg);border-radius:8px;padding:20px;box-shadow:0 2px 5px #0000001a}.admin-actions h3{margin-bottom:15px;color:var(--primary-color)}.user-list-container{background-color:var(--card-bg);border-radius:8px;padding:20px;box-shadow:0 2px 5px #0000001a}.user-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.add-user-button{width:auto;padding:8px 16px}.user-table-container{overflow-x:auto}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border-color)}.user-table th{background-color:#f8f9fa;font-weight:600}.user-table tr:hover{background-color:#f8f9fa}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-badge.active{background-color:#2ecc7133;color:var(--success-color)}.status-badge.inactive{background-color:#e74c3c33;color:var(--error-color)}.action-buttons{display:flex;gap:8px}.edit-button,.delete-button{width:auto;padding:4px 8px;font-size:12px}.delete-button{background-color:var(--secondary-color)}.no-users{text-align:center;padding:20px;color:#666}.user-edit-container{background-color:var(--card-bg);border-radius:8px;padding:20px;box-shadow:0 2px 5px #0000001a}.user-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.back-button{width:auto;padding:8px 16px}.user-edit-form{max-width:800px}.checkbox-group{display:flex;align-items:center;gap:8px}.checkbox-group input[type=checkbox]{width:auto}.checkbox-group label{margin-bottom:0}.checkboxes{display:flex;gap:20px}.form-actions{display:flex;gap:10px;margin-top:20px}.cancel-button{background-color:#6c757d}:root{--primary-color: #3498db;--primary-dark: #2980b9;--secondary-color: #e74c3c;--text-color: #333;--text-light: #666;--bg-color: #f5f5f5;--card-bg: #fff;--border-color: #ddd;--success-color: #2ecc71;--error-color: #e74c3c;--error-bg: rgba(231, 76, 60, .1);--admin-sidebar-width: 250px;--admin-header-height: 60px;--container-max-width: 1200px;--form-max-width: 400px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--border-radius-sm: 4px;--border-radius-md: 6px;--border-radius-lg: 10px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*{box-sizing:border-box;margin:0;padding:0}html,body{margin:0;padding:0}html,body{height:100%;width:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;color:var(--text-color);background-color:var(--bg-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{line-height:1.2;margin-bottom:var(--spacing-md);color:var(--text-color)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md)}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark)}label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-color)}input:not([type=radio]):not([type=checkbox]),select,textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3498db33}button{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--border-radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);background-color:var(--primary-color);color:#fff}button:hover{background-color:var(--primary-dark);transform:translateY(-1px)}button:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{color:var(--error-color);background-color:var(--error-bg);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);font-size:.875rem}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--spacing-md)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.card{background-color:var(--card-bg);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.form-container{width:100%;max-width:var(--form-max-width);margin:0 auto;padding:var(--spacing-xl)}.form-group{margin-bottom:var(--spacing-lg)}@media (max-width: 768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.form-container{padding:var(--spacing-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(to bottom right,#f5f7fa,#e4e8f0);padding:var(--spacing-md)}.login-box{background-color:var(--card-bg);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl);width:100%;max-width:var(--form-max-width)}.login-box h2{text-align:center;color:var(--primary-color);margin-bottom:var(--spacing-lg)}.login-form{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.input-group{width:100%;display:flex;flex-direction:column;align-items:center}.input-group label{text-align:center;margin-bottom:var(--spacing-sm)}.input-group input{width:100%;max-width:300px;text-align:center}.login-btn,.admin-btn{width:100%;max-width:300px;padding:var(--spacing-md);font-weight:600}.login-btn{background-color:var(--primary-color)}.admin-btn{background-color:var(--secondary-color)}.auth-link{margin-top:var(--spacing-lg);text-align:center;font-size:.875rem}.auth-link a{color:var(--primary-color);text-decoration:none}.auth-link a:hover{text-decoration:underline}.log-viewer-container{padding:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.log-viewer-header{display:flex;flex-direction:column;margin-bottom:1.5rem}.log-viewer-header h2{margin-top:0;margin-bottom:1rem;font-size:1.5rem;color:#2c3e50}.log-tabs{display:flex;margin-bottom:1rem;border-bottom:1px solid #dee2e6}.tab-button{padding:.75rem 1.5rem;border:none;background-color:transparent;color:#6c757d;cursor:pointer;font-size:1rem;font-weight:500;border-bottom:2px solid transparent;transition:all .2s ease}.tab-button:hover{color:#495057;background-color:#f8f9fa}.tab-button.active{color:#007bff;border-bottom-color:#007bff;background-color:#fff}.log-filters{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.filter-group{display:flex;align-items:center}.filter-group label{margin-right:.5rem;font-weight:500;color:#2c3e50}.log-type-select,.limit-select,.audit-filter-select{padding:.375rem .75rem;border:1px solid #ced4da;border-radius:4px;background-color:#fff;min-width:100px}.audit-date-input{padding:.375rem .75rem;border:1px solid #ced4da;border-radius:4px;background-color:#fff;min-width:140px}.refresh-button{padding:.375rem .75rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.refresh-button:hover{background-color:#2980b9}.error-message{padding:.75rem;margin-bottom:1rem;background-color:#f8d7da;color:#721c24;border-radius:4px}.logs-loading,.no-logs{padding:2rem;text-align:center;color:#6c757d;font-style:italic}.log-entries-container{max-height:calc(100vh - 280px);overflow-y:auto;border:1px solid #e9ecef;border-radius:4px;margin-bottom:1rem}.log-entries{display:flex;flex-direction:column}.log-entry{padding:.75rem;border-bottom:1px solid #e9ecef;transition:background-color .2s}.log-entry:last-child{border-bottom:none}.log-entry:hover{background-color:#f8f9fa}.log-entry-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.log-timestamp{font-family:monospace;color:#6c757d;font-size:.85rem}.log-level{padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase}.level-error{background-color:#f8d7da;color:#721c24}.level-warn{background-color:#fff3cd;color:#856404}.level-info{background-color:#d1ecf1;color:#0c5460}.level-debug{background-color:#e2e3e5;color:#383d41}.level-unknown{background-color:#f8f9fa;color:#6c757d}.log-message{margin-bottom:.5rem;word-break:break-word;font-weight:500}.log-details{font-size:.85rem;color:#495057;background-color:#f8f9fa;padding:.5rem;border-radius:4px;max-height:200px;overflow-y:auto}.log-detail{margin-bottom:.25rem;display:flex}.detail-key{font-weight:700;margin-right:.5rem;min-width:120px}.detail-value{word-break:break-all;font-family:monospace}.log-pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem}.pagination-button{padding:.375rem .75rem;background-color:#f8f9fa;border:1px solid #ced4da;border-radius:4px;cursor:pointer;transition:background-color .2s}.pagination-button:hover:not(:disabled){background-color:#e9ecef}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{padding:.375rem .75rem;color:#6c757d}@media (max-width: 768px){.log-filters{flex-direction:column;align-items:flex-start}.filter-group{width:100%;margin-bottom:.5rem}.log-timestamp,.log-level{font-size:.75rem}.log-entry-header{flex-direction:column;gap:.25rem}.log-detail{flex-direction:column}.detail-key{min-width:auto}}.audit-entry{border-left:4px solid #17a2b8}.audit-entry .log-entry-header{display:flex;align-items:center;gap:1rem}.log-action{background-color:#e9ecef;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;color:#495057}.system-entry{border-left:4px solid #6c757d}
