*{box-sizing:border-box;margin:0;padding:0}body{color:#202124;background:#f8f9fa;min-height:100vh;font-family:Google Sans,Segoe UI,Roboto,sans-serif}h1{color:#1a73e8;margin-bottom:.5rem;font-size:1.75rem}h2{color:#1a73e8;margin-bottom:.5rem;font-size:1.4rem}p{color:#5f6368;margin-bottom:1rem;font-size:1rem;line-height:1.5}a{color:#1a73e8;text-decoration:none}a:hover{text-decoration:underline}.page-center{justify-content:center;align-items:flex-start;min-height:100vh;padding:2rem 1rem;display:flex}.container{width:100%;max-width:640px}.container-wide{width:100%;max-width:900px}.text-center{text-align:center}.btn{cursor:pointer;border:none;border-radius:24px;margin-top:.75rem;padding:.75rem 2rem;font-size:1rem;font-weight:500;transition:background .2s,box-shadow .2s;display:inline-block}.btn:disabled{opacity:.4;cursor:default}.btn-primary{color:#fff;background:#1a73e8}.btn-primary:hover:not(:disabled){background:#1557b0;box-shadow:0 1px 3px #0003}.btn-danger{color:#fff;background:#d93025}.btn-danger:hover{background:#b3261e}.btn-secondary{color:#202124;background:#e8eaed}.btn-secondary:hover{background:#dadce0}.btn-sm{padding:.5rem 1.5rem;font-size:.9rem}.btn-outline{color:#1a73e8;background:0 0;border:1px solid #dadce0}.btn-outline:hover{background:#e8f0fe}.card{background:#fff;border-radius:12px;margin-bottom:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.video-wrap{aspect-ratio:16/9;background:#000;border-radius:12px;width:100%;max-width:480px;margin:1rem auto;position:relative;overflow:hidden}.video-wrap video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.rec-dot{color:#fff;background:#d93025e6;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:700;animation:1s infinite pulse;position:absolute;top:12px;left:12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.timer-ring{width:120px;height:120px;margin:1.5rem auto;position:relative}.timer-ring svg{transform:rotate(-90deg)}.timer-track{fill:none;stroke:#e8eaed;stroke-width:8px}.timer-fill{fill:none;stroke:#1a73e8;stroke-width:8px;stroke-linecap:round;transition:stroke-dashoffset .95s linear}.timer-fill.recording{stroke:#d93025}.timer-text{justify-content:center;align-items:center;font-size:2rem;font-weight:600;display:flex;position:absolute;inset:0}.badge{color:#1a73e8;background:#e8f0fe;border-radius:16px;padding:.35rem 1rem;font-size:.85rem;font-weight:500;display:inline-block}.question-text{color:#202124;background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1rem;font-size:1.25rem;font-weight:500;box-shadow:0 1px 3px #0000001a}.hint{color:#80868b;font-size:.85rem}.status{border-radius:8px;margin:1rem 0;padding:.5rem 1rem;font-size:.9rem}.status.info{color:#174ea6;background:#e8f0fe}.status.success{color:#137333;background:#e6f4ea}.status.error{color:#c5221f;background:#fce8e6}.spinner{border:4px solid #e8eaed;border-top-color:#1a73e8;border-radius:50%;width:48px;height:48px;margin:2rem auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.checkmark{color:#137333;background:#e6f4ea;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:1.5rem auto;font-size:3rem;display:flex}.progress-grid{grid-template-columns:1fr repeat(3,60px);align-items:center;gap:.5rem;font-size:.9rem;display:grid}.progress-grid .header{color:#5f6368;font-weight:600}.dot{cursor:pointer;border-radius:50%;width:24px;height:24px;margin:0 auto;transition:transform .15s}.dot:hover{transform:scale(1.2)}.dot.done{background:#34a853}.dot.pending{background:#e8eaed}.input{border:1px solid #dadce0;border-radius:8px;outline:none;width:100%;margin-bottom:.75rem;padding:.6rem 1rem;font-family:inherit;font-size:.95rem}.input:focus{border-color:#1a73e8}.dropzone{text-align:center;cursor:pointer;border:2px dashed #dadce0;border-radius:12px;padding:2rem;transition:border-color .2s,background .2s}.dropzone:hover,.dropzone.dragover{background:#e8f0fe;border-color:#1a73e8}.assignment-item{cursor:pointer;border-bottom:1px solid #f1f3f4;justify-content:space-between;align-items:center;padding:1rem;transition:background .15s;display:flex}.assignment-item:hover{background:#f8f9fa}.assignment-item:last-child{border-bottom:none}.login-btn{cursor:pointer;background:#fff;border:1px solid #dadce0;border-radius:8px;align-items:center;gap:.75rem;width:100%;margin-bottom:.75rem;padding:.75rem 1.5rem;font-size:1rem;transition:background .15s,box-shadow .15s;display:flex}.login-btn:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.dots{justify-content:center;gap:.5rem;margin-top:1rem;display:flex}.dots .dot-sm{background:#dadce0;border-radius:50%;width:12px;height:12px}.dots .dot-sm.active{background:#1a73e8}.dots .dot-sm.done{background:#34a853}.modal-backdrop{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:90%;max-width:720px;max-height:90vh;padding:1.5rem;overflow:auto}.modal video{border-radius:8px;width:100%}@media (max-width:480px){.page-center{padding:1rem .5rem}h1{font-size:1.4rem}.video-wrap{max-width:100%}}
