.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:transparent;padding:2rem}.login-container{width:100%;max-width:450px}.login-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card h1{text-align:center;color:#667eea;font-size:2rem;margin-bottom:.5rem}.login-title.clickable-title{cursor:pointer;transition:all .3s;-webkit-user-select:none;user-select:none}.login-title.clickable-title:hover{color:#5568d3;transform:scale(1.05)}.login-title.clickable-title:active{transform:scale(.98)}.login-card h2{text-align:center;color:#333;font-size:1.5rem;margin-bottom:2rem;font-weight:600}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1.5rem;border-left:4px solid #c33}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.form-submit{display:flex;justify-content:center;margin-top:1.5rem}.form-submit .btn{width:100%;max-width:300px}.switch-mode{text-align:center;margin-top:1.5rem;color:#666}.link-button{background:none;border:none;color:#667eea;cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.link-button:hover{color:#5568d3}.demo-credentials{margin-top:2rem;padding:1rem;background:#f8f9fa;border-radius:8px;text-align:center;font-size:.9rem}.demo-credentials p{margin:.5rem 0}.demo-credentials code{background:#e9ecef;padding:.25rem .5rem;border-radius:4px;font-family:monospace}.exercice-card{transition:transform .2s,box-shadow .2s;position:relative}.exercice-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.exercice-card.selected{border:3px solid #667eea;background:#f0f4ff}.exercice-select{position:absolute;top:1rem;right:1rem}.select-checkbox{transform:scale(1.5);cursor:pointer}.difficulte{color:#ffc107;font-size:.875rem}.exercice-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.tag{background:#e9ecef;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;color:#495057}.exercice-meta,.exercice-header{position:relative;z-index:1}.exercices-page{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{color:#fff;font-size:2rem;font-weight:600}.generate-buttons{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}.header-actions{display:flex;gap:1rem}.export-card{background:#e8f5e9;border-left:4px solid #28a745}.export-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.export-actions{display:flex;gap:1rem;flex-wrap:wrap}.exercices-list{display:grid;gap:1.5rem}.dms-page{animation:fadeIn .3s}.dms-list{display:grid;gap:1.5rem}.dm-card{transition:transform .2s,box-shadow .2s}.dm-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.dm-header{margin-bottom:1rem}.dm-title{font-size:1.5rem;font-weight:600;color:#333;margin-bottom:.75rem}.dm-meta{display:flex;gap:1rem;flex-wrap:wrap}.dm-instructions{background:#f8f9fa;padding:1rem;border-radius:8px;margin:1rem 0;line-height:1.6}.dm-date{margin:1rem 0;color:#666;font-size:1rem}.create-exercice-page{animation:fadeIn .3s}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.create-dm-page{animation:fadeIn .3s}.exercices-selection{max-height:400px;overflow-y:auto;border:2px solid #e0e0e0;border-radius:8px;padding:1rem}.exercice-checkbox{display:block;padding:1rem;margin-bottom:.75rem;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s}.exercice-checkbox:hover{border-color:#667eea;background:#f8f9ff}.exercice-checkbox.selected{border-color:#667eea;background:#e8ebff}.exercice-checkbox input[type=checkbox]{margin-right:1rem;transform:scale(1.2)}.exercice-checkbox-content{display:flex;flex-direction:column;gap:.5rem}.exercice-checkbox-meta{font-size:.875rem;color:#666}.exercice-checkbox-enonce{font-size:.9rem;color:#333;margin-top:.5rem}.no-exercices{padding:2rem;text-align:center;color:#666;background:#f8f9fa;border-radius:8px}.generate-exercices-page{animation:fadeIn .3s}.types-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.type-item{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;transition:all .3s}.type-item:hover{border-color:#667eea;background:#f8f9ff}.type-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;flex:1}.type-checkbox input[type=checkbox]{transform:scale(1.2)}.type-label{font-weight:500;font-size:1rem}.count-input{width:60px;padding:.5rem;border:2px solid #e0e0e0;border-radius:6px;text-align:center}.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-checkbox input[type=checkbox]{transform:scale(1.2)}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.export-buttons{display:flex;gap:1rem}.exercices-preview{display:grid;gap:1rem}.preview-exercice{padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.preview-exercice-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.preview-enonce{line-height:1.6;color:#333}.points-editable{cursor:pointer!important;transition:all .2s!important;position:relative!important;display:inline-block!important;z-index:1000!important;pointer-events:auto!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important;border:2px solid transparent!important;touch-action:manipulation!important}.points-editable:hover{background-color:#ff9800!important;transform:scale(1.1)!important;box-shadow:0 4px 8px #ff980066!important;border-color:#ff6f00!important}.points-editable:active{transform:scale(.95)!important;background-color:#f57c00!important}.points-editable:before{content:"✏️ ";font-size:.9em;opacity:0;transition:opacity .2s;margin-right:.2em}.points-editable:hover:before{opacity:1}.points-editor{display:inline-flex;align-items:center;gap:.25rem}.points-input{width:50px;padding:.25rem;border:2px solid #667eea;border-radius:4px;text-align:center;font-weight:700}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s}.modal-content{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;width:90%;animation:slideUp .3s}.modal-content h2{margin-top:0;margin-bottom:1.5rem;color:#333}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.form-input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-input:focus{outline:none;border-color:#667eea}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.preview-header{flex-direction:column;align-items:flex-start}.export-buttons{width:100%;flex-direction:column}.export-buttons .btn{width:100%}}.app{min-height:100vh;position:relative;z-index:1}.navbar{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #0000001a;padding:1rem 2rem;position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-title{font-size:1.5rem;color:#667eea;font-weight:600}.clickable-title{cursor:pointer;transition:all .3s;-webkit-user-select:none;user-select:none}.clickable-title:hover{color:#5568d3;transform:scale(1.05)}.clickable-title:active{transform:scale(.98)}.nav-links{display:flex;gap:2rem}.nav-link{text-decoration:none;color:#333;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:all .3s}.nav-link:hover{background:#667eea;color:#fff}.nav-user{color:#667eea;font-weight:500;margin-right:1rem}.btn-logout{background:transparent;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.btn-logout:hover{background:#dc3545;color:#fff}.loading-container{display:flex;align-items:center;justify-content:center;min-height:50vh}.loading-spinner{font-size:1.2rem;color:#667eea}.main-content{max-width:1200px;margin:2rem auto;padding:0 2rem}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#667eea}.form-textarea{min-height:120px;resize:vertical}.badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;pointer-events:auto}.badge-primary{background:#667eea;color:#fff}.badge-success{background:#28a745;color:#fff}.badge-warning{background:#ffc107;color:#333}.badge-info{background:#17a2b8;color:#fff}.filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-group{flex:1;min-width:200px}.actions{display:flex;gap:.5rem;margin-top:1rem}.exercice-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.exercice-title{font-size:1.25rem;font-weight:600;color:#333;margin-bottom:.5rem}.exercice-meta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.exercice-enonce{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1rem;line-height:1.6}.exercice-corrige{background:#e8f5e9;padding:1rem;border-radius:8px;margin-top:1rem;border-left:4px solid #28a745}.corrige-toggle{margin-top:1rem;cursor:pointer;color:#667eea;font-weight:500}.corrige-toggle:hover{text-decoration:underline}.empty-state{text-align:center;padding:3rem;color:#333;background:#f8f9fa;border-radius:12px;border:2px dashed #dee2e6}.empty-state h3{color:#495057;font-size:1.5rem;margin-bottom:.5rem;font-weight:600}.empty-state p{color:#6c757d;font-size:1rem;margin:0}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.7}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#ff9a9e,#fecfef,#fecfef,#ffecd2,#fcb69f);background-attachment:fixed;min-height:100vh;position:relative}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#ff9a9ecc,#fecfefcc,#fecfefcc,#ffecd2cc,#fcb69fcc);filter:blur(40px);z-index:-1;pointer-events:none}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
