@tailwind base;@tailwind components;@tailwind utilities;body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Montserrat,Lato,Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-header{background:#fff;border-bottom:1px solid #00000014;box-shadow:0 1px 3px #3c40431a;height:64px;left:0;position:fixed;right:0;top:0;z-index:1000}.header-container{align-items:center;display:flex;gap:.75rem;height:100%;justify-content:space-between;max-width:100%;padding:0 1rem}.hamburger-button{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:none;height:40px;justify-content:center;padding:0;transition:background .2s ease;width:40px}.hamburger-button:hover{background:#0000000d}.hamburger-icon{display:flex;flex-direction:column;height:18px;justify-content:space-between;position:relative;width:24px}.hamburger-icon:after,.hamburger-icon:before,.hamburger-line{background:#5f6368;border-radius:2px;content:"";display:block;height:2px;transition:all .3s ease;width:100%}.hamburger-icon:before{transform-origin:top left}.hamburger-icon:after{transform-origin:bottom left}.hamburger-button[aria-expanded=true] .hamburger-icon:before{transform:rotate(45deg) translate(5px,-2px)}.hamburger-button[aria-expanded=true] .hamburger-line{opacity:0}.hamburger-button[aria-expanded=true] .hamburger-icon:after{transform:rotate(-45deg) translate(5px,2px)}.header-brand{align-items:center;display:flex;gap:.75rem;min-width:256px;padding-left:.5rem}.header-icon{font-size:1.75rem}.header-title{color:#e4002b;font-size:1.375rem;font-weight:700;letter-spacing:-.25px}.header-search{flex:1 1;margin:0 2rem;max-width:720px}.search-wrapper{align-items:center;background:#f1f3f4;border-radius:24px;display:flex;height:48px;padding:0 1rem;transition:all .2s ease}.search-wrapper:hover{background:#e8eaed}.search-wrapper:focus-within{background:#fff;box-shadow:0 1px 3px #3c404326,0 4px 8px #3c40431a}.search-input{background:#0000;border:none;flex:1 1;font-size:1rem;padding:0 .5rem}.search-input::placeholder{color:#5f6368}.header-actions,.login-button{align-items:center;display:flex;gap:.5rem}.login-button{background:#e4002b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:700;letter-spacing:.5px;padding:.625rem 1.25rem;text-transform:uppercase;transition:all .2s ease}.login-button:hover{background:#c70024;box-shadow:0 2px 8px #e4002b66;transform:translateY(-1px)}.user-menu{position:relative}.user-menu-button{align-items:center;background:#0000;border:1px solid #0000;border-radius:24px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem .75rem;transition:all .15s ease}.user-menu-button:hover{background:#3c404314}.user-email{color:#3c4043;font-size:.875rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-icon{color:#5f6368;font-size:.6rem;transition:transform .2s ease}.user-menu-button:hover .dropdown-icon{transform:translateY(1px)}.dropdown-menu{animation:dropdownFadeIn .15s ease;background:#fff;border-radius:8px;box-shadow:0 2px 10px #3c404326,0 8px 40px #3c404333;padding:.5rem 0;position:absolute;right:0;top:calc(100% + 8px);width:280px;z-index:1001}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:1rem 1.25rem!important}.user-info{text-align:left}.user-email-full{color:#202124;font-size:.9rem;font-weight:500;margin-bottom:.25rem;word-break:break-all}.user-status{color:#5f6368;font-size:.8rem}.dropdown-divider{background:#e8eaed;height:1px;margin:.5rem 0}.dropdown-item{background:#0000;border:none;color:#3c4043;cursor:pointer;font-size:.875rem;padding:.75rem 1.25rem;text-align:left;transition:background .15s ease;width:100%}.dropdown-action{align-items:center;display:flex;gap:.75rem}.dropdown-action:hover{background:#f1f3f4}.dropdown-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@media (max-width:900px){.hamburger-button{display:flex}.header-brand{min-width:auto}.header-title{font-size:1.125rem}.user-email{display:none}.user-menu-button{background:#e4002b;border-radius:50%;color:#fff;height:40px;justify-content:center;padding:0;width:40px}.user-menu-button:before{content:"👤";font-size:1.1rem}.dropdown-icon{display:none}}@media (max-width:600px){.app-header{height:56px}.header-container{padding:0 .75rem}.header-icon{font-size:1.5rem}.header-title{font-size:1rem}.dropdown-menu{right:.5rem;width:calc(100vw - 1rem)}}.sidebar{background:#fffffffa;border-right:1px solid #00000014;display:flex;flex-direction:column;height:calc(100vh - 64px);min-width:256px;overflow-y:auto;padding:.5rem 0;position:-webkit-sticky;position:sticky;top:64px;width:256px}.sidebar-main-action{padding:.75rem 1rem}.compose-button{align-items:center;background:#e4002b;border:none;border-radius:8px;box-shadow:0 2px 8px #e4002b59;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:700;gap:.75rem;letter-spacing:.5px;padding:.875rem 1.5rem;text-decoration:none;text-transform:uppercase;transition:all .2s ease}.compose-button:hover{background:#c70024;box-shadow:0 4px 12px #e4002b73;transform:translateY(-1px)}.compose-button:active{transform:translateY(0)}.compose-icon{font-size:1.2rem}.compose-text{font-weight:600}.sidebar-nav{padding:.5rem 0}.nav-item{align-items:center;border-radius:0 24px 24px 0;color:#202124;display:flex;font-size:.9rem;font-weight:500;gap:1rem;margin:0 .5rem;padding:.625rem 1.5rem;position:relative;text-decoration:none;transition:all .15s ease}.nav-item:hover{background:#2b4c9b14}.nav-item.active{background:#2b4c9b26;color:#2b4c9b;font-weight:700}.nav-item.active:before{background:#2b4c9b;border-radius:0 4px 4px 0;content:"";height:24px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.nav-icon{flex-shrink:0;height:1.25rem;width:1.25rem}.icon-generate:before{content:"✨"}.icon-history:before{content:"📚"}.icon-ratings:before{content:"⭐"}.nav-label{flex:1 1}.nav-badge{background:#ea4335;border-radius:50%;height:8px;width:8px}.sidebar-divider{background:#00000014;height:1px;margin:.75rem 1rem}.sidebar-section{padding:.5rem 0}.sidebar-section-title{color:#5f6368;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.5rem 1.5rem;text-transform:uppercase}.sidebar-labels{padding:.25rem 0}.label-item{align-items:center;border-radius:0 24px 24px 0;color:#3c4043;cursor:pointer;display:flex;font-size:.85rem;gap:.875rem;margin:0 .5rem;padding:.5rem 1.5rem;transition:background .15s ease}.label-item:hover{background:#0000000a}.label-color{border-radius:50%;flex-shrink:0;height:12px;width:12px}.label-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-auth-prompt{padding:1rem 1.5rem;text-align:center}.sidebar-auth-prompt p{color:#5f6368;font-size:.8rem;line-height:1.4;margin-bottom:.75rem}.sidebar-login-btn{align-items:center;background:#0000;border:1px solid #dadce0;border-radius:8px;color:#2b4c9b;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.sidebar-login-btn:hover{background:#2b4c9b14;border-color:#2b4c9b}.sidebar-footer{border-top:1px solid #0000000f;margin-top:auto;padding:1rem 1.5rem}.sidebar-info{align-items:center;color:#80868b;display:flex;font-size:.75rem;gap:.5rem}.info-icon{font-size:.9rem}.sidebar-overlay{display:none}@media (max-width:900px){.sidebar-overlay{animation:fadeIn .2s ease;background:#00000080;bottom:0;display:block;right:0;z-index:998}.sidebar,.sidebar-overlay{left:0;position:fixed;top:64px}.sidebar{box-shadow:2px 0 8px #00000026;height:calc(100vh - 64px);min-width:256px;transform:translateX(-100%);transition:transform .3s ease;width:256px;z-index:999}.sidebar.sidebar-open{transform:translateX(0)}.nav-label{display:block}.nav-item{border-radius:0 24px 24px 0;justify-content:flex-start;margin:0 .5rem;padding:.625rem 1.5rem}.info-text,.nav-item.active:before,.sidebar-auth-prompt p{display:block}}@media (max-width:600px){.sidebar-overlay{top:56px}.sidebar{height:calc(100vh - 56px);top:56px}}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#00000040}.form-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;max-width:800px;padding:2rem;width:100%}.course-form{gap:2rem}.course-form,.form-section{display:flex;flex-direction:column}.form-section{gap:1.5rem}.form-section h2{border-bottom:2px solid #2b4c9b;color:#2b4c9b;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;padding-bottom:.5rem}.section-title-with-info{align-items:center;display:flex;gap:.75rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr}.label-with-info{align-items:center;display:flex;gap:.5rem}.form-group label .max-indicator{color:#e67e22;font-size:.85rem;font-weight:400}.form-group input,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:#2b4c9b;box-shadow:0 0 0 3px #2b4c9b1a;outline:none}.form-group textarea{min-height:100px;resize:vertical}.help-text{color:#777;font-size:.85rem;font-style:italic}.submit-button{background:#e4002b;border:none;border-radius:8px;box-shadow:0 4px 15px #e4002b66;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;letter-spacing:1px;padding:1rem 2rem;text-transform:uppercase;transition:all .3s ease}.submit-button:hover:not(:disabled){background:#c70024;box-shadow:0 6px 20px #e4002b99;transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.6}.loading-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;padding:3rem;text-align:center}.loading-container h3{color:#2b4c9b;font-size:1.8rem;font-weight:700;margin-bottom:1rem}.loading-step{color:#333;font-size:1.1rem;font-weight:600;margin:1rem 0;min-height:30px}.loading-info{color:#777;font-size:.95rem;line-height:1.6;margin-top:1.5rem}.games-selector{border-top:2px solid #eee;margin-top:2rem;padding-top:2rem}.games-selector h4{color:#333;font-size:1.3rem;font-weight:700;margin-bottom:1.5rem}.games-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.game-card{background:#2b4c9b;border:none;border-radius:12px;color:#fff;cursor:pointer;padding:1.5rem;text-align:center;transition:all .3s ease}.game-card:hover{background:#1f3a7a;box-shadow:0 10px 30px #2b4c9b80;transform:translateY(-5px)}.game-icon{font-size:3rem;margin-bottom:.5rem}.game-card h5{font-size:1.1rem;margin:.5rem 0}.game-card p{font-size:.85rem;margin:0;opacity:.9}.game-modal-overlay{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.game-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90%;max-width:90%;overflow:auto;padding:2rem;position:relative}.close-game{align-items:center;background:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:40px;z-index:10}.close-game:hover{background:#c0392b;transform:rotate(90deg)}.alert{font-weight:500;margin-top:1rem;padding:1rem}.alert-error{background:#fee;border:2px solid #fcc}.results-container{background:#f9f9f9;border:2px solid #2b4c9b;border-radius:12px;margin-top:2rem;padding:2rem}.results-container h2{color:#2b4c9b;font-weight:700;margin-bottom:1.5rem;text-align:center}.files-list{margin-bottom:1.5rem}.files-list h3{color:#333;font-size:1.2rem;font-weight:700;margin-bottom:1rem}.file-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 5px #0000000d;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:1rem}.file-name{color:#333;font-weight:600}.download-button{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.download-button:hover{background:#45a049;transform:scale(1.05)}.download-all-button{box-shadow:0 4px 15px #e4002b66;font-size:1.1rem;letter-spacing:1px;padding:1rem 2rem;transition:all .3s ease;width:100%}.download-all-button:hover{box-shadow:0 6px 20px #e4002b99;transform:translateY(-2px)}.repartition-inputs{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.repartition-item{display:flex;flex-direction:column;gap:.5rem}.repartition-item label{color:#555;font-size:.9rem;font-weight:600}.input-with-percent{align-items:center;display:flex;position:relative}.input-with-percent input{flex:1 1;padding-right:2rem}.percent-sign{color:#2b4c9b;font-weight:600;pointer-events:none;position:absolute;right:.75rem}.total-indicator{align-items:center;display:flex;font-weight:600;gap:.5rem;margin-top:.5rem}.total-warning{color:#e53e3e;font-weight:700}.section-description{color:#777;font-size:.95rem;margin:.5rem 0 1rem}.formats-list{display:flex;flex-direction:column;gap:.75rem}.format-item{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;padding:1rem 1.25rem;transition:all .3s ease}.format-item:hover{border-color:#2b4c9b;box-shadow:0 2px 8px #2b4c9b26;transform:translateX(5px)}.format-info{gap:1rem}.format-icon{flex-shrink:0;font-size:2rem}.format-text{display:flex;flex-direction:column;gap:.25rem}.format-name{color:#333;font-size:1rem;font-weight:700}.format-description{color:#777;font-size:.85rem}.format-item input[type=checkbox]{accent-color:#2b4c9b;cursor:pointer;flex-shrink:0;height:24px;width:24px}.format-item:has(input[type=checkbox]:checked){background:#2b4c9b0d;border-color:#2b4c9b}@media (max-width:768px){.form-container{padding:1.5rem}.form-row,.games-grid,.repartition-inputs{grid-template-columns:1fr}.game-modal{max-width:95%;padding:1rem}.file-item{align-items:stretch;flex-direction:column;gap:.75rem}.download-button{width:100%}.format-item{padding:.875rem 1rem}.format-icon{font-size:1.5rem}.format-name{font-size:.95rem}.format-description{font-size:.8rem}}.success-notification-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10000}.success-notification{animation:slideDown .5s ease-out;background:#2b4c9b;border-radius:20px;box-shadow:0 20px 60px #2b4c9b80;color:#fff;max-width:500px;padding:3rem 2.5rem;text-align:center;width:90%}.success-icon{animation:bounce 1s ease-in-out infinite;font-size:5rem;margin-bottom:1rem}.success-notification h2{color:#fff;font-size:2rem;margin-bottom:.5rem;text-shadow:0 2px 10px #0003}.success-notification p{color:#ffffffe6;font-size:1.2rem;margin-bottom:2rem}.notification-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.notification-button{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;min-width:180px;padding:.875rem 1.75rem;transition:all .3s ease}.notification-button.primary{background:#e4002b;box-shadow:0 4px 15px #e4002b4d;color:#fff;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.notification-button.primary:hover{background:#c70024;box-shadow:0 6px 20px #e4002b80;transform:translateY(-2px)}.notification-button.secondary{background:#fff3;border:2px solid #ffffff80;color:#fff}.notification-button.secondary:hover{background:#ffffff4d;border-color:#fffc}@keyframes slideDown{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.success-notification{padding:2rem 1.5rem}.success-icon{font-size:4rem}.success-notification h2{font-size:1.5rem}.success-notification p{font-size:1rem}.notification-actions{flex-direction:column}.notification-button{width:100%}}.mini-games-section{background:#2b4c9b0d;border:2px solid #2b4c9b33;border-radius:12px;margin-top:2rem;padding:2rem}.mini-games-section h3{color:#2b4c9b;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}.mini-games-section .section-description{color:#777;font-size:.95rem;margin-bottom:1.5rem;text-align:center}.games-grid-permanent{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.game-card-permanent{background:#2b4c9b;border:none;border-radius:12px;box-shadow:0 4px 15px #2b4c9b4d;color:#fff;cursor:pointer;padding:1.5rem;text-align:center;transition:all .3s ease}.game-card-permanent:hover:not(:disabled){background:#1f3a7a;box-shadow:0 6px 25px #2b4c9b80;transform:translateY(-3px)}.game-card-permanent:disabled{cursor:not-allowed;opacity:.5;transform:none}.game-card-permanent h5{font-size:1.1rem;margin:1rem 0 .5rem}.game-card-permanent p{font-size:.85rem;margin:0;opacity:.9}.info-button-container{display:inline-block;position:relative}.info-button{align-items:center;background:#2b4c9b;border:none;border-radius:50%;color:#fff;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:.7rem;font-style:italic;font-weight:700;height:20px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:20px}.info-button:hover{background:#1e3a7a;transform:scale(1.1)}.info-button:focus{outline:2px solid #2b4c9b;outline-offset:2px}.info-tooltip{animation:fadeInTooltip .2s ease;bottom:calc(100% + 8px);left:50%;pointer-events:auto;position:absolute;transform:translateX(-50%);z-index:1000}.info-tooltip-content{word-wrap:break-word;background:#333;border-radius:8px;box-shadow:0 4px 12px #0000004d;color:#fff;font-size:.85rem;line-height:1.5;max-width:300px;min-width:200px;padding:.75rem 1rem;text-align:left;white-space:normal}.info-tooltip-arrow{border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid #333;height:0;left:50%;position:absolute;top:100%;transform:translateX(-50%);width:0}@keyframes fadeInTooltip{0%{opacity:0;transform:translateX(-50%) translateY(4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.format-info{align-items:center;display:flex;gap:.5rem;justify-content:space-between;width:100%}.format-info .info-button-container{flex-shrink:0}@media (max-width:768px){.games-grid-permanent{gap:1rem;grid-template-columns:1fr}.mini-games-section{padding:1.5rem}.info-tooltip-content{font-size:.8rem;max-width:250px;padding:.625rem .875rem}}input[type=range]{cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;border:3px solid;border-radius:50%;box-shadow:0 2px 6px #0003;cursor:pointer;height:18px;-webkit-transition:all .2s ease;transition:all .2s ease;width:18px}input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 3px 8px #0000004d;transform:scale(1.15)}input[type=range]::-moz-range-thumb{background:#fff;border:3px solid;border-radius:50%;box-shadow:0 2px 6px #0003;cursor:pointer;height:18px;-moz-transition:all .2s ease;transition:all .2s ease;width:18px}input[type=range]::-moz-range-thumb:hover{box-shadow:0 3px 8px #0000004d;transform:scale(1.15)}input[type=range][name=COURS_PCT]::-webkit-slider-thumb{border-color:#1e3a8a}input[type=range][name=COURS_PCT]::-moz-range-thumb{border-color:#1e3a8a}input[type=range][name=EXEMPLES_PCT]::-webkit-slider-thumb{border-color:#dc2626}input[type=range][name=EXEMPLES_PCT]::-moz-range-thumb{border-color:#dc2626}input[type=range][name=EXERCICES_PCT]::-webkit-slider-thumb{border-color:#1e3a8a}input[type=range][name=EXERCICES_PCT]::-moz-range-thumb{border-color:#1e3a8a}.game-container{max-width:100%;overflow-x:auto}.game-container h3{color:#535353;font-family:Courier New,monospace}.game-instructions{display:flex;font-family:Courier New,monospace;gap:2rem}.game-instructions span{background:#f0f0f0;border-radius:4px;font-weight:600;padding:.3rem .8rem}.game-canvas{border:3px solid #535353;border-radius:4px;box-shadow:0 4px 10px #0000001a}.trex-chrome .chrome-canvas{background:#fff;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}.game-score{color:#535353}.game-hint,.game-score{font-family:Courier New,monospace}.game-hint{color:#666;font-size:.95rem;font-style:italic;margin:.5rem 0 0}@keyframes pixel-flash{0%,to{opacity:1}50%{opacity:.8}}@media (max-width:1024px){.game-canvas{height:auto;max-width:100%}}@media (max-width:768px){.game-canvas{height:auto;max-width:100%}.game-instructions{flex-direction:column;gap:.5rem}.game-container{padding:1rem}}.game-canvas{background:#fff}.game-container{align-items:center;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.game-container h3{color:#667eea;font-size:1.5rem;margin:0}.game-instructions{color:#666;font-size:.9rem;margin:0;text-align:center}.game-canvas{background:#1a1a2e;border:3px solid #667eea;border-radius:8px;cursor:pointer}.game-score{color:#333;font-size:1.2rem;font-weight:700}.history-container{animation:fadeIn .3s ease}.history-header{margin-bottom:1.5rem}.history-header h1{color:#2b4c9b;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.history-subtitle{color:#777;font-size:.9rem}.history-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-box{flex:1 1;min-width:250px}.search-input{background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%235f6368'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E");background-position:.875rem;background-repeat:no-repeat;border:1px solid #dadce0;border-radius:24px;color:#202124;font-size:.9rem;padding:.75rem 1rem .75rem 2.5rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:#2b4c9b;box-shadow:0 0 0 2px #2b4c9b33;outline:none}.search-input::placeholder{color:#80868b}.sort-box{align-items:center;display:flex;gap:.5rem}.sort-box label{color:#5f6368;font-size:.875rem}.sort-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%235f6368' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-position:calc(100% - .75rem);background-repeat:no-repeat;border:1px solid #dadce0;border-radius:8px;color:#3c4043;cursor:pointer;font-size:.875rem;padding:.625rem 2rem .625rem 1rem}.sort-select:focus{border-color:#2b4c9b;outline:none}.history-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem}.stat-card{background:#fff;border:1px solid #0000000f;border-radius:12px;box-shadow:0 1px 2px #3c40431a;padding:1rem 1.25rem}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-value{color:#2b4c9b;font-size:1.5rem;font-weight:700}.stat-label{color:#777;font-size:.8rem}.generations-list{display:flex;flex-direction:column;gap:1rem}.generation-card{background:#fff;border:1px solid #0000000f;border-radius:12px;box-shadow:0 1px 2px #3c40431a;padding:1.25rem;transition:all .2s ease}.generation-card:hover{border-color:#2b4c9b4d;box-shadow:0 2px 8px #3c404326}.generation-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.generation-title h3{color:#333;font-size:1.1rem;font-weight:700;margin-bottom:.25rem}.generation-matiere{background:#2b4c9b;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.generation-date{color:#80868b;font-size:.8rem;white-space:nowrap}.generation-details{background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:.75rem}.detail-line{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem}.detail-line-group{display:flex;gap:1.5rem}.detail-row{align-items:center;display:flex;gap:.5rem}.detail-row-repartition{flex-wrap:wrap}.detail-label{color:#777;font-size:.8rem;font-weight:600}.detail-value{color:#333;font-size:.85rem}.generation-actions{border-top:1px solid #e8eaed;margin-bottom:1rem;padding-top:.75rem}.regenerate-button{align-items:center;background:#2b4c9b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s ease}.regenerate-button:hover{background:#1e3a7a;box-shadow:0 2px 8px #2b4c9b4d;transform:translateY(-1px)}.regenerate-button:active{transform:translateY(0)}.generation-files{border-top:1px solid #e8eaed;padding-top:1rem}.generation-files h4{color:#5f6368;font-size:.85rem;font-weight:500;margin-bottom:.75rem}.files-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.file-download-button{align-items:center;background:#fff;border:1px solid #dadce0;border-radius:8px;color:#3c4043;cursor:pointer;display:flex;font-size:.75rem;font-weight:600;justify-content:center;padding:.5rem 1rem;transition:all .15s ease}.file-download-button:hover{background:#f1f3f4;border-color:#2b4c9b;color:#2b4c9b}.file-format{font-family:SF Mono,Monaco,monospace}.download-all-button{align-items:center;background:#e4002b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:700;gap:.5rem;letter-spacing:.5px;padding:.625rem 1rem;text-transform:uppercase;transition:all .2s ease}.download-all-button:hover{background:#c70024;box-shadow:0 2px 8px #e4002b66;transform:translateY(-1px)}.generation-files-unavailable{border-top:1px solid #e8eaed;padding-top:1rem}.generation-files-unavailable p{color:#80868b;font-size:.85rem;font-style:italic}.loading-state{padding:4rem 2rem;text-align:center}.loading-state p{color:#5f6368;font-size:.9rem}.empty-state{background:#fff;border-radius:12px;box-shadow:0 1px 2px #3c40431a;padding:4rem 2rem}.empty-state p{color:#777}.retry-button{background:#0000;border:1px solid #dc3545;border-radius:20px;color:#dc3545;cursor:pointer;font-size:.85rem;margin-left:1rem;padding:.5rem 1rem;transition:all .2s ease}.retry-button:hover{background:#dc3545;color:#fff}@media (max-width:768px){.history-controls{flex-direction:column}.search-box{min-width:100%}.sort-box{justify-content:space-between}.detail-line-group,.generation-header{flex-direction:column}.detail-line-group{gap:.5rem}}.rating-form-container{margin:0 auto;max-width:800px;padding:2rem;width:100%}.rating-form{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:2.5rem}.rating-form h1{border-bottom:3px solid #2b4c9b;color:#2b4c9b;font-size:2rem;margin-bottom:2rem;padding-bottom:1rem;text-align:center}.rating-form-content{display:flex;flex-direction:column;gap:2.5rem}.rating-section{align-items:center;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border-radius:12px;display:flex;flex-direction:column;gap:1.5rem;padding:2rem}.rating-prompt{color:#333;font-size:1.25rem;font-weight:600;margin:0;text-align:center}.stars-container{align-items:center;display:flex;gap:.5rem;justify-content:center}.star-button{background:none;border:none;cursor:pointer;font-size:2.5rem;line-height:1;padding:.5rem;transition:all .2s ease}.star-button:hover{transform:scale(1.1)}.star-button:focus{border-radius:4px;outline:2px solid #2b4c9b;outline-offset:2px}.star-icon{color:#ddd;display:block;transition:color .2s ease}.star-button.active .star-icon{color:gold;text-shadow:0 0 10px #ffd70080}.rating-selected{color:#2b4c9b;font-size:1rem;font-weight:600;margin:0}.comment-section{display:flex;flex-direction:column;gap:1rem}.comment-prompt{color:#333;font-size:1.1rem;font-weight:600;margin:0}.comment-textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;min-height:150px;padding:1rem;resize:vertical;transition:all .3s ease;width:100%}.comment-textarea:focus{border-color:#2b4c9b;box-shadow:0 0 0 3px #2b4c9b1a;outline:none}.char-count{color:#777;font-size:.85rem;font-style:italic;text-align:right}.error-message{background:#fee;border-left:4px solid #c33;color:#c33}.error-message,.success-message{border-radius:8px;font-weight:500;padding:1rem}.success-message{background:#efe;border-left:4px solid #3c3;color:#3c3}.submit-rating-button{background:#e4002b;border:none;border-radius:8px;box-shadow:0 4px 15px #e4002b66;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;letter-spacing:1px;padding:1rem 2rem;text-transform:uppercase;transition:all .3s ease;width:100%}.submit-rating-button:hover:not(:disabled){box-shadow:0 6px 20px #e4002b99;transform:translateY(-2px)}.submit-rating-button:active:not(:disabled){transform:translateY(0)}.submit-rating-button:disabled{background:#ccc;box-shadow:none;cursor:not-allowed}.auth-required-message{background:#f5f5f5;border-radius:8px;color:#777;font-size:1.1rem;padding:2rem;text-align:center}@media (max-width:768px){.rating-form-container{padding:1rem}.rating-form{padding:1.5rem}.rating-form h1{font-size:1.5rem}.rating-prompt{font-size:1.1rem}.star-button{font-size:2rem}.rating-section{padding:1.5rem}}.login-form-container,.register-form-container{margin:0 auto;max-width:450px;padding:2rem}.login-form-container h2,.register-form-container h2{color:#333;font-size:2rem;margin-bottom:.5rem;text-align:center}.form-subtitle{color:#666;font-size:1rem;margin-bottom:2rem;text-align:center}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem;position:relative}.form-group label{color:#333;font-size:.95rem;font-weight:600}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:.9rem 1rem;transition:all .3s ease}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.alert-error{background-color:#fee;border-left:4px solid #c33;color:#c33}.alert-error,.alert-success{border-radius:8px;font-size:.95rem;padding:.9rem 1rem}.alert-success{background-color:#efe;border-left:4px solid #3c3;color:#3c3}.alert-info{background-color:#e3f2fd;border-left:4px solid #1976d2;border-radius:8px;color:#1976d2;font-size:.95rem;padding:.9rem 1rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);font-size:1.1rem;padding:1rem 2rem;transition:all .3s ease}.btn-primary:hover:not(:disabled){box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:linear-gradient(135deg,#f093fb,#f5576c);border:none;color:#fff;font-size:.95rem;padding:.8rem 1.5rem;transition:all .3s ease;width:100%}.btn-secondary:hover:not(:disabled){box-shadow:0 5px 20px #f5576c66;transform:translateY(-2px)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.resend-verification-container{margin:-.5rem 0}.form-footer{color:#666;margin-top:1rem;text-align:center}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:inherit;font-weight:600;padding:0;text-decoration:underline}.link-button:hover{color:#764ba2}.forgot-password-link{align-self:flex-end;background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:600;margin-top:.25rem;padding:0;text-decoration:none;transition:color .3s ease;width:-webkit-fit-content;width:fit-content}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.password-requirements{background-color:#f9f9f9;border-radius:6px;color:#666;font-size:.85rem;margin-top:.5rem;padding:.7rem}.password-requirements ul{margin:.5rem 0 0;padding-left:1.5rem}.password-requirements li{margin:.3rem 0}@media (max-width:600px){.login-form-container,.register-form-container{padding:1.5rem 1rem}.login-form-container h2,.register-form-container h2{font-size:1.6rem}}.auth-modal-overlay{align-items:center;animation:fadeIn .3s ease-out forwards;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;display:flex;height:100%;justify-content:center;left:0;overflow-y:auto;padding:1rem;position:fixed;top:0;width:100%;z-index:10000}.auth-modal-card{animation:slideUp .4s ease-out forwards;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0006;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}.modal-close-button{align-items:center;background:#0000000d;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;line-height:1;position:absolute;right:1.5rem;top:1.5rem;transition:all .3s ease;width:40px;z-index:10}.modal-close-button:hover{background:#0000001a;color:#333;transform:rotate(90deg)}.auth-modal-content{padding:1rem .5rem}@media (max-width:600px){.auth-modal-overlay{padding:.5rem}.auth-modal-card{border-radius:15px;max-height:95vh}.modal-close-button{font-size:1.3rem;height:35px;right:1rem;top:1rem;width:35px}.auth-modal-card{-webkit-overflow-scrolling:touch;overflow-y:auto}}.verify-email-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.verify-email-card{animation:slideUp .5s ease-out forwards;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;padding:3rem 2.5rem;text-align:center;width:100%}.spinner{animation:spin 1s linear infinite;border:6px solid #f3f3f3;border-top-color:#667eea;height:60px;margin:0 auto 2rem;width:60px}.error-icon,.success-icon{animation:bounce .6s ease-out;font-size:5rem;margin-bottom:1.5rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}.verify-email-card h2{color:#333;font-size:2rem;margin-bottom:1rem}.verify-email-card p{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:1rem}.redirect-message{color:#999;font-size:.95rem;font-style:italic}.btn-home{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:2rem;padding:1rem 2rem;transition:all .3s ease}.btn-home:hover{box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.btn-home:active{transform:translateY(0)}@media (max-width:600px){.verify-email-container{padding:1rem}.verify-email-card{padding:2rem 1.5rem}.verify-email-card h2{font-size:1.6rem}.verify-email-card p{font-size:1rem}.error-icon,.success-icon{font-size:4rem}}.reset-password-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.reset-password-card{animation:slideUp .4s ease-out forwards;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;padding:2.5rem;width:100%}.reset-password-card h2{color:#333;font-size:2rem;margin-bottom:.5rem;text-align:center}.reset-password-card .form-subtitle{color:#666;font-size:.95rem;margin-bottom:2rem;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:600px){.reset-password-container{padding:1rem}.reset-password-card{border-radius:15px;padding:1.5rem}.reset-password-card h2{font-size:1.5rem}}*{box-sizing:border-box;margin:0;padding:0}body{background:#f7f7f7;color:#333;font-family:Montserrat,Lato,Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif}.app,body{min-height:100vh}.app{display:flex;flex-direction:column}.app-body{display:flex;flex:1 1;margin-top:64px}.main-content{background:#f7f7f7;flex:1 1;min-height:calc(100vh - 64px);overflow-y:auto;padding:1.5rem 2rem}.main-content>*{margin:0 auto;max-width:900px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spinner{animation:spin .8s linear infinite;border:3px solid #e4002b33;border-radius:50%;border-top-color:#e4002b;height:40px;margin:0 auto 1rem;width:40px}.alert{animation:fadeIn .3s ease;border-radius:8px;font-size:.9rem;margin:1rem 0;padding:1rem 1.25rem}.alert-error{background:#fce8e6;border-left:4px solid #ea4335;color:#c5221f}.alert-success{background:#e6f4ea;border-left:4px solid #34a853;color:#137333}.alert-warning{background:#fef7e0;border-left:4px solid #fbbc05;color:#b06000}.alert-info{background:#e8f0fe;border-left:4px solid #4285f4;color:#1a73e8}.card{background:#fff;border-radius:8px;box-shadow:0 1px 2px #3c40431a,0 2px 6px #3c404326;margin-bottom:1rem;padding:1.5rem}.btn-primary{align-items:center;background:#e4002b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:700;gap:.5rem;letter-spacing:.5px;padding:.75rem 1.5rem;text-decoration:none;text-transform:uppercase;transition:all .2s ease}.btn-primary:hover{background:#c70024;box-shadow:0 4px 12px #e4002b66;transform:translateY(-1px)}.btn-secondary{align-items:center;background:#fff;border:1px solid #dadce0;border-radius:8px;color:#2b4c9b;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.btn-secondary:hover{background:#f7f7f7;border-color:#2b4c9b}.loading-state{align-items:center;color:#5f6368;display:flex;flex-direction:column;justify-content:center;padding:3rem}.empty-state{color:#5f6368;padding:3rem;text-align:center}.empty-state h2{color:#333;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.empty-state p{font-size:.9rem}@media (max-width:900px){.main-content{padding:1rem}}@media (max-width:600px){.app-body{margin-top:56px}.main-content{min-height:calc(100vh - 56px);padding:.75rem}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00000040}:focus-visible{outline:2px solid #e4002b;outline-offset:2px}::selection{background:#e4002b4d}
/*# sourceMappingURL=main.fa1984e1.css.map*/