.aa-shell{min-height:90vh;background:#f1f2f4;padding-block:clamp(1.5rem,4vw,3rem)}.aa-shell .container{max-width:1220px;margin:0 auto;padding-inline:1.25rem}.aa-shell .auth-card{max-width:26rem;margin:4rem auto;background:#fff;border-radius:1rem;padding:2.5rem;box-shadow:0 4px 24px #00000014}.aa-shell .auth-logo{max-width:200px;margin:0 auto 1.5rem;display:block}.aa-shell .auth-card h1{font-family:var(--font-heading);font-size:1.5rem;color:#1a2332;margin-bottom:.25rem}.aa-shell .auth-sub{font-size:.9rem;color:#666;margin-bottom:1.5rem}.aa-shell .auth-card label{display:block;font-size:.8125rem;font-weight:700;color:#1a2332;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.aa-shell .auth-row{display:flex;gap:.625rem}.aa-shell .auth-row input{flex:1;border:2px solid #ddd;border-radius:.5rem;padding:.625rem .875rem;font-size:1rem;font-family:inherit;transition:border-color .15s}.aa-shell .auth-row input:focus{outline:none;border-color:#f0901c}.aa-shell .auth-error{font-size:.875rem;color:#c0392b;margin-top:.5rem}.aa-shell .btn-primary{background:#1a2332;color:#fff;border:none;border-radius:.5rem;padding:.625rem 1.25rem;font-weight:700;font-size:.9375rem;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s;text-decoration:none;display:inline-block}.aa-shell .btn-primary:hover{background:#f0901c}.aa-shell .btn-ghost{background:#ffffff1a;color:#fff;border:1.5px solid rgba(255,255,255,.35);border-radius:999px;padding:.5rem 1.1rem;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.aa-shell .btn-ghost:hover{background:#fff3}.aa-shell .hero{background:linear-gradient(150deg,#1a2332,#2a3550 65%,#1f2940);border-radius:1rem;padding:1.75rem 2rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;box-shadow:0 14px 36px -18px #1a233280}.aa-shell .hero__eyebrow{font-family:var(--font-mono, monospace);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:#ffd24a;margin:0 0 .35rem}.aa-shell .hero__title{font-family:var(--font-heading);font-size:clamp(1.5rem,3vw,2rem);color:#fff;margin:0;letter-spacing:-.02em}.aa-shell .hero__sub{color:#ffffffb3;font-size:.9rem;margin:.35rem 0 0}.aa-shell .hero__side{display:flex;flex-direction:column;align-items:flex-end;gap:.6rem}.aa-shell .admin-nav{display:flex;gap:.4rem}.aa-shell .admin-nav a{color:#ffffffb3;text-decoration:none;font-size:.82rem;font-weight:700;padding:.3rem .85rem;border-radius:999px;border:1.5px solid transparent}.aa-shell .admin-nav a:hover{color:#fff}.aa-shell .admin-nav a.active{color:#ffd24a;border-color:#ffd24a66;background:#ffd24a1a}.aa-shell .summary{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin-bottom:1.5rem}@media (max-width: 640px){.aa-shell .summary{grid-template-columns:repeat(2,1fr)}}.aa-shell .card{background:#fff;border-radius:.85rem;padding:1.1rem 1.35rem;box-shadow:0 2px 12px #0000000d;border:1px solid #e7e8ea;position:relative;overflow:hidden}.aa-shell .card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#f0901c}.aa-shell .card--warn{border-color:#f0c36d;background:#fffaf0}.aa-shell .card--warn:before{background:#d9911f}.aa-shell .card-value{font-family:var(--font-heading);font-size:2rem;font-weight:800;color:#1a2332;line-height:1}.aa-shell .card-label{font-size:.74rem;color:#888;margin-top:.4rem;text-transform:uppercase;letter-spacing:.07em;font-weight:700}.aa-shell .controls{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.aa-shell .filter-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.aa-shell .tab{background:#fff;border:1.5px solid #dcdde0;border-radius:999px;padding:.42rem 1.05rem;font-size:.8125rem;font-weight:700;cursor:pointer;font-family:inherit;color:#555;transition:all .15s}.aa-shell .tab:hover{border-color:#1a2332;color:#1a2332}.aa-shell .tab.active{background:#1a2332;color:#fff;border-color:#1a2332}.aa-shell .search{border:1.5px solid #dcdde0;border-radius:999px;padding:.46rem 1.05rem;font-size:.875rem;font-family:inherit;min-width:250px;transition:border-color .15s;background:#fff}.aa-shell .search:focus{outline:none;border-color:#f0901c}.aa-shell .count{font-size:.8rem;color:#999;margin-bottom:.6rem;font-weight:600}.aa-shell .foot-note{font-size:.78rem;color:#aaa;margin-top:.85rem;text-align:center}.aa-shell .table-wrap{overflow-x:auto;border-radius:.85rem;box-shadow:0 2px 16px #00000012;background:#fff}.aa-shell .data-table{width:100%;border-collapse:collapse;font-size:.875rem}.aa-shell .data-table thead th{background:#1a2332;color:#fffc;text-align:left;padding:.8rem 1rem;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap}.aa-shell .data-table thead th.num{text-align:center}.aa-shell .data-table thead th:first-child{border-radius:.85rem 0 0}.aa-shell .data-table thead th:last-child{border-radius:0 .85rem 0 0}.aa-shell .row{cursor:pointer;transition:background .12s}.aa-shell .row:hover{background:#f6f8ff}.aa-shell .row:focus{outline:2px solid #F0901C;outline-offset:-2px}.aa-shell .data-table td{padding:.8rem 1rem;border-bottom:1px solid #f0f0ee;vertical-align:middle;color:#2a2a2a;white-space:nowrap}.aa-shell .data-table td.num{text-align:center;font-variant-numeric:tabular-nums}.aa-shell .data-table tr:last-child td{border-bottom:none}.aa-shell .col-student strong{display:block;font-size:.94rem;color:#1a2332}.aa-shell .col-student .sub{display:block;color:#999;font-size:.76rem;margin-top:2px}.aa-shell .attempt-num{font-weight:800;color:#1a2332;font-family:var(--font-heading)}.aa-shell .col-student .sub,.aa-shell td .sub{display:block;color:#999;font-size:.76rem;margin-top:2px}.aa-shell .result-grade{font-weight:800;color:#1a2332;font-family:var(--font-heading);background:linear-gradient(135deg,#f0901c21,#ffd24a1a);padding:.2em .6em;border-radius:6px}.aa-shell .muted{color:#aaa}.aa-shell .flag{color:#c87a14;font-size:1rem;margin-left:2px}.aa-shell .acc{font-weight:800;font-variant-numeric:tabular-nums}.aa-shell .acc--high{color:#2a7a3e}.aa-shell .acc--mid{color:#c8973a}.aa-shell .acc--low{color:#c0392b}.aa-shell .status{display:inline-block;font-size:.74rem;font-weight:700;padding:.24em .7em;border-radius:999px;white-space:nowrap}.aa-shell .st--done{background:#d4edda;color:#155724}.aa-shell .st--auto{background:#fdeccd;color:#8a5a00}.aa-shell .st--live{background:#cfe2ff;color:#0a3678}.aa-shell .st--neutral{background:#ececec;color:#555}.aa-shell .report-link{color:#1a2332;font-weight:800;text-decoration:none;border-bottom:2px solid #F0901C;padding-bottom:1px}.aa-shell .report-link:hover{color:#f0901c}.aa-shell .empty{text-align:center;padding:3rem;color:#888}.aa-shell .modal-backdrop{position:fixed;inset:0;background:#1a23328c;z-index:1000;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(2px)}.aa-shell .modal-backdrop:not([hidden]){display:flex}.aa-shell .modal-card{background:#fff;border-radius:1rem;width:100%;max-width:580px;max-height:86vh;overflow-y:auto;box-shadow:0 12px 48px #00000040}.aa-shell .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;border-radius:1rem 1rem 0 0;z-index:1}.aa-shell .modal-header h2{font-family:var(--font-heading);font-size:1.1875rem;color:#1a2332}.aa-shell .modal-close{background:none;border:none;font-size:1.125rem;cursor:pointer;color:#888;padding:.25rem .5rem;border-radius:.375rem;line-height:1;transition:color .15s,background .15s}.aa-shell .modal-close:hover{color:#1a2332;background:#f0f0ee}.aa-shell .modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.2rem}.aa-shell .report-cta{display:flex}.aa-shell .report-btn{width:100%;text-align:center;font-size:1rem;padding:.8rem 1.25rem}.aa-shell .detail-section h3{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#f0901c;margin-bottom:.6rem}.aa-shell .detail-row{display:flex;gap:.75rem;padding:.4rem 0;border-bottom:1px solid #f4f4f2;font-size:.875rem;align-items:baseline}.aa-shell .detail-row:last-child{border-bottom:none}.aa-shell .detail-label{color:#999;min-width:150px;flex-shrink:0}.aa-shell .detail-value{color:#1a2332;font-weight:500;word-break:break-word}.aa-shell .detail-value code{font-family:JetBrains Mono,monospace;font-size:.78rem;background:#f4f4f2;padding:.15em .4em;border-radius:.25rem;word-break:break-all}.aa-shell .detail-meta{border-top:1px solid #eee;padding-top:1rem}.aa-shell .trend{display:flex;gap:0;overflow-x:auto;padding:.5rem 0 .25rem}.aa-shell .trend-pt{display:flex;flex-direction:column;align-items:center;gap:5px;position:relative;min-width:64px;flex:1}.aa-shell .trend-g{font-family:var(--font-heading);font-weight:800;font-size:.82rem;color:#999;height:18px;line-height:18px}.aa-shell .trend-dot{width:13px;height:13px;border-radius:50%;position:relative;z-index:1;background:#cdd2da;border:3px solid #fff;box-shadow:0 0 0 2px #cdd2da}.aa-shell .trend-lbl{font-size:.68rem;color:#aaa}.aa-shell .trend-pt:not(:first-child):before{content:"";position:absolute;z-index:0;top:30px;left:-50%;width:100%;height:2px;background:#e2e5ea}.aa-shell .trend-pt--now .trend-g{color:#c8761a}.aa-shell .trend-pt--now .trend-dot{background:linear-gradient(135deg,#f0901c,#ffd24a);box-shadow:0 0 0 2px #f0901c}.aa-shell .trend-pt--now .trend-lbl{color:#c8761a;font-weight:700}
