:root{--primary: #59803c;--primary-dark: #4e7135;--primary-light: #6a9848;--danger: #d63031;--danger-dark: #b71c1c;--danger-light: #d93c3b;--neutral-dark: #2c3e50;--neutral-medium: #6c757d;--neutral-light: #e0e0e0;--background-main: #e0e0e0;--background-card: #d6d6d6;--text-color: #333333;--shadow-sm: 0 4px 8px rgba(0, 0, 0, .1);--shadow-md: 0 6px 18px rgba(0, 0, 0, .08);--shadow-primary: 0 4px 12px rgba(78, 113, 60, .2);--shadow-primary-hover: 0 6px 15px rgba(89, 128, 60, .3);--shadow-danger: 0 4px 12px rgba(255, 118, 117, .2);--shadow-danger-hover: 0 6px 15px rgba(255, 118, 117, .3)}@font-face{font-family:Cabinet;src:url(/assets/cabinet-DZ-mBhZu.ttf) format("truetype");font-weight:400;font-style:normal}body{background-color:var(--background-main);color:var(--text-color);transition:background-color .3s,color .3s}*{font-family:Cabinet,sans-serif}body.dark-mode{--primary: #59803c;--primary-dark: #4e7135;--primary-light: #6a9848;--danger: #d63031;--danger-dark: #b71c1c;--neutral-dark: #f8f9fa;--neutral-medium: #d1d8e0;--neutral-light: #a5b1c2;--background-main: #1c2226;--background-card: #242c35;--text-color: #f8f9fa;--shadow-sm: 0 4px 8px rgba(0, 0, 0, .25);--shadow-md: 0 6px 18px rgba(0, 0, 0, .2);--shadow-primary: 0 4px 12px rgba(78, 113, 60, .3);--shadow-primary-hover: 0 6px 15px rgba(89, 128, 60, .4);--shadow-danger: 0 4px 12px rgba(214, 48, 49, .3);--shadow-danger-hover: 0 6px 15px rgba(214, 48, 49, .4)}@media(max-width:600px){body,#root,.admin-home-container,.generico,.home-studente,.iscrizione-corso-studente,.riassunto-corsi-studente{height:auto!important;min-height:100vh;justify-content:flex-start!important;overflow-y:auto!important}#root{padding-top:10px;padding-bottom:20px;box-sizing:border-box}}.homepage-container{max-width:850px;margin:80px auto;padding:45px;background-color:var(--background-main);border-radius:15px;box-shadow:var(--shadow-md);text-align:center;transition:all .3s;height:80vh;display:flex;flex-direction:column;justify-content:center}.appName{color:var(--primary-light);font-size:58px;font-weight:800;letter-spacing:-.5px;transition:color .3s}.h3{color:var(--neutral-dark);margin:35px 0 25px;font-size:24px;font-weight:500;transition:color .3s}#ass{width:70%;height:4px;background-color:var(--primary-light);margin:15px auto 30px;border-radius:4px;transition:background-color .3s}.role-selection{display:flex;justify-content:center;flex-wrap:wrap;gap:20px;margin-top:35px;padding:20px}.role-selection button{transition:all .4s cubic-bezier(.25,.8,.25,1)}.role-selection:hover button{opacity:.5;filter:grayscale(.8);transform:scale(.95)}.role-selection button:hover{opacity:1!important;filter:grayscale(0)!important;transform:scale(1.1) translateY(-10px)!important;z-index:10;box-shadow:0 15px 30px #0003!important;border-color:var(--primary-light)}.homepage-container button{padding:16px 30px;min-width:160px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.8px;background-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary);position:relative;overflow:hidden;z-index:1}.homepage-container button:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--primary-dark);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;z-index:-1}.homepage-wrapper{display:flex;flex-direction:column;justify-content:center;min-height:100vh;width:100%;position:relative}.homepage-container button:hover{transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.homepage-container button:hover:before{transform:scaleX(1)}.homepage-container button:active{transform:translateY(1px)}.theme-toggle-container{position:absolute;top:20px;right:20px}.theme-toggle-container button{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;padding:0;min-width:unset;background-color:var(--background-main);color:var(--primary);box-shadow:var(--shadow-sm);border:2px solid var(--primary-light);transition:all .3s ease}.theme-toggle-container button:before{display:none}.theme-toggle-container button:hover{transform:rotate(20deg) scale(1.1);background-color:var(--primary);color:#fff}.theme-toggle-container svg{width:24px;height:24px}@media(max-width:768px){.homepage-container{padding:30px;margin:40px 20px;border-radius:12px}.appName{font-size:36px}.h3{font-size:22px}.button-group{gap:15px}}.transition-overlay{position:fixed;border-radius:50%;z-index:9999;pointer-events:none;transform:translate(-50%,-50%) scale(0);background-color:var(--primary);transition:transform .8s cubic-bezier(.77,0,.175,1);will-change:transform}.transition-overlay.expanded{transform:translate(-50%,-50%) scale(100)}@media(max-width:600px){.homepage-container{padding:0;margin:auto;overflow:hidden;min-height:85vh;display:flex;flex-direction:column;justify-content:center;width:90%}.appName{font-size:36px;padding:0 25px;margin-top:20px}.h3{font-size:20px;padding:0 25px;margin-bottom:40px}.role-selection{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;scroll-snap-type:x mandatory;gap:15px;width:100%;margin-top:10px;padding:20px 50% 50px;box-sizing:border-box;scrollbar-width:none;align-items:center}.role-selection::-webkit-scrollbar{display:none}.role-selection button{scroll-snap-align:center;flex-shrink:0;width:220px;padding:20px;margin:0;opacity:.5;transform:scale(.85);transition:all .4s cubic-bezier(.34,1.56,.64,1);filter:grayscale(.5)}.role-selection button.active{opacity:1;transform:scale(1.15);z-index:10;box-shadow:0 15px 35px #59803c66;background-color:var(--primary);color:#fff;border:2px solid white;filter:grayscale(0)}}.toggle-switch{display:flex;align-items:center;gap:10px;cursor:pointer}.toggle-switch .icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-color);transition:color .3s ease}.switch-label{position:relative;display:inline-block;width:50px;height:24px}.switch-label .checkbox{opacity:0;width:0;height:0}.switch-label .slider{position:absolute;inset:0;background-color:var(--neutral-light);border-radius:34px;transition:background-color .3s ease}.switch-label .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background-color:var(--background-main);border-radius:50%;transition:transform .3s ease}.checkbox:checked+.slider{background-color:var(--primary)}.checkbox:checked+.slider:before{transform:translate(26px)}.spinner-container{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background:transparent;z-index:9999}.spinner{width:40px;height:40px;border:4px solid #b0b0b0;border-top:4px solid #333333;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-container{max-width:450px;margin:80px auto;padding:40px;background-color:var(--background-main);border-radius:12px;box-shadow:var(--shadow-md);text-align:center}.login-title{color:var(--primary-light);font-size:32px;font-weight:700;margin-bottom:30px;letter-spacing:-.5px}.login-separator{width:60%;height:3px;background-color:var(--primary-light);margin:20px auto 30px;border-radius:2px}.login-form{display:flex;flex-direction:column;gap:25px;margin-top:30px}.form-group{display:flex;flex-direction:column;text-align:left}.form-group label{color:var(--neutral-dark);margin-bottom:8px;font-weight:600;font-size:16px}.form-group input{padding:14px;border:2px solid var(--neutral-light);border-radius:8px;font-size:16px;transition:all .2s ease}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #79b34e40;outline:none}.submit-button{padding:14px 30px;margin-top:20px;background-color:var(--primary);color:#fff;border:none;border-radius:12px;font-size:17px;font-weight:600;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-primary)}.submit-button:hover{background-color:var(--primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.back-link{margin-top:25px;display:inline-block;color:var(--neutral-medium);text-decoration:none;font-size:15px}.back-link:hover{color:var(--primary);text-decoration:underline}@media(max-width:600px){.login-container{margin:40px 20px;padding:25px}.login-title{font-size:26px}.form-group input{padding:12px}.submit-button{padding:12px 20px}}.riassunto-corsi-studente{max-width:1200px;margin:80px auto;padding:40px;background-color:var(--background-main);border-radius:12px;box-shadow:var(--shadow-md);text-align:center}.riassunto-corsi-studente h1{color:var(--primary-light);margin-bottom:25px;font-size:32px;font-weight:700;letter-spacing:-.5px}.riassunto-corsi-studente button{display:inline-block;width:auto;margin:15px 10px 30px;padding:14px 28px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px;background-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.riassunto-corsi-studente button:hover{background-color:var(--primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.riassunto-corsi-studente p{margin:30px 0;color:var(--neutral-medium);font-size:18px;font-weight:500}.riassunto-corsi-studente .orario-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:25px;box-shadow:var(--shadow-sm);overflow:hidden;background-color:var(--background-card);table-layout:fixed}.riassunto-corsi-studente .orario-table th,.riassunto-corsi-studente .orario-table td{padding:16px 12px;text-align:center;color:var(--text-color);border:1px solid rgba(121,179,78,.25);width:20%}.riassunto-corsi-studente .orario-table th{background-color:var(--primary);color:#fff;font-weight:600;letter-spacing:.3px;border-bottom-width:2px}.riassunto-corsi-studente .corso-cell{vertical-align:top;background-color:#79b34e26}.riassunto-corsi-studente .empty-cell{background-color:var(--background-card)}.riassunto-corsi-studente .corso-item{padding:12px;margin-bottom:10px;border-radius:8px;box-shadow:var(--shadow-sm)}.riassunto-corsi-studente .corso-0{background-color:#6c5ce71a;border-left:4px solid var(--primary)}.riassunto-corsi-studente .corso-1{background-color:#2196f31a;border-left:4px solid #2196f3}.riassunto-corsi-studente .corso-2{background-color:#4caf501a;border-left:4px solid #4caf50}.riassunto-corsi-studente .corso-3{background-color:#ff98001a;border-left:4px solid #ff9800}.riassunto-corsi-studente .corso-4{background-color:#f443361a;border-left:4px solid #f44336}.riassunto-corsi-studente .corso-titolo{font-weight:500;text-align:left;position:relative;color:var(--neutral-dark)}.riassunto-corsi-studente .info-icon{display:inline-block;width:20px;height:20px;border-radius:50%;background-color:var(--primary);color:#fff;font-size:12px;text-align:center;line-height:20px;margin-left:8px;cursor:pointer;position:relative}.riassunto-corsi-studente .info-icon .tooltip{visibility:hidden;width:220px;background-color:var(--background-card);color:var(--text-color);text-align:left;border-radius:8px;padding:8px;position:absolute;z-index:1;bottom:140%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s ease,transform .3s ease;font-weight:400;font-size:12px;box-shadow:var(--shadow-md);line-height:1.4}.riassunto-corsi-studente .info-icon .tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:8px;border-style:solid;border-color:var(--background-card) transparent transparent transparent}.riassunto-corsi-studente .orario-table{overflow:visible}.riassunto-corsi-studente .info-icon:hover .tooltip{visibility:visible;opacity:1;transform:translate(-50%) translateY(-5px)}.riassunto-corsi-studente .error{color:#f44336;padding:15px;margin:20px 0;border-radius:8px;background-color:#f443361a}@media(max-width:768px){.riassunto-corsi-studente{padding:25px;margin:40px 20px;border-radius:10px}.riassunto-corsi-studente h1{font-size:26px;margin-bottom:15px}.riassunto-corsi-studente button{width:100%;margin:10px 0;font-size:15px;padding:12px 20px}.riassunto-corsi-studente .orario-table{display:none}.riassunto-corsi-studente .mobile-view{display:block!important}.riassunto-corsi-studente .fascia-oraria{background-color:var(--primary);color:#fff;padding:10px;border-radius:8px 8px 0 0;font-weight:600;margin-top:20px}.riassunto-corsi-studente .corso-mobile-card{padding:15px;margin-bottom:15px;border-radius:0 0 8px 8px;box-shadow:var(--shadow-sm);text-align:left}.riassunto-corsi-studente .corso-mobile-card.corso-0{background-color:#79b34e40;border-left:4px solid var(--primary)}.riassunto-corsi-studente .corso-mobile-card.corso-1{background-color:#2196f31a;border-left:4px solid #2196f3}.riassunto-corsi-studente .corso-mobile-card.corso-2{background-color:#4caf501a;border-left:4px solid #4caf50}.riassunto-corsi-studente .corso-mobile-card.corso-3{background-color:#ff98001a;border-left:4px solid #ff9800}.riassunto-corsi-studente .corso-mobile-card.corso-4{background-color:#f443361a;border-left:4px solid #f44336}.riassunto-corsi-studente .corso-mobile-card:last-child{margin-bottom:25px}.riassunto-corsi-studente .corso-mobile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.riassunto-corsi-studente .corso-mobile-titolo{font-weight:600;color:var(--primary-light);font-size:16px}.riassunto-corsi-studente .corso-mobile-aula{background-color:var(--primary-light);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.riassunto-corsi-studente .corso-mobile-aula:before{content:"Classe: "}.riassunto-corsi-studente .corso-mobile-dettagli{color:var(--neutral-medium);font-size:14px;line-height:1.4}.riassunto-corsi-studente .corso-mobile-footer{margin-top:12px;padding-top:8px;border-top:1px solid rgba(121,179,78,.25);display:flex;justify-content:flex-end;font-size:13px;color:var(--neutral-dark)}.riassunto-corsi-studente .corso-mobile-footer div:first-child{display:none}.riassunto-corsi-studente .mobile-empty{text-align:center;padding:15px;background-color:var(--background-card);color:var(--neutral-medium);border-radius:0 0 8px 8px;font-style:italic;margin-bottom:15px}.riassunto-corsi-studente .mobile-toggle{background-color:var(--primary-light);color:#fff;padding:12px;border-radius:12px;margin:20px auto 0;font-weight:600;font-size:14px;display:inline-block;text-align:center;width:100%;max-width:250px;box-shadow:var(--shadow-sm);cursor:pointer}}.riassunto-corsi-studente .mobile-view{display:none}@media(max-width:480px){.riassunto-corsi-studente{padding:15px;margin:20px 10px}.riassunto-corsi-studente h1{font-size:22px}.riassunto-corsi-studente .corso-mobile-card{padding:12px}.riassunto-corsi-studente .corso-mobile-titolo{font-size:15px}}.corsi-disponibili-studente{max-width:1200px;margin:80px auto;padding:40px;background-color:var(--background-main);border-radius:12px;box-shadow:var(--shadow-md);text-align:center}.corsi-disponibili-studente header{margin-bottom:30px}.corsi-disponibili-studente h1{color:var(--primary-light);margin-bottom:15px;font-size:32px;font-weight:700;letter-spacing:-.5px}.corsi-disponibili-studente h3{color:var(--neutral-dark);margin-bottom:25px;font-size:18px;font-weight:400}.corsi-disponibili-studente button{display:inline-block;width:auto;margin:0 10px 20px;padding:14px 28px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px;background-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.corsi-disponibili-studente button:hover{background-color:var(--primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.corsi-disponibili-studente table{width:100%;border-collapse:separate;border-spacing:0;margin-top:25px;box-shadow:var(--shadow-sm);border-radius:10px;overflow:hidden;background-color:var(--background-card)}.corsi-disponibili-studente th,.corsi-disponibili-studente td{padding:16px 12px;text-align:center;color:var(--text-color);border:1px solid rgba(121,179,78,.15)}.corsi-disponibili-studente th{background-color:var(--primary);color:#fff;font-weight:600;letter-spacing:.3px;border-bottom-width:2px}.corsi-disponibili-studente td{border-top:none;border-bottom-width:1px}.corsi-disponibili-studente tr:last-child td{border-bottom:none}.corsi-disponibili-studente .occupied-cell{background-color:#79b34e40;font-weight:500;color:var(--text-color)}.corsi-disponibili-studente .empty-cell{background-color:var(--background-card);border-left-width:1px}.corsi-disponibili-studente p{margin:30px 0;color:var(--neutral-medium);font-size:18px;font-weight:500}.corsi-accordion-container{width:100%;margin-top:20px}.corso-accordion{margin-bottom:15px;border-radius:8px;overflow:hidden;background-color:var(--background-card);box-shadow:var(--shadow-sm)}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background-color:var(--primary);color:#fff;cursor:pointer;font-weight:600}.accordion-header h3{margin:0;color:#fff!important;font-size:16px!important;font-weight:600!important}.accordion-icon{transition:transform .3s ease;font-size:12px}.accordion-icon.expanded{transform:rotate(180deg)}.accordion-content{padding:15px;background-color:var(--background-card)}.accordion-item{margin-bottom:12px}.accordion-item strong{display:block;margin-bottom:4px;color:var(--primary-light)}.accordion-item p{margin:0 0 8px!important;color:var(--text-color)!important;font-size:15px!important;font-weight:400!important}.orari-container{display:flex;flex-direction:column;gap:8px;margin-top:5px}.orario-box{background-color:#79b34e36;border-radius:6px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;border-left:3px solid var(--primary)}.orario-time{font-weight:600;color:var(--text-color)}.orario-seats{background-color:var(--primary);color:#fff;padding:4px 8px;border-radius:12px;font-size:13px;font-weight:500}@media(max-width:768px){.corsi-accordion-container{display:block}.corsi-disponibili-studente table{display:none}.corsi-disponibili-studente{padding:25px;margin:40px 20px;border-radius:10px}.corsi-disponibili-studente h1{font-size:26px;margin-bottom:15px}.corsi-disponibili-studente h3{font-size:16px;margin-bottom:20px}.corsi-disponibili-studente button{width:100%;margin:10px 0;font-size:15px;padding:12px 20px}}@media(min-width:769px){.corsi-accordion-container{display:none}}.home-studente{max-width:800px;margin:80px auto;padding:40px;background-color:var(--background-main);border-radius:12px;box-shadow:var(--shadow-md);text-align:center;display:flex;flex-direction:column;align-items:center}.home-studente h1{color:var(--primary-light);font-size:38px;font-weight:700;margin-bottom:30px;letter-spacing:-.5px}.home-studente .btn{padding:14px 30px;margin:12px 0;width:80%;max-width:400px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px}.home-studente .btn-primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 12px #79b34e40}.home-studente .btn-primary:hover{background-color:var(--primary-dark);transform:translateY(-3px);box-shadow:0 6px 15px #79b34e40}.home-studente .btn-danger{background-color:var(--danger);color:#fff;box-shadow:0 4px 12px #d630314d;margin-top:25px}.home-studente .btn-danger:hover{background-color:var(--danger-dark);transform:translateY(-3px);box-shadow:0 6px 15px #d6303166}.home-studente .login-separator{width:60%;height:3px;background-color:var(--primary-light);margin:20px auto 30px;border-radius:2px}.home-studente .actions-container{display:flex;flex-direction:column;gap:15px;width:100%;margin-top:20px}@media(max-width:700px){.home-studente{margin:40px 20px;padding:25px}.home-studente h1{font-size:26px;margin-bottom:20px}.home-studente .btn{padding:12px 20px;font-size:14px;width:100%}}.iscrizione-corso-studente{max-width:1000px;margin:80px auto;padding:40px;background-color:var(--background-main);border-radius:12px;box-shadow:var(--shadow-md);text-align:center}.iscrizione-corso-studente header{margin-bottom:30px;position:relative}.iscrizione-corso-studente h1{color:var(--primary-light);margin-bottom:15px;font-size:32px;font-weight:700;letter-spacing:-.5px}.iscrizione-corso-studente h2{color:var(--neutral-dark);margin-bottom:25px;font-size:24px;font-weight:600}.iscrizione-corso-studente h3{color:var(--neutral-dark);margin:20px 0 15px;font-size:18px;font-weight:500}.iscrizione-corso-studente button{display:inline-block;width:auto;margin:0 10px 20px;padding:14px 28px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px;background-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.iscrizione-corso-studente button:hover{background-color:var(--primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.iscrizione-corso-studente button:disabled{background-color:var(--neutral-medium);transform:none;cursor:not-allowed;opacity:.65;box-shadow:var(--shadow-sm)}.iscrizione-corso-studente header button{position:absolute;left:0;top:0;padding:10px 18px;font-size:14px}.iscrizione-corso-studente .card{background-color:var(--background-card);padding:30px;margin-bottom:0;border-radius:10px;box-shadow:var(--shadow-sm)}.iscrizione-corso-studente .form-group{margin-bottom:20px;text-align:left}.iscrizione-corso-studente label{display:block;margin-bottom:8px;font-weight:600;color:var(--neutral-dark)}.iscrizione-corso-studente select{width:100%;padding:14px;border:2px solid var(--primary);border-radius:8px;font-size:16px;color:var(--text-color);background-color:var(--background-main);transition:all .2s ease}.iscrizione-corso-studente select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #79b34e40;outline:none}.iscrizione-corso-studente .course-details{margin-top:25px;background-color:var(--background-main);padding:20px;border-radius:8px;text-align:left;border-left:3px solid var(--primary-light)}.iscrizione-corso-studente .course-details p{margin:10px 0;color:var(--text-color)}.iscrizione-corso-studente .course-details .btn{width:100%;margin-top:20px;background-color:var(--primary-light)}.iscrizione-corso-studente .course-details .btn:hover{background-color:var(--primary);box-shadow:var(--shadow-primary-hover)}.iscrizione-corso-studente .disiscrizione-section{margin-top:40px;padding-top:20px}.iscrizione-corso-studente .btn-danger{background-color:#d63031;box-shadow:var(--shadow-danger)}.iscrizione-corso-studente .btn-danger:hover{background-color:#b71c1c;box-shadow:var(--shadow-danger-hover)}.iscrizione-corso-studente .btn-danger:disabled{background-color:var(--primary-light);color:#fff;opacity:.5}.message-popup{position:fixed;top:-100px;left:50%;transform:translate(-50%);width:auto;min-width:300px;max-width:80%;padding:18px 25px;background-color:var(--background-card);border-radius:8px;box-shadow:0 5px 20px #0003;z-index:1000;text-align:center;font-weight:600;font-size:16px;transition:top .4s ease-in-out;border-left:5px solid}.message-popup.error{border-left-color:var(--danger);color:var(--danger-dark);background-color:#d6303126}.message-popup.info{border-left-color:var(--primary);color:var(--primary-light);background-color:#79b34e40}.message-popup.show{top:20px}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.message-popup.hide{animation:fadeOut .5s forwards}@media(max-width:768px){.iscrizione-corso-studente{padding:20px;margin:20px 15px;border-radius:8px}.iscrizione-corso-studente h1{font-size:24px;margin-bottom:10px}.iscrizione-corso-studente h2{font-size:20px;margin-bottom:15px}.iscrizione-corso-studente h3{font-size:16px;margin:15px 0 10px}.iscrizione-corso-studente .card{padding:15px;margin-bottom:20px}.iscrizione-corso-studente button{width:100%;margin:10px 0;padding:10px 16px;font-size:14px;border-radius:12px}.iscrizione-corso-studente header button{position:relative;display:block;width:100%;margin:0 auto 15px;padding:8px 16px;font-size:13px}.iscrizione-corso-studente select{padding:10px;font-size:14px;border-radius:6px}.iscrizione-corso-studente .form-group{margin-bottom:15px}.iscrizione-corso-studente label{font-size:14px;margin-bottom:5px}.iscrizione-corso-studente .course-details{padding:15px;margin-top:15px}.iscrizione-corso-studente .course-details p{font-size:14px;margin:8px 0}.iscrizione-corso-studente .disiscrizione-section{margin-top:25px}.message-popup{top:auto;bottom:-100px;min-width:220px;max-width:90%;padding:12px;font-size:13px;border-left-width:4px;border-radius:8px 8px 0 0}.message-popup.show{top:auto;bottom:20px}.message-popup.hide{bottom:-100px}}@media(max-width:480px){.iscrizione-corso-studente{padding:15px;margin:15px 10px}.iscrizione-corso-studente h1{font-size:22px}.iscrizione-corso-studente .card,.iscrizione-corso-studente .course-details{padding:12px}.message-popup.show{bottom:25px}}.generico{max-width:900px;margin:50px auto;padding:30px;background-color:var(--background-main);border-radius:12px;box-shadow:var(--shadow-md)}.generico h2{color:var(--primary-light);margin-bottom:25px;font-size:32px;font-weight:700;letter-spacing:-.5px;text-align:center}.generico h3{color:var(--primary-light);margin:30px 0 20px;font-size:24px;font-weight:600;text-align:center}.generico button{display:inline-block;width:auto;margin:15px 0;padding:12px 24px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px;background-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.generico button:hover{background-color:var(--primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-primary-hover)}.generico button[type=button]{background-color:var(--primary);box-shadow:var(--shadow-md)}.generico button[type=button]:hover{background-color:var(--primary-dark)}.generico form{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:25px 0;background-color:var(--background-card);padding:25px;border-radius:10px;box-shadow:var(--shadow-sm)}.generico form>div{display:flex;flex-direction:column;margin-bottom:15px}.generico label{font-weight:600;margin-bottom:8px;color:var(--neutral-dark);text-align:left}.generico input[type=text],.generico input[type=number],.generico input[type=email],.generico textarea,.generico select{padding:12px 15px;border:2px solid var(--primary-light);border-radius:8px;font-size:15px;transition:border .3s ease,box-shadow .3s ease;background-color:var(--background-card);color:var(--text-color)}.generico input[type=text]:focus,.generico input[type=number]:focus,.generico textarea:focus,.generico select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #79b34e3d;outline:none}.generico textarea{resize:vertical;min-height:120px}.generico input[type=checkbox]{margin-right:10px;width:18px;height:18px;accent-color:var(--primary)}.generico .checkbox-group{display:flex;flex-direction:row;align-items:center;margin-bottom:8px}.generico table{width:100%;border-collapse:collapse;margin-top:20px;background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.generico table th,.generico table td{border:1px solid #ddd;padding:12px 15px;text-align:left}.generico table th{background-color:var(--primary-light);color:#000;font-weight:600;letter-spacing:.3px}.generico table tr:nth-child(2n){background-color:#f9f9f9}.generico table tr:hover{background-color:#f1f1f1}.generico table button{padding:8px 16px;margin:0;background-color:var(--danger);box-shadow:var(--shadow-danger)}.generico table button:hover{background-color:var(--danger-dark);box-shadow:var(--shadow-danger-hover)}.generico table{width:100%;border-collapse:separate;border-spacing:0;margin-top:25px;box-shadow:var(--shadow-sm);overflow:hidden;background-color:var(--background-card)}.generico th,.generico td{padding:16px 12px;text-align:center;color:var(--text-color)}.generico th{background-color:var(--primary-light);font-weight:600;letter-spacing:.3px}.generico td{background-color:var(--background-card)}@media(max-width:768px){.generico{padding:20px;margin:15px;border-radius:10px}.generico h2{font-size:26px}.generico form{grid-template-columns:1fr}.generico form>div{margin-bottom:20px}.generico table{display:block;overflow-x:auto;white-space:nowrap}.generico button{width:100%;padding:12px 20px;font-size:14px}}
