.game-wrapper{background:linear-gradient(135deg,#5c3317 0%,#704214 30%,#8b6f47 60%,#d4a574 100%);min-height:100vh;position:relative;overflow-x:hidden}.game-container{min-height:100vh;padding:2rem 1rem 6rem;position:relative}.confetti-particle{pointer-events:none;z-index:1000;font-size:1.5rem;animation:2.5s ease-in forwards confettiFall;position:fixed}.confetti-small{font-size:1rem;animation-duration:1.5s}@keyframes confettiFall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.game-start{flex-direction:column;justify-content:center;align-items:center;display:flex}.game-start-content{flex-wrap:wrap;justify-content:center;align-items:center;gap:2rem;max-width:1100px;margin:0 auto;display:flex}.character-display{text-align:center}.character-emoji{filter:drop-shadow(0 10px 20px #0000004d);font-size:6rem;animation:3s ease-in-out infinite characterFloat;display:block}.character-large{font-size:8rem;animation:1s ease-in-out infinite characterCelebrate}@keyframes characterFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes characterCelebrate{0%,to{transform:scale(1)rotate(0)}50%{transform:scale(1.15)rotate(10deg)}}.character-message{color:#ffffffe6;margin-top:1rem;font-size:1.1rem;font-weight:600}.start-form-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff7;border:2px solid #ffffff80;border-radius:1.5rem;width:100%;max-width:480px;padding:2.5rem;box-shadow:0 25px 60px #0000004d}.game-main-title{color:#704214;background:linear-gradient(135deg,#704214,#f60);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:1.75rem;font-weight:800}.game-main-subtitle{color:#666;margin-bottom:1.5rem;font-size:1rem}.form-group{margin-bottom:1.25rem}.form-group label{color:#333;margin-bottom:.5rem;font-weight:600;display:block}.game-input{box-sizing:border-box;border:2px solid #e0e0e0;border-radius:.75rem;width:100%;padding:.875rem 1rem;font-size:1rem;transition:all .2s}.game-input:focus{border-color:#f60;outline:none;box-shadow:0 0 0 3px #f603}.game-btn{cursor:pointer;border:none;border-radius:.75rem;min-height:48px;padding:.875rem 1.5rem;font-size:1rem;font-weight:700;transition:all .2s}.game-btn:disabled{opacity:.6;cursor:not-allowed}.game-btn-primary{color:#fff;background:linear-gradient(135deg,#f60,#ff8c00);width:100%;margin-top:.5rem;box-shadow:0 4px 15px #f606}.game-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff660080}.game-btn-secondary{color:#333;background:#f0f0f0;border:2px solid #e0e0e0}.game-btn-secondary:hover:not(:disabled){background:#e8e8e8}.game-btn-ghost{color:#fff;background:0 0;border:2px solid #fff9}.game-btn-ghost:hover:not(:disabled){background:#ffffff1a}.game-btn-outline{color:#704214;background:0 0;border:2px solid #704214;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.game-btn-outline:hover{color:#fff;background:#704214}.game-features{border-top:2px solid #f0f0f0;margin-top:1.5rem;padding-top:1.5rem}.game-features h3{color:#333;margin-bottom:.75rem;font-size:1rem}.game-features ul{margin:0;padding:0;list-style:none}.game-features li{color:#555;padding:.35rem 0;font-size:.95rem}.game-back-link{color:#ffffffe6;font-weight:600;text-decoration:none;transition:color .2s;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.game-back-link:hover{color:#fff}.game-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0003;border-radius:1rem;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.game-header-left{flex-direction:column;gap:.25rem;display:flex}.game-logo{color:#fff;font-size:1.1rem;font-weight:700}.game-user{color:#ffffffe6;font-size:.9rem}.game-header-right{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.phase-badge{color:#fff;background:linear-gradient(135deg,#f60,#ff8c00);border-radius:2rem;flex-shrink:0;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.progress-container{align-items:center;gap:.75rem;min-width:120px;display:flex}.progress-bar{background:#ffffff4d;border-radius:4px;flex:1;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#f60,#28a745);border-radius:4px;height:100%;transition:width .5s}.progress-text{color:#fff;min-width:40px;font-size:.9rem;font-weight:700}.game-main{max-width:800px;margin:0 auto}.phase-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff7;border:2px solid #ffffff80;border-radius:1.25rem;padding:2rem;box-shadow:0 20px 50px #00000040}.phase-header{text-align:center;margin-bottom:1.5rem}.phase-badge-inline{color:#704214;background:#70421426;border-radius:2rem;margin-bottom:.75rem;padding:.35rem .75rem;font-size:.8rem;font-weight:700;display:inline-block}.phase-title{color:#704214;margin:0 0 .5rem;font-size:1.75rem}.phase-subtitle{color:#666;margin:0;font-size:1rem}.phase-description{color:#555;border-bottom:2px solid #f0f0f0;margin-bottom:1.5rem;padding-bottom:1.5rem;font-size:1rem;line-height:1.6}.question-block{margin-bottom:1.5rem}.question-label{color:#f60;margin-bottom:.5rem;font-size:.85rem;font-weight:700}.question-text{color:#333;margin-bottom:1rem;font-size:1.2rem;font-weight:600;line-height:1.5}.question-hint{color:#666;background:#f8f9fa;border-left:3px solid #f60;border-radius:.5rem;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.9rem}.game-textarea{resize:vertical;box-sizing:border-box;border:2px solid #e0e0e0;border-radius:.75rem;width:100%;min-height:120px;margin-bottom:1rem;padding:1rem;font-family:inherit;font-size:1rem;transition:all .2s}.game-textarea:focus{border-color:#f60;outline:none;box-shadow:0 0 0 3px #f603}.game-textarea::placeholder{color:#999}.options-list{flex-direction:column;gap:.75rem;display:flex}.option-btn{text-align:left;cursor:pointer;color:#333;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:.75rem;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;font-size:1rem;transition:all .2s;display:flex}.option-btn:hover:not(:disabled){background:#fff9f5;border-color:#f60;transform:translate(4px)}.option-btn.selected{background:#f5ebe0;border-color:#704214;box-shadow:0 0 0 3px #70421433}.option-btn:disabled{cursor:default}.option-radio{color:#fff;background:#e0e0e0;border:2px solid #ccc;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.option-btn.selected .option-radio{background:#704214;border-color:#704214}.option-text{flex:1;line-height:1.5}.feedback-box{background:linear-gradient(135deg,#f0f9ff,#f5ebe0);border:2px solid #f60;border-radius:.75rem;margin-top:1.5rem;padding:1.5rem;overflow:hidden}.feedback-box h4{color:#704214;margin:0 0 .5rem;font-size:1rem}.feedback-box p{color:#555;margin:.5rem 0;line-height:1.5}.feedback-box .consequence{background:#fff;border-left:4px solid #28a745;border-radius:.5rem;padding:.75rem;margin-top:.75rem!important}.feedback-box .game-btn{margin-top:1rem}.phase-nav{border-top:2px solid #f0f0f0;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1.5rem;display:flex}.phase-counter{color:#666;font-size:.95rem;font-weight:600}.game-complete{justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.completion-card{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);text-align:center;background:#fffffffa;border:2px solid #ffffff80;border-radius:1.5rem;width:100%;max-width:600px;padding:2.5rem;box-shadow:0 30px 80px #0000004d}.completion-title{color:#704214;margin:0 0 .5rem;font-size:2rem}.completion-subtitle{color:#666;margin-bottom:1.5rem;font-size:1.1rem}.score-display{margin-bottom:2rem}.score-circle{background:linear-gradient(135deg,#704214,#f60);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:140px;height:140px;margin:0 auto 1rem;display:flex;box-shadow:0 15px 40px #f606}.score-value{color:#fff;font-size:3rem;font-weight:800;line-height:1}.score-unit{color:#ffffffe6;font-size:1.5rem}.score-message{font-size:1.1rem;font-weight:700}.phase-scores-list{text-align:left;border-bottom:2px solid #f0f0f0;margin-bottom:1.5rem;padding-bottom:1.5rem}.phase-scores-list h3{color:#333;margin-bottom:1rem;font-size:1rem}.phase-score-row{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.phase-emoji{flex-shrink:0;font-size:1.25rem}.phase-name{color:#333;flex:0 0 180px;font-size:.9rem;font-weight:500}.phase-score-bar{background:#e0e0e0;border-radius:4px;flex:1;height:8px;overflow:hidden}.phase-score-fill{background:linear-gradient(90deg,#f60,#704214);border-radius:4px;height:100%;transition:width .5s}.phase-score-num{color:#666;text-align:right;min-width:60px;font-size:.9rem;font-weight:600}.one-sentence-highlight{text-align:center;background:linear-gradient(135deg,#f5ebe0,#fff5eb);border:2px solid #f60;border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem}.one-sentence-highlight h3{color:#704214;margin:0 0 .75rem;font-size:1.1rem}.one-sentence-text{color:#333;margin:0;font-size:1.25rem;font-style:italic;font-weight:600;line-height:1.6}.fiche-projet{text-align:left;background:#f8f9fa;border:2px solid #d4a574;border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem}.fiche-projet h3{color:#704214;margin:0 0 1rem;font-size:1.1rem}.fiche-item{border-bottom:1px solid #e0e0e0;margin-bottom:1rem;padding-bottom:1rem}.fiche-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.fiche-item strong{color:#f60;margin-bottom:.35rem;font-size:.9rem;display:block}.fiche-item p{color:#333;margin:0;line-height:1.6}.project-summary{text-align:left;background:#f8f9fa;border-left:4px solid #f60;border-radius:.75rem;margin-bottom:1.5rem;padding:1.25rem}.project-summary h3{color:#333;margin:0 0 .75rem;font-size:1rem}.project-summary p{color:#555;margin:.35rem 0;font-size:.95rem}.completion-actions{flex-direction:column;gap:.75rem;display:flex}@media (max-width:768px){.game-header{flex-direction:column;align-items:flex-start}.phase-title{font-size:1.4rem}.question-text{font-size:1.05rem}.option-btn{padding:.875rem 1rem}.phase-name{flex:0 0 120px;font-size:.8rem}.score-circle{width:120px;height:120px}.score-value{font-size:2.5rem}}
