*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #3b82f6;--primary-dark: #1e40af;--primary-light: #60a5fa;--secondary-color: #8b5cf6;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--info-color: #0ea5e9;--light-gray: #f3f4f6;--medium-gray: #d1d5db;--dark-gray: #6b7280;--text-dark: #1f2937;--text-light: #6b7280;--border-radius: 8px;--transition: all .3s ease}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#f9fafb,#f3f4f6);color:var(--text-dark);line-height:1.6}#root{min-height:100vh}h1{font-size:2rem;font-weight:700;margin-bottom:1rem;color:var(--text-dark)}h2{font-size:1.5rem;font-weight:700;margin-bottom:.75rem;color:var(--text-dark)}h3{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-dark)}p{margin-bottom:1rem;color:var(--text-light)}a{color:var(--primary-color);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-dark);text-decoration:underline}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.hidden{display:none}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);box-shadow:0 4px 12px #00000026;position:sticky;top:0;z-index:100;height:60px}.header-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;height:100%}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;color:#fff;font-weight:700;font-size:1.5rem;transition:var(--transition)}.logo:hover{opacity:.9;text-decoration:none}.logo-icon{font-size:1.75rem}.logo-text{background:linear-gradient(135deg,#fff,#e0e7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:1.5rem}.user-profile{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#ffffff26;border-radius:6px;color:#fff;cursor:pointer;transition:var(--transition)}.user-profile:hover{background:#ffffff40}.user-avatar{font-size:1.5rem}.user-name{font-weight:500;font-size:.95rem}.logout-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.35rem .85rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:var(--transition);font-weight:500}.logout-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}@media(max-width:768px){.header-container{padding:0 1rem}.logo-text,.user-name{display:none}}.sidebar{width:260px;background:linear-gradient(180deg,#fff,#fafbfc);border-right:1px solid var(--medium-gray);height:calc(100vh - 60px);position:fixed;left:0;top:60px;overflow-y:auto;box-shadow:2px 0 4px #0000000d}.sidebar-nav{padding:1.5rem 0}.sidebar-title{padding:0 1.5rem 1rem;border-bottom:2px solid var(--light-gray);margin-bottom:1rem}.sidebar-title h3{margin:0;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--dark-gray);font-weight:600}.nav-list{list-style:none;padding:0;margin:0}.nav-parent{margin:.25rem 0}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;color:var(--text-light);font-weight:500;transition:var(--transition);position:relative;cursor:pointer}.nav-link:hover{color:var(--primary-color);background:var(--light-gray);text-decoration:none}.nav-link.active{color:var(--primary-color);background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border-right:3px solid var(--primary-color)}.nav-icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;width:24px}.nav-label{font-size:.95rem;flex:1}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--medium-gray);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--dark-gray)}.nav-dropdown{cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%}.dropdown-arrow{font-size:12px;transition:transform .3s ease}.sub-nav{list-style:none;padding-left:0;margin:.5rem 0 0}.sub-nav li{margin:0}.nav-sublink{display:block;padding:.625rem 1.5rem .625rem 3.5rem;color:var(--text-light);text-decoration:none;font-size:.9rem;transition:var(--transition);position:relative}.nav-sublink:before{content:"";position:absolute;left:2.5rem;top:50%;transform:translateY(-50%);width:4px;height:4px;background:var(--medium-gray);border-radius:50%}.nav-sublink:hover{color:var(--primary-color);background:var(--light-gray)}.nav-sublink.active{color:var(--primary-color);font-weight:600;background:linear-gradient(135deg,rgba(59,130,246,.08) 0%,transparent 100%)}.nav-sublink.active:before{background:var(--primary-color)}@media(max-width:768px){.sidebar{width:70px}.nav-link{padding:1rem .5rem;justify-content:center}.nav-label{display:none}.nav-icon{width:auto}.sidebar-title{display:none}}.layout{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(135deg,#f9fafb,#f3f4f6)}.layout-body{display:flex;flex:1;padding-top:60px}.main-content{flex:1;margin-left:260px;background:linear-gradient(135deg,#f9fafb,#f3f4f6);min-height:calc(100vh - 60px);transition:margin-left .3s ease}.content-wrapper{max-width:1400px;margin:0 auto;padding:2rem 1.5rem;width:100%}@media(max-width:768px){.main-content{margin-left:70px}}@media(max-width:480px){.content-wrapper{padding:1rem}}.btn{font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background:#7c3aed;box-shadow:0 4px 12px #8b5cf666;transform:translateY(-2px)}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:#059669;box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 12px #ef444466;transform:translateY(-2px)}.btn-warning{background:var(--warning-color);color:#fff}.btn-warning:hover:not(:disabled){background:#d97706;box-shadow:0 4px 12px #f59e0b66;transform:translateY(-2px)}.btn-outline{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-outline:hover:not(:disabled){background:var(--light-gray);border-color:var(--primary-dark);color:var(--primary-dark)}.btn-ghost{background:transparent;color:var(--primary-color)}.btn-ghost:hover:not(:disabled){background:var(--light-gray)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-md{padding:.75rem 1.5rem;font-size:.95rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.btn-full-width{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:disabled{pointer-events:none}.card{background:#fff;border-radius:var(--border-radius);box-shadow:0 1px 3px #00000014;overflow:hidden;transition:var(--transition);border:1px solid rgba(0,0,0,.05)}.card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.card-header{padding:1.5rem;border-bottom:1px solid var(--light-gray);background:linear-gradient(135deg,rgba(59,130,246,.05) 0%,transparent 100%)}.card-header h2,.card-header h3{margin:0}.card-body{padding:1.5rem}.card-footer{padding:1.5rem;border-top:1px solid var(--light-gray);background:#f3f4f680;display:flex;gap:1rem;justify-content:flex-end}@media(max-width:768px){.card-header,.card-body,.card-footer{padding:1rem}}.form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;color:var(--text-dark);font-size:.95rem}.required{color:var(--danger-color);margin-left:.25rem}.form-input,.form-textarea,.form-select{padding:.75rem 1rem;border:1.5px solid var(--medium-gray);border-radius:6px;font-size:.95rem;font-family:inherit;transition:var(--transition);background:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-input:hover:not(:focus),.form-textarea:hover:not(:focus),.form-select:hover:not(:focus){border-color:var(--primary-light)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{background:var(--light-gray);cursor:not-allowed;color:var(--dark-gray)}.form-input.error,.form-textarea.error,.form-select.error{border-color:var(--danger-color)}.form-input.error:focus,.form-textarea.error:focus,.form-select.error:focus{box-shadow:0 0 0 3px #ef44441a}.error-message{font-size:.875rem;color:var(--danger-color);font-weight:500}.form-textarea{resize:vertical;min-height:100px}@media(max-width:768px){.form{gap:1rem}.form-group{gap:.25rem}}.table-wrapper{overflow-x:auto;border-radius:var(--border-radius);border:1px solid var(--medium-gray)}.table{width:100%;border-collapse:collapse;background:#fff}.table-head{background:linear-gradient(135deg,var(--light-gray) 0%,rgba(243,244,246,.5) 100%);border-bottom:2px solid var(--medium-gray)}.table-cell-header{padding:1rem;text-align:left;font-weight:600;color:var(--text-dark);font-size:.9rem;white-space:nowrap}.table-row{transition:var(--transition)}.table-row:hover{background:var(--light-gray)}.table-row:last-child{border-bottom:none}.table-body .table-row{border-bottom:1px solid var(--medium-gray)}.table-cell{padding:1rem;color:var(--text-light);font-size:.95rem}.table-cell a{color:var(--primary-color);font-weight:500}.table-cell a:hover{color:var(--primary-dark);text-decoration:underline}@media(max-width:768px){.table-cell-header,.table-cell{padding:.75rem;font-size:.875rem}}.alert{padding:1rem;border-radius:var(--border-radius);display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-content{display:flex;gap:1rem;align-items:flex-start;flex:1}.alert-icon{font-weight:700;font-size:1.25rem;flex-shrink:0}.alert-message{display:flex;flex-direction:column;gap:.25rem}.alert-title{display:block;font-weight:600}.alert-text{font-size:.95rem;line-height:1.5}.alert-close{background:none;border:none;cursor:pointer;font-size:1.25rem;padding:0;flex-shrink:0;transition:var(--transition);opacity:.7}.alert-close:hover{opacity:1}.alert-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-left:4px solid var(--success-color);color:#047857}.alert-success .alert-icon{color:var(--success-color)}.alert-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border-left:4px solid var(--danger-color);color:#7f1d1d}.alert-error .alert-icon{color:var(--danger-color)}.alert-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid var(--warning-color);color:#78350f}.alert-warning .alert-icon{color:var(--warning-color)}.alert-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-left:4px solid var(--info-color);color:#0c4a6e}.alert-info .alert-icon{color:var(--info-color)}@media(max-width:768px){.alert{padding:.75rem;gap:.75rem}.alert-text{font-size:.9rem}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid var(--light-gray)}.page-title-section{flex:1}.page-title{margin:0;font-size:2rem;font-weight:700;color:var(--text-dark)}.page-subtitle{margin:.5rem 0 0;color:var(--text-light);font-size:1rem}.page-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end}@media(max-width:768px){.page-header{flex-direction:column;align-items:stretch;gap:1rem}.page-actions{justify-content:flex-start}.page-title{font-size:1.5rem}}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#f5f5f5}.login-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 0 10px #0000001a;width:300px}.login-form h2{text-align:center;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem}.form-group input{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px}.error{color:red;text-align:center;margin-bottom:1rem}button{width:100%;padding:.75rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}button:hover{background-color:#0056b3}.dashboard{width:100%;background:linear-gradient(135deg,#f9fafb,#f3f4f6)}.welcome-section{background:linear-gradient(135deg,#3b82f6,#1e40af);padding:3rem 2rem;border-radius:12px;margin-bottom:2rem;color:#fff;box-shadow:0 4px 20px #3b82f64d}.welcome-content h1{color:#fff;margin-bottom:.5rem;font-size:2.5rem}.welcome-content p{color:#ffffffe6;font-size:1.1rem;margin-bottom:0}.stats-section{margin-bottom:3rem}.stats-title{margin-bottom:1.5rem}.stats-title h2{font-size:1.75rem;color:var(--text-dark);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1.5rem;text-decoration:none;transition:var(--transition);box-shadow:0 2px 8px #00000014;border-left:4px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.stat-card.stat-blue{border-left-color:#3b82f6}.stat-card.stat-green{border-left-color:#10b981}.stat-card.stat-purple{border-left-color:#8b5cf6}.stat-card.stat-orange{border-left-color:#f59e0b}.stat-icon{font-size:2.5rem;min-width:60px;text-align:center}.stat-content{flex:1}.stat-content h3{color:var(--text-light);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--text-dark);margin:0}.stat-arrow{font-size:1.5rem;color:var(--primary-color);opacity:0;transition:var(--transition)}.stat-card:hover .stat-arrow{opacity:1;transform:translate(4px)}.quick-actions-section{margin-bottom:3rem}.quick-actions-header{margin-bottom:1.5rem}.quick-actions-header h2{font-size:1.75rem;color:var(--text-dark);margin:0 0 .5rem}.quick-actions-header p{color:var(--text-light);margin:0;font-size:1rem}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.action-card{background:#fff;border-radius:12px;padding:2rem 1.5rem;text-decoration:none;transition:var(--transition);position:relative;border-top:3px solid transparent;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,currentColor,transparent)}.action-card:hover{transform:translateY(-8px);box-shadow:0 12px 28px #0000001f}.action-card.action-blue{border-top-color:#3b82f6;color:#3b82f6}.action-card.action-green{border-top-color:#10b981;color:#10b981}.action-card.action-purple{border-top-color:#8b5cf6;color:#8b5cf6}.action-card.action-orange{border-top-color:#f59e0b;color:#f59e0b}.action-card.action-red{border-top-color:#ef4444;color:#ef4444}.action-card.action-indigo{border-top-color:#6366f1;color:#6366f1}.action-icon{font-size:3rem;margin-bottom:1rem}.action-card h3{color:var(--text-dark);margin:0 0 .5rem;font-size:1.25rem}.action-card p{color:var(--text-light);font-size:.9rem;margin:0 0 1rem}.action-arrow{display:inline-block;opacity:0;transition:var(--transition)}.action-card:hover .action-arrow{opacity:1;transform:translate(4px)}.info-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:3rem}.info-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:var(--transition)}.info-card:hover{box-shadow:0 6px 16px #0000001f}.info-card h3{color:var(--text-dark);font-size:1.1rem;margin:0 0 .5rem}.info-card p{color:var(--text-light);margin:0 0 .5rem;font-size:.95rem}.info-card small{color:var(--medium-gray);font-size:.85rem;margin:0}@media(max-width:768px){.welcome-section{padding:2rem 1rem;margin-bottom:1.5rem}.welcome-content h1{font-size:1.75rem}.welcome-content p{font-size:1rem}.stats-grid,.quick-actions-grid,.info-section{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem;gap:1rem}.action-card{padding:1.5rem}.action-icon{font-size:2.5rem}}.page-container{width:100%}.page-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem}.page-grid>.card:only-child,.page-grid>.card:nth-child(1):nth-last-child(1){grid-column:1 / -1}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.status-passed{background:#d1fae5;color:#065f46}.status-failed{background:#fee2e2;color:#7f1d1d}.score-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.85rem;font-weight:700;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#0c4a6e}.code-badge{background:var(--light-gray);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;color:var(--text-dark);font-family:Monaco,Courier New,monospace}.action-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3}@media(max-width:768px){.page-grid{grid-template-columns:1fr;gap:1.5rem}.form-row{grid-template-columns:1fr;gap:1rem}.page-grid>.card{grid-column:1 / -1}}
