@import"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Inter:wght@100..900&family=Outfit:wght@300;400;500;600;700;800;900&display=swap";.language-selector{display:flex;align-items:center}.language-select{padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;cursor:pointer;background:#fff;transition:border-color .3s}.language-select:hover{border-color:#667eea}.language-select:focus{outline:none;border-color:#667eea}.app-header{background:linear-gradient(135deg,#4a4a8a,#6a6aaa);padding:1rem 2rem;box-shadow:0 4px 15px #0000004d;position:sticky;top:0;z-index:1000}.app-header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:1.5rem}.app-logo{height:60px;width:auto;object-fit:contain}.app-header-text{display:flex;flex-direction:column;align-items:flex-start}.app-title{font-size:1.8rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3);margin:0;letter-spacing:1px;line-height:1.2}.app-subtitle{font-size:.9rem;font-weight:400;color:#e0e0e0;margin:0;letter-spacing:.5px;line-height:1.3}@media (max-width: 768px){.app-header{padding:.75rem 1.5rem}.app-header-content{flex-direction:column;align-items:center;gap:.5rem}.app-logo{height:50px}.app-header-text{align-items:center}.app-title{font-size:1.3rem}.app-subtitle{font-size:.8rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:1rem}.login-box{background-color:#2a2a4a;border-radius:20px;padding:2.5rem;max-width:450px;width:100%;box-shadow:0 10px 40px #00000080;border:1px solid #4a4a6a}.login-title{text-align:center;font-size:2rem;color:#fff;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.login-subtitle{text-align:center;color:#b0b0c0;margin-bottom:2rem;font-size:1rem}.login-type-selector{display:flex;gap:1rem;margin-bottom:2rem}.login-type-btn{flex:1;padding:.75rem;font-size:1rem;font-weight:600;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;cursor:pointer;transition:all .3s ease}.login-type-btn:hover{background-color:#4a4a7a;border-color:#5a5a8a}.login-type-btn.active{background-color:#4a4a8a;border-color:#6a6aaa;box-shadow:0 0 10px #6a6aaa80}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input{padding:.75rem 1rem;font-size:1rem;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;outline:none;transition:all .3s ease}.form-group input:focus{border-color:#6a6aaa;background-color:#4a4a6a}.form-group input::placeholder{color:#808090}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input{width:100%;padding-right:3rem!important}.password-toggle-btn{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:#808090;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.password-toggle-btn:hover{color:#a0a0b0}.login-btn{padding:1rem;font-size:1.1rem;font-weight:700;border:none;border-radius:12px;background:linear-gradient(135deg,#4a4a8a,#6a6aaa);color:#fff;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#5a5a9a,#7a7aba);transform:translateY(-2px);box-shadow:0 5px 15px #6a6aaa66}.login-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#f44336;color:#fff;padding:.75rem 1rem;border-radius:10px;text-align:center;font-size:.9rem;margin-bottom:1.5rem;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-info{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #4a4a6a;font-size:.85rem;color:#808090}.login-info p{margin:.5rem 0}.login-info strong{color:#a0a0b0}.professor-nav{display:flex;gap:1rem;justify-content:center;padding:1rem 2rem;background-color:#1a1a2e;border-bottom:2px solid #4a4a6a}.professor-nav-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#e0e0e0;cursor:pointer;transition:all .3s ease}.professor-nav-btn:hover{background-color:#4a4a6a;border-color:#6a6aaa;transform:translateY(-2px);box-shadow:0 5px 15px #0000004d}.professor-nav-btn.active{background:linear-gradient(135deg,#2196f3,#1976d2);border-color:#1976d2;box-shadow:0 0 15px #2196f380;transform:scale(1.05)}.voting-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.voting-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:2px solid #4a4a6a}.voting-title{font-size:2.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.voting-main{max-width:1200px;margin:0 auto}.voting-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a;animation:fadeIn .5s ease}.vote-counter{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;padding:1rem;background:linear-gradient(135deg,#3a3a5a,#4a4a6a);border-radius:10px;border:2px solid #5a5a7a}.vote-count{font-size:2.5rem;font-weight:800;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.5)}.vote-divider,.vote-max{font-size:2rem;font-weight:700;color:#b0b0c0}.vote-label{font-size:1rem;font-weight:600;color:#b0b0c0;text-transform:uppercase;letter-spacing:1px}.vote-limit-message{text-align:center;padding:1rem;background:linear-gradient(135deg,#f44336,#ef5350);color:#fff;border-radius:10px;font-weight:700;font-size:1.1rem;margin-bottom:1.5rem;box-shadow:0 4px 15px #f4433666}.question-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;margin-bottom:2rem;border:1px solid #4a4a6a;animation:fadeIn .5s ease}.question-display{text-align:center}.question-text{font-size:1.5rem;color:#fff;margin:1.5rem 0;font-weight:500;line-height:1.6}.edit-question-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;cursor:pointer;transition:all .3s ease}.edit-question-btn:hover{background-color:#4a4a6a;border-color:#5a5a7a;transform:translateY(-2px)}.question-edit{display:flex;flex-direction:column;gap:1.5rem}.question-input{width:100%;padding:1rem;font-size:1.1rem;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;outline:none;resize:vertical;transition:all .3s ease;font-family:inherit}.question-input:focus{border-color:#6a6aaa;background-color:#4a4a6a}.question-input::placeholder{color:#808090}.question-edit-actions{display:flex;gap:1rem;justify-content:center}.save-question-btn,.cancel-question-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;color:#fff}.save-question-btn{background:linear-gradient(135deg,#4caf50,#45a049)}.save-question-btn:hover{background:linear-gradient(135deg,#5cb860,#4caf50);transform:translateY(-2px);box-shadow:0 5px 15px #4caf5066}.cancel-question-btn{background:linear-gradient(135deg,#f44336,#d32f2f)}.cancel-question-btn:hover{background:linear-gradient(135deg,#ef5350,#f44336);transform:translateY(-2px);box-shadow:0 5px 15px #f4433666}.course-section{margin-bottom:3rem}.section-title{font-size:1.8rem;color:#e0e0e0;margin-bottom:1.5rem;text-align:center}.course-buttons{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.course-button{padding:.75rem 1.5rem;font-size:1.1rem;font-weight:600;border:2px solid #4a4a6a;border-radius:12px;background-color:#2a2a4a;color:#fff;cursor:pointer;transition:all .3s ease}.course-button:hover{background-color:#3a3a5a;border-color:#5a5a7a;transform:translateY(-2px)}.course-button.selected{background-color:#4a4a8a;border-color:#6a6aaa;box-shadow:0 0 15px #6a6aaa80;transform:scale(1.05)}.voting-section{text-align:center;animation:fadeIn .5s ease}.voting-image-container{margin-bottom:2rem;display:flex;justify-content:center;animation:fadeIn .5s ease}.voting-image{max-width:100%;max-height:400px;border-radius:15px;border:3px solid #4a4a6a;box-shadow:0 10px 30px #00000080}.voting-buttons{display:flex;flex-direction:column;gap:1.5rem;align-items:center;margin-top:2rem}.vote-button{padding:1.5rem 3rem;font-size:1.3rem;font-weight:700;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;min-width:300px;color:#fff}.vote-button:hover{transform:scale(1.05);box-shadow:0 10px 30px #0000004d}.vote-button:active{transform:scale(.98)}.success-section{text-align:center;animation:fadeIn .5s ease;padding:3rem}.success-icon{font-size:5rem;color:#4caf50;margin-bottom:1.5rem;animation:scaleIn .5s ease}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-title{font-size:2.5rem;color:#fff;margin-bottom:1rem}.success-message{font-size:1.2rem;color:#e0e0e0;margin-bottom:1.5rem}.success-vote-type{font-size:1.1rem;color:#b0b0c0;margin-bottom:2.5rem}.success-vote-type strong{color:#fff;font-weight:700}.success-actions{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.continue-btn,.observation-btn{padding:1rem 2.5rem;font-size:1.1rem;font-weight:600;border:none;border-radius:30px;cursor:pointer;transition:all .3s ease;min-width:200px}.continue-btn{background:linear-gradient(135deg,#4a4a8a,#6a6aaa);color:#fff}.continue-btn:hover{background:linear-gradient(135deg,#5a5a9a,#7a7aba);transform:translateY(-2px);box-shadow:0 5px 15px #6a6aaa66}.observation-btn{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.observation-btn:hover{background:linear-gradient(135deg,#ffa726,#ff9800);transform:translateY(-2px);box-shadow:0 5px 15px #ff980066}@media (max-width: 768px){.voting-container{padding:1rem}.voting-header{flex-direction:column;gap:1rem;text-align:center}.voting-title{font-size:1.8rem}.user-info{flex-direction:column}.course-button{padding:.6rem 1.2rem;font-size:1rem}.vote-button{padding:1.2rem 2rem;font-size:1.1rem;min-width:250px}.success-actions{flex-direction:column}.continue-btn,.observation-btn{width:100%}}.alerts-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.alerts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #4a4a6a}.alerts-title{font-size:2.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.alerts-nav{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}.nav-btn.active{box-shadow:0 0 15px #ffffff80;transform:scale(1.05)}.nav-btn:nth-child(1),.nav-btn:nth-child(2),.nav-btn:nth-child(3){background:linear-gradient(135deg,#2196f3,#1976d2)}.voting-nav{background:linear-gradient(135deg,#2196f3,#1976d2)}.alerts-main{max-width:1400px;margin:0 auto}.course-selector-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;margin-bottom:2rem;border:1px solid #4a4a6a}.course-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.course-button{padding:1rem;font-size:1.1rem;font-weight:600;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#e0e0e0;cursor:pointer;transition:all .3s ease}.course-button:hover{background-color:#4a4a6a;border-color:#6a6aaa;transform:translateY(-2px)}.course-button.selected{background:linear-gradient(135deg,#4a4a8a,#6a6aaa);border-color:#8a8aba;box-shadow:0 4px 15px #6a6aaa66}.students-list-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;margin-bottom:2rem;border:1px solid #4a4a6a;animation:fadeIn .5s ease}.back-btn{padding:.5rem 1rem;background-color:#3a3a5a;color:#e0e0e0;border:2px solid #4a4a6a;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;margin-bottom:1rem}.back-btn:hover{background-color:#4a4a6a;border-color:#6a6aaa;transform:translate(-5px)}.students-list{margin-top:1rem}.no-students{text-align:center;padding:2rem;color:#b0b0c0}.students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.student-card{background-color:#3a3a5a;border-radius:10px;padding:1rem;border-left:3px solid #4a4a6a;transition:all .3s ease}.student-card:hover{transform:translate(5px);box-shadow:0 5px 15px #0000004d;border-left-color:#6a6aaa}.student-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.student-id{font-size:.8rem;color:#808090;font-weight:600}.student-name{font-size:1rem;color:#e0e0e0;font-weight:600}.student-points{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid #4a4a6a}.points-label{font-size:.85rem;color:#b0b0c0}.points-value{font-size:.9rem;color:#fff;font-weight:700}.alerts-summary{background-color:#2a2a4a;border-radius:15px;padding:2rem;margin-bottom:2rem;border:1px solid #4a4a6a}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.summary-card.high-severity{border:2px solid #f44336}.summary-card.medium-severity{border:2px solid #ff9800}.summary-card.low-severity{border:2px solid #4caf50}.summary-card.total{border:2px solid #4a4a6a}.alerts-list-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.no-alerts{text-align:center;padding:4rem 2rem;color:#b0b0c0}.no-alerts-icon{font-size:5rem;color:#4caf50;margin-bottom:1rem}.alerts-list{display:flex;flex-direction:column;gap:1.5rem}.alert-card{background-color:#3a3a5a;border-radius:10px;padding:1.5rem;border-left:4px solid;transition:all .3s ease;animation:fadeIn .5s ease}.alert-card:hover{transform:translate(5px);box-shadow:0 5px 15px #0000004d}.alert-card[data-severity=HIGH]{border-left-color:#f44336}.alert-card[data-severity=MEDIUM]{border-left-color:#ff9800}.alert-card[data-severity=LOW]{border-left-color:#4caf50}.results-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a;text-align:center}.results-section p{color:#b0b0c0;margin-bottom:1.5rem}.observation-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;margin-bottom:2rem;border:1px solid #4a4a6a;animation:fadeIn .5s ease}.observation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.observation-header .back-btn{flex:0 0 auto;width:150px;padding:1rem 1.5rem;background:linear-gradient(135deg,#f44336,#e53935);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #f443364d}.observation-header .back-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f4433680;background:linear-gradient(135deg,#e53935,#d32f2f)}.observation-header .save-observations-btn{margin-top:0;width:150px;padding:1rem 1.5rem;flex:0 0 auto}.observation-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.observation-button{background-color:#3a3a5a;border-radius:10px;padding:1rem;text-align:left;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.observation-button:hover{background-color:#4a4a6a;transform:translateY(-2px);box-shadow:0 5px 15px #0000004d}.observation-checkbox-item{background-color:#3a3a5a;border-radius:10px;padding:1rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.observation-checkbox-item:hover{background-color:#4a4a6a;transform:translateY(-2px);box-shadow:0 5px 15px #0000004d}.observation-checkbox-item.selected{border-color:#4caf50;background-color:#4a4a6a}.checkbox-container input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#4caf50}.observation-content{flex:1}.save-observations-btn{margin-top:1.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #4caf504d;width:100%}.save-observations-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4caf5080;background:linear-gradient(135deg,#45a049,#5bb863)}.save-observations-btn:disabled{background:linear-gradient(135deg,#4a4a6a,#5a5a7a);cursor:not-allowed;opacity:.6}.observation-name{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin-bottom:.5rem}.observation-details{display:flex;justify-content:space-between;align-items:center}.observation-category{font-size:.85rem;font-weight:700;color:#fff;padding:.2rem .5rem;border-radius:4px}.observation-score{font-size:.9rem;color:#b0b0c0;font-weight:600}.alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.type-badge{display:inline-block;padding:.3rem .8rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;background-color:#4a4a6a;color:#fff}.severity-badge{display:inline-block;padding:.3rem .8rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;color:#fff}.alert-body{display:flex;flex-direction:column;gap:.75rem}.alert-student,.alert-course,.alert-points,.alert-details,.alert-timestamp{display:flex;justify-content:space-between;align-items:center;font-size:.95rem}.student-label,.course-label,.points-label,.details-label,.timestamp-label{color:#b0b0c0;font-weight:600}.student-name,.course-name,.points-value,.details-text,.timestamp-value{color:#e0e0e0;font-weight:500}.points-value{font-weight:700;color:#fff}@media (max-width: 768px){.alerts-container{padding:1rem}.alerts-header{flex-direction:column;gap:1rem;text-align:center}.alerts-title{font-size:1.8rem}.user-info,.alerts-nav{flex-direction:column}.nav-btn{width:100%}.summary-cards{grid-template-columns:1fr 1fr}.summary-value{font-size:2.5rem}.alert-student,.alert-course,.alert-points,.alert-details,.alert-timestamp{flex-direction:column;align-items:flex-start;gap:.25rem}}.results-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.results-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#2196f3,#1976d2);border-radius:15px;margin-bottom:2rem}.header-left{display:flex;align-items:center;gap:1rem}.results-title{font-size:2rem;font-weight:800;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.header-nav-btn{padding:.5rem 1.5rem;background-color:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .3s ease;box-shadow:0 2px 8px #4caf504d}.header-nav-btn:hover{background-color:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5080}.voting-header-btn{background:linear-gradient(135deg,#4caf50,#66bb6a)}.results-main{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.results-nav{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.nav-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;color:#fff;background:linear-gradient(135deg,#4a4a8a,#6a6aaa)}.nav-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000004d;background:linear-gradient(135deg,#6a6aaa,#8a8aca)}.manometer-section{background:linear-gradient(135deg,#2a2a4a,#1a1a3a);border-radius:20px;padding:2.5rem;border:2px solid #4a4a6a;box-shadow:0 10px 30px #0000004d}.manometer-display{display:flex;align-items:center;gap:3rem;justify-content:center;flex-wrap:wrap}.manometer-gauge{position:relative;width:350px;height:175px;border-radius:175px 175px 0 0;overflow:hidden;background:#1a1a2a;box-shadow:inset 0 0 30px #00000080,0 5px 20px #0000004d}.gauge-bg{position:absolute;width:100%;height:100%;background:conic-gradient(from 180deg,#1a1a2a,#1a1a2a 90deg);border-radius:175px 175px 0 0}.gauge-arc{position:absolute;width:100%;height:100%;border-radius:175px 175px 0 0;clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}.green-arc{background:conic-gradient(from 180deg,#4caf50,#66bb6a 36deg,#1a1a2a 36deg,#1a1a2a 90deg);mask:radial-gradient(circle at 50% 100%,transparent 60%,black 61%);-webkit-mask:radial-gradient(circle at 50% 100%,transparent 60%,black 61%)}.yellow-arc{background:conic-gradient(from 180deg,#1a1a2a,#1a1a2a 36deg,#ff9800 36deg,#ffb74d 72deg,#1a1a2a 72deg,#1a1a2a 90deg);mask:radial-gradient(circle at 50% 100%,transparent 60%,black 61%);-webkit-mask:radial-gradient(circle at 50% 100%,transparent 60%,black 61%)}.red-arc{background:conic-gradient(from 180deg,#1a1a2a,#1a1a2a 72deg,#f44336 72deg,#ef5350 90deg);mask:radial-gradient(circle at 50% 100%,transparent 60%,black 61%);-webkit-mask:radial-gradient(circle at 50% 100%,transparent 60%,black 61%)}.gauge-ticks{position:absolute;width:100%;height:100%;top:0;left:0}.gauge-tick{position:absolute;bottom:0;left:50%;width:2px;height:15px;background-color:#ffffff4d;transform-origin:bottom center;transition:opacity .3s ease}.gauge-tick:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:4px;height:4px;background-color:#ffffff80;border-radius:50%}.tick-label{position:absolute;bottom:-25px;left:50%;transform:translate(-50%);font-size:.75rem;font-weight:600;color:#fff9;white-space:nowrap}.manometer-needle{position:absolute;bottom:0;left:50%;width:3px;height:160px;background:linear-gradient(to top,#fff,#e0e0e0);transform-origin:bottom center;transform:rotate(-90deg);transition:transform 1.5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 15px #ffffff80,0 2px 5px #0000004d;z-index:10}.needle-center{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:30px;height:30px;background:radial-gradient(circle at 30% 30%,#fff,#e0e0e0,#b0b0b0);border-radius:50%;box-shadow:0 5px 15px #0006,inset 0 2px 5px #ffffff80;z-index:11}.manometer-info{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.manometer-value{font-size:3rem;font-weight:800;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.5);letter-spacing:-1px}.manometer-label{font-size:.9rem;color:#b0b0c0;text-transform:uppercase;letter-spacing:2px;font-weight:600}.manometer-status{font-size:1.1rem;color:#e0e0e0;font-weight:500}.status-indicator{font-weight:700;padding:.25rem .75rem;border-radius:20px;text-transform:uppercase;letter-spacing:1px;font-size:.9rem}.status-indicator.positive{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;box-shadow:0 2px 10px #4caf5066}.status-indicator.precaution{background:linear-gradient(135deg,#ff9800,#ffb74d);color:#fff;box-shadow:0 2px 10px #ff980066}.status-indicator.alert{background:linear-gradient(135deg,#f44336,#ef5350);color:#fff;box-shadow:0 2px 10px #f4433666}.trend-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.trend-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.trend-filters{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:600;border:2px solid #4a4a6a;border-radius:8px;background-color:#3a3a5a;color:#fff;cursor:pointer;transition:all .3s ease}.filter-btn:hover{background-color:#4a4a6a;border-color:#5a5a7a}.filter-btn.active{background-color:#4a4a8a;border-color:#6a6aaa;box-shadow:0 0 10px #6a6aaa80}.trend-graph{background-color:#3a3a5a;border-radius:10px;padding:1rem;height:200px;display:flex;align-items:center;justify-content:center}.trend-svg{width:100%;height:100%}.sampling-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.sampling-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.sampling-stat{display:flex;flex-direction:column;gap:.5rem;background-color:#3a3a5a;padding:1.5rem;border-radius:10px}.stat-label{font-size:.9rem;color:#b0b0c0}.stat-value{font-size:1.5rem;font-weight:700;color:#fff}.courses-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.course-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.course-card{background-color:#3a3a5a;border-radius:12px;padding:1.5rem;border:2px solid #4a4a6a;transition:all .3s ease}.course-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000004d}.course-card-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background-color:#3a3a5a;border-radius:10px 10px 0 0}.course-card-title{font-size:1.3rem;font-weight:700;color:#fff}.course-card-badges{display:flex;gap:.5rem}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1px}.observations-badge{padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff;box-shadow:0 2px 10px #9c27b066}.observations-badge.clickable{cursor:pointer;transition:all .3s ease}.observations-badge.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 15px #9c27b099}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:linear-gradient(135deg,#2a2a4a,#1a1a3a);border-radius:20px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;border:2px solid #4a4a6a;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #4a4a6a}.modal-title{font-size:1.5rem;font-weight:700;color:#fff}.modal-close{background:none;border:none;color:#fff;font-size:2rem;font-weight:700;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.modal-close:hover{background-color:#f44336;transform:rotate(90deg)}.modal-body{max-height:60vh;overflow-y:auto}.no-observations{text-align:center;color:#b0b0c0;font-size:1.1rem;padding:2rem}.observations-list{display:flex;flex-direction:column;gap:1rem}.observation-item{background-color:#3a3a5a;padding:1rem;border-radius:10px;border-left:4px solid #9c27b0}.observation-student{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.5rem}.observation-details{display:flex;flex-direction:column;gap:.25rem}.observation-name{font-size:.95rem;color:#e0e0e0;font-weight:600}.observation-meta{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#b0b0c0}.observer-name{font-weight:500}.status-badge.positivo{background-color:#4caf50;color:#fff}.status-badge.precaución{background-color:#ff9800;color:#fff}.status-badge.alerta{background-color:#f44336;color:#fff}.status-badge.sin_datos{background-color:#4a4a6a;color:#fff}.course-card-body{display:flex;flex-direction:row;gap:1.5rem;align-items:flex-start}.card-left{display:flex;align-items:center;padding-right:1rem}.mini-manometer{width:20px;height:140px;background:#2a2a4a;border-radius:15px;position:relative;overflow:hidden;box-shadow:inset 0 2px 8px #0000004d,0 4px 12px #0003;border:3px solid #3a3a5a}.mini-manometer-fill{width:100%;position:absolute;bottom:0;border-radius:0 0 12px 12px;transition:height .5s ease,background-color .5s ease;box-shadow:0 -2px 8px #0000001a}.mini-manometer:before{content:"";position:absolute;bottom:-5px;left:50%;transform:translate(-50%);width:30px;height:30px;background:#3a3a5a;border-radius:50%;border:3px solid #2a2a4a;box-shadow:0 4px 12px #0000004d;z-index:1}.mini-manometer:after{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:8px;height:8px;background:#ffffff80;border-radius:50%;z-index:2}.card-right{flex:1;min-width:0}.vote-details{display:flex;flex-direction:column;gap:.75rem}.vote-detail-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #3a3a5a}.detail-label{font-size:.85rem;color:#b0b0c0;font-weight:500}.detail-value{font-size:.9rem;color:#fff;font-weight:600}.vote-breakdown{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background-color:#3a3a5a;border-radius:8px}.vote-breakdown-item{display:flex;justify-content:space-between;align-items:center}.vote-breakdown-item.green{color:#4caf50}.vote-breakdown-item.yellow{color:#ff9800}.vote-breakdown-item.red{color:#f44336}.breakdown-label{font-size:.85rem;font-weight:500}.breakdown-value{font-size:.9rem;font-weight:700}.course-stats .stat{display:flex;flex-direction:column;gap:.25rem}.course-stats .stat-label{font-size:.8rem;color:#b0b0c0}.course-stats .stat-value{font-size:1.1rem;font-weight:600;color:#fff}@media (max-width: 768px){.results-container{padding:1rem}.results-header{flex-direction:column;gap:1rem;text-align:center}.results-title{font-size:1.8rem}.user-info,.results-nav{flex-direction:column}.nav-btn{width:100%}.manometer-display{flex-direction:column;gap:2rem}.manometer-gauge{width:250px;height:125px}.trend-header{flex-direction:column;align-items:flex-start}.trend-filters{width:100%}.filter-btn{flex:1}.course-cards{grid-template-columns:1fr}}.admin-config-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.admin-main{max-width:1200px;margin:0 auto}.config-tabs{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.tab-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;cursor:pointer;transition:all .3s ease}.tab-btn:hover{background-color:#4a4a6a;border-color:#5a5a7a}.tab-btn.active{background-color:#4a4a8a;border-color:#6a6aaa;box-shadow:0 0 10px #6a6aaa80}.config-content{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.config-subsection-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background-color:#4a4a6a;color:#e0e0e0;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative}.help-icon:hover{background-color:#6a6a8a;transform:scale(1.1)}.help-icon-symbol{line-height:1}.tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;background-color:#3a3a5a;color:#e0e0e0;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;line-height:1.4;max-width:1600px;white-space:normal;word-wrap:break-word;box-shadow:0 4px 12px #0006;border:1px solid #4a4a6a;z-index:100}.tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#3a3a5a}.config-section{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.config-section-title{font-size:1.8rem;color:#e0e0e0;margin-bottom:1rem}.config-description{color:#b0b0c0;margin-bottom:2rem;font-size:1rem}.subsection-title{font-size:1.3rem;color:#e0e0e0;margin-bottom:1rem;margin-top:2rem}.question-config{background-color:#3a3a5a;padding:1.5rem;border-radius:10px;margin-bottom:2rem}.question-config .form-group{margin-bottom:0}.question-config textarea{resize:vertical;min-height:80px}.image-preview{margin-top:1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.preview-image{max-width:100%;max-height:300px;border-radius:10px;border:2px solid #4a4a6a}.remove-image-btn{padding:.5rem 1rem;background-color:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.remove-image-btn:hover{background-color:#d32f2f;transform:translateY(-2px)}.config-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;color:#e0e0e0;font-weight:600}.form-input{padding:.75rem 1rem;font-size:1rem;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;outline:none;transition:all .3s ease}.form-input:focus{border-color:#6a6aaa;background-color:#4a4a6a}.form-input.small{width:100px}.save-btn,.add-btn{padding:1rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;color:#fff}.save-btn{background:linear-gradient(135deg,#4a4a8a,#6a6aaa);margin-top:1rem}.save-btn:hover{background:linear-gradient(135deg,#5a5a9a,#7a7aba);transform:translateY(-2px);box-shadow:0 5px 15px #6a6aaa66}.add-btn{background:linear-gradient(135deg,#4caf50,#45a049)}.add-btn:hover{background:linear-gradient(135deg,#5cb860,#4caf50);transform:translateY(-2px);box-shadow:0 5px 15px #4caf5066}.remove-btn{padding:.5rem 1rem;background-color:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.remove-btn:hover{background-color:#d32f2f}.remove-btn-small{padding:.25rem .5rem;background-color:#f44336;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:600;transition:all .3s ease;font-size:1.2rem}.remove-btn-small:hover{background-color:#d32f2f}.edit-btn-small{padding:.25rem .5rem;background-color:#2196f3;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:600;transition:all .3s ease;font-size:1rem}.edit-btn-small:hover{background-color:#1976d2}.save-btn-small{padding:.25rem .5rem;background-color:#4caf50;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:600;transition:all .3s ease;font-size:1rem}.save-btn-small:hover{background-color:#45a049}.cancel-btn-small{padding:.25rem .5rem;background-color:#ff9800;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:600;transition:all .3s ease;font-size:1rem}.cancel-btn-small:hover{background-color:#f57c00}.student-edit-form{display:flex;gap:.5rem;flex:1;align-items:center}.student-edit-form .form-input{flex:1;padding:.5rem;font-size:.9rem}.voting-buttons-config{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.button-config-item{display:flex;align-items:center;gap:1rem;background-color:#3a3a5a;padding:1rem;border-radius:10px}.button-order{font-size:1.5rem;font-weight:700;color:#e0e0e0;min-width:40px}.color-input{width:60px;height:40px;border:2px solid #4a4a6a;border-radius:8px;cursor:pointer;background:none}.personnel-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}.personnel-table th,.personnel-table td{padding:1rem;text-align:left;border-bottom:1px solid #4a4a6a}.personnel-table th{background-color:#3a3a5a;font-weight:600;color:#e0e0e0}.personnel-table td{color:#fff}.table-input{padding:.5rem;font-size:1rem;border:2px solid #4a4a6a;border-radius:8px;background-color:#4a4a6a;color:#fff;outline:none;width:100%}.table-input:focus{border-color:#6a6aaa}.table-select{padding:.5rem;font-size:1rem;border:2px solid #4a4a6a;border-radius:8px;background-color:#4a4a6a;color:#fff;outline:none;cursor:pointer}.pin-cell{font-family:monospace;font-size:1.2rem;font-weight:700;color:#e0e0e0}.database-layout{margin-bottom:1.5rem}.courses-panel,.students-panel{background-color:#3a3a5a;padding:1.5rem;border-radius:10px;max-width:600px;margin:0 auto}.back-btn{padding:.5rem 1rem;background-color:#2196f3;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;margin-bottom:1rem}.back-btn:hover{background-color:#1976d2;transform:translateY(-2px)}.courses-panel h3,.students-panel h3{font-size:1.2rem;color:#e0e0e0;margin-bottom:.5rem}.students-panel-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #4a4a6a}.students-panel-course-name{font-size:1.8rem;font-weight:700;color:#4a4a8a;text-transform:uppercase;letter-spacing:2px}.course-list,.student-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.course-item,.student-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#4a4a6a;border-radius:8px;cursor:pointer;transition:all .3s ease}.course-item:hover,.student-item:hover{background-color:#5a5a7a}.course-item.selected{background-color:#4a4a8a;border:2px solid #6a6aaa}.course-name,.student-name{font-weight:600;color:#fff}.student-count{font-size:.85rem;color:#b0b0c0}.student-points{font-size:.85rem;color:#b0b0c0;background-color:#3a3a5a;padding:.25rem .5rem;border-radius:12px}.add-student-form{display:flex;gap:.5rem;margin-bottom:1rem}.observations-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.observation-config-item{display:flex;align-items:center;gap:1rem;background-color:#3a3a5a;padding:1rem;border-radius:10px}@media (max-width: 768px){.admin-config-container{padding:1rem}.admin-header{flex-direction:column;gap:1rem;text-align:center}.admin-title{font-size:1.8rem}.user-info,.admin-nav{flex-direction:column}.nav-btn{width:100%}.config-tabs{flex-direction:column}.tab-btn{width:100%}.database-layout{grid-template-columns:1fr}.button-config-item,.observation-config-item{flex-direction:column;align-items:stretch}.personnel-table{font-size:.85rem}.personnel-table th,.personnel-table td{padding:.5rem}}.password-display{display:flex;gap:.5rem}.toggle-password-btn{padding:.5rem 1rem;background-color:#4a4a8a;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;white-space:nowrap}.toggle-password-btn:hover{background-color:#5a5a9a;transform:translateY(-2px)}.success-message{background-color:#4caf50;color:#fff;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:600}.error-message{color:#f44336;font-size:.85rem;margin-top:.5rem;font-weight:600}.password-requirements{background-color:#3a3a5a;padding:1.5rem;border-radius:10px;margin-top:2rem}.password-requirements h4{color:#fff;margin-bottom:1rem;font-size:1.1rem}.password-requirements ul{list-style-type:disc;padding-left:1.5rem;color:#b0b0c0}.password-requirements li{margin-bottom:.5rem}.admin-audit-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.history-nav{background:linear-gradient(135deg,#2196f3,#1976d2)}.audit-main{max-width:1400px;margin:0 auto}.audit-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.audit-column{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:2px solid;animation:fadeIn .5s ease}.green-column{border-color:#4caf50}.critical-column{border-color:#f44336}.column-title{font-size:1.5rem;color:#fff;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.column-icon{font-size:1.8rem}.green-column .column-icon{color:#4caf50}.critical-column .column-icon{color:#f44336}.column-description{color:#b0b0c0;margin-bottom:1.5rem;font-size:.95rem}.user-list{display:flex;flex-direction:column;gap:1rem;max-height:500px;overflow-y:auto}.audit-user-card{background-color:#3a3a5a;border-radius:10px;padding:1.5rem;border-left:4px solid;transition:all .3s ease}.audit-user-card:hover{transform:translate(5px);box-shadow:0 5px 15px #0000004d}.audit-user-card.active{border-left-color:#4caf50}.audit-user-card.critical{border-left-color:#f44336}.user-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.user-card-name{font-size:1.1rem;font-weight:700;color:#fff}.status-badge{padding:.3rem .8rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.status-badge.active{background-color:#4caf50;color:#fff}.status-badge.critical{background-color:#f44336;color:#fff}.user-card-details{display:flex;flex-direction:column;gap:.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.detail-label{color:#b0b0c0}.detail-value{color:#e0e0e0;font-weight:600}.detail-value.warning{color:#ff9800}.pattern-varied{color:#4caf50}.audit-summary{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.summary-card{background-color:#3a3a5a;padding:2rem;border-radius:10px;text-align:center;transition:all .3s ease}.summary-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000004d}.summary-value{font-size:3rem;font-weight:700;color:#fff;margin-bottom:.5rem}.summary-label{font-size:1rem;color:#b0b0c0;font-weight:600}@media (max-width: 768px){.admin-audit-container{padding:1rem}.admin-header{flex-direction:column;gap:1rem;text-align:center}.admin-title{font-size:1.8rem}.user-info,.admin-nav{flex-direction:column}.nav-btn{width:100%}.audit-grid,.summary-stats{grid-template-columns:1fr}.summary-value{font-size:2.5rem}}.admin-history-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #4a4a6a}.admin-title{font-size:2.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.user-info{display:flex;align-items:center;gap:1rem;color:#e0e0e0}.user-role{background-color:#4a4a8a;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600}.logout-btn{padding:.5rem 1rem;background-color:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.logout-btn:hover{background-color:#d32f2f;transform:translateY(-2px)}.admin-nav{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}.nav-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;color:#fff}.nav-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000004d}.results-nav{background:linear-gradient(135deg,#4caf50,#45a049)}.config-nav{background:linear-gradient(135deg,#4a4a8a,#6a6aaa)}.audit-nav{background:linear-gradient(135deg,#9c27b0,#7b1fa2)}.history-main{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.history-filters{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.section-title{font-size:1.5rem;color:#e0e0e0;margin-bottom:1.5rem}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.9rem;color:#e0e0e0;font-weight:600}.filter-select,.filter-input{padding:.75rem 1rem;font-size:1rem;border:2px solid #4a4a6a;border-radius:10px;background-color:#3a3a5a;color:#fff;outline:none;transition:all .3s ease}.filter-select:focus,.filter-input:focus{border-color:#6a6aaa;background-color:#4a4a6a}.export-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;cursor:pointer;transition:all .3s ease}.export-btn:hover{background:linear-gradient(135deg,#42a5f5,#2196f3);transform:translateY(-2px);box-shadow:0 5px 15px #2196f366}.history-table-section{background-color:#2a2a4a;border-radius:15px;padding:2rem;border:1px solid #4a4a6a}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.history-table-container{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table th,.history-table td{padding:1rem;text-align:left;border-bottom:1px solid #4a4a6a}.history-table th{background-color:#3a3a5a;font-weight:600;color:#e0e0e0;position:sticky;top:0}.history-table td{color:#fff}.history-table tr:hover{background-color:#3a3a5a}.type-badge{display:inline-block;padding:.3rem .8rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;color:#fff}.no-data{text-align:center;color:#b0b0c0;font-style:italic;padding:2rem}@media (max-width: 768px){.admin-history-container{padding:1rem}.admin-header{flex-direction:column;gap:1rem;text-align:center}.admin-title{font-size:1.8rem}.user-info,.admin-nav{flex-direction:column}.nav-btn{width:100%}.filter-grid{grid-template-columns:1fr}.history-table{font-size:.85rem}.history-table th,.history-table td{padding:.5rem}}.master-control-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.master-login-card{max-width:400px;margin:100px auto;background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003}.master-title{font-size:28px;color:#333;margin-bottom:10px;text-align:center}.master-subtitle{color:#666;text-align:center;margin-bottom:30px;font-size:14px}.master-login-form{display:flex;flex-direction:column;gap:15px}.master-input{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}.master-input:focus{outline:none;border-color:#667eea}.master-login-btn{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.master-login-btn:hover{transform:translateY(-2px)}.back-btn{margin-top:20px;padding:10px 20px;background:#f0f0f0;color:#333;border:none;border-radius:8px;cursor:pointer;width:100%;transition:background .3s}.back-btn:hover{background:#e0e0e0}.master-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:20px 40px;border-radius:12px;margin-bottom:30px;box-shadow:0 4px 20px #0000001a}.header-actions{display:flex;gap:15px;align-items:center}.master-save-btn{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background .3s}.master-save-btn:hover{background:#45a049}.save-message{color:#4caf50;font-weight:600;font-size:14px}.master-logout-btn{padding:10px 20px;background:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background .3s}.master-logout-btn:hover{background:#d32f2f}.master-main{background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 20px #0000001a}.master-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:25px;border-radius:12px;text-align:center;color:#fff}.stat-value{font-size:36px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.9}.institutions-table-container{overflow-x:auto}.institutions-table{width:100%;border-collapse:collapse}.institutions-table thead{background:#f5f5f5}.institutions-table th{padding:15px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.institutions-table td{padding:15px;border-bottom:1px solid #e0e0e0}.institutions-table tbody tr:hover{background:#f9f9f9}.disabled-row{opacity:.5;background:#fafafa}.floor-number{font-weight:700;color:#667eea}.institution-name{cursor:pointer;color:#333}.institution-name:hover{color:#667eea;text-decoration:underline}.edit-name-container{display:flex;gap:5px;align-items:center}.edit-name-input{padding:5px 10px;border:2px solid #667eea;border-radius:4px;font-size:14px;width:200px}.save-name-btn{padding:5px 10px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600}.cancel-edit-btn{padding:5px 10px;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600}.key-cell{font-family:Courier New,monospace;font-size:13px;color:#666;cursor:pointer}.key-cell:hover{color:#667eea;text-decoration:underline}.edit-key-container{display:flex;gap:5px;align-items:center}.edit-key-input{padding:5px 10px;border:2px solid #667eea;border-radius:4px;font-size:13px;font-family:Courier New,monospace;width:120px}.save-key-btn{padding:5px 10px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:12px}.user-key{color:#667eea}.admin-key{color:#764ba2}.date-cell{font-size:13px;color:#666}.days-cell{font-size:14px;font-weight:600;color:#667eea;text-align:center}.duration-cell{font-size:13px;color:#666;cursor:pointer}.duration-cell:hover{color:#667eea;text-decoration:underline}.status-cell{text-align:center}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.status-badge.active{background:#e8f5e9;color:#4caf50}.status-badge.disabled{background:#ffebee;color:#f44336}.actions-cell{text-align:center}.toggle-btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:13px;transition:all .3s}.toggle-btn.active{background:#f44336;color:#fff}.toggle-btn.active:hover{background:#d32f2f}.toggle-btn.disabled{background:#4caf50;color:#fff}.toggle-btn.disabled:hover{background:#45a049}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-white: #ffffff;--text-main: #f8fafc;--text-muted: #94a3b8;--accent-gold: #f59e0b;--accent-blue: #3b82f6;--accent-rose: #f43f5e;--color-positive: #10b981;--color-neutral: #f59e0b;--color-negative: #f43f5e;--bg-noir: #020617;--bg-glass: rgba(15, 23, 42, .6);--border-glass: rgba(255, 255, 255, .1);--shadow-premium: 0 25px 50px -12px rgba(0, 0, 0, .7);--border-color: rgba(255, 255, 255, .1)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:Inter,Outfit,sans-serif;background-color:var(--bg-primary);color:var(--text-main);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}.font-montserrat{font-family:Montserrat,sans-serif}.font-inter{font-family:Inter,sans-serif}.bg-industrial-grid{background-color:var(--bg-primary);background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px}.bg-radial-glow{background:radial-gradient(circle at 50% 50%,rgba(37,99,235,.15) 0%,transparent 70%)}.text-gold{color:var(--accent-gold)}.bg-gold{background-color:var(--accent-gold)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.w-full{width:100%}.max-w-7xl{max-width:80rem;width:100%}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-24{margin-bottom:6rem}.mt-12{margin-top:3rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-12{gap:3rem}.p-8{padding:2rem}.px-8{padding-left:2rem;padding-right:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.font-black{font-weight:900}.uppercase{text-transform:uppercase}.tracking-tight{letter-spacing:-.025em}.tracking-tighter{letter-spacing:-.05em}.tracking-widest{letter-spacing:.1em}.italic{font-style:italic}.section-padding{padding-top:6rem;padding-bottom:6rem}@media (min-width: 1024px){.section-padding{padding-top:10rem;padding-bottom:10rem}}.glass-container{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass)}.glass-card{background:#ffffff08;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .8s ease-out forwards}@keyframes glowPulse{0%,to{opacity:.85;text-shadow:0 0 20px rgba(59,130,246,.3),0 0 40px rgba(59,130,246,.2),0 0 60px rgba(59,130,246,.1)}50%{opacity:1;text-shadow:0 0 30px rgba(59,130,246,.6),0 0 60px rgba(59,130,246,.4),0 0 90px rgba(59,130,246,.2),0 0 120px rgba(59,130,246,.1)}}@keyframes pulseRing{0%{box-shadow:0 0 #f59e0b99}70%{box-shadow:0 0 0 8px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}@keyframes pulseDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.85)}}.pending-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background-color:#f59e0b;flex-shrink:0;animation:pulseDot 1.2s ease-in-out infinite,pulseRing 1.8s ease-in-out infinite}::-webkit-scrollbar-track{background:#2a2a4a}::-webkit-scrollbar-thumb{background:#4a4a6a;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#5a5a7a}.container{max-width:1200px;margin:0 auto;padding:2rem}.card{background-color:#2a2a4a;border-radius:15px;padding:1.5rem;box-shadow:0 4px 15px #0000004d;border:1px solid #4a4a6a}.text-center{text-align:center}.mt-2{margin-top:2rem}.mb-2{margin-bottom:2rem}.mt-1{margin-top:1rem}.mb-1{margin-bottom:1rem}
