:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100%;overflow-x:hidden}#root{width:100%;margin:0;padding:0}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}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}}:root{--primary: #646cff;--primary-hover: #535bf2;--bg-dark: #f8fafc;--bg-card: rgba(255, 255, 255, .85);--border-color: rgba(0, 0, 0, .08);--text-primary: #0f172a;--text-secondary: #475569;--c1-color: #e53e3e;--c2-color: #dd6b20;--c3-color: #d69e2e;--c4-color: #38a169;--c5-color: #319795}body{margin:0;font-family:Outfit,Inter,system-ui,-apple-system,sans-serif;background-color:#f1f5f9;color:var(--text-primary);overflow-x:hidden}.app-container{width:100%;max-width:1300px;margin:0 auto;min-height:100vh;padding:1.5rem;box-sizing:border-box;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;background:#ffffff05;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-color);padding:.85rem 1.75rem;margin-bottom:1rem;border-radius:16px;box-shadow:0 4px 30px #0003}.header-brand{display:flex;align-items:center;gap:.65rem;font-size:1.35rem;font-weight:800;color:var(--primary);letter-spacing:-.5px}.header-title{background:linear-gradient(to right,#646cff,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.user-profile-menu{display:flex;align-items:center;gap:1rem}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-size:.85rem;font-weight:600;color:#fff}.user-email{font-size:.75rem;color:var(--text-secondary)}.user-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--primary);box-shadow:0 0 12px #646cff4d}.logout-btn{background-color:transparent;border:1px solid rgba(255,255,255,.15);color:#cbd5e0;padding:.35rem .75rem;font-size:.75rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background-color:#e53e3e1a;border-color:#f56565;color:#fc8181;transform:translateY(-1px)}.content-wrapper{display:grid;grid-template-columns:1.1fr 1fr;gap:1.5rem;flex:1;min-height:0}.content-wrapper.result-hidden{grid-template-columns:1fr}.btn-avaliar-redacao{background:linear-gradient(135deg,var(--primary) 0%,#535bf2 100%);color:#fff;border:none;padding:.6rem 1.4rem;font-size:.9rem;font-weight:600;border-radius:10px;cursor:pointer;box-shadow:0 4px 15px #646cff4d;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-avaliar-redacao:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #646cff80;background:linear-gradient(135deg,#747bff,#646cff)}.btn-avaliar-redacao:active:not(:disabled){transform:translateY(0)}.btn-avaliar-redacao:disabled{background:#ffffff14;color:#ffffff4d;box-shadow:none;cursor:not-allowed}.input-section{display:flex;flex-direction:column;gap:1rem}.textarea-container{display:flex;flex-direction:column;flex:1;background:#ffffff05;border:1px solid var(--border-color);border-radius:16px;overflow:hidden;box-shadow:0 10px 30px #00000026;transition:border-color .25s ease,box-shadow .25s ease;min-height:750px;height:auto}.textarea-container:focus-within{border-color:#646cff66;box-shadow:0 10px 30px #646cff14}.essay-textarea{width:100%;flex:1;padding:1.5rem 1.5rem 1.5rem 1rem;font-size:1.05rem;line-height:1.65rem;background:#ffffff05 linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:100% 1.65rem;background-attachment:local;color:#fff;border:none;border-left:2px solid rgba(245,101,101,.25)!important;resize:none;overflow-y:hidden;font-family:Inter,system-ui,sans-serif;box-sizing:border-box;outline:none}.essay-textarea::placeholder{color:#ffffff40;font-style:italic}.essay-editor-wrapper{display:flex;flex:1;width:100%;position:relative}.line-numbers-sidebar{display:flex;flex-direction:column;padding:1.5rem 0;text-align:center;font-family:Inter,system-ui,sans-serif;font-size:.8rem;color:var(--text-secondary);opacity:.65;width:45px;flex-shrink:0;-webkit-user-select:none;user-select:none;box-sizing:border-box}.line-number-item{height:1.65rem;line-height:1.65rem;font-weight:600}.textarea-footer{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.5rem;background:#0003;border-top:1px solid var(--border-color);font-size:.85rem;position:sticky;bottom:0;z-index:10;box-shadow:0 -4px 15px #00000026}.metrics{display:flex;gap:1rem}.metric-badge{background:#ffffff0d;padding:.35rem .75rem;border-radius:8px;border:1px solid rgba(255,255,255,.05);color:#cbd5e0}.metric-badge strong{color:var(--primary);font-size:.95rem}.metric-badge.warning{border-color:#e53e3e66;background:#e53e3e0d}.metric-badge.warning strong{color:#f56565}.error-note{color:#f56565;font-size:.8rem;font-weight:500;animation:fadeIn .3s ease}.result-container{background:#ffffff05;border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;box-shadow:0 10px 30px #00000026;overflow-y:auto;max-height:calc(100vh - 8rem)}.empty-result{height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:3rem 1.5rem;box-sizing:border-box}.empty-state-icon{font-size:3.5rem;margin-bottom:1rem;animation:float 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-result h3{font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:.5rem}.empty-result p{color:var(--text-secondary);max-width:320px;line-height:1.5;margin:0}.scoreboard-container{background:linear-gradient(135deg,#1f173d4d,#0f0c1b4d);border:1px solid rgba(100,108,255,.15);border-radius:16px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;position:relative;box-shadow:0 8px 32px #0000001a}.scoreboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.scoreboard-header h3{font-size:1.1rem;font-weight:700;color:#fff;margin:0;letter-spacing:-.2px}.nota-final{font-size:.85rem;color:var(--text-secondary)}.nota-final strong{font-size:1.4rem;color:#fff;background:linear-gradient(to right,#646cff,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.radial-progress-bar{display:flex;justify-content:center;align-items:center;margin:.5rem 0 1.25rem}.circular-chart{display:block;margin:10px auto;max-width:130px;max-height:130px}.circle-bg{fill:none;stroke:#ffffff0d;stroke-width:2.8}.circle{fill:none;stroke:var(--primary);stroke-width:2.8;stroke-linecap:round;transition:stroke-dasharray .8s ease-in-out}.circular-chart.blue .circle{stroke:url(#blueGradient)}.circular-chart .circle{stroke:#646cff}.percentage{fill:#fff;font-family:Outfit,sans-serif;font-size:7.5px;font-weight:800;text-anchor:middle}.competencias-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;border-top:1px solid rgba(255,255,255,.06);padding-top:1rem}.competencia-mini-card{display:flex;flex-direction:column;align-items:center;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:.5rem .25rem;position:relative}.comp-label{font-size:.7rem;font-weight:700;color:var(--text-secondary);margin-bottom:.35rem}.progress-track{width:80%;height:4px;background:#ffffff14;border-radius:20px;overflow:hidden;margin-bottom:.35rem}.progress-fill{height:100%;background:var(--primary);border-radius:20px;transition:width .6s ease}.competencia-mini-card:nth-child(1) .progress-fill{background-color:var(--c1-color)}.competencia-mini-card:nth-child(2) .progress-fill{background-color:var(--c2-color)}.competencia-mini-card:nth-child(3) .progress-fill{background-color:var(--c3-color)}.competencia-mini-card:nth-child(4) .progress-fill{background-color:var(--c4-color)}.competencia-mini-card:nth-child(5) .progress-fill{background-color:var(--c5-color)}.comp-nota{font-size:.85rem;font-weight:700;color:#fff}.ai-status-bar{display:flex;align-items:center;gap:.5rem;background:#38b2ac14;border:1px solid rgba(56,178,172,.25);color:#38b2ac;padding:.65rem 1rem;border-radius:10px;font-size:.8rem;font-weight:500;margin-bottom:1rem}.ai-status-bar.warn{background:#e5893614;border-color:#e5893640;color:#ed8936}.ai-indicator{width:8px;height:8px;background:#38b2ac;border-radius:50%;display:inline-block;box-shadow:0 0 8px #38b2ac;animation:pulse-dot 1.8s infinite}.ai-status-bar.warn .ai-indicator{background:#ed8936;box-shadow:0 0 8px #ed8936}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}}.ai-analysis-button-container{margin-bottom:1.25rem}.ai-analysis-button{width:100%;background:linear-gradient(135deg,#646cff,#7c3aed);color:#fff;border:none;padding:.85rem;border-radius:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 15px #646cff40}.ai-analysis-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #646cff59;background:linear-gradient(135deg,#7c3aed,#646cff)}.ai-analysis-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.competencias-tabs-container{background:#ffffff03;border:1px solid var(--border-color);border-radius:16px;overflow:hidden;margin-bottom:1.5rem}.tabs-header{display:grid;grid-template-columns:repeat(5,1fr);background:#00000026;border-bottom:1px solid var(--border-color)}.tab-btn{background:transparent;border:none;color:var(--text-secondary);padding:.85rem;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;outline:none}.tab-btn:hover{background:#ffffff05;color:#fff}.tab-btn.active{background:#ffffff0a;color:#fff;position:relative}.tab-btn.active:after{content:"";position:absolute;bottom:0;left:15%;width:70%;height:3px;border-radius:10px}.tab-btn:nth-child(1).active:after{background-color:var(--c1-color)}.tab-btn:nth-child(2).active:after{background-color:var(--c2-color)}.tab-btn:nth-child(3).active:after{background-color:var(--c3-color)}.tab-btn:nth-child(4).active:after{background-color:var(--c4-color)}.tab-btn:nth-child(5).active:after{background-color:var(--c5-color)}.tab-content{padding:1.25rem}.tab-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.tab-panel-header h4{font-size:.95rem;font-weight:700;color:#fff;margin:0}.tab-panel-score{font-size:.9rem;font-weight:800;background:#ffffff0d;padding:.25rem .65rem;border-radius:8px;color:#fff}.comp-description{font-size:.8rem;color:var(--text-secondary);line-height:1.5;margin:0 0 1rem}.matches-list{display:flex;flex-direction:column;gap:.85rem;margin-top:1rem}.matches-list h5{font-size:.85rem;color:#fff;margin:0}.error-item-card{background:#ffffff05;border:1px solid rgba(245,101,101,.15);border-left:4px solid var(--c1-color);border-radius:12px;padding:.85rem 1rem;box-shadow:0 4px 12px #0000000d;transition:all .2s ease}.error-item-card:hover{transform:translate(2px);border-color:#f565654d}.error-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.error-snippet{font-weight:700;color:var(--c1-color);font-style:italic;font-size:.85rem}.btn-ignore-err{background:transparent;border:none;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:color .2s}.btn-ignore-err:hover{color:#fff;text-decoration:underline}.error-explain-msg{font-size:.8rem;color:#fff;margin:0 0 .5rem;line-height:1.4}.ai-explain-box{background:#38b2ac0d;border-left:2px solid var(--c5-color);padding:.5rem .75rem;border-radius:4px;font-size:.75rem;color:#cbd5e0;line-height:1.4;margin:0 0 .75rem}.error-sug-list{display:flex;flex-direction:column;gap:.35rem}.error-sug-list span{font-size:.7rem;color:var(--text-secondary);font-weight:600}.sug-chips{display:flex;flex-wrap:wrap;gap:.5rem}.sug-chip{background:#48bb7814;border:1px solid rgba(72,187,120,.2);color:#48bb78;padding:.25rem .65rem;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.sug-chip:hover{background:#48bb7826;border-color:#48bb7866;transform:translateY(-1px)}.success-banner-c1{background:#48bb7814;border:1px solid rgba(72,187,120,.2);color:#48bb78;padding:.75rem;border-radius:10px;text-align:center;font-size:.8rem;font-weight:600}.ai-feedback-block{background:#ffffff03;border:1px solid var(--border-color);border-radius:12px;padding:.85rem 1rem;margin-bottom:.85rem}.ai-feedback-block h5{font-size:.85rem;color:#fff;margin:0 0 .5rem}.ai-feedback-block ul{margin:0;padding-left:1.25rem}.ai-feedback-block li{font-size:.8rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.35rem}.ai-text-box{font-size:.8rem;color:var(--text-secondary);line-height:1.5;margin:0}.structural-note{font-size:.75rem;color:var(--text-secondary);background:#ffffff05;padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border-color);line-height:1.4;margin-top:1rem}.checklist-container{background:#0000001a;border:1px solid var(--border-color);border-radius:12px;padding:.85rem 1rem;margin-top:1rem}.checklist-container h5{font-size:.85rem;color:#fff;margin:0 0 .75rem}.checklist-grid{display:flex;flex-direction:column;gap:.65rem}.checklist-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:8px;background:#ffffff05;border:1px solid var(--border-color);transition:all .25s ease}.checklist-item.checked{background:#48bb7808;border-color:#48bb7826}.checklist-item.missing{background:#ffffff03;border-color:#ffffff0a;opacity:.6}.check-icon{width:20px;height:20px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:.75rem;font-weight:700}.checked .check-icon{background:#48bb781a;color:#48bb78}.missing .check-icon{background:#ffffff0d;color:var(--text-secondary)}.check-details{display:flex;flex-direction:column}.check-details strong{font-size:.8rem;color:#fff}.checked .check-details strong{color:#48bb78}.check-details span{font-size:.7rem;color:var(--text-secondary)}.sti-recommendation-box{background:linear-gradient(135deg,#646cff0f,#7c3aed0f);border:1px solid rgba(100,108,255,.25);border-radius:12px;padding:1rem;margin-top:1.25rem}.sti-header{display:flex;align-items:center;gap:.5rem;color:#a855f7;font-size:.85rem;font-weight:700;margin-bottom:.5rem}.sti-recommendation-box h5{font-size:.9rem;color:#fff;margin:0 0 .35rem}.sti-recommendation-box p{font-size:.75rem;color:var(--text-secondary);line-height:1.4;margin:0 0 .75rem}.sti-content{background:#00000040;border-left:2px solid #a855f7;padding:.65rem .85rem;border-radius:6px;font-size:.75rem;color:#cbd5e0;line-height:1.4}.exemplos-melhoria-section{border-top:1px solid var(--border-color);padding-top:1.25rem;margin-top:1.25rem}.exemplos-melhoria-section h4{font-size:.95rem;font-weight:700;color:#fff;margin:0 0 .85rem}.exemplo-card{background:#ffffff03;border:1px solid var(--border-color);border-radius:12px;padding:.85rem;margin-bottom:.85rem}.exemplo-row{margin-bottom:.5rem}.exemplo-row p{margin:.25rem 0 0;font-size:.8rem;line-height:1.4}.exemplo-row.problem .label-err{font-size:.7rem;color:var(--c1-color)}.exemplo-row.problem p{color:#e53e3e;font-style:italic}.exemplo-row.success .label-ok{font-size:.7rem;color:#48bb78}.exemplo-row.success p{color:#48bb78;font-weight:500}.exemplo-explain{font-size:.75rem;color:var(--text-secondary);background:#ffffff05;padding:.5rem;border-radius:6px;line-height:1.4}.pulse-spinner{width:28px;height:28px;border-radius:50%;background-color:var(--primary);opacity:.7;margin:0 auto .75rem;animation:pulse-scale 1.2s infinite ease-in-out}@keyframes pulse-scale{0%{transform:scale(0)}to{transform:scale(1);opacity:0}}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;margin:0 auto;animation:spin .8s linear infinite}@media(max-width:960px){.content-wrapper{grid-template-columns:1fr}.result-container{max-height:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.profile-selector{display:flex;background:#ffffff08;padding:.25rem;border-radius:10px;border:1px solid var(--border-color);margin-right:1rem}.profile-btn{background:transparent;border:none;color:var(--text-secondary);padding:.45rem 1rem;font-size:.8rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease}.profile-btn:hover{color:#fff}.profile-btn.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #646cff66}.teacher-view-container{gap:1.75rem}.teacher-input-panel{background:#ffffff03;border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;box-shadow:0 10px 30px #00000026;box-sizing:border-box}.section-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;border-bottom:1px solid var(--border-color);padding-bottom:.75rem}.section-header-row h3{margin:0;font-size:1.25rem;font-weight:700;color:#fff}.offline-control{display:flex;align-items:center}.offline-toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);cursor:pointer}.offline-toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.offline-warning-banner{background:#ecc94b1a;border:1px solid rgba(236,201,75,.25);color:#ecc94b;padding:.75rem 1rem;border-radius:10px;font-size:.75rem;font-weight:500;line-height:1.4;margin-bottom:1.25rem;animation:fadeIn .3s ease}.teacher-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.teacher-form .tema-select,.teacher-form .custom-tema-input{background:#0003;border:1px solid var(--border-color);color:#fff;padding:.75rem 1rem;border-radius:10px;font-size:.9rem;outline:none;transition:all .2s;width:100%;box-sizing:border-box}.teacher-form .tema-select:focus,.teacher-form .custom-tema-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #646cff26}.camera-upload-btn-container{display:flex;width:100%}.hidden-file-input{display:none}.camera-label-btn{display:flex;justify-content:center;align-items:center;gap:.5rem;background:#ffffff0a;border:1.5px dashed var(--border-color);color:#fff;padding:1rem;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;text-align:center}.camera-label-btn:hover{background:#646cff0d;border-color:var(--primary);color:var(--primary)}.image-preview-box{display:flex;flex-direction:column;align-items:center;background:#00000040;border:1px solid var(--border-color);border-radius:12px;padding:.75rem;gap:.5rem;margin-top:.5rem}.form-image-preview{max-width:100%;max-height:180px;border-radius:8px;object-fit:contain}.image-preview-label{font-size:.7rem;color:#48bb78;font-weight:600}.ocr-template-selector{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.template-chips{display:flex;gap:.5rem}.template-chip-btn{flex:1;background:#ffffff08;border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem;border-radius:8px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.template-chip-btn:hover{background:#ffffff0f;color:#fff}.template-chip-btn.active{background:var(--primary-hover);border-color:var(--primary);color:#fff;box-shadow:0 2px 6px #646cff33}.teacher-textarea{min-height:120px!important}.teacher-submit-btn{margin-top:.5rem}.offline-queue-card{margin-top:1.5rem;background:#ffffff05;border:1px solid var(--border-color);border-radius:12px;padding:1rem}.offline-queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.offline-queue-header h4{margin:0;font-size:.85rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.sync-now-btn{background:#38b2ac;color:#fff;border:none;padding:.35rem .75rem;font-size:.75rem;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s}.sync-now-btn:hover{background:#319795;transform:translateY(-1px)}.offline-items-list{display:flex;flex-direction:column;gap:.5rem;max-height:150px;overflow-y:auto}.offline-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;border-radius:8px;background:#0003;border:1px solid var(--border-color)}.offline-item-info{display:flex;flex-direction:column;gap:.15rem}.offline-item-info strong{font-size:.8rem;color:#fff}.offline-item-meta{font-size:.7rem;color:var(--text-secondary)}.offline-badge{background:#ecc94b1a;border:1px solid rgba(236,201,75,.2);color:#ecc94b;font-size:.65rem;font-weight:700;padding:.2rem .5rem;border-radius:4px}.teacher-dashboard-panel{display:flex;flex-direction:column;gap:1.5rem}.dashboard-filters{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;background:#00000026;padding:1rem;border-radius:12px;border:1px solid var(--border-color);margin-bottom:.5rem}.dashboard-filters .filter-group{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:140px}.dashboard-filters .filter-group label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase}.dashboard-filters .tema-select{background:#ffffff08;border:1px solid var(--border-color);color:#fff;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;outline:none;cursor:pointer;width:100%}.print-report-btn{background:#ffffff0d;border:1px solid var(--border-color);color:#fff;padding:.55rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.4rem;height:fit-content}.print-report-btn:hover{background:#ffffff1a;border-color:#fff}.teacher-analytics-content{display:flex;flex-direction:column;gap:1.5rem}.metrics-cards-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:1.25rem}.metric-score-card{background:linear-gradient(135deg,#646cff0d,#0000);border:1px solid rgba(100,108,255,.15);border-radius:14px;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between;gap:.75rem;box-shadow:0 4px 15px #0000001a}.metric-score-card.dist-card{background:#ffffff03;border-color:var(--border-color)}.card-lbl{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.card-val{font-size:2.25rem;font-weight:800;background:linear-gradient(to right,#646cff,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.mini-bar{width:100%;height:6px;background:#ffffff14;border-radius:10px;overflow:hidden}.mini-fill{height:100%;background:linear-gradient(to right,#646cff,#a855f7);border-radius:10px}.dist-item{display:flex;align-items:center;font-size:.8rem;color:var(--text-secondary);gap:.5rem}.dist-item strong{color:#fff;margin-left:auto;font-size:.85rem}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot.green{background-color:var(--c4-color);box-shadow:0 0 6px var(--c4-color)}.dot.yellow{background-color:var(--c3-color);box-shadow:0 0 6px var(--c3-color)}.dot.red{background-color:var(--c1-color);box-shadow:0 0 6px var(--c1-color)}.competencies-aggregates-card{background:#ffffff03;border:1px solid var(--border-color);border-radius:14px;padding:1.25rem}.competencies-aggregates-card h4{margin:0 0 1rem;font-size:.95rem;font-weight:700;color:#fff}.teacher-comp-grid{border-top:none;padding-top:0}.teacher-comp-grid .competencia-mini-card{padding:.75rem .5rem}.student-grades-list-section{display:flex;flex-direction:column;gap:.85rem}.student-grades-list-section h4{margin:0;font-size:.95rem;font-weight:700;color:#fff}.student-table-container{overflow-x:auto;border:1px solid var(--border-color);border-radius:12px;background:#0000001a}.student-grades-table{width:100%;border-collapse:collapse;text-align:left;font-size:.85rem}.student-grades-table th{background:#ffffff05;border-bottom:1px solid var(--border-color);padding:.75rem 1rem;color:var(--text-secondary);font-weight:700;font-size:.75rem;text-transform:uppercase}.student-grades-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);color:#cbd5e0}.student-row:last-child td{border-bottom:none}.student-row:hover{background:#ffffff03}.student-theme-cell{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.8rem;color:var(--text-secondary)}.table-grade-badge{background:#646cff1a;border:1px solid rgba(100,108,255,.2);color:var(--primary-hover);padding:.25rem .5rem;border-radius:6px;font-weight:700;font-size:.8rem}.actions-cell{display:flex;gap:.5rem}.table-view-btn{margin:0;padding:.35rem .65rem;background:#38b2ac14;border-color:#38b2ac33;color:#38b2ac}.table-view-btn:hover{background:#38b2ac26;border-color:#38b2ac66}.table-delete-btn{margin:0;padding:.35rem .65rem;background:#e5656514;border:1px solid rgba(229,101,101,.2);color:#f56565;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.table-delete-btn:hover{background:#e5656526;border-color:#e5656566;transform:translateY(-1px)}.preview-essay-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}.preview-essay-modal{width:90%;max-width:680px;background:#0f0c1b;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 20px 50px #00000080;overflow:hidden;display:flex;flex-direction:column;max-height:85vh}.preview-essay-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#ffffff05;border-bottom:1px solid var(--border-color)}.preview-essay-modal .modal-header h3{margin:0;font-size:1.1rem;font-weight:700;color:#fff}.preview-essay-modal .modal-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:.85rem}.modal-meta-row{font-size:.8rem;color:var(--text-secondary);margin:0}.modal-meta-row strong{color:#fff}.modal-grades-summary{display:flex;flex-direction:column;background:#646cff0d;border:1px solid rgba(100,108,255,.15);padding:.85rem 1.25rem;border-radius:10px;gap:.25rem;margin:.5rem 0}.modal-grades-summary strong{font-size:1.05rem;color:#fff}.modal-subgrades{font-size:.75rem;color:var(--text-secondary);letter-spacing:.5px}.essay-content-preview-box{background:#ffffff05 linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:100% 1.65rem;background-attachment:local;border:1px solid var(--border-color);border-left:2px solid rgba(245,101,101,.25)!important;padding:1.5rem 1.5rem 1.5rem 2.5rem;border-radius:12px;font-family:Inter,system-ui,sans-serif;line-height:1.65rem;font-size:1.05rem;color:#e2e8f0;max-height:300px;overflow-y:auto}.preview-essay-paragraph{margin:0 0 1.65rem;text-indent:2.5rem}.preview-essay-paragraph:last-child{margin-bottom:0}.print-only{display:none}@media print{.no-print,.app-header,.profile-selector,.user-profile-menu,.teacher-input-panel,.dashboard-filters,.actions-cell,th.no-print,td.no-print{display:none!important}.print-only{display:block!important}body{background:#fff!important;color:#000!important;font-family:Inter,system-ui,-apple-system,sans-serif!important;padding:0!important;margin:0!important}.app-container{padding:0!important;max-width:100%!important}.content-wrapper{display:block!important}.teacher-dashboard-panel{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important;max-height:none!important}.print-header{border-bottom:2px solid #000!important;padding-bottom:1rem!important;margin-bottom:1.5rem!important}.print-header h2{margin:0 0 .5rem!important;color:#000!important;font-size:1.5rem!important}.print-header p{margin:.25rem 0!important;font-size:.85rem!important;color:#333!important}.metrics-cards-grid{grid-template-columns:1fr 1fr!important;gap:1rem!important;margin-bottom:1.5rem!important}.metric-score-card{background:#f7fafc!important;border:1px solid #e2e8f0!important;color:#000!important;box-shadow:none!important;padding:1rem!important;border-radius:8px!important}.card-lbl{color:#4a5568!important;font-size:.75rem!important}.card-val{background:none!important;-webkit-text-fill-color:initial!important;color:#2b6cb0!important;font-size:2rem!important}.mini-bar{background:#edf2f7!important}.mini-fill{background:#2b6cb0!important}.dist-item{color:#2d3748!important}.dist-item strong{color:#000!important}.dot{border:1px solid #718096!important;box-shadow:none!important}.competencies-aggregates-card{background:#f7fafc!important;border:1px solid #e2e8f0!important;padding:1rem!important;border-radius:8px!important;margin-bottom:1.5rem!important;page-break-inside:avoid}.competencies-aggregates-card h4{color:#000!important;font-size:.9rem!important;border-bottom:1px solid #e2e8f0!important;padding-bottom:.5rem!important}.competencia-mini-card{background:#fff!important;border:1px solid #e2e8f0!important;color:#000!important}.comp-label{color:#4a5568!important}.comp-nota{color:#000!important}.progress-track{background:#edf2f7!important}.student-grades-list-section{page-break-inside:auto}.student-grades-list-section h4{color:#000!important;margin-bottom:.5rem!important}.student-table-container{border:1px solid #cbd5e0!important;background:#fff!important;border-radius:0!important}.student-grades-table{font-size:.8rem!important}.student-grades-table th{background:#edf2f7!important;border-bottom:2px solid #cbd5e0!important;color:#2d3748!important;padding:.5rem!important}.student-grades-table td{border-bottom:1px solid #e2e8f0!important;color:#000!important;padding:.5rem!important}.student-theme-cell{color:#4a5568!important;max-width:none!important;white-space:normal!important;overflow:visible!important;text-overflow:clip!important}.table-grade-badge{background:none!important;border:none!important;color:#000!important;padding:0!important;font-weight:700!important}}body{background-color:#f1f5f9;color:var(--text-primary)}.app-header{background:#ffffffd9;box-shadow:0 4px 20px #0000000a}.header-brand{color:var(--primary)}.user-name{color:var(--text-primary)}.logout-btn{border:1px solid rgba(0,0,0,.15);color:var(--text-secondary)}.logout-btn:hover{background-color:#e53e3e14;border-color:#e53e3e;color:#e53e3e}.textarea-container{background:#fff;box-shadow:0 1px 3px #3c404326,0 4px 8px 3px #3c40431a!important;border:1px solid rgba(0,0,0,.08)!important}.essay-textarea{background:#00000001 linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:100% 1.65rem;background-attachment:local;color:var(--text-primary);border-left:2px solid rgba(229,62,62,.2)!important}.essay-textarea::placeholder{color:#00000059}.textarea-footer{background:#f8fafc;color:var(--text-secondary)}.metric-badge{background:#f1f5f9;border:1px solid rgba(0,0,0,.06);color:var(--text-secondary)}.result-container{background:#fff;box-shadow:0 10px 30px #0000000a}.empty-result h3{color:var(--text-primary)}.scoreboard-container{background:linear-gradient(135deg,#f8fafc,#edf2f7);border:1px solid rgba(100,108,255,.15);box-shadow:0 8px 24px #646cff0a}.scoreboard-header h3{color:var(--text-primary)}.percentage{fill:var(--text-primary)}.circle-bg{stroke:#0000000a}.competencia-mini-card{background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 2px 8px #00000005}.comp-nota{color:var(--text-primary)}.progress-track{background:#0000000f}.tab-btn{background:#fff;border:1px solid rgba(0,0,0,.06);color:var(--text-secondary)}.tab-btn:hover{background:#f8fafc;color:var(--text-primary)}.tab-btn.active{background:#f1f5f9;color:var(--text-primary);border-color:#0000001a}.pilula-box{background:#fff;border:1px solid rgba(0,0,0,.06)}.pilula-title,.panel-header h3{color:var(--text-primary)}.panel-header-desc{color:var(--text-secondary)}.panel-section{background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 12px #00000005}.panel-section h4,.form-label{color:var(--text-primary)}.form-select,.form-input,.textarea-simple{background:#fff;border:1px solid rgba(0,0,0,.12);color:var(--text-primary)}.form-select:focus,.form-input:focus,.textarea-simple:focus{border-color:var(--primary);box-shadow:0 0 0 3px #646cff26}.stats-card{background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 12px #00000005}.stats-value{color:var(--text-primary)}.stats-label{color:var(--text-secondary)}.progress-bar-bg{background:#0000000f}.student-grades-list-section h4{color:var(--text-primary)}.student-table-container{background:#fff;border:1px solid rgba(0,0,0,.08)}.student-grades-table th{background:#f8fafc;color:var(--text-secondary)}.student-grades-table td{color:var(--text-primary)}.student-row:hover{background:#00000005}.preview-essay-overlay{background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-essay-modal{background:#fff;color:var(--text-primary);box-shadow:0 10px 40px #0000001f}.modal-header h3{color:var(--text-primary)}.essay-content-preview-box{background:#00000001 linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:100% 1.65rem;color:var(--text-primary);border-left:2px solid rgba(229,62,62,.2)}.c5-badge-validator{background:#f0fdf4;border:1px solid #bbf7d0}.validator-title{color:#166534}.element-item{background:#fff;border:1px solid rgba(0,0,0,.06)}.element-name{color:var(--text-primary)}.feedback-bubble{background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 4px 15px #0000000a}.feedback-bubble.c1{border-left:4px solid var(--c1-color)}.feedback-bubble.c2{border-left:4px solid var(--c2-color)}.feedback-bubble.c3{border-left:4px solid var(--c3-color)}.feedback-bubble.c4{border-left:4px solid var(--c4-color)}.feedback-bubble.c5{border-left:4px solid var(--c5-color)}.feedback-title{color:var(--text-primary)}.feedback-text{color:var(--text-secondary)}.suggestions-card{background:#fff;border:1px solid rgba(0,0,0,.06)}.suggestions-card h4{color:var(--text-primary)}.suggestion-item{border-left:3px solid var(--primary)}.suggestion-text{color:var(--text-primary)}.ocr-guide-box{background:#edf2f7;border-left:4px solid var(--primary);color:var(--text-primary)}.ocr-guide-box strong{color:var(--text-primary)}.profile-selector{background:#0000000a}.profile-selector .selector-btn.active{background:#fff;color:var(--primary);box-shadow:0 2px 8px #00000014}.login-screen{display:flex;min-height:100vh;width:100vw;margin:0;padding:0;box-sizing:border-box;background:#fff;overflow:hidden;font-family:Outfit,Inter,system-ui,sans-serif;position:fixed;inset:0;z-index:9999}.login-visual{flex:1.25;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:5rem;background:linear-gradient(135deg,#4f46e5,#6366f1,#818cf8);color:#fff;position:relative;overflow:hidden;box-sizing:border-box}.login-visual:before{content:"";position:absolute;top:-20%;left:-20%;width:70%;height:70%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%;filter:blur(60px);pointer-events:none}.login-visual:after{content:"";position:absolute;bottom:-20%;right:-20%;width:70%;height:70%;background:radial-gradient(circle,rgba(99,102,241,.45) 0%,transparent 70%);border-radius:50%;filter:blur(60px);pointer-events:none}.login-visual-content{max-width:520px;display:flex;flex-direction:column;gap:2.25rem;z-index:2;text-align:left}.login-visual-content .brand-logo{display:flex;align-items:center;gap:.75rem;font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:-.5px}.login-visual-content h1{font-size:2.85rem;font-weight:800;line-height:1.15;color:#fff!important;letter-spacing:-1px;margin:0}.login-visual-content p{font-size:1.15rem;line-height:1.6;color:#ffffffe0!important;margin:0}.features-bullets{display:flex;flex-direction:column;gap:1.25rem;margin-top:.5rem}.bullet-item{display:flex;align-items:center;gap:1rem;font-size:1.05rem;font-weight:600;color:#fff!important}.bullet-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);font-size:1.1rem;color:#fff!important;flex-shrink:0}.login-form-area{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem;background:#f8fafc;box-sizing:border-box}.login-card{width:100%;max-width:420px;background:#fff;padding:3rem;border-radius:24px;box-shadow:0 20px 40px #0f172a0d;border:1px solid rgba(0,0,0,.04);display:flex;flex-direction:column;align-items:stretch;text-align:left;box-sizing:border-box}.login-card h2{font-size:2rem;font-weight:800;color:#0f172a!important;margin:0 0 .5rem;letter-spacing:-.5px}.login-card .card-subtitle{font-size:.95rem;color:#64748b!important;margin:0 0 2.5rem;line-height:1.5}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:1rem;width:100%;padding:.9rem 1.5rem;font-size:1rem;font-weight:700;color:#0f172a!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000005}.google-login-btn:hover{border-color:#cbd5e1!important;background:#f8fafc!important;transform:translateY(-1px);box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #0000000d}.google-login-btn:active{transform:translateY(0)}.privacy-terms{margin:2.25rem 0 0;font-size:.8rem;color:#94a3b8!important;line-height:1.5;text-align:center}.privacy-terms a{color:#6366f1!important;text-decoration:none;font-weight:600}.privacy-terms a:hover{text-decoration:underline}@media(max-width:992px){.login-screen{flex-direction:column;position:relative;overflow:auto}.login-visual{flex:none;padding:3rem 2rem;align-items:center;text-align:center}.login-visual-content{align-items:center;text-align:center;gap:1.5rem}.login-visual-content h1{font-size:2.2rem}.features-bullets{display:none}.login-form-area{flex:1;padding:2.5rem 1.5rem;background:#fff}.login-card{padding:2rem;box-shadow:none;border:none}}.tema-selector-container{display:flex;flex-direction:column;gap:.6rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:1.25rem 1.5rem;box-shadow:0 4px 20px #00000005;margin-bottom:.5rem;transition:all .3s ease}.tema-selector-container:focus-within{border-color:#646cff40;box-shadow:0 4px 20px #646cff0f}.tema-label{font-size:.85rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.tema-select{width:100%;padding:.85rem 2.5rem .85rem 1.25rem;font-size:.95rem;font-family:Outfit,Inter,sans-serif;color:var(--text-primary);background-color:#f8fafc;border:1px solid rgba(0,0,0,.08);border-radius:12px;cursor:pointer;outline:none;transition:all .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23646cff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.25rem center;background-size:1.15rem}.tema-select:hover{background-color:#f1f5f9;border-color:#646cff33}.tema-select:focus{background-color:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #646cff1f}.custom-tema-input{width:100%;padding:.85rem 1.25rem;font-size:.95rem;font-family:Outfit,Inter,sans-serif;color:var(--text-primary);background-color:#f8fafc;border:1px solid rgba(0,0,0,.08);border-radius:12px;outline:none;transition:all .2s ease;box-sizing:border-box;margin-top:.5rem}.custom-tema-input:hover{background-color:#f1f5f9}.custom-tema-input:focus{background-color:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #646cff1f}.activity-banner{background:linear-gradient(135deg,#f0f7ff,#e0f2fe);border:1px solid #bae6fd;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 15px #00000008;animation:fadeIn .3s ease}.activity-banner-content{display:flex;flex-direction:column;gap:.5rem;flex:1}.activity-badge{display:inline-block;background:#bae6fd;color:#0369a1;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700;width:fit-content;text-transform:uppercase;letter-spacing:.5px}.activity-theme-title{margin:0;font-size:1.15rem;font-weight:800;color:#0f172a}.activity-details-row{display:flex;gap:1.5rem;font-size:.85rem;color:#475569}.activity-details-row strong{color:#1e293b}.student-name-input-row{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem;max-width:400px}.student-name-input-row label{font-size:.8rem;font-weight:700;color:#475569;text-transform:uppercase}.student-activity-name-input{padding:.75rem 1rem;font-size:.9rem;border:1px solid #cbd5e1;border-radius:10px;outline:none;transition:all .2s ease;background:#fff;color:#0f172a}.student-activity-name-input:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c726}.quit-activity-btn{align-self:flex-start;background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s ease}.quit-activity-btn:hover{background:#dc2626;transform:translateY(-1px)}.plan-badge{display:inline-block;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:700;margin-left:.5rem}.plan-badge.premium{background:linear-gradient(135deg,#fef08a,#facc15);color:#854d0e;border:1px solid #fef08a;box-shadow:0 2px 8px #facc1533}.plan-badge.free{background:#e2e8f0;color:#475569;border:1px solid #cbd5e1}.metric-badge.cota-badge{background:#e0f2fe;border:1px solid #bae6fd;color:#0369a1}.teacher-tabs-container{display:flex;gap:.5rem;border-bottom:2px solid rgba(0,0,0,.06);padding-bottom:.75rem;margin-bottom:1.5rem}.teacher-tab-btn{background:none;border:none;padding:.6rem 1.2rem;font-size:.9rem;font-weight:700;color:#64748b;cursor:pointer;border-radius:8px;transition:all .2s ease}.teacher-tab-btn:hover{background:#00000005;color:#1e293b}.teacher-tab-btn.active{background:#646cff;color:#fff}.digitalize-mode-tabs{display:flex;gap:.75rem;margin-bottom:1.75rem;border-bottom:1px solid #e2e8f0;padding-bottom:.75rem}.digitalize-tab-btn{padding:.6rem 1.25rem;font-size:.85rem;font-weight:700;border-radius:8px;border:1px solid transparent;background:transparent;color:#64748b;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;gap:.5rem}.digitalize-tab-btn:hover{background:#f1f5f9;color:#0f172a}.digitalize-tab-btn.active{background:#646cff14!important;color:#646cff!important;border-color:#646cff26!important}.generated-link-box{background:#f0fdf4!important;border:1px solid #bbf7d0!important;border-radius:12px;padding:1.25rem;margin-top:1.5rem;box-shadow:0 4px 12px #00000005}.generated-link-box h5{color:#166534!important;font-size:.95rem;font-weight:800;margin:0 0 .5rem}.generated-link-box p{color:#374151!important;font-size:.8rem;margin:0 0 .75rem}.link-copy-row{display:flex;gap:.5rem}.link-input{flex:1;padding:.65rem .85rem;font-size:.85rem;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#1e293b;outline:none}.copy-btn{padding:.65rem 1.25rem;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease}.copy-btn:hover{background:#535bf2}.copy-btn.success:hover{background:#16a34a!important}.teacher-input-panel{background:#fff!important;border:1px solid rgba(0,0,0,.06)!important;border-radius:16px!important;padding:1.5rem!important;box-shadow:0 10px 30px #0000000a!important;box-sizing:border-box!important}.teacher-form .form-group label{color:var(--text-primary)!important;font-weight:700!important}.teacher-form .tema-select,.teacher-form .custom-tema-input,.teacher-form .essay-textarea.teacher-textarea{background:#f8fafc!important;border:1px solid rgba(0,0,0,.12)!important;color:var(--text-primary)!important}.teacher-form .tema-select:focus,.teacher-form .custom-tema-input:focus,.teacher-form .essay-textarea.teacher-textarea:focus{background:#fff!important;border-color:var(--primary)!important;box-shadow:0 0 0 3px #646cff26!important}.template-chip-btn{background:#f1f5f9!important;border:1px solid rgba(0,0,0,.08)!important;color:var(--text-secondary)!important;font-weight:600!important;transition:all .2s!important}.template-chip-btn:hover{background:#e2e8f0!important;color:var(--text-primary)!important}.template-chip-btn.active{background:#646cff!important;border-color:#646cff!important;color:#fff!important;box-shadow:0 2px 8px #646cff40!important}.essay-textarea.teacher-textarea{background:#f8fafc linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px)!important;background-size:100% 1.65rem!important;color:var(--text-primary)!important;line-height:1.65rem!important;border-left:2px solid rgba(229,62,62,.2)!important}.teacher-dashboard-panel .teacher-form{background:#fff!important;border:1px solid rgba(0,0,0,.06)!important;border-radius:16px!important;padding:1.5rem!important;box-shadow:0 4px 20px #00000005!important}.teacher-input-panel h3,.teacher-input-panel h4,.teacher-dashboard-panel h3,.teacher-dashboard-panel h4{color:var(--text-primary)!important}.offline-toggle-label span{color:var(--text-primary)!important;font-weight:600!important}.teacher-admin-layout{display:flex;min-height:calc(100vh - 140px);width:100%;background-color:#f8fafc;border-radius:20px;overflow:hidden;box-shadow:0 10px 40px #00000005;border:1px solid rgba(0,0,0,.05);margin-top:.5rem}.admin-sidebar{width:260px;background:#fff;border-right:1px solid #e2e8f0;padding:2rem 1.25rem;display:flex;flex-direction:column;gap:2rem;flex-shrink:0;transition:width .25s cubic-bezier(.4,0,.2,1),padding .25s cubic-bezier(.4,0,.2,1)}.admin-sidebar.collapsed{width:75px;padding:2rem .5rem;align-items:center}.admin-sidebar.collapsed .sidebar-brand{padding-bottom:1.5rem;width:100%;justify-content:center}.admin-sidebar.collapsed .sidebar-menu{align-items:center;width:100%}.admin-sidebar.collapsed .sidebar-item{justify-content:center;padding:.75rem;width:44px;height:44px;border-radius:12px;box-sizing:border-box}.admin-sidebar.collapsed .sidebar-item:hover{transform:scale(1.05)}.admin-sidebar.collapsed .sidebar-icon{margin:0;display:flex;align-items:center;justify-content:center}.sidebar-toggle-btn:hover{background-color:#f1f5f9!important;color:#0f172a!important}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding-bottom:1.5rem;border-bottom:1px solid #f1f5f9}.sidebar-logo{font-size:1.5rem}.sidebar-title{font-size:1.05rem;font-weight:800;color:#0f172a;letter-spacing:-.5px;text-transform:uppercase}.sidebar-menu{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.sidebar-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;border-radius:10px;color:#64748b;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1)}.sidebar-item:hover{background:#f1f5f9;color:#0f172a;transform:translate(3px)}.sidebar-item.active{background:#646cff14;color:#646cff;font-weight:700}.sidebar-icon{font-size:1.15rem}.admin-main-content{flex:1;padding:1.25rem 2.25rem 2.25rem;background:#f8fafc;overflow-y:auto;display:flex;flex-direction:column;gap:1.75rem;box-sizing:border-box}.admin-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000004;border:1px solid rgba(0,0,0,.04);box-sizing:border-box}.admin-card-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f1f5f9;padding-bottom:1.5rem;margin-bottom:1.75rem;gap:1.5rem;flex-wrap:wrap}.admin-header-title-area h2{margin:0 0 .25rem;font-size:1.4rem;font-weight:800;color:#0f172a;letter-spacing:-.3px}.admin-header-title-area p{margin:0;color:#64748b;font-size:.85rem}.dashboard-filters{display:flex;align-items:flex-end;gap:1.25rem;background:#fff;padding:0;border:none;box-shadow:none;flex-wrap:wrap}.dashboard-filters .filter-group{display:flex;flex-direction:column;gap:.4rem}.dashboard-filters .filter-group label{font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.dashboard-filters .tema-select{padding:.6rem 1rem;font-size:.85rem;border:1px solid #cbd5e1;border-radius:8px;background:#fff!important;color:#1e293b!important;outline:none;min-width:220px;transition:all .2s ease;font-weight:500}.dashboard-filters .tema-select:hover{border-color:#94a3b8}.dashboard-filters .tema-select:focus{border-color:#646cff;box-shadow:0 0 0 3px #646cff1f}.print-report-btn{background:#646cff!important;border:1px solid #646cff!important;color:#fff!important;padding:.6rem 1.25rem!important;font-size:.85rem!important;font-weight:700!important;border-radius:8px!important;cursor:pointer!important;transition:all .2s ease!important;box-shadow:0 2px 8px #646cff26!important}.print-report-btn:hover{background:#535bf2!important;border-color:#535bf2!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px #646cff40!important}.metrics-cards-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:1.5rem;margin-bottom:2rem}.metric-score-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between;min-height:120px;position:relative;box-shadow:0 2px 10px #00000001}.metric-score-card.dist-card{justify-content:flex-start;gap:.85rem}.metric-score-card .card-lbl{font-size:.8rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.metric-score-card .card-val{font-size:2.25rem;font-weight:800;color:#0f172a;line-height:1;margin:.5rem 0;background:linear-gradient(135deg,#646cff,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.metric-score-card .mini-bar{width:100%;height:6px;background:#f1f5f9;border-radius:10px;overflow:hidden;margin-top:.5rem}.metric-score-card .mini-fill{height:100%;background:linear-gradient(to right,#646cff,#a855f7);border-radius:10px}.distribution-details{display:flex;flex-direction:column;gap:.5rem}.dist-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#475569}.dist-item strong{color:#0f172a;margin-left:auto}.dist-item .dot{width:8px;height:8px;border-radius:50%}.dist-item .dot.green{background:#10b981}.dist-item .dot.yellow{background:#f59e0b}.dist-item .dot.red{background:#ef4444}.competencies-aggregates-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:1.5rem;margin-bottom:2rem}.competencies-aggregates-card h4{margin:0 0 1.25rem;font-size:1.05rem;font-weight:800;color:#0f172a;letter-spacing:-.2px}.teacher-comp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;border-top:none;padding-top:0}.teacher-comp-grid .competencia-mini-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem .75rem;text-align:center;transition:all .2s ease}.teacher-comp-grid .competencia-mini-card:hover{border-color:#cbd5e1;background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #00000005}.teacher-comp-grid .comp-label{font-size:.75rem;font-weight:700;color:#475569;margin-bottom:.5rem;line-height:1.3;height:32px;display:flex;align-items:center;justify-content:center}.teacher-comp-grid .progress-track{width:100%;height:5px;background:#e2e8f0;border-radius:10px;margin-bottom:.5rem}.teacher-comp-grid .comp-nota{font-size:.9rem;font-weight:800;color:#0f172a}.student-grades-list-section{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:1.5rem}.student-grades-list-section h4{margin:0 0 1.25rem;font-size:1.05rem;font-weight:800;color:#0f172a;letter-spacing:-.2px}.student-table-container{overflow-x:auto;border:1px solid #e2e8f0;border-radius:10px}.student-grades-table{width:100%;border-collapse:collapse;text-align:left}.student-grades-table th{background:#f8fafc;color:#475569;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;padding:.85rem 1rem;border-bottom:1px solid #e2e8f0}.student-grades-table td{padding:1rem;border-bottom:1px solid #f1f5f9;font-size:.85rem;color:#334155;vertical-align:middle}.student-grades-table tr:last-child td{border-bottom:none}.student-grades-table tr:hover{background:#f8fafc}.student-grades-table td strong{color:#0f172a;font-weight:700}.student-theme-cell{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-grade-badge{display:inline-block;padding:.3rem .6rem;background:#646cff14;color:#646cff;font-weight:800;border-radius:6px;font-size:.85rem}.actions-cell{display:flex;gap:.5rem;align-items:center}.table-view-btn{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569;padding:.35rem .75rem;font-size:.75rem;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s ease}.table-view-btn:hover{background:#e2e8f0;color:#0f172a;transform:translateY(-1px)}.table-delete-btn{background:transparent;border:none;color:#ef4444;font-size:.75rem;font-weight:600;cursor:pointer;padding:.35rem .5rem;transition:all .2s ease;border-radius:6px}.table-delete-btn:hover{background:#ef444414;text-decoration:none}@media(max-width:1024px){.teacher-admin-layout{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid #e2e8f0;padding:1.5rem}.sidebar-brand{padding-bottom:1rem}.sidebar-menu{flex-direction:row;flex-wrap:wrap;gap:.5rem}.metrics-cards-grid{grid-template-columns:1fr}.teacher-comp-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.app-container{max-width:100%!important;padding:0!important;margin:0!important;background:#f8fafc;display:flex;flex-direction:column}.app-header{background:#fff!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;border:none!important;border-bottom:1px solid #e2e8f0!important;border-radius:0!important;padding:.75rem 2rem!important;margin-bottom:0!important;box-shadow:0 1px 3px #00000005!important;width:100%!important;box-sizing:border-box!important;position:sticky;top:0;z-index:1000;display:flex;justify-content:space-between;align-items:center}.header-brand{color:#0f172a!important;font-weight:800!important;display:flex;align-items:center;gap:.65rem;font-size:1.3rem;letter-spacing:-.5px}.header-title{background:none!important;-webkit-text-fill-color:initial!important;color:#0f172a!important;font-weight:800!important}.content-wrapper{max-width:1300px;width:100%;margin:1.5rem auto!important;padding:0 1.5rem;box-sizing:border-box;flex:1}.teacher-admin-layout{margin-top:0!important;border-radius:0!important;border:none!important;min-height:calc(100vh - 58px);box-shadow:none!important;background-color:#f8fafc}.admin-sidebar{border-right:1px solid #e2e8f0;background:#fff;min-height:calc(100vh - 58px)}.profile-selector{background:#f1f5f9!important;padding:.25rem!important;border-radius:8px!important;border:1px solid #cbd5e1!important;display:flex}.profile-btn{color:#64748b!important;padding:.4rem 1rem!important;font-size:.8rem!important;font-weight:700!important;border-radius:6px!important;background:transparent!important;border:none!important;cursor:pointer;transition:all .15s ease!important;box-shadow:none!important}.profile-btn:hover{color:#0f172a!important}.profile-btn.active{background:#fff!important;color:#646cff!important;box-shadow:0 2px 6px #0000000f!important}.user-name{color:#0f172a!important;font-weight:700!important}.user-email{color:#64748b!important}.logout-btn{border:1px solid #cbd5e1!important;color:#475569!important;background:transparent!important}.logout-btn:hover{background-color:#fef2f2!important;border-color:#fca5a5!important;color:#ef4444!important}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.65rem 1.5rem;background:#f8fafc;border-bottom:1px solid var(--border-color, rgba(0, 0, 0, .08));-webkit-user-select:none;user-select:none}.toolbar-left{display:flex;align-items:center}.toolbar-doc-title{font-size:.85rem;font-weight:700;color:var(--text-secondary, #475569);display:flex;align-items:center;gap:.35rem}.toolbar-doc-title .doc-icon{font-size:1rem}.toolbar-right{display:flex;align-items:center;gap:.75rem}.toolbar-camera-btn{display:flex;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.8rem;font-weight:700;border-radius:8px;cursor:pointer;background:#646cff14;border:1px solid rgba(100,108,255,.15);color:var(--primary, #646cff);transition:all .2s ease;margin:0}.toolbar-camera-btn:hover{background:#646cff24;border-color:#646cff4d;transform:translateY(-1px)}.toolbar-camera-btn:active{transform:translateY(0)}.textarea-container.essay-official-sheet{max-width:820px;width:100%;margin:0 auto;background:#fff!important;border:1px solid #cbd5e1!important;box-shadow:0 20px 40px #00000040!important;border-radius:12px;transition:transform .3s ease,box-shadow .3s ease;overflow:hidden}.textarea-container.essay-official-sheet:focus-within{border-color:#94a3b8!important;box-shadow:0 20px 45px #94a3b840!important}.essay-official-sheet .essay-textarea{background:#fff linear-gradient(rgba(203,213,225,.6) 1px,transparent 1px)!important;background-size:100% 25px!important;background-attachment:local!important;color:#0f172a!important;font-size:.975rem!important;line-height:25px!important;padding:1.5rem 2rem 1.5rem 1.5rem!important;border:none!important;border-left:2px solid rgba(239,68,68,.6)!important;font-family:Inter,system-ui,sans-serif!important;letter-spacing:-.01em!important;resize:none!important;outline:none!important;min-height:750px!important}.essay-official-sheet .essay-textarea::placeholder{color:#94a3b8!important;font-style:italic!important}.essay-official-sheet .line-numbers-sidebar{background:#f8fafc!important;border-right:1px solid #e2e8f0!important;color:#64748b!important;opacity:.85!important;padding:1.5rem 0!important;width:45px!important}.essay-official-sheet .line-number-item{height:25px!important;line-height:25px!important;font-weight:700!important;color:#94a3b8!important}.essay-official-sheet .editor-toolbar{background:#f8fafc!important;border-bottom:1px solid #e2e8f0!important}.essay-official-sheet .toolbar-doc-title{color:#334155!important}.essay-official-sheet .textarea-footer{background:#f8fafc!important;border-top:1px solid #e2e8f0!important;color:#64748b!important}.essay-official-sheet .metric-badge{background:#64748b14!important;color:#475569!important;border:1px solid rgba(100,116,139,.15)!important}.role-selection-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background:#f8fafc;font-family:Outfit,Inter,system-ui,sans-serif;box-sizing:border-box;padding:2rem;position:fixed;inset:0;z-index:9999;overflow-y:auto}.role-selection-container{width:100%;max-width:800px;display:flex;flex-direction:column;align-items:center;gap:3rem;animation:fadeIn .4s ease-out}.role-selection-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.role-selection-header .brand-logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:800;color:#4f46e5;margin-bottom:.5rem}.role-selection-header h1{font-size:2.5rem;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.5px}.role-selection-header p{font-size:1.1rem;color:#64748b;margin:0;max-width:500px}.role-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;width:100%;box-sizing:border-box}.role-card{background:#fff;border:1px solid rgba(0,0,0,.04);border-radius:24px;padding:3rem 2rem;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 30px #0f172a08;position:relative;overflow:hidden}.role-card-icon-wrapper{width:80px;height:80px;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:2rem;transition:all .3s ease}.student-card .role-card-icon-wrapper{background:#4f46e514;color:#4f46e5}.teacher-card .role-card-icon-wrapper{background:#0d948814;color:#0d9488}.role-card h2{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 1rem;letter-spacing:-.5px}.role-card p{font-size:.95rem;line-height:1.6;color:#64748b;margin:0 0 2.5rem;flex-grow:1}.role-card-action{font-size:.95rem;font-weight:700;padding:.75rem 1.5rem;border-radius:12px;transition:all .2s ease;width:100%;box-sizing:border-box}.student-card .role-card-action{background:#4f46e5;color:#fff}.teacher-card .role-card-action{background:#0d9488;color:#fff}.role-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0f172a0f}.student-card:hover{border-color:#4f46e540}.student-card:hover .role-card-icon-wrapper{background:#4f46e5;color:#fff;transform:scale(1.05)}.student-card:hover .role-card-action{background:#4338ca}.teacher-card:hover{border-color:#0d948840}.teacher-card:hover .role-card-icon-wrapper{background:#0d9488;color:#fff;transform:scale(1.05)}.teacher-card:hover .role-card-action{background:#0f766e}@media(max-width:768px){.role-cards-grid{grid-template-columns:1fr;gap:1.5rem}.role-card{padding:2rem 1.5rem}.role-selection-header h1{font-size:2rem}}
