*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;font-size:14px;background:#f0f2f5;color:#1a1a2e;min-height:100vh}a{color:#1d6fbf;text-decoration:none}a:hover{text-decoration:underline}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1d5c38,#0f3a22)}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-logo{height:80px;width:auto;margin-bottom:16px}.login-header h1{font-size:1.2rem;font-weight:700;color:#1d5c38;margin-bottom:6px}.login-header p{font-size:.8rem;color:#64748b}.login-form{display:flex;flex-direction:column;gap:16px}.login-btn{width:100%;justify-content:center;padding:12px;font-size:1rem}.btn-logout{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 14px;font-size:.8rem;border-radius:6px;cursor:pointer;white-space:nowrap}.btn-logout:hover{background:#ffffff40}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#1d5c38,#174d2f 60%,#0f3a22);color:#fff;padding:20px 0;box-shadow:0 2px 12px #0000004d}.header-content{max-width:900px;margin:0 auto;padding:0 24px}.header-logo{display:flex;align-items:center;gap:16px}.header-icon{font-size:2.4rem;line-height:1}.header-logo-img{height:100px;width:auto}.header-logo h1{font-size:1.6rem;font-weight:700;letter-spacing:-.3px}.header-logo p{font-size:.8rem;color:#b8d9c6;margin-top:2px}.app-main{flex:1;max-width:900px;width:100%;margin:32px auto;padding:0 24px;display:flex;flex-direction:column;gap:24px}.app-footer{text-align:center;padding:16px;color:#94a3b8;font-size:.75rem;border-top:1px solid #e2e8f0}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 4px #00000014,0 4px 16px #0000000f}.card h2{font-size:1.1rem;font-weight:600;margin-bottom:4px}.card h3{font-size:1rem;font-weight:600;margin-bottom:16px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-subtitle{color:#64748b;font-size:.85rem;margin-bottom:20px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .15s ease;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#0f3460;color:#fff}.btn-primary:hover:not(:disabled){background:#1d4e8a}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.scan-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:500;color:#374151}.form-input{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-family:inherit;transition:border-color .15s;outline:none}.form-input:focus{border-color:#0f3460;box-shadow:0 0 0 3px #0f34601f}.form-input:disabled{background:#f8fafc}.form-error{color:#dc2626;font-size:.82rem;padding:8px 12px;background:#fef2f2;border-radius:6px;border-left:3px solid #dc2626}.status-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.status-pending{background:#f1f5f9;color:#64748b}.status-running{background:#dbeafe;color:#1d4ed8}.status-completed{background:#dcfce7;color:#15803d}.status-failed{background:#fee2e2;color:#dc2626}.progress-bar{height:6px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin-top:6px}.progress-bar.large{height:10px}.progress-fill{height:100%;background:linear-gradient(90deg,#0f3460,#1d6fbf);border-radius:999px;transition:width .5s ease}.progress-container{margin-top:16px}.progress-label{font-size:.8rem;color:#64748b;margin-top:6px;text-align:center}.scan-list{display:flex;flex-direction:column;gap:10px}.scan-item{padding:14px 16px;border:1.5px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .15s}.scan-item:hover{border-color:#0f3460;background:#f8fafc}.scan-item-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.scan-url{font-size:.875rem;font-weight:500;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.scan-item-meta{display:flex;gap:16px;font-size:.78rem;color:#94a3b8}.issue-pages-stat{margin-left:auto;font-weight:600}.issue-stat-good{color:#15803d}.issue-stat-warn{color:#b45309}.issue-stat-bad{color:#dc2626}.empty-state{color:#94a3b8;font-size:.875rem;text-align:center;padding:32px 0}.scan-detail{display:flex;flex-direction:column;gap:24px}.detail-nav{display:flex;justify-content:space-between;margin-bottom:16px}.detail-title{font-size:1.3rem;font-weight:700}.detail-url{color:#64748b;font-size:.85rem;margin-top:4px;margin-bottom:20px;word-break:break-all}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-box{display:flex;flex-direction:column;align-items:center;padding:14px 8px;border-radius:10px;background:#f8fafc;border:1.5px solid #e2e8f0}.stat-value{font-size:1.5rem;font-weight:700;color:#0f3460}.stat-label{font-size:.72rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;margin-top:2px}.detail-title-row{display:flex;align-items:center;gap:12px}.scan-timestamp{font-size:.8rem;color:#64748b}.status-pill{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:999px;text-transform:capitalize}.status-pill-completed{background:#dcfce7;color:#15803d}.status-pill-running{background:#eff6ff;color:#1d4ed8}.status-pill-paused{background:#fef9c3;color:#a16207}.status-pill-cancelled{background:#f1f5f9;color:#64748b}.status-pill-failed{background:#fef2f2;color:#dc2626}.stat-status-completed{background:#f0fdf4;border-color:#86efac}.stat-status-completed .stat-value{color:#15803d}.stat-status-running{background:#eff6ff;border-color:#93c5fd}.stat-status-running .stat-value{color:#1d4ed8}.stat-status-failed{background:#fef2f2;border-color:#fca5a5}.stat-status-failed .stat-value{color:#dc2626}.error-banner{margin-top:12px;padding:10px 14px;background:#fef2f2;border-left:3px solid #dc2626;border-radius:6px;color:#dc2626;font-size:.85rem}.pages-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.pages-list-header h3{margin:0}.btn-sm{padding:4px 12px;font-size:.8rem}.pages-list{display:flex;flex-direction:column;gap:6px}.page-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:8px;transition:all .15s}.page-done{cursor:pointer}.page-done:hover{border-color:#0f3460;background:#f8fafc}.page-expanded{border-color:#0f3460;background:#f0f4fa;border-bottom-left-radius:0;border-bottom-right-radius:0}.page-failed{background:#fef9f9;border-color:#fca5a5}.page-url{font-size:.82rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.page-badge{flex-shrink:0}.violation-count{font-size:.8rem;font-weight:600;padding:3px 10px;border-radius:999px}.violation-count.has{background:#fee2e2;color:#dc2626}.violation-count.clean{background:#dcfce7;color:#15803d}.violations-panel{border-left:4px solid #0f3460;border-top-left-radius:0;border-top-right-radius:0;margin-top:-6px;padding-top:20px}.violations-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.violations-title h3{margin-bottom:4px}.violations-url{font-size:.78rem;color:#64748b;word-break:break-all;max-width:600px}.violations-summary{font-size:.82rem;color:#64748b;margin-bottom:12px}.violations-list{display:flex;flex-direction:column;gap:8px}.violation-item{border:1.5px solid #e2e8f0;border-radius:8px;overflow:hidden}.violation-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#f8fafc;border:none;cursor:pointer;font-family:inherit;font-size:.875rem;text-align:left;gap:12px}.violation-header:hover{background:#f1f5f9}.violation-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.impact-tag{flex-shrink:0;display:inline-block;padding:2px 9px;border-radius:999px;font-size:.7rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.rule-id{flex-shrink:0;font-size:.78rem;font-weight:600;color:#374151;background:#e2e8f0;padding:2px 8px;border-radius:4px}.violation-help{font-size:.82rem;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.violation-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.nodes-count{font-size:.78rem;color:#94a3b8}.expand-chevron{font-size:.7rem;color:#94a3b8}.violation-body{padding:14px 16px;display:flex;flex-direction:column;gap:10px;font-size:.85rem;color:#374151;border-top:1px solid #e2e8f0;background:#fff}.wcag-tag{display:inline-block;background:#dbeafe;color:#1d4ed8;padding:1px 7px;border-radius:4px;font-size:.75rem;font-weight:500;margin:0 3px 3px 0}.affected-elements{display:flex;flex-direction:column;gap:8px;margin-top:4px}.node-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:10px 12px}.node-html{display:block;font-family:Courier New,monospace;font-size:.78rem;color:#0f172a;white-space:pre-wrap;word-break:break-all}.failure-summary{margin-top:6px;font-size:.8rem;color:#dc2626}.no-violations{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 0;color:#16a34a}.no-violations-icon{font-size:2.5rem}.no-violations p{font-size:.9rem;color:#374151}.loading-text{color:#94a3b8;padding:16px 0}.header-actions{display:flex;align-items:center;gap:10px}.header-user{font-size:.82rem;color:#fffc;display:flex;align-items:center;gap:6px}.btn-secondary.btn{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 14px;font-size:.8rem}.btn-secondary.btn:hover{background:#ffffff40}.badge-role{display:inline-block;padding:1px 8px;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.badge-admin{background:#fef3c7;color:#92400e}.badge-standard{background:#e0f2fe;color:#075985}.badge-you{color:#94a3b8;font-size:.78rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal-box{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0000004d;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:1.1rem;font-weight:700}.modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:#94a3b8;padding:4px 8px;border-radius:6px}.modal-close:hover{background:#f1f5f9;color:#374151}.modal-loading{padding:24px;color:#94a3b8;text-align:center}.modal-footer{padding:16px 24px;border-top:1px solid #e2e8f0}.users-table{width:100%;border-collapse:collapse;font-size:.875rem}.users-table th{text-align:left;padding:10px 16px;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid #e2e8f0}.users-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.row-self td{background:#f8fafc}.user-actions{display:flex;gap:6px;justify-content:flex-end}.btn-danger{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5}.btn-danger:hover{background:#fee2e2}.inline-form{margin:0 24px 8px;padding:16px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:10px}.inline-form-label{font-size:.875rem;color:#374151}.inline-form-actions{display:flex;gap:8px}.add-user-form{display:flex;flex-direction:column;gap:12px}.add-user-form h3{font-size:.9rem;font-weight:600;margin-bottom:4px}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
