@import"https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Inter:wght@400;500;600&display=swap";:root{--bg: #0F0F23;--bg-card: #1A1A35;--bg-card2: #141428;--purple: #7C3AED;--purple-l: #9B59F6;--gold: #F59E0B;--green: #10B981;--red: #EF4444;--text: #E8E8F0;--text-muted:#8888AA;--border: rgba(124,58,237,.25);--glow: 0 0 24px rgba(124,58,237,.35);--radius: 14px;--radius-sm: 8px;--font-display: "Sora", sans-serif;--font-body: "Inter", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;-webkit-font-smoothing:antialiased}.splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.splash-logo{font-size:3rem}.splash-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(ellipse at 60% 20%,rgba(124,58,237,.18) 0%,transparent 70%)}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:48px 40px;text-align:center;max-width:380px;width:90%;box-shadow:var(--glow)}.login-logo{font-size:3.5rem;margin-bottom:12px}.login-title{font-family:var(--font-display);font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--purple-l),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.login-subtitle{color:var(--text-muted);margin-bottom:32px;line-height:1.5}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px 20px;background:#fff;color:#333;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.btn-google:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000004d}.btn-google:disabled{opacity:.6;cursor:not-allowed}.login-hint{color:var(--text-muted);font-size:.78rem;margin-top:16px}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;max-width:800px;width:100%;margin:0 auto;padding:28px 16px 60px}.navbar{display:flex;align-items:center;gap:8px;padding:0 20px;height:60px;background:#1a1a35eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.navbar-brand{display:flex;align-items:center;gap:8px;cursor:pointer;margin-right:12px}.navbar-logo{font-size:1.4rem}.navbar-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--purple-l),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.navbar-links{display:flex;gap:4px;flex:1}.nav-link{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px 12px;border-radius:8px;font-size:.88rem;font-weight:500;transition:color .15s,background .15s}.nav-link.active,.nav-link:hover{color:var(--text);background:#7c3aed33}.navbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}.navbar-xp{display:flex;align-items:center;gap:8px}.navbar-level-icon{font-size:1.2rem}.navbar-xp-mini{display:flex;flex-direction:column;gap:3px}.navbar-xp-mini span{font-size:.75rem;color:var(--gold);font-weight:600}.navbar-xp-track{width:80px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.navbar-xp-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .6s ease}.navbar-user{display:flex;align-items:center;gap:6px}.navbar-avatar{width:30px;height:30px;border-radius:50%;border:2px solid var(--purple)}.btn-signout{background:none;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;width:28px;height:28px;border-radius:50%;font-size:.9rem;transition:color .15s}.btn-signout:hover{color:var(--red)}.home-page{display:flex;flex-direction:column;gap:28px}.home-hero{text-align:center;padding:20px 0 4px}.hero-title{font-family:var(--font-display);font-size:clamp(1.7rem,5vw,2.4rem);font-weight:800;line-height:1.2;margin-bottom:10px}.hero-accent{background:linear-gradient(135deg,var(--purple-l),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-sub{color:var(--text-muted);font-size:1rem}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--bg-card)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--purple);background:#7c3aed14}.drop-zone-icon{font-size:2.8rem;margin-bottom:12px}.drop-zone-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:6px}.drop-zone-sub{color:var(--text-muted);margin-bottom:6px}.drop-zone-hint{font-size:.78rem;color:var(--text-muted)}.upload-error{color:var(--red);margin-top:12px;font-size:.88rem;background:#ef44441a;padding:8px 12px;border-radius:var(--radius-sm)}.processing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.preview-img{width:100%;max-height:220px;object-fit:cover;display:block}.processing-info{padding:20px 24px}.processing-label{font-family:var(--font-display);font-size:1rem;font-weight:600;margin-bottom:12px;color:var(--purple-l)}.progress-bar-track{height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--gold));border-radius:4px;transition:width .4s ease;box-shadow:0 0 10px var(--purple)}.progress-pct{text-align:right;font-size:.8rem;color:var(--text-muted);margin-top:6px}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.summary-top{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:20px 20px 0}.summary-img{width:120px;height:90px;object-fit:cover;border-radius:var(--radius-sm)}.summary-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:10px;line-height:1.3}.summary-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-size:.75rem;padding:3px 9px;border:1px solid var(--border);border-radius:20px;color:var(--text-muted)}.tag-subject{border-color:var(--purple);color:var(--purple-l)}.summary-body{padding:20px}.summary-section-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;margin-top:16px}.summary-section-title:first-child{margin-top:0}.summary-text{color:var(--text-muted);line-height:1.65;font-size:.95rem}.key-points{list-style:none;display:flex;flex-direction:column;gap:6px}.key-point{display:flex;align-items:flex-start;gap:10px;font-size:.92rem;line-height:1.5;color:var(--text)}.key-point-dot{width:6px;height:6px;border-radius:50%;background:var(--purple);flex-shrink:0;margin-top:7px}.btn-start-quiz{display:block;width:calc(100% - 40px);margin:16px 20px 20px;padding:14px;text-align:center;background:linear-gradient(135deg,var(--purple),#5B21B6);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:1rem;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px #7c3aed66}.btn-start-quiz:hover{transform:translateY(-2px);box-shadow:0 6px 28px #7c3aed8c}.quiz-wrapper{display:flex;flex-direction:column;gap:16px}.quiz-header{display:flex;align-items:center;gap:12px}.quiz-progress-track{flex:1;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--purple);transition:width .4s ease}.quiz-counter{font-size:.82rem;color:var(--text-muted);white-space:nowrap}.question-card{background:var(--bg-card);border:1px solid rgba(124,58,237,.3);border-top:3px solid var(--type-color, var(--purple));border-radius:var(--radius);padding:22px;box-shadow:0 0 30px #7c3aed1f}.question-type-badge{display:flex;align-items:center;gap:6px;margin-bottom:16px}.question-type-badge span:first-child{font-size:1rem}.question-type-badge span:nth-child(2){font-size:.78rem;font-weight:600;color:var(--type-color, var(--purple-l));text-transform:uppercase;letter-spacing:.04em}.question-pts{margin-left:auto;font-size:.78rem;color:var(--gold);font-weight:600;background:#f59e0b1a;padding:2px 8px;border-radius:20px;border:1px solid rgba(245,158,11,.3)}.question-text{font-family:var(--font-display);font-size:1.05rem;font-weight:600;line-height:1.5;margin-bottom:18px}.options-grid{display:flex;flex-direction:column;gap:8px}.option{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;font-size:.93rem;color:var(--text);transition:border-color .15s,background .15s}.option:hover:not(:disabled){border-color:var(--purple);background:#7c3aed1a}.option.selected{border-color:var(--purple);background:#7c3aed26}.option.correct{border-color:var(--green);background:#10b98126;color:var(--green)}.option.wrong{border-color:var(--red);background:#ef44441f;color:var(--red)}.option-letter{width:26px;height:26px;flex-shrink:0;border-radius:50%;background:#ffffff12;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--text-muted)}.vf-row{display:flex;gap:12px}.vf-btn{flex:1;padding:16px;background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text);transition:border-color .15s,background .15s}.vf-btn:hover:not(:disabled){border-color:var(--purple);background:#7c3aed1a}.vf-btn.selected{border-color:var(--purple);background:#7c3aed33}.vf-btn.correct{border-color:var(--green);background:#10b98126}.vf-btn.wrong{border-color:var(--red);background:#ef44441f}.trous-text{line-height:1.8}.trous-blank{display:inline-block;min-width:80px}.correct-word{color:var(--green);font-weight:700}.wrong-word{color:var(--red);font-weight:700}.trous-input-row{display:flex;gap:8px;margin-top:16px;align-items:center}.trous-input{flex:1;padding:10px 14px;background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;transition:border-color .15s}.trous-input:focus{outline:none;border-color:var(--purple)}.hint-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;font-size:1rem}.hint-text{margin-top:8px;font-size:.85rem;color:var(--gold);font-style:italic}.submit-btn{padding:10px 18px;background:var(--purple);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:600;cursor:pointer;transition:opacity .15s}.submit-btn:disabled{opacity:.4;cursor:not-allowed}.submit-btn:hover:not(:disabled){opacity:.85}.feedback-box{margin-top:16px;padding:14px 16px;border-radius:var(--radius-sm);border-left:4px solid;animation:fadeIn .25s ease}.feedback-correct{border-color:var(--green);background:#10b9811a}.feedback-wrong{border-color:var(--red);background:#ef444414}.feedback-title{font-weight:700;font-size:.95rem;margin-bottom:6px}.feedback-correct .feedback-title{color:var(--green)}.feedback-wrong .feedback-title{color:var(--red)}.feedback-explanation{font-size:.88rem;color:var(--text-muted);margin-bottom:12px;line-height:1.5}.btn-next{padding:9px 18px;background:var(--purple);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:600;cursor:pointer;font-size:.9rem;transition:opacity .15s}.btn-next:hover{opacity:.85}.quiz-score-bar{text-align:right;font-size:.85rem;color:var(--text-muted);padding:4px 0}.quiz-score-bar strong{color:var(--gold)}.results-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:30px 24px;text-align:center}.results-stars{font-size:2rem;margin-bottom:10px}.results-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;margin-bottom:20px}.results-score-circle{display:inline-flex;flex-direction:column;align-items:center;width:120px;height:120px;border-radius:50%;border:4px solid var(--purple);justify-content:center;margin:0 auto 16px;box-shadow:0 0 30px #7c3aed4d}.results-score-pct{font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--purple-l)}.results-score-pts{font-size:.75rem;color:var(--text-muted)}.results-xp-gained{font-size:1rem;color:var(--gold);font-weight:700;margin-bottom:24px;animation:pulse .6s ease}.results-breakdown{text-align:left;display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.result-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);font-size:.85rem}.result-row.ok{background:#10b98114}.result-row.ko{background:#ef44440f}.result-q-text{flex:1;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-pts{color:var(--gold);font-weight:700;font-size:.8rem}.results-actions{display:flex;gap:12px;justify-content:center}.btn-retry,.btn-home{padding:11px 24px;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;font-size:.95rem;border:none}.btn-retry{background:var(--purple);color:#fff}.btn-home{background:var(--bg-card2);color:var(--text);border:1px solid var(--border)}.dashboard{display:flex;flex-direction:column;gap:24px}.dashboard-header{display:flex;align-items:center;gap:14px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.avatar{width:52px;height:52px;border-radius:50%;border:2px solid var(--purple)}.dashboard-name{font-family:var(--font-display);font-size:1.2rem;font-weight:700}.dashboard-sub{color:var(--text-muted);font-size:.88rem}.xp-bar-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.xp-level-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.xp-level-icon{font-size:1.5rem}.xp-level-info{flex:1;display:flex;flex-direction:column}.xp-level-name{font-weight:600;font-size:.9rem}.xp-total{color:var(--gold);font-size:.82rem;font-weight:600}.xp-next-label{font-size:.75rem;color:var(--text-muted);text-align:right}.xp-track{height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.xp-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--gold));border-radius:4px;transition:width .8s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 8px var(--gold)}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 12px;text-align:center;display:flex;flex-direction:column;gap:4px}.stat-icon{font-size:1.3rem}.stat-value{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--purple-l)}.stat-label{font-size:.72rem;color:var(--text-muted)}.section-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}.badge-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .15s}.badge-card.earned{border-color:var(--gold);box-shadow:0 0 12px #f59e0b33}.badge-card.locked{opacity:.4}.badge-card.earned:hover{transform:translateY(-2px)}.badge-icon{font-size:1.5rem}.badge-name{font-size:.7rem;color:var(--text-muted);text-align:center;line-height:1.3}.result-item{position:relative;overflow:hidden;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;padding:12px 14px}.result-item-bar{position:absolute;top:0;left:0;bottom:0;background:#7c3aed1a;transition:width .5s ease}.result-item-content{position:relative;display:flex;gap:12px;align-items:center}.result-item-pct{font-weight:700;color:var(--purple-l);min-width:40px}.result-item-score{flex:1;color:var(--text-muted);font-size:.88rem}.result-item-date{font-size:.78rem;color:var(--text-muted)}.empty-results{text-align:center;padding:30px;color:var(--text-muted)}.empty-hint{margin-top:6px;font-size:.88rem;color:var(--text-muted)}.loading-text{color:var(--text-muted);text-align:center;padding:20px}.xp-toast{position:fixed;bottom:28px;right:24px;background:linear-gradient(135deg,var(--purple),#5B21B6);color:#fff;padding:12px 20px;border-radius:40px;display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:1rem;font-weight:700;box-shadow:0 6px 24px #7c3aed80;animation:toastIn .3s ease,toastOut .3s ease 2.2s forwards;z-index:999}.xp-toast-icon{font-size:1.1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}@keyframes toastOut{to{opacity:0;transform:translateY(16px)}}@media(max-width:600px){.main-content{padding:16px 12px 48px}.stats-row{grid-template-columns:repeat(2,1fr)}.navbar-xp{display:none}.summary-top{grid-template-columns:1fr}.summary-img{width:100%;height:160px}.vf-row{flex-direction:column}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.course-list{display:flex;flex-direction:column;gap:20px}.course-list-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;display:flex;align-items:center;gap:10px}.course-count{background:var(--purple);color:#fff;font-size:.8rem;padding:2px 8px;border-radius:20px}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.course-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s}.course-card.clickable{cursor:pointer}.course-card.clickable:hover{transform:translateY(-3px);box-shadow:0 8px 28px #7c3aed40;border-color:var(--purple)}.course-card-img{width:100%;height:120px;object-fit:cover;display:block}.course-card-body{padding:12px 14px}.course-card-title{font-family:var(--font-display);font-size:.95rem;font-weight:600;margin-bottom:8px;line-height:1.3}.course-card-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.course-card-date{font-size:.75rem;color:var(--text-muted)}.course-delete-btn{position:absolute;top:8px;right:8px;background:#0009;border:none;border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:.85rem;opacity:0;transition:opacity .15s}.course-card:hover .course-delete-btn{opacity:1}.course-card-processing{padding:8px 14px;font-size:.8rem;color:var(--text-muted);background:#f59e0b14;border-top:1px solid var(--border)}.empty-courses{text-align:center;padding:60px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.empty-courses-icon{font-size:3rem;margin-bottom:12px}.empty-courses-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-bottom:8px}.empty-courses-sub{color:var(--text-muted)}.previews-grid{display:grid;gap:3px;max-height:200px;overflow:hidden}.previews-1{grid-template-columns:1fr}.previews-2{grid-template-columns:1fr 1fr}.previews-3{grid-template-columns:1fr 1fr 1fr}.previews-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.previews-5{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}.preview-thumb{width:100%;height:100px;object-fit:cover;display:block}.previews-1 .preview-thumb,.previews-2 .preview-thumb{height:200px}.processing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.processing-pages{font-size:.78rem;color:var(--gold);background:#f59e0b1a;padding:2px 8px;border-radius:20px;border:1px solid rgba(245,158,11,.3)}.processing-label{margin-bottom:0}.btn-reset{margin-top:12px;padding:8px 16px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:.88rem;transition:color .15s,border-color .15s}.btn-reset:hover{color:var(--text);border-color:var(--purple)}
