*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--primary-color: #1e40af;--primary-hover: #1e3a8a;--primary-light: #3b82f6;--secondary-color: #0891b2;--accent-color: #0d9488;--success-color: #059669;--warning-color: #d97706;--danger-color: #dc2626;--text-dark: #0f172a;--text-medium: #475569;--text-light: #64748b;--text-lighter: #94a3b8;--bg-dark: #0f172a;--bg-light: #f8fafc;--bg-lighter: #f1f5f9;--bg-white: #ffffff;--border-color: #e2e8f0;--border-dark: #cbd5e1;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;background-color:var(--bg-light);color:var(--text-dark);overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--text-dark)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s ease}button:disabled{opacity:.6;cursor:not-allowed}a{color:var(--primary-color);text-decoration:none;transition:color .3s ease}a:hover{color:var(--primary-hover)}input,textarea{font-family:inherit;font-size:1em}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.sidebar{width:280px;height:100vh;background:var(--bg-white);border-right:2px solid var(--border-color);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-md);animation:slideInLeft .4s ease}.sidebar-header{padding:2rem 1.5rem 1.25rem;border-bottom:2px solid var(--border-color);background:linear-gradient(180deg,var(--bg-white) 0%,var(--bg-light) 100%)}.sidebar-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.sidebar-header h2{font-size:1.5rem;margin:0;color:var(--text-dark);font-weight:800;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{margin-top:.5rem;font-size:.9rem;color:var(--text-light);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--bg-lighter);border:2px solid transparent;border-radius:12px;color:var(--text-dark);cursor:pointer;transition:all .2s ease}.sidebar-logout:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-1px)}.sidebar-logout svg{width:18px;height:18px}.sidebar-nav{flex:1;overflow-y:auto;padding:1rem 0}.sidebar-state{padding:.75rem 1.5rem;color:var(--text-light);font-size:.9rem;font-weight:600}.sidebar-error{color:#b91c1c}.sidebar-group{margin-top:.25rem}.sidebar-group-label{padding:.75rem 1.5rem .25rem;font-size:.75rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light)}.sidebar-nav ul{list-style:none;padding:0;margin:0}.sidebar-nav li{margin:0;animation:slideInLeft .4s ease both}.sidebar-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;width:100%;background:transparent;color:var(--text-medium);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;border-left:3px solid transparent;position:relative;text-decoration:none}.sidebar-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:0;height:0;background:var(--primary-color);border-radius:0 4px 4px 0;transition:all .3s ease}.sidebar-item:hover{background:var(--bg-lighter);color:var(--primary-color);padding-left:2rem}.sidebar-item:hover:before{width:4px;height:70%}.sidebar-item:hover .sidebar-item-icon{transform:scale(1.15) rotate(5deg)}.sidebar-item.active{background:linear-gradient(90deg,#1e40af26,#1e40af0d);color:var(--primary-color);border-left-color:var(--primary-color);font-weight:800}.sidebar-item.active:before{width:4px;height:100%}.sidebar-item-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}.sidebar-item-icon svg{width:100%;height:100%}.sidebar-item-label{flex:1}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:200;width:48px;height:48px;background:linear-gradient(135deg,var(--primary-color),var(--primary-light));border:none;border-radius:12px;color:#fff;cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:all .3s ease}.mobile-menu-toggle:hover{background:linear-gradient(135deg,var(--primary-hover),var(--primary-color));transform:scale(1.05) rotate(5deg);box-shadow:var(--shadow-xl)}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-menu-toggle svg{width:24px;height:24px}.mobile-overlay{display:none;position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;animation:fadeIn .3s ease}@media(max-width:768px){.mobile-menu-toggle{display:flex}.sidebar{transform:translate(-100%);box-shadow:none}.sidebar.mobile-open{transform:translate(0);box-shadow:var(--shadow-xl)}.mobile-overlay{display:block}}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px;transition:background .3s ease}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-panel{display:flex;min-height:100vh;background:var(--bg-light);overflow-x:hidden}.admin-content{flex:1;margin-left:280px;display:flex;flex-direction:column;min-height:100vh;animation:fadeIn .5s ease}.admin-header{background:var(--bg-white);border-bottom:2px solid var(--border-color);padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:var(--shadow);animation:slideInUp .4s ease}.admin-header h1{font-size:1.6rem;color:var(--text-dark);margin:0;font-weight:800;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-main{flex:1;padding:2rem;animation:fadeIn .6s ease .2s both}.content-wrapper{max-width:1400px;margin:0 auto}.content-card{background:var(--bg-white);border-radius:20px;padding:2.25rem;box-shadow:var(--shadow-md);border:1px solid var(--border-color);animation:slideInUp .5s ease}.content-card h2{font-size:1.6rem;margin-bottom:.75rem;color:var(--text-dark);font-weight:800}.content-card>p{color:var(--text-medium);font-size:1rem;margin-bottom:1.5rem;line-height:1.7}.page-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem}.muted{color:var(--text-light)}.data-table{width:100%;border-collapse:collapse;border-spacing:0}.data-table th,.data-table td{padding:.85rem .75rem;border-bottom:1px solid var(--border-color);vertical-align:top}.data-table th{font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light);font-weight:800}.data-table td{color:var(--text-medium);font-weight:600}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.8rem;font-weight:800;background:var(--bg-lighter);color:var(--text-dark);border:1px solid var(--border-color)}.badge+.badge{margin-left:.35rem}.badge-success{background:#0596691a;color:var(--success-color);border-color:#05966940}.badge-danger{background:#dc26261a;color:var(--danger-color);border-color:#dc262640}.badge-warning{background:#d977061a;color:var(--warning-color);border-color:#d9770640}.btn{padding:.55rem .9rem;border-radius:12px;border:2px solid transparent;background:var(--bg-lighter);color:var(--text-dark);font-weight:800;cursor:pointer;transition:all .2s ease}.btn:hover{transform:translateY(-1px);border-color:var(--primary-color);color:var(--primary-color)}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-light));color:#fff}.btn-primary:hover{border-color:transparent;color:#fff}.btn-danger{background:#dc26261a;color:var(--danger-color);border-color:#dc262640}.btn-danger:hover{border-color:#dc262659;color:var(--danger-color)}.btn-success{background:#22c55e1a;color:var(--success-color);border-color:#22c55e40}.btn-success:hover{border-color:#22c55e59;color:var(--success-color)}.page-state{padding:1rem 0;color:var(--text-light);font-weight:700}.page-error{color:var(--danger-color)}@media(max-width:768px){.admin-content{margin-left:0}.admin-header{padding:4.5rem 1.25rem 1rem}.admin-main{padding:1.25rem}.content-card{padding:1.5rem}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e40af,#0891b2);background-size:200% 200%;animation:gradientShift 15s ease infinite;padding:1rem;overflow-x:hidden;position:relative}.login-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(30,64,175,.3) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(8,145,178,.3) 0%,transparent 50%);animation:fadeIn 1s ease}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.login-card{background:var(--bg-white);padding:2.5rem;border-radius:20px;box-shadow:var(--shadow-xl);width:100%;max-width:420px;position:relative;z-index:1;animation:slideUp .6s ease-out}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color),var(--accent-color));border-radius:20px 20px 0 0}.login-header{text-align:center;margin-bottom:2rem;animation:fadeIn .8s ease-out .2s both}.login-logo{width:64px;height:64px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);border-radius:16px;color:#fff;box-shadow:0 8px 20px #1e40af4d}.login-logo svg{width:36px;height:36px}.login-header h1{font-size:1.75rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.login-header p{color:var(--text-light);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-error{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:1px solid rgba(220,38,38,.35);background:#dc262614;color:#b91c1c;border-radius:12px;font-weight:500;font-size:.9rem;animation:slideUp .3s ease-out}.login-error svg{width:20px;height:20px;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:.5rem;animation:slideUp .6s ease-out both}.form-group:nth-child(1){animation-delay:.3s}.form-group:nth-child(2){animation-delay:.4s}.form-group label{font-weight:600;color:var(--text-dark);font-size:.9rem;transition:color .3s ease}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper svg{position:absolute;left:1rem;width:20px;height:20px;color:var(--text-lighter);transition:color .3s ease;pointer-events:none}.input-wrapper input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid var(--border-color);border-radius:10px;font-size:1rem;transition:all .3s ease;background:var(--bg-white)}.input-wrapper input::placeholder{color:var(--text-lighter);opacity:1}.input-wrapper input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #1e40af1a}.input-wrapper:focus-within svg{color:var(--primary-color)}.login-button{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff;padding:1rem;border:none;border-radius:10px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;margin-top:.5rem;position:relative;overflow:hidden;animation:slideUp .6s ease-out .5s both}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.login-button:hover:not(:disabled):before{left:100%}.login-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 25px #1e40af66}.login-button:active:not(:disabled){transform:translateY(-1px);box-shadow:0 5px 15px #1e40af4d}.login-button:disabled{opacity:.7;cursor:not-allowed;background:var(--text-lighter)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem}.login-button:disabled{display:flex;align-items:center;justify-content:center}.login-footer{margin-top:1.5rem;text-align:center;padding-top:1.5rem;border-top:1px solid var(--border-color);animation:fadeIn .8s ease-out .6s both}.login-footer p{color:var(--text-lighter);font-size:.85rem;margin:0}@media(max-width:640px){.login-card{padding:2rem}.login-header h1{font-size:1.5rem}.login-logo{width:56px;height:56px}.login-logo svg{width:30px;height:30px}}.dashboard-container{display:flex;flex-direction:column;gap:1.5rem}.dashboard-welcome{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.welcome-content h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-dark)}.welcome-content p{margin:0}.user-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-gray);border-radius:12px}.user-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-email{font-size:.875rem;color:var(--text-light)}.user-roles{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.25rem}.user-roles .badge-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff}.dashboard-section{display:flex;flex-direction:column;gap:1rem}.dashboard-section h3{margin:0;font-size:1.1rem;color:var(--text-dark)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.quick-action-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;text-decoration:none;color:inherit;transition:all .2s ease}.quick-action-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #1e40af1a;transform:translateY(-2px)}.quick-action-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-action-icon.admin-icon{background:linear-gradient(135deg,#7c3aed,#a855f7)}.quick-action-icon svg{width:24px;height:24px}.quick-action-content{display:flex;flex-direction:column;gap:.25rem}.quick-action-title{font-weight:600;color:var(--text-dark)}.quick-action-desc{font-size:.85rem;color:var(--text-light)}.info-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd}.info-card p{margin:0;color:#0369a1;line-height:1.6}.info-card strong{color:#0c4a6e}@media(max-width:768px){.dashboard-welcome{flex-direction:column;align-items:flex-start}.user-info{width:100%}.quick-actions{grid-template-columns:1fr}}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}select.form-input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231E40AF' d='M2 4l4 4 4-4'/%3E%3C/svg%3E")}.assignment-info{padding:1rem;background:var(--bg-lighter);border-radius:10px;margin-bottom:1rem}.assignment-info p{margin:0}.assignment-info p+p{margin-top:.25rem}.no-problems-notice{padding:1rem;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:8px;color:var(--warning-color);font-size:.9rem;margin-bottom:1rem}.no-problems-notice a{color:var(--primary-color);text-decoration:underline;font-weight:600}.user-selection-grid{display:flex;flex-direction:column;gap:.5rem;max-height:280px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px;padding:.75rem;background:var(--bg-lighter)}.user-selection-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer;flex-shrink:0}.user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.user-name{font-weight:600;color:var(--text-dark);font-size:.95rem}.user-email{font-size:.85rem;color:var(--text-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-selection-grid::-webkit-scrollbar,.modal-body::-webkit-scrollbar{width:6px}.user-selection-grid::-webkit-scrollbar-track,.modal-body::-webkit-scrollbar-track{background:var(--bg-lighter);border-radius:3px}.user-selection-grid::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:3px}.user-selection-grid::-webkit-scrollbar-thumb:hover,.modal-body::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.solution-count-btn{font-weight:600;padding:.25rem .5rem;border-radius:6px}.solution-count-btn.has-solutions{color:var(--primary-color);background:#1e40af14}.solution-count-btn:hover{background:#1e40af26}.modal-xl{max-width:800px}.empty-state{text-align:center;padding:2rem;color:var(--text-light)}.empty-state p{margin:0}.solutions-list{display:flex;flex-direction:column;gap:1rem}.solution-card{border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;background:var(--bg-white)}.solution-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.solution-date{font-size:.85rem;color:var(--text-light)}.solution-description{margin-bottom:1rem}.solution-description strong{display:block;font-size:.85rem;color:var(--text-light);margin-bottom:.25rem}.solution-description p{margin:0;color:var(--text-dark);line-height:1.5}.solution-files{margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-lighter);border-radius:8px}.solution-files strong{display:block;font-size:.85rem;color:var(--text-light);margin-bottom:.5rem}.solution-files ul{margin:0;padding:0;list-style:none}.solution-files li{padding:.25rem 0}.solution-files a{color:var(--primary-color);text-decoration:none;font-weight:500}.solution-files a:hover{text-decoration:underline}.file-size{margin-left:.5rem;color:var(--text-light);font-size:.85rem}.solution-review{padding:1rem;background:var(--bg-lighter);border-radius:8px;margin-bottom:1rem}.solution-review strong{display:block;font-size:.85rem;color:var(--text-light);margin-bottom:.25rem}.solution-review p{margin:0;color:var(--text-dark)}.review-notes{font-style:italic;color:var(--text-light);margin-top:.5rem!important}.points-awarded{margin-top:.5rem!important}.solution-actions{display:flex;justify-content:flex-end}.radio-group{display:flex;gap:1.5rem}.radio-item input[type=radio]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.radio-label{font-weight:600;font-size:.95rem}.radio-label.approve{color:var(--success-color)}.radio-label.reject{color:var(--danger-color)}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal{max-height:90vh}.modal-lg,.modal-xl{max-width:100%}.user-selection-grid{max-height:200px}.filters-bar{flex-direction:column;align-items:stretch}.search-box{min-width:unset}.filter-group{flex-direction:column;align-items:stretch}.filter-group .form-input{width:100%}}.folder-tree{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;min-width:300px;max-width:340px;display:flex;flex-direction:column;max-height:100%;box-shadow:0 1px 3px #0000000d}.folder-tree-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-light);border-radius:12px 12px 0 0}.folder-tree-title{font-weight:700;font-size:.9rem;color:var(--text-dark);display:flex;align-items:center;gap:.5rem}.folder-tree-title:before{content:"📁";font-size:1.1rem}.btn-add-root-folder{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8rem;font-weight:600;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #3b82f640}.btn-add-root-folder:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f659}.btn-add-root-folder svg{width:14px;height:14px;stroke:#fff}.folder-search{padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.folder-search-input{width:100%;padding:.625rem .875rem .625rem 2.25rem;border:1px solid var(--border-color);border-radius:8px;font-size:.85rem;background:var(--bg-white);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");background-repeat:no-repeat;background-position:.75rem center;transition:all .2s}.folder-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.folder-search-input::placeholder{color:var(--text-muted)}.folder-tree-content{flex:1;overflow-y:auto;padding:.5rem 0}.folder-tree-content.drag-over-root{background:#3b82f60d}.root-folder{display:flex;align-items:center;padding:.625rem 1rem;cursor:pointer;transition:all .15s;gap:.625rem;margin:0 .5rem .25rem;border-radius:8px}.root-folder:hover{background:var(--bg-light)}.root-folder.selected{background:#3b82f61a;border-left:3px solid var(--primary);padding-left:calc(1rem - 3px)}.folder-item-wrapper{margin:0 .5rem}.folder-item{display:flex;align-items:center;padding:.5rem .75rem;cursor:pointer;transition:all .15s;gap:.5rem;border-radius:8px;margin-bottom:2px}.folder-item:hover{background:var(--bg-light)}.folder-item.selected{background:#3b82f61a;border-left:3px solid var(--primary);margin-left:-3px;padding-left:calc(.75rem + 3px)}.folder-item.drag-over{background:#3b82f626;outline:2px dashed var(--primary);outline-offset:-2px}.folder-expand-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;font-size:.6rem;color:var(--text-muted);padding:0;flex-shrink:0;border-radius:4px;transition:all .15s}.folder-expand-btn:hover{background:var(--bg-light);color:var(--text-dark)}.folder-icon{font-size:1.1rem;flex-shrink:0}.document-icon{font-size:.95rem;flex-shrink:0;opacity:.8}.folder-name{flex:1;min-width:0;font-size:.875rem;font-weight:500;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-name{flex:1;font-size:.825rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-actions{display:flex;gap:.375rem;margin-left:auto;flex-shrink:0}.folder-action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#0000000a;border:none;border-radius:5px;cursor:pointer;transition:all .15s;padding:0}.folder-action-btn svg{width:14px;height:14px;flex-shrink:0;display:block}.folder-action-btn.action-add{color:#16a34a}.folder-action-btn.action-add:hover{background:#16a34a;color:#fff}.folder-action-btn.action-edit{color:#2563eb}.folder-action-btn.action-edit:hover{background:#2563eb;color:#fff}.folder-action-btn.action-delete{color:#dc2626}.folder-action-btn.action-delete:hover{background:#dc2626;color:#fff}.folder-children{margin-left:.75rem;padding-left:.75rem;border-left:1px dashed var(--border-color)}.document-item{display:flex;align-items:center;padding:.4rem .75rem;cursor:pointer;transition:all .15s;gap:.5rem;border-radius:6px;margin-bottom:1px}.document-item:hover{background:var(--bg-light)}.root-documents{border-top:1px solid var(--border-color);margin-top:.5rem;padding-top:.5rem}.drop-zone-hint{margin:.75rem;padding:1rem;border:2px dashed var(--primary);border-radius:8px;text-align:center;font-size:.8rem;color:var(--primary);background:#3b82f60d;font-weight:500}.folder-empty-state{padding:2rem 1rem;text-align:center;color:var(--text-muted)}.folder-empty-state p{font-size:.85rem;margin:0}.search-highlight{background:#fbbf244d;border-radius:2px;padding:0 2px}.no-search-results{padding:1.5rem 1rem;text-align:center;color:var(--text-muted);font-size:.85rem}.folder-item[draggable=true],.document-item[draggable=true]{cursor:grab}.folder-item[draggable=true]:active,.document-item[draggable=true]:active{cursor:grabbing}@media(max-width:1024px){.folder-tree{min-width:260px;max-width:300px}}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.pdf-modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.pdf-modal{background:var(--bg-white, #fff);border-radius:16px;box-shadow:var(--shadow-xl, 0 20px 50px rgba(0, 0, 0, .25));width:min(1100px,95vw);height:min(90vh,100vh);display:flex;flex-direction:column;overflow:hidden}.pdf-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #e5e7eb);gap:1rem}.pdf-modal-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text-dark, #0f172a);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pdf-modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-light, #64748b);padding:0}.pdf-modal-close:hover{color:var(--text-dark, #0f172a)}.pdf-modal-toolbar{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem 1rem;border-bottom:1px solid var(--border-color, #e5e7eb);background:var(--bg-lighter, #f8fafc);flex-wrap:wrap}.pdf-modal-toolbar button{background:var(--bg-white, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:6px;padding:.35rem .75rem;font-size:.85rem;cursor:pointer;color:var(--text-dark, #0f172a)}.pdf-modal-toolbar button:disabled{opacity:.4;cursor:not-allowed}.pdf-modal-toolbar .pdf-page-info{font-size:.85rem;color:var(--text-dark, #0f172a);min-width:90px;text-align:center}.pdf-modal-body{flex:1;overflow:auto;background:#4b5563;padding:1rem;display:flex;justify-content:center;align-items:flex-start}.pdf-modal-state{color:#fff;font-size:.95rem;padding:2rem;text-align:center}.pdf-modal-error{color:#fee2e2;background:#991b1b;border-radius:8px;padding:.75rem 1rem;margin:1rem;font-size:.9rem}.pdf-modal-page-wrapper{background:#fff;box-shadow:0 4px 20px #0000004d}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-white);border-radius:16px;box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-lighter)}.role-list{display:flex;flex-direction:column;gap:.5rem}.role-checkbox{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s}.role-checkbox:hover{border-color:var(--primary-light);background:#3b82f60a}.role-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:var(--primary-color);cursor:pointer}.role-name{font-weight:600;color:var(--text-dark)}.role-desc{display:block;font-size:.85rem;color:var(--text-light);margin-top:.25rem}.user-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.user-checkbox{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s}.user-checkbox:hover{border-color:var(--primary-light);background:#3b82f60a}.user-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.user-info{flex:1}.user-name{font-weight:600;color:var(--text-dark)}.user-email{font-size:.85rem;color:var(--text-light)}.form-group{margin-bottom:1rem}.form-input{width:100%;padding:.65rem .9rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.modal-wide{max-width:560px}.file-upload-area{position:relative;border:2px dashed var(--border-color);border-radius:10px;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-lighter)}.file-upload-area:hover{border-color:var(--primary-color);background:#3b82f60a}.file-placeholder{color:var(--text-light);font-size:.95rem}.file-selected{display:flex;flex-direction:column;gap:.25rem}.file-selected .file-name{font-weight:600;color:var(--text-dark);word-break:break-all}.file-selected .file-size{font-size:.85rem;color:var(--text-light)}.btn-secondary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none}.btn-secondary:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.btn-secondary:disabled{background:linear-gradient(135deg,#a5b4fc,#c4b5fd);cursor:not-allowed}.question-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.question-number{font-weight:700;color:var(--primary-color);font-size:.9rem}.question-text{font-weight:600;color:var(--text-dark);margin-bottom:.75rem;line-height:1.5}.question-options{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.question-options li{padding:.5rem .75rem;border-radius:6px;font-size:.9rem;color:var(--text-muted);background:var(--bg-white);border:1px solid var(--border-color)}.question-options li.correct-answer{background:#22c55e1a;border-color:#22c55e4d;color:#15803d;font-weight:600}.badge-difficulty-1{background:#22c55e26;color:#15803d}.badge-difficulty-2{background:#fbbf2426;color:#b45309}.badge-difficulty-3{background:#ef444426;color:#dc2626}.documents-layout{display:flex;gap:1.5rem;height:calc(100vh - 200px);min-height:500px}.documents-main{flex:1;display:flex;flex-direction:column;min-width:0}.documents-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.documents-header h2{margin:0}.current-folder-path{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted);margin-top:.25rem}.current-folder-path .folder-breadcrumb{display:flex;align-items:center;gap:.25rem}.documents-table-container{flex:1;overflow-y:auto}.input-modal-content{padding:1rem 0}.input-modal-content label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-dark)}.input-modal-content input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem}.input-modal-content input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.documents-search-bar{display:flex;gap:.75rem;margin-bottom:1rem;align-items:center}.search-input-wrapper{position:relative;flex:1}.documents-search-input{width:100%;padding:.65rem 2.5rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;background:var(--bg-white);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");background-repeat:no-repeat;background-position:.75rem center;transition:all .2s}.documents-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.documents-search-input::placeholder{color:var(--text-muted)}.search-clear-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-light);border:none;border-radius:50%;cursor:pointer;font-size:1.1rem;color:var(--text-muted);transition:all .15s}.search-clear-btn:hover{background:var(--bg-card);color:var(--text-dark)}.status-filter-select{padding:.65rem 2rem .65rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;background:var(--bg-white);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' 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:calc(100% - .75rem) center;transition:all .2s;min-width:140px}.status-filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.status-filter-select:hover{border-color:var(--primary-light)}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border-top:1px solid var(--border-color);background:var(--bg-lighter);border-radius:0 0 8px 8px}.pagination-btn{padding:.5rem .875rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-white);color:var(--text-dark);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;min-width:38px}.pagination-btn:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{display:flex;align-items:center;gap:.375rem;padding:0 .75rem;font-size:.9rem}.pagination-current{font-weight:600;color:var(--primary)}.pagination-total{color:var(--text-muted)}@media(max-width:1024px){.documents-layout{flex-direction:column;height:auto}.documents-layout .folder-tree{max-width:none;max-height:300px}.documents-search-bar{flex-direction:column}.status-filter-select{width:100%}}.permission-code{background:var(--bg-lighter);padding:.25rem .5rem;border-radius:6px;font-size:.85rem;font-family:monospace;color:var(--primary-color)}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal{max-height:90vh}}.problem-info{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-lighter);border-radius:8px;margin-bottom:1.25rem}.problem-info h4{margin:0;font-size:1rem;font-weight:700;color:var(--text-dark)}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.modal{background:var(--bg-white);border-radius:16px;box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-lg{max-width:650px}.form-group:last-child{margin-bottom:0}.form-textarea{resize:vertical;min-height:100px;font-family:inherit}.user-selection-grid{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px;padding:.75rem;background:var(--bg-lighter)}.user-selection-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-white);border-radius:8px;cursor:pointer;transition:background .2s,box-shadow .2s;border:1px solid transparent}.user-selection-item:hover{background:var(--bg-lighter)}.user-selection-item:has(input:checked){background:#1e40af0d;border-color:var(--primary-color)}.user-selection-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);flex-shrink:0}.user-selection-item .user-info{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.user-selection-item .user-name{font-weight:600;color:var(--text-dark);font-size:.95rem}.user-selection-item .user-email{font-size:.85rem;color:var(--text-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-box{flex:1;min-width:250px}.search-box .form-input{width:100%}.filter-group{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.filter-group .form-input{width:auto;min-width:150px}.filter-results{padding:.5rem .75rem;background:var(--bg-lighter);border-radius:6px;font-size:.85rem;color:var(--text-light);margin-bottom:1rem}.btn-text{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:.5rem;font-size:.9rem}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal{max-height:90vh}.form-row{flex-direction:column;gap:0}.filters-bar{flex-direction:column;align-items:stretch}.search-box{min-width:unset}.filter-group{flex-direction:column;align-items:stretch}.filter-group .form-input{width:100%}}.quiz-questions-page{padding:0}.quiz-stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.quiz-stat-card{background:var(--bg-lighter);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem;text-align:center;transition:all .2s}.quiz-stat-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm)}.quiz-stat-value{font-size:1.75rem;font-weight:700;color:var(--primary-color);line-height:1.2}.quiz-stat-label{font-size:.85rem;color:var(--text-light);margin-top:.25rem}.quiz-content{display:flex;flex-direction:column;gap:1.5rem}.document-selection{background:var(--bg-lighter);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem}.document-select-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.document-select-header label{font-weight:600;color:var(--text-dark);font-size:.95rem}.document-select{width:100%;padding:.65rem .9rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;background:var(--bg-white);cursor:pointer;transition:border-color .2s,box-shadow .2s}.document-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1e40af1a}.document-info{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.document-title{font-weight:600;color:var(--text-dark);font-size:.9rem}.document-count{font-size:.85rem;color:var(--text-light);background:#3b82f61a;padding:.25rem .75rem;border-radius:20px}.questions-table-wrapper{background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.questions-table-wrapper .data-table{margin-bottom:0;border-radius:0}.quiz-questions-page .question-text{font-weight:500;color:var(--text-dark);margin-bottom:.5rem;line-height:1.4}.quiz-questions-page .question-options{display:flex;flex-wrap:wrap;gap:.375rem}.quiz-questions-page .question-options .badge{font-size:.75rem;padding:.25rem .5rem}.quiz-questions-page .modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.quiz-questions-page .modal{background:var(--bg-white);border-radius:16px;box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.quiz-questions-page .modal-wide{max-width:640px}.quiz-questions-page .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.quiz-questions-page .modal-header h3{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-dark)}.quiz-questions-page .modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-light);cursor:pointer;padding:0;line-height:1;transition:color .2s}.quiz-questions-page .modal-close:hover{color:var(--text-dark)}.quiz-questions-page .modal-body{padding:1.5rem;overflow-y:auto;flex:1}.quiz-questions-page .modal-footer{display:flex;gap:.75rem;justify-content:flex-end;align-items:center;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-lighter)}.generated-question{background:var(--bg-lighter);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem}.generated-question:last-child{margin-bottom:0}.generated-question .question-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.generated-question .question-number{font-weight:700;color:var(--primary-color);font-size:.9rem}.generated-question .question-text{font-weight:600;color:var(--text-dark);margin-bottom:.75rem;line-height:1.5}.question-options-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.question-options-list li{padding:.5rem .75rem;border-radius:6px;font-size:.9rem;color:var(--text-muted);background:var(--bg-white);border:1px solid var(--border-color)}.question-options-list li.correct-answer{background:#22c55e1a;border-color:#22c55e4d;color:#15803d;font-weight:600}.correct-mark{color:#22c55e;font-weight:700}.quiz-questions-page .form-group{margin-bottom:1rem}.quiz-questions-page .form-group label{display:block;font-weight:600;color:var(--text-dark);margin-bottom:.5rem;font-size:.9rem}.quiz-questions-page .form-input{width:100%;padding:.65rem .9rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.quiz-questions-page .form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1e40af1a}.btn-sm{padding:.375rem .625rem!important;font-size:.75rem!important;border-radius:6px!important}@media(max-width:768px){.quiz-stats-cards{grid-template-columns:repeat(2,1fr)}.document-select-header{flex-direction:column;align-items:flex-start;gap:.75rem}.document-select-header .btn{width:100%}.document-info{flex-direction:column;align-items:flex-start;gap:.5rem}.quiz-questions-page .modal{margin:1rem;max-height:calc(100vh - 2rem)}}@media(max-width:480px){.quiz-stats-cards{grid-template-columns:1fr}}.modal-lg{max-width:720px}.role-info{margin-bottom:1.25rem;padding:1rem;background:var(--bg-lighter);border-radius:10px}.role-info p{margin:0}.permissions-link{font-weight:700;cursor:pointer;color:var(--primary-color);transition:color .2s}.permissions-link:hover{color:var(--primary-hover);text-decoration:underline}.permissions-grid{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding:.5rem 0}.permission-category{border:1px solid var(--border-color);border-radius:12px;overflow:visible;background:var(--bg-white)}.permission-category-header{background:var(--bg-lighter);padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.category-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:600;margin:0}.category-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer;flex-shrink:0}.category-checkbox input[type=checkbox]:disabled{cursor:default;opacity:.6}.category-name{flex:1;color:var(--text-dark);font-weight:700;font-size:.95rem}.category-count{font-size:.8rem;color:var(--text-light);font-weight:600;background:var(--bg-white);padding:.2rem .5rem;border-radius:6px}.permission-list{display:flex;flex-direction:column;background:var(--bg-white);padding:0;margin:0}.permission-item{display:flex;align-items:flex-start;gap:.75rem;padding:.6rem 1rem;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-color);margin:0}.permission-item:last-child{border-bottom:none}.permission-item:hover{background:#3b82f60a}.permission-item input[type=checkbox]{width:16px;height:16px;margin-top:2px;accent-color:var(--primary-color);cursor:pointer;flex-shrink:0}.permission-item input[type=checkbox]:disabled{cursor:default;opacity:.6}.permission-info{flex:1;min-width:0;display:flex;flex-direction:column}.permission-name{display:block;font-weight:600;color:var(--text-dark);font-size:.875rem}.permission-desc{display:block;font-size:.75rem;color:var(--text-light);margin-top:.15rem}.permissions-grid::-webkit-scrollbar{width:6px}.permissions-grid::-webkit-scrollbar-track{background:var(--bg-lighter);border-radius:3px}.permissions-grid::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:3px}.permissions-grid::-webkit-scrollbar-thumb:hover{background:var(--text-light)}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal{max-height:90vh}.modal-lg{max-width:100%}.permissions-grid{max-height:280px}}.analytics-container{display:flex;flex-direction:column;gap:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;position:relative}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:24px;height:24px}.users-icon{background:#3b82f61a;color:#3b82f6}.docs-icon{background:#10b9811a;color:#10b981}.quiz-icon{background:#8b5cf61a;color:#8b5cf6}.tasks-icon{background:#f59e0b1a;color:#f59e0b}.stat-content{display:flex;flex-direction:column;flex:1}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-dark);line-height:1.2}.stat-label{font-size:.875rem;color:var(--text-muted)}.stat-badge{position:absolute;top:.75rem;right:.75rem}.stat-sub{position:absolute;bottom:.5rem;right:.75rem;font-size:.75rem;color:var(--text-muted)}.risk-panel h3{margin-top:0;margin-bottom:1rem}.risk-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.risk-item{text-align:center;padding:1rem;border-radius:8px;background:var(--bg-light);border-left:4px solid}.risk-item.risk-low{border-left-color:#10b981}.risk-item.risk-medium{border-left-color:#f59e0b}.risk-item.risk-high{border-left-color:#ef4444}.risk-value{font-size:2rem;font-weight:700;color:var(--text-dark)}.risk-item.risk-high .risk-value{color:#ef4444}.risk-item.risk-medium .risk-value{color:#f59e0b}.risk-label{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.top-risks{border-top:1px solid var(--border-color);padding-top:1rem}.top-risks h4{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem}.risk-list{display:flex;flex-direction:column;gap:.5rem}.risk-list-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-light);border-radius:6px}.risk-title{flex:1;font-size:.875rem;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.risk-overdue{font-size:.75rem;color:#ef4444;white-space:nowrap}.audit-stats-card h3{margin-top:0;margin-bottom:1rem}.audit-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.audit-stat-section{background:var(--bg-light);padding:1rem;border-radius:8px}.audit-stat-section h4{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.audit-stat-row{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0}.audit-stat-label{font-size:.875rem;color:var(--text-dark)}.audit-stat-value{font-weight:600;font-size:.875rem}.completion-rate{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.completion-bar{height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.completion-fill{height:100%;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:3px;transition:width .3s ease}.completion-rate span{font-size:.75rem;color:var(--text-muted)}.task-stats-card h3{margin-top:0;margin-bottom:1rem}.task-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.task-stat-section{background:var(--bg-light);padding:1rem;border-radius:8px}.task-stat-section h4{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem}.priority-bars{display:flex;flex-direction:column;gap:.5rem}.priority-bar-item{display:flex;align-items:center;gap:.5rem}.priority-label{width:50px;font-size:.75rem;color:var(--text-dark)}.priority-bar-wrapper{flex:1;height:12px;background:var(--bg-card);border-radius:6px;overflow:hidden}.priority-bar{height:100%;border-radius:6px;transition:width .3s ease}.priority-bar.critical{background:#ef4444}.priority-bar.high{background:#f59e0b}.priority-bar.medium{background:#3b82f6}.priority-bar.low{background:#10b981}.priority-count{width:30px;font-size:.875rem;font-weight:600;text-align:right;color:var(--text-dark)}.status-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.status-item{text-align:center;padding:.75rem;background:var(--bg-card);border-radius:6px;border-left:3px solid}.status-item.open{border-left-color:#ef4444}.status-item.in-progress{border-left-color:#3b82f6}.status-item.resolved{border-left-color:#10b981}.status-item.closed{border-left-color:#6b7280}.status-value{font-size:1.5rem;font-weight:700;color:var(--text-dark)}.status-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.metrics-list{display:flex;flex-direction:column;gap:.75rem}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-card);border-radius:6px}.metric-label{font-size:.875rem;color:var(--text-dark)}.metric-value{font-weight:600;font-size:.875rem}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.chart-card{min-height:300px}.bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:200px;padding:1rem 0;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.bar-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1}.bars{display:flex;align-items:flex-end;gap:4px;height:160px}.bar{width:16px;min-height:4px;border-radius:4px 4px 0 0;transition:height .3s ease}.quiz-bar{background:#8b5cf6}.task-bar{background:#f59e0b}.user-bar{background:#3b82f6}.bar-label{font-size:.75rem;color:var(--text-muted)}.chart-legend{display:flex;gap:1.5rem;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.legend-color{width:12px;height:12px;border-radius:3px}.quiz-color{background:#8b5cf6}.task-color{background:#f59e0b}.user-color{background:#3b82f6}.quiz-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.quiz-stat{text-align:center;padding:1rem;background:var(--bg-light);border-radius:8px}.quiz-stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-dark)}.quiz-stat-label{font-size:.75rem;color:var(--text-muted)}.quiz-difficulty-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.quiz-diff-item{text-align:center;padding:.5rem;border-radius:6px;border-left:3px solid}.quiz-diff-item.easy{background:#10b9811a;border-left-color:#10b981}.quiz-diff-item.medium{background:#3b82f61a;border-left-color:#3b82f6}.quiz-diff-item.hard{background:#ef44441a;border-left-color:#ef4444}.diff-count{display:block;font-size:1.25rem;font-weight:700;color:var(--text-dark)}.diff-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.difficulty-breakdown{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.difficulty-breakdown h4{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem}.difficulty-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.difficulty-name{width:60px;font-size:.875rem;color:var(--text-dark)}.difficulty-bar-container{flex:1;height:8px;background:var(--bg-light);border-radius:4px;overflow:hidden}.difficulty-bar{height:100%;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:4px;transition:width .3s ease}.difficulty-value{width:45px;text-align:right;font-size:.875rem;font-weight:600;color:var(--text-dark)}.hardest-questions{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.hardest-questions h4{font-size:.875rem;color:var(--text-muted);margin-bottom:.75rem}.hardest-q-item{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-light);border-radius:6px;margin-bottom:.5rem}.hardest-q-text{flex:1;font-size:.8rem;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hardest-q-rate{font-size:.75rem;color:#ef4444;white-space:nowrap}.performers-card{max-height:450px;overflow-y:auto}.performers-list{display:flex;flex-direction:column;gap:.75rem}.performer-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-light);border-radius:8px}.performer-rank{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border-radius:50%;font-weight:700;font-size:.875rem}.performer-info{flex:1;display:flex;flex-direction:column;min-width:0}.performer-name{font-weight:600;color:var(--text-dark)}.performer-email{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.performer-dept{background:var(--bg-card);padding:.125rem .5rem;border-radius:4px;margin-right:.5rem;font-size:.7rem;color:var(--text-dark)}.performer-stats{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.performer-meta{font-size:.7rem;color:var(--text-muted)}.dept-performance-card h3{margin-top:0;margin-bottom:1rem}.dept-table-wrapper{overflow-x:auto}.dept-performance-card .data-table{min-width:700px}.dept-name{font-weight:600;color:var(--text-dark)}.dept-points{font-weight:700;color:var(--primary)}.mini-progress{display:flex;align-items:center;gap:.5rem}.mini-progress-bar{width:60px;height:6px;background:var(--bg-light);border-radius:3px;overflow:hidden}.mini-progress-bar:after{content:"";display:block;height:100%;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:3px}.mini-progress span{font-size:.75rem;color:var(--text-muted)}.text-success{color:#10b981}.text-danger{color:#ef4444}.text-warning{color:#f59e0b}.text-info{color:#3b82f6}.text-muted{color:var(--text-muted)}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.analytics-grid{grid-template-columns:1fr}.quiz-stats-grid{grid-template-columns:repeat(3,1fr)}.risk-grid{grid-template-columns:repeat(2,1fr)}.audit-stats-grid,.task-stats-grid{grid-template-columns:1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.risk-grid,.status-grid{grid-template-columns:repeat(2,1fr)}.quiz-difficulty-grid{grid-template-columns:repeat(3,1fr)}}.departments-page{padding:0}.btn-group{display:flex;gap:.5rem;justify-content:flex-end}.modal-wide{max-width:720px}.modal-body{padding:1.5rem;overflow-y:auto;flex:1 1 auto;min-height:200px}.form-input::placeholder{color:var(--text-lighter)}.members-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.confirm-inline{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.25);border-radius:8px;margin-bottom:1rem}.confirm-inline span{font-weight:600;color:var(--danger-color)}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:var(--bg-lighter);border-radius:3px}.modal-body::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:3px}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal{max-height:90vh}.modal-wide{max-width:100%}.members-header{flex-direction:column;gap:.75rem;align-items:flex-start}}.audits-page{padding:0}.filters-bar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:200px;max-width:300px}.search-box input{width:100%;padding:.6rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.search-box input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1e40af1a}.btn-group{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-input:disabled{background:var(--bg-lighter);cursor:not-allowed;opacity:.7}@media(max-width:768px){.filters-bar{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.filter-group{flex-wrap:wrap}.form-row{grid-template-columns:1fr}.modal-overlay{padding:.5rem}.modal{max-height:90vh}.modal-wide{max-width:100%}}.audit-detail-page{padding:0}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.btn-back{background:var(--bg-lighter);border:1px solid var(--border-color)}.header-content{display:flex;align-items:center;gap:1rem;flex:1}.header-content h2{margin:0}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-bottom:1.5rem}.tab{padding:.75rem 1.5rem;background:none;border:none;font-size:.95rem;font-weight:600;color:var(--text-light);cursor:pointer;position:relative;transition:color .2s}.tab:hover{color:var(--text-dark)}.tab.active{color:var(--primary-color)}.tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--primary-color)}.tab-content{min-height:300px}.tab-actions{display:flex;justify-content:flex-end;margin-bottom:1rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.info-card{background:var(--bg-lighter);border-radius:10px;padding:1rem}.info-card.full-width{grid-column:1 / -1}.info-card h4{margin:0 0 .5rem;font-size:.85rem;color:var(--text-light);font-weight:600}.info-card p{margin:0;font-size:.95rem;color:var(--text-dark);font-weight:500}.form-textarea{resize:vertical;min-height:80px}.checkbox-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem 0}.checkbox-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:6px;cursor:pointer;transition:background .15s}.checkbox-item:hover{background:var(--bg-lighter)}.checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color)}.radio-group{display:flex;gap:1rem}.radio-item{display:flex;align-items:center;gap:.5rem;cursor:pointer}.radio-item input[type=radio]{width:18px;height:18px;accent-color:var(--primary-color)}.badge-orange{background:#f97316;color:#fff}.error-page{text-align:center;padding:3rem}.error-page p{margin-bottom:1rem;color:var(--danger-color)}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.tabs{overflow-x:auto}.tab{padding:.75rem 1rem;white-space:nowrap}.info-grid{grid-template-columns:1fr}.modal-overlay{padding:.5rem}.modal{max-height:90vh}.modal-wide{max-width:100%}}.my-actions-page{padding:0}.text-danger{color:var(--danger-color)}.text-sm{font-size:.8rem}.btn-group{display:flex;gap:.5rem;justify-content:flex-start;flex-wrap:wrap}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-white);border-radius:16px;box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-wide{max-width:640px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-header h3{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-dark)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-light);cursor:pointer;padding:0;line-height:1;transition:color .2s}.modal-close:hover{color:var(--text-dark)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1 1 auto}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-lighter);flex-shrink:0}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:600;color:var(--text-dark);margin-bottom:.5rem;font-size:.9rem}.form-input{width:100%;padding:.7rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s;background:var(--bg-white);color:var(--text-dark)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1e40af1a}.form-textarea{resize:vertical;min-height:100px}.form-error{padding:.75rem 1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.25);border-radius:8px;color:var(--danger-color);font-weight:600;margin-bottom:1rem}.info-box{padding:.75rem 1rem;background:var(--bg-lighter);border-radius:8px;margin-bottom:1rem}.action-detail{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;gap:1rem;align-items:flex-start}.detail-row .label{font-weight:600;color:var(--text-light);min-width:120px;flex-shrink:0}.detail-row.full{flex-direction:column;gap:.5rem}.detail-row.full p{margin:0;padding:.75rem;background:var(--bg-lighter);border-radius:8px;white-space:pre-wrap}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--bg-lighter);border-radius:6px}.file-item a{color:var(--primary-color);font-weight:600;text-decoration:none}.file-item a:hover{text-decoration:underline}.file-size{color:var(--text-light);font-size:.85rem}.file-upload-area{position:relative;border:2px dashed var(--border-color);border-radius:8px;padding:1rem;transition:border-color .2s}.file-upload-area:hover{border-color:var(--primary-color)}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-placeholder{text-align:center;color:var(--text-light);padding:1rem}.file-selected{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-lighter);border-radius:6px}.file-name{font-weight:600;flex:1}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover{background:#059669}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal{max-height:90vh}.modal-wide{max-width:100%}}.all-actions-page{padding:1.5rem}.page-toolbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.page-toolbar h2{margin:0 0 .25rem;font-size:1.5rem;color:var(--text-primary)}.page-toolbar .muted{color:var(--text-secondary);font-size:.875rem;margin:0}.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;text-align:center}.stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-card .stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.stat-card.stat-warning{border-left:3px solid var(--warning)}.stat-card.stat-info{border-left:3px solid var(--info)}.stat-card.stat-success{border-left:3px solid var(--success)}.stat-card.stat-danger{border-left:3px solid var(--danger)}.filters-bar{margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.filter-group .form-input{width:240px}.filter-group select{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-card)}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;padding:0;font:inherit;text-decoration:underline}.link-btn:hover{color:var(--primary-dark)}@media(max-width:1200px){.stats-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.stats-row{grid-template-columns:repeat(2,1fr)}.filter-group{flex-wrap:wrap}.filter-group .form-input{width:100%}}.my-audits-page{padding:0}.filters-bar{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center}.filter-group{display:flex;gap:.5rem;align-items:center}.filter-group select{padding:.6rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;background:var(--bg-white);cursor:pointer}.filter-group select:focus{outline:none;border-color:var(--primary-color)}.btn-text{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:.5rem}.btn-text:hover{text-decoration:underline}.audits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.audit-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:.75rem}.audit-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.audit-card-inactive{opacity:.6}.audit-card-inactive:hover{opacity:.8}.audit-card-header{display:flex;gap:.5rem;flex-wrap:wrap}.audit-card-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-dark);line-height:1.3}.audit-card-departments{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-lighter);border-radius:8px;margin-top:.25rem}.department-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.department-label{font-size:.75rem;color:var(--text-light);font-weight:600;text-transform:uppercase}.department-name{font-size:.9rem;font-weight:600;color:var(--text-dark)}.department-arrow{font-size:1.25rem;color:var(--text-light);flex-shrink:0}.audit-card-dates{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-light);margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border-color)}.date-separator{color:var(--text-lighter)}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem;color:var(--text-light);background:var(--bg-lighter);border-radius:12px}.loading{text-align:center;padding:3rem;color:var(--text-light)}@media(max-width:768px){.audits-grid{grid-template-columns:1fr}.audit-card-departments{flex-direction:column;gap:.5rem}.department-arrow{transform:rotate(90deg)}}
