.index-page{position:relative;width:100vw;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}.background-image{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/assets/landscape.png);background-size:cover;background-position:center;filter:brightness(.7);z-index:1}.logo-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:15;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem}.welcome-screen,.cgu-screen,.login-screen{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem}.logo-zoom{text-align:center;animation:zoomIn 3s ease-out;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:scale(1)}.logo-waiting{cursor:pointer}.logo-waiting:hover{transform:scale(1.05);transition:transform .3s ease}.logo-background{pointer-events:none;z-index:5;transition:all 1.2s ease-in-out}.logo-background .logo-zoom{transform:translateY(-20vh);opacity:.3;transition:all 1.2s ease-in-out}.logo-background .game-title,.logo-background .click-hint{opacity:0;transition:opacity .6s ease-out}.logo-background .logo{width:120px;transition:width 1.2s ease-in-out}.logo-container.clickable{cursor:pointer;pointer-events:auto;opacity:1}.logo-container.clickable:hover{transform:scale(1.05);transition:transform .3s ease}.click-hint{position:absolute;bottom:40%;left:50%;transform:translate(-50%);color:var(--color-secondary);font-size:1.2rem;font-family:var(--font-main);text-shadow:2px 2px 4px rgba(0,0,0,.8);animation:pulse 2s infinite;white-space:nowrap}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-top{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fade-in 1s ease-in}.slide-in-top{animation:slide-in-top .8s ease-out}@keyframes zoomIn{0%{transform:scale(.1);opacity:0}50%{opacity:1}to{transform:scale(1)}}.logo{width:200px;height:auto;margin:0 auto 2rem;filter:drop-shadow(0 0 20px rgba(212,175,55,.5));display:block}.game-title{font-family:var(--font-main);font-size:3.5rem;color:var(--color-secondary);text-shadow:2px 2px 4px rgba(0,0,0,.8),0 0 40px rgba(212,175,55,.6);letter-spacing:.3rem;line-height:1.2}.parchment-scroll{background:var(--color-parchment);padding:1.5rem 2rem;border-radius:8px;box-shadow:var(--shadow-lg);border:3px solid var(--color-primary);width:280px;min-height:auto;max-height:fit-content;text-align:center;display:block}.btn-connexion{font-size:1.2rem;padding:.8rem 2rem;background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border:3px solid var(--color-dark);color:var(--color-dark);font-weight:700;text-transform:uppercase;letter-spacing:2px;width:100%;max-width:220px}.btn-connexion:hover{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));transform:scale(1.05)}.parchment-cgu{background:var(--color-parchment);padding:1.5rem;border-radius:8px;box-shadow:var(--shadow-lg);border:3px solid var(--color-primary);width:400px;max-height:60vh;min-height:auto;overflow-y:auto;display:block}.parchment-cgu h2{color:var(--color-dark);text-align:center;margin-bottom:1.5rem;font-size:1.5rem;border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}.cgu-content{color:var(--color-dark);font-size:.95rem;line-height:1.8;margin-bottom:1.5rem;max-height:300px;overflow-y:auto;padding-right:1rem}.cgu-content ul{margin:1rem 0;padding-left:2rem}.cgu-content li{margin-bottom:.5rem}.cgu-checkbox{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1.5rem 0}.cgu-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.cgu-checkbox label{color:var(--color-dark);font-weight:600;cursor:pointer}.btn-continue{width:100%;padding:.75rem;font-size:1.1rem}.login-form-container{background:var(--color-parchment);padding:1.2rem 1.5rem;border-radius:8px;box-shadow:var(--shadow-lg);border:3px solid var(--color-primary);width:280px;min-height:auto;max-height:fit-content;display:block}.login-form h2{color:var(--color-dark);text-align:center;margin-bottom:1rem;font-size:1.2rem}.form-group{margin-bottom:1rem}.form-group input{padding:.6rem;font-size:.9rem;border:2px solid var(--color-primary);border-radius:5px;background:#ffffffe6}.form-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.form-actions button{width:100%;padding:.6rem;font-size:.9rem}.error-message{background:#f443361a;border:2px solid var(--color-error);color:var(--color-error);padding:.75rem;border-radius:5px;margin-bottom:1rem;font-weight:600;text-align:center}.version-info{position:fixed;bottom:1rem;right:1.5rem;background:#8b4513cc;color:var(--color-light);padding:.5rem 1rem;border-radius:5px;font-size:.85rem;font-family:var(--font-ui);border:1px solid var(--color-secondary);z-index:100}@media (max-width: 768px){.parchment-scroll,.parchment-cgu,.login-form-container{min-width:auto;width:90%;max-width:500px;padding:1.5rem}.game-title{font-size:2.5rem}.form-actions{flex-direction:column}}.register-page{position:relative;width:100vw;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;overflow-y:auto}.wood-background{position:fixed;top:0;left:0;width:100%;height:100%;background-image:url(/assets/wood-table.png);background-size:cover;background-position:center;filter:brightness(.8);z-index:1}.register-container{position:relative;z-index:10;width:100%;max-width:700px;animation:slideInTop .5s ease-out}.parchment-form{background:var(--color-parchment);border:3px solid var(--color-primary);border-radius:10px;padding:2.5rem;box-shadow:var(--shadow-lg);position:relative}.form-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--color-primary)}.form-logo{width:80px;height:auto;margin-bottom:1rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.form-header h2{color:var(--color-dark);font-size:1.8rem;margin:0}.error-message{background:#f443361a;border:2px solid var(--color-error);color:var(--color-error);padding:1rem;border-radius:5px;margin-bottom:1.5rem;font-weight:600;text-align:center;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.success-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s}.success-message{background:var(--color-parchment);padding:3rem;border-radius:10px;border:3px solid var(--color-success);text-align:center;box-shadow:var(--shadow-lg);animation:zoomIn .5s}.success-message h2{color:var(--color-success);margin-bottom:1rem}.success-message p{color:var(--color-dark);font-size:1.1rem;margin:.5rem 0}form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--color-dark);font-weight:600;font-size:.95rem;font-family:var(--font-ui)}.form-group input,.form-group select{padding:.75rem;font-size:1rem;border:2px solid var(--color-primary);border-radius:5px;background:#fffffff2;color:var(--color-dark);transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus{border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}.form-hint{font-size:.85rem;color:var(--color-warning);font-style:italic}.pseudo-input-wrapper{position:relative}.pseudo-check{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-weight:700;font-size:.9rem}.pseudo-check.success{color:var(--color-success)}.pseudo-check.error{color:var(--color-error)}.cgu-group{flex-direction:row;align-items:center;gap:.75rem;margin-top:.5rem}.cgu-group input[type=checkbox]{width:20px;height:20px;cursor:pointer}.cgu-group label{margin:0;cursor:pointer;font-size:.95rem}.cgu-group a{color:var(--color-primary);text-decoration:underline;font-weight:600}.cgu-group a:hover{color:var(--color-secondary)}.form-actions{display:flex;gap:1rem;margin-top:1rem}.form-actions button{flex:1;padding:.875rem;font-size:1rem}.btn-primary{background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border-color:var(--color-dark);color:var(--color-dark)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))}.btn-secondary{background:linear-gradient(135deg,var(--color-primary),var(--color-wood));border-color:var(--color-secondary);color:var(--color-light)}.btn-bug-report{position:absolute;bottom:-60px;right:1rem;background:#8b4513e6;border:2px solid var(--color-secondary);color:var(--color-light);padding:.5rem 1rem;font-size:.9rem;border-radius:5px;cursor:pointer;transition:all var(--transition-normal)}.btn-bug-report:hover{background:var(--color-primary);transform:translateY(-2px)}@media (max-width: 768px){.parchment-form{padding:1.5rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-bug-report{position:static;margin-top:1rem;width:100%}}.profile-page{position:relative;width:100vw;min-height:100vh;padding:2rem;overflow-y:auto}.wood-background{position:fixed;top:0;left:0;width:100%;height:100%;background-image:url(/assets/wood-table.png);background-size:cover;background-position:center;filter:brightness(.7);z-index:1}.profile-header{position:relative;z-index:10;display:flex;justify-content:flex-end;gap:1rem;margin-bottom:2rem}.btn-settings,.btn-logout{padding:.75rem 1.5rem;font-size:1rem;background:#8b4513e6;border:2px solid var(--color-secondary);color:var(--color-light);cursor:pointer;border-radius:5px;transition:all var(--transition-normal)}.btn-settings:hover,.btn-logout:hover{background:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.profile-container{position:relative;z-index:10;display:grid;grid-template-columns:350px 1fr;gap:2rem;max-width:1400px;margin:0 auto;animation:fadeIn .5s}.slots-section h2{color:var(--color-secondary);text-align:center;margin-bottom:1.5rem;font-size:1.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.7)}.character-slots{display:flex;flex-direction:column;gap:1rem}.character-slot{background:var(--color-parchment);border:3px solid var(--color-primary);border-radius:10px;padding:1rem;cursor:pointer;transition:all var(--transition-normal);min-height:100px;display:flex;align-items:center;justify-content:center}.character-slot:hover{transform:translate(10px);border-color:var(--color-secondary);box-shadow:var(--shadow-md)}.character-slot.selected{border-color:var(--color-secondary);background:#d4af3733;box-shadow:0 0 20px #d4af3780}.slot-occupied{display:flex;align-items:center;gap:1rem;width:100%}.class-icon{width:60px;height:60px;border-radius:50%;border:2px solid var(--color-primary);object-fit:cover}.slot-info{display:flex;flex-direction:column;gap:.25rem}.char-name{font-family:var(--font-main);font-size:1.2rem;font-weight:600;color:var(--color-dark)}.char-level{font-size:.9rem;color:#2c1810b3}.slot-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#2c181099}.empty-icon{font-size:2rem}.slot-locked{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#2c181080;opacity:.7}.locked-icon{font-size:2rem}.slot-locked:hover{opacity:1;color:var(--color-secondary)}.character-details{display:flex;align-items:center;justify-content:center}.parchment-details,.parchment-empty{background:var(--color-parchment);border:3px solid var(--color-primary);border-radius:10px;padding:2.5rem;width:100%;max-width:600px;box-shadow:var(--shadow-lg);animation:slideInTop .5s}.character-portrait{text-align:center;margin-bottom:1.5rem}.character-portrait img{width:200px;height:300px;object-fit:cover;border:3px solid var(--color-primary);border-radius:10px;box-shadow:var(--shadow-md)}.parchment-details h3{color:var(--color-dark);text-align:center;font-size:2rem;margin-bottom:.5rem}.character-class{text-align:center;color:var(--color-primary);font-size:1.3rem;font-weight:600;margin-bottom:.5rem}.character-tier{text-align:center;color:#2c1810b3;font-size:1rem;margin-bottom:1.5rem}.character-stats{margin:1.5rem 0}.stat-bar{margin-bottom:1rem}.stat-bar span{display:block;color:var(--color-dark);font-weight:600;margin-bottom:.5rem}.progress-bar{height:20px;background:#2c181033;border-radius:10px;overflow:hidden;border:1px solid var(--color-primary)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-secondary),var(--color-primary));transition:width .3s ease}.character-actions{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.btn-continue,.btn-delete,.btn-create{width:100%;padding:1rem;font-size:1.1rem}.btn-continue{background:linear-gradient(135deg,var(--color-success),#2e7d32);border-color:var(--color-dark);color:#fff}.btn-create{background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border-color:var(--color-dark);color:var(--color-dark)}.btn-delete{background:linear-gradient(135deg,var(--color-error),#c62828);border-color:var(--color-dark);color:#fff}.empty-slot-message{text-align:center;padding:3rem 0}.empty-slot-message h3{color:var(--color-dark);margin-bottom:1rem}.empty-slot-message p{color:#2c1810b3;margin-bottom:2rem}.modal-content{background:var(--color-parchment);border:3px solid var(--color-primary);border-radius:10px;padding:2.5rem;max-width:500px;width:90%;box-shadow:var(--shadow-lg);animation:zoomIn .3s}.modal-content h3{color:var(--color-dark);margin-bottom:1.5rem;text-align:center}.modal-content p{color:var(--color-dark);line-height:1.6;margin-bottom:1rem}.warning-text{color:var(--color-error);font-weight:600;font-style:italic}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.modal-actions button{flex:1;padding:.75rem}.btn-cancel{background:#8b4513cc;border-color:var(--color-primary);color:var(--color-light)}.btn-confirm-delete{background:linear-gradient(135deg,var(--color-error),#c62828);border-color:var(--color-dark);color:#fff}.modal-settings{max-width:600px}.settings-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid rgba(139,69,19,.3)}.settings-section:last-of-type{border-bottom:none}.settings-section h4{color:var(--color-primary);margin-bottom:1rem;font-size:1.2rem}.settings-section label{display:flex;flex-direction:column;gap:.5rem;color:var(--color-dark);font-weight:600;margin-bottom:1rem}.settings-section select{padding:.5rem;border:2px solid var(--color-primary);border-radius:5px;background:#fff}.btn-setting{width:100%;margin-bottom:.5rem;padding:.75rem;background:var(--color-primary);color:var(--color-light);border:2px solid var(--color-dark)}.btn-close-modal{width:100%;margin-top:1.5rem;padding:.75rem}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;z-index:2000}.loading-overlay p{color:var(--color-light);font-size:1.2rem}@media (max-width: 1024px){.profile-container{grid-template-columns:1fr}.slots-section{order:2}.character-details{order:1}}@media (max-width: 768px){.profile-page{padding:1rem}.profile-header{flex-direction:column}.character-slots{flex-direction:row;overflow-x:auto}.character-slot{min-width:250px}.parchment-details,.parchment-empty{padding:1.5rem}}.choice-page{position:relative;width:100vw;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;overflow:hidden}.starry-background{position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at bottom,#1b2735,#090a0f);z-index:1}.starry-background:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20px 30px,white,transparent),radial-gradient(2px 2px at 60px 70px,white,transparent),radial-gradient(1px 1px at 50px 50px,white,transparent),radial-gradient(1px 1px at 130px 80px,white,transparent),radial-gradient(2px 2px at 90px 10px,white,transparent);background-repeat:repeat;background-size:200px 200px;animation:twinkle 5s ease-in-out infinite;opacity:.8}@keyframes twinkle{0%,to{opacity:.8}50%{opacity:.4}}.eudyce-container{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;margin-bottom:3rem}.eudyce-figure{position:relative;margin-bottom:2rem}.eudyce-image{width:300px;height:400px;object-fit:contain;filter:drop-shadow(0 0 30px rgba(212,175,55,.6));animation:float 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.eudyce-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;background:radial-gradient(circle,rgba(212,175,55,.3) 0%,transparent 70%);animation:pulse 3s ease-in-out infinite;pointer-events:none}@keyframes pulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}.magic-book{margin-bottom:1.5rem;animation:bookGlow 2s ease-in-out infinite}.magic-book img{width:150px;height:auto;filter:drop-shadow(0 0 20px rgba(212,175,55,.8))}@keyframes bookGlow{0%,to{filter:drop-shadow(0 0 20px rgba(212,175,55,.6))}50%{filter:drop-shadow(0 0 30px rgba(212,175,55,1))}}.eudyce-message{background:#2c1810cc;border:2px solid var(--color-secondary);border-radius:10px;padding:1.5rem 2rem;max-width:600px;box-shadow:0 0 30px #d4af374d}.eudyce-text{color:var(--color-light);font-family:var(--font-text);font-size:1.3rem;font-style:italic;text-align:center;line-height:1.6;margin:0}.choices-container{position:relative;z-index:10;display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1200px;width:100%}.slide-in-up{animation:slideInUp .8s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.choice-card{background:linear-gradient(135deg,#e8d5b7f2,#e4c8a5f2);border:3px solid var(--color-primary);border-radius:15px;padding:2rem;cursor:pointer;transition:all var(--transition-normal);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;overflow:hidden}.choice-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(212,175,55,.2) 0%,transparent 70%);opacity:0;transition:opacity var(--transition-slow)}.choice-card:hover{transform:translateY(-10px) scale(1.05);border-color:var(--color-secondary);box-shadow:0 20px 40px #00000080,0 0 40px #d4af3799}.choice-card:hover:before{opacity:1}.choice-icon{width:100px;height:100px;margin-bottom:1.5rem;position:relative;z-index:2}.choice-icon img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.choice-card h3{color:var(--color-dark);font-size:1.5rem;margin-bottom:1rem;position:relative;z-index:2}.choice-description{color:var(--color-dark);font-size:1rem;line-height:1.6;margin-bottom:1.5rem;position:relative;z-index:2}.choice-description p{margin-bottom:.75rem}.choice-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;width:100%;position:relative;z-index:2}.detail-item{background:#8b451333;padding:.5rem 1rem;border-radius:5px;color:var(--color-dark);font-weight:600;font-size:.9rem;border:1px solid var(--color-primary)}.choice-badge{background:#8b4513cc;color:var(--color-light);padding:.5rem 1rem;border-radius:5px;font-size:.85rem;font-weight:600;border:2px solid var(--color-primary);position:relative;z-index:2}.choice-badge.recommended{background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));color:var(--color-dark);border-color:var(--color-dark);animation:recommendPulse 2s ease-in-out infinite}@keyframes recommendPulse{0%,to{box-shadow:0 0 10px #d4af3780}50%{box-shadow:0 0 20px #d4af37}}.btn-back:hover{background:var(--color-primary);transform:translate(-5px);box-shadow:var(--shadow-md)}@media (max-width: 1024px){.choices-container{grid-template-columns:1fr;gap:2rem;max-width:500px}.eudyce-image{width:200px;height:300px}}@media (max-width: 768px){.choice-page,.eudyce-message{padding:1rem}.eudyce-text{font-size:1.1rem}.choice-card{padding:1.5rem}.choice-icon{width:80px;height:80px}.btn-back{bottom:1rem;left:1rem}}.select-page{position:relative;width:100vw;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;overflow:hidden}.wood-background{position:fixed;top:0;left:0;width:100%;height:100%;background-image:url(/assets/wood-table.png);background-size:cover;background-position:center;filter:brightness(.7);z-index:1}.select-container{position:relative;z-index:10;display:grid;grid-template-columns:200px 1fr;gap:3rem;max-width:1200px;width:100%;animation:fadeIn .5s}.classes-section{display:flex;flex-direction:column;gap:1.5rem}.class-medallion{width:120px;height:120px;border-radius:50%;background:var(--color-wood);border:4px solid var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.class-medallion:before{content:"";position:absolute;width:100%;height:100%;background:radial-gradient(circle,rgba(212,175,55,.3) 0%,transparent 70%);opacity:0;transition:opacity var(--transition-normal)}.class-medallion:hover{transform:scale(1.1) rotate(5deg);border-color:var(--color-secondary);box-shadow:0 0 30px #d4af37cc}.class-medallion:hover:before{opacity:1}.class-medallion.selected{border-color:var(--color-secondary);border-width:5px;box-shadow:0 0 40px #d4af37;animation:pulse 2s ease-in-out infinite}.class-medallion img{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));position:relative;z-index:2}.details-section{display:flex;align-items:center;justify-content:center}.parchment-scroll{background:var(--color-parchment);border:4px solid var(--color-primary);border-radius:15px;padding:2.5rem;width:100%;max-width:700px;box-shadow:var(--shadow-lg);min-height:600px;animation:slideInRight .5s}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.parchment-scroll h2{color:var(--color-dark);text-align:center;font-size:2rem;margin-bottom:2rem;border-bottom:2px solid var(--color-primary);padding-bottom:1rem}.character-portraits{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.portrait{position:relative;cursor:pointer;transition:all var(--transition-normal);border:3px solid var(--color-primary);border-radius:10px;overflow:hidden;background:#ffffff80}.portrait img{width:100%;height:300px;object-fit:cover;display:block;transition:all var(--transition-normal)}.portrait.faded img{opacity:.3;filter:grayscale(80%)}.portrait:hover img{transform:scale(1.05);filter:brightness(1.1)}.portrait.selected{border-color:var(--color-secondary);border-width:4px;box-shadow:0 0 30px #d4af37cc;background:#d4af3733}.portrait.selected img{opacity:1!important;filter:none!important}.gender-label{position:absolute;bottom:0;left:0;right:0;background:#2c1810e6;color:var(--color-light);text-align:center;padding:.5rem;font-weight:600;font-family:var(--font-ui)}.class-description{color:var(--color-dark);font-size:1rem;line-height:1.6;margin-bottom:1.5rem;padding:1rem;background:#ffffff80;border-radius:8px;border:1px solid var(--color-primary)}.class-strengths{margin-bottom:2rem;padding:1rem;background:#8b45131a;border-radius:8px;border:1px solid var(--color-primary)}.class-strengths h4{color:var(--color-primary);margin-bottom:.75rem;font-size:1.1rem}.class-strengths ul{list-style:none;padding:0;margin:0}.class-strengths li{color:var(--color-dark);padding:.5rem;margin-bottom:.25rem;background:#fff9;border-radius:5px;font-weight:600}.class-strengths li:before{content:"⚔️ ";margin-right:.5rem}.character-name-input{margin-bottom:2rem}.character-name-input label{display:block;color:var(--color-dark);font-weight:600;margin-bottom:.5rem;font-family:var(--font-ui)}.name-input-wrapper{position:relative}.name-input-wrapper input{width:100%;padding:.75rem 3rem .75rem .75rem;font-size:1.1rem;border:2px solid var(--color-primary);border-radius:8px;background:#fff;font-family:var(--font-main)}.name-input-wrapper input:focus{border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}.validation-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.5rem;font-weight:700}.validation-icon.valid{color:var(--color-success)}.validation-icon.invalid{color:var(--color-error)}.validation-message{display:block;margin-top:.5rem;color:var(--color-error);font-size:.9rem;font-style:italic}.btn-start{width:100%;padding:1rem 2rem;font-size:1.3rem;background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border:3px solid var(--color-dark);color:var(--color-dark);font-weight:700;cursor:pointer;border-radius:10px;transition:all var(--transition-normal);box-shadow:var(--shadow-md)}.btn-start:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));transform:translateY(-3px);box-shadow:var(--shadow-lg)}.btn-start:disabled{opacity:.5;cursor:not-allowed;background:#8b451380}.no-selection{text-align:center;padding:4rem 2rem}.no-selection h3{color:var(--color-dark);margin-bottom:1rem;font-size:1.8rem}.no-selection p{color:#2c1810b3;font-size:1.1rem}.btn-back{position:fixed;bottom:2rem;left:2rem;z-index:100;padding:.75rem 1.5rem;background:#8b4513e6;border:2px solid var(--color-secondary);color:var(--color-light);font-size:1rem;border-radius:5px;cursor:pointer;transition:all var(--transition-normal)}.btn-back:hover{background:var(--color-primary);transform:translate(-5px)}.modal-content{background:var(--color-parchment);border:4px solid var(--color-primary);border-radius:15px;padding:2.5rem;max-width:600px;width:90%;box-shadow:var(--shadow-lg);animation:zoomIn .3s}.modal-content h3{color:var(--color-dark);text-align:center;margin-bottom:2rem;font-size:1.8rem}.confirm-summary{display:grid;grid-template-columns:200px 1fr;gap:2rem;margin-bottom:2rem;padding:1.5rem;background:#ffffff80;border-radius:10px;border:2px solid var(--color-primary)}.confirm-portrait{width:100%;height:auto;border-radius:10px;border:2px solid var(--color-primary)}.confirm-details{display:flex;flex-direction:column;justify-content:center;gap:.75rem}.confirm-details p{color:var(--color-dark);font-size:1.1rem;margin:0}.confirm-details strong{color:var(--color-primary)}.confirm-message{text-align:center;color:var(--color-dark);font-size:1.1rem;margin-bottom:2rem;font-style:italic}.modal-actions{display:flex;gap:1rem}.modal-actions button{flex:1;padding:1rem;font-size:1.1rem}.btn-cancel{background:#8b4513cc;border:2px solid var(--color-primary);color:var(--color-light)}.btn-confirm{background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border:3px solid var(--color-dark);color:var(--color-dark);font-weight:700}@media (max-width: 1024px){.select-container{grid-template-columns:1fr}.classes-section{flex-direction:row;justify-content:center;order:2}.details-section{order:1}}@media (max-width: 768px){.select-page{padding:1rem}.parchment-scroll{padding:1.5rem}.character-portraits{grid-template-columns:1fr}.confirm-summary{grid-template-columns:1fr;text-align:center}.class-medallion{width:80px;height:80px}.class-medallion img{width:50px;height:50px}}.destiny-input-container,.destiny-question-container,.destiny-result-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;position:relative;z-index:10}.destiny-input-container .parchment-scroll,.destiny-question-container .parchment-scroll,.destiny-result-container .parchment-scroll{background:#f4ecdcf2;border:3px solid #8b6f47;border-radius:15px;padding:2rem;max-width:600px;width:100%;box-shadow:0 10px 40px #00000080}.destiny-input-container h2,.destiny-question-container h2,.destiny-result-container h2{color:#2c1810;font-family:Cinzel,serif;font-size:2rem;margin-bottom:1.5rem;text-align:center;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:#2c1810;font-weight:600;margin-bottom:.5rem;font-size:1.1rem}.form-group input,.form-group textarea{width:100%;padding:.8rem;border:2px solid #8b6f47;border-radius:8px;font-size:1rem;font-family:Crimson Text,serif;background:#ffffffe6;color:#2c1810;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#d4af37;box-shadow:0 0 10px #d4af374d}.form-group textarea{resize:vertical;min-height:100px}.gender-buttons{display:flex;gap:1rem}.gender-buttons button{flex:1;padding:1rem;background:#8b6f4733;border:2px solid #8b6f47;border-radius:8px;color:#2c1810;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.gender-buttons button:hover{background:#8b6f474d;transform:translateY(-2px)}.gender-buttons button.active{background:#8b6f47;color:#f4ecdc;border-color:#d4af37;box-shadow:0 0 15px #d4af3766}.gender-buttons button:disabled{opacity:.5;cursor:not-allowed}.question-progress{text-align:center;color:#8b6f47;font-weight:600;margin-bottom:1rem;font-size:.9rem}.question-text{color:#2c1810;font-family:Crimson Text,serif;font-size:1.3rem;line-height:1.6;margin-bottom:1.5rem;text-align:center}.result-summary{background:#d4af371a;border:2px solid #d4af37;border-radius:10px;padding:1.5rem;margin-bottom:1.5rem}.result-summary h3{color:#8b6f47;font-family:Cinzel,serif;font-size:1.5rem;margin-bottom:1rem;text-align:center}.result-summary p{color:#2c1810;font-family:Crimson Text,serif;font-size:1.1rem;line-height:1.6}.error-message{background:#dc35451a;border:2px solid #dc3545;border-radius:8px;color:#721c24;padding:1rem;margin-bottom:1rem;text-align:center;font-weight:600}.btn-primary{width:100%;padding:1rem;background:linear-gradient(135deg,#8b6f47,#6b5235);border:none;border-radius:8px;color:#f4ecdc;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;margin-bottom:1rem;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 15px #0000004d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#6b5235,#8b6f47);transform:translateY(-2px);box-shadow:0 6px 20px #0006}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-back{width:100%;padding:.8rem;background:#8b6f4733;border:2px solid #8b6f47;border-radius:8px;color:#2c1810;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-back:hover:not(:disabled){background:#8b6f474d;transform:translateY(-2px)}.btn-back:disabled{opacity:.5;cursor:not-allowed}.fade-in{animation:fadeIn .8s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.game-area{position:relative;width:100vw;height:100vh;overflow:hidden}.wood-table-background{position:fixed;top:0;left:0;width:100%;height:100%;background-image:url(/assets/wood-table.png);background-size:cover;background-position:center;filter:brightness(.8);z-index:1}.tokens-bar{position:fixed;top:0;left:0;right:0;height:60px;background:linear-gradient(180deg,#2c1810f2,#2c1810cc);border-bottom:3px solid var(--color-secondary);display:flex;justify-content:space-between;align-items:center;padding:0 2rem;z-index:100;box-shadow:0 2px 10px #00000080}.token-info{display:flex;align-items:center;gap:1.5rem}.character-name{color:var(--color-secondary);font-family:var(--font-main);font-size:1.3rem;font-weight:600}.character-level{color:var(--color-light);font-size:1rem}.token-counter{display:flex;align-items:center;gap:.5rem;background:#8b451399;padding:.5rem 1rem;border-radius:20px;border:2px solid var(--color-secondary)}.token-icon{font-size:1.5rem}.token-value{color:var(--color-light);font-weight:600;font-size:1.1rem}.game-container{position:relative;z-index:10;display:grid;grid-template-columns:200px 1fr;height:calc(100vh - 60px);margin-top:60px;padding:2rem;gap:2rem}.left-panel{display:flex;flex-direction:column;gap:1.5rem;align-items:center;padding-top:2rem}.game-object{width:120px;height:120px;cursor:pointer;transition:all var(--transition-normal);position:relative;display:flex;align-items:center;justify-content:center}.game-object:hover{transform:scale(1.1);filter:drop-shadow(0 0 20px rgba(212,175,55,.8))}.game-object img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.game-object.medallion{background:radial-gradient(circle,#8b4513cc,#2c1810e6);border-radius:50%;border:3px solid var(--color-primary);padding:.5rem}.stats-display{width:100%;height:100%;display:flex;flex-direction:column;gap:.5rem;justify-content:center;padding:.5rem}.stat{height:12px;border-radius:6px;transition:width .3s ease;border:1px solid rgba(0,0,0,.3)}.stat.health{background:var(--color-health)}.stat.stamina{background:var(--color-stamina)}.stat.mana{background:var(--color-mana)}.center-panel{display:flex;flex-direction:column;align-items:center;gap:2rem;overflow:hidden}.open-book{position:relative;width:100%;max-width:900px;height:500px;background:var(--color-parchment);border-radius:10px;box-shadow:0 10px 30px #00000080,inset 0 0 20px #8b451333;border:5px solid var(--color-wood);display:flex;overflow:hidden}.book-pages{display:flex;width:100%;height:100%}.book-page{flex:1;padding:2rem;overflow-y:auto;position:relative}.book-page:before{content:"";position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,rgba(139,69,19,.3),transparent)}.left-page:before{right:0}.right-page:before{left:0}.page-content{color:var(--color-dark);font-family:var(--font-text);font-size:.95rem;line-height:1.8}.narrative-entry{margin-bottom:1.5rem;animation:fadeIn .5s}.narrative-entry.action{background:#8b45131a;padding:.75rem;border-radius:5px;border-left:3px solid var(--color-primary)}.player-action{color:var(--color-primary);display:block;margin-bottom:.5rem;font-family:var(--font-ui)}.narrative-entry p{margin:0}.narrative-image{width:100%;max-width:300px;height:auto;margin-top:1rem;border-radius:8px;border:2px solid var(--color-primary);box-shadow:var(--shadow-md)}.book-navigation{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;gap:1rem;z-index:10}.btn-prev-page,.btn-next-page{width:40px;height:40px;background:#8b4513cc;border:2px solid var(--color-secondary);color:var(--color-light);font-size:1.2rem;border-radius:50%;cursor:pointer;transition:all var(--transition-normal)}.btn-prev-page:hover,.btn-next-page:hover{background:var(--color-primary);transform:scale(1.1)}.player-parchment{width:100%;max-width:900px;background:var(--color-parchment);border:3px solid var(--color-primary);border-radius:10px;padding:1.5rem;box-shadow:var(--shadow-lg)}.parchment-content{display:flex;flex-direction:column;gap:1rem}.parchment-content textarea{width:100%;min-height:100px;padding:1rem;font-family:var(--font-text);font-size:1rem;border:2px solid var(--color-primary);border-radius:8px;background:#ffffffe6;color:var(--color-dark);resize:vertical}.parchment-content textarea:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}.parchment-actions{display:flex;gap:1rem;align-items:center}.btn-illustration{width:50px;height:50px;font-size:1.8rem;background:#8b4513cc;border:2px solid var(--color-secondary);color:var(--color-light);border-radius:8px;cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.btn-illustration:hover{background:var(--color-primary);transform:scale(1.1)}.btn-send{flex:1;padding:.75rem 2rem;font-size:1.1rem;background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border:3px solid var(--color-dark);color:var(--color-dark);font-weight:600;cursor:pointer;border-radius:8px;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-send:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s}.game-modal{background:var(--color-parchment);border:4px solid var(--color-primary);border-radius:15px;padding:2.5rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.game-modal h3{color:var(--color-dark);margin-bottom:1.5rem;text-align:center;font-size:1.8rem;border-bottom:2px solid var(--color-primary);padding-bottom:1rem}.game-modal p{color:var(--color-dark);margin-bottom:.75rem;font-size:1.1rem}.game-modal strong{color:var(--color-primary)}.game-modal textarea{width:100%;min-height:150px;padding:1rem;border:2px solid var(--color-primary);border-radius:8px;font-family:var(--font-text);margin-bottom:1rem}.game-modal button{width:100%;padding:.75rem;margin-top:.5rem}.btn-close-modal{background:#8b4513cc;border:2px solid var(--color-primary);color:var(--color-light)}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;z-index:2000}.loading-screen p{color:var(--color-light);font-size:1.3rem;font-family:var(--font-text)}.book-page::-webkit-scrollbar{width:8px}.book-page::-webkit-scrollbar-track{background:#8b451333;border-radius:4px}.book-page::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:4px}.book-page::-webkit-scrollbar-thumb:hover{background:var(--color-secondary)}@media (max-width: 1200px){.game-container{grid-template-columns:150px 1fr}.game-object{width:100px;height:100px}.open-book{height:400px}}@media (max-width: 768px){.game-container{grid-template-columns:1fr;gap:1rem}.left-panel{flex-direction:row;overflow-x:auto;padding-top:0}.game-object{width:80px;height:80px;flex-shrink:0}.open-book{height:300px}.book-pages{flex-direction:column}.book-page{padding:1rem}.tokens-bar{padding:0 1rem}.character-name{font-size:1rem}.parchment-actions{flex-direction:column}.btn-illustration{width:100%}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #8B4513;--color-secondary: #D4AF37;--color-dark: #2C1810;--color-light: #F5E6D3;--color-parchment: #E8D5B7;--color-wood: #3E2723;--color-success: #4CAF50;--color-error: #F44336;--color-warning: #FF9800;--color-info: #2196F3;--color-health: #DC143C;--color-stamina: #32CD32;--color-mana: #4169E1;--font-main: "Cinzel", "Georgia", serif;--font-text: "Crimson Text", "Times New Roman", serif;--font-ui: "Lato", "Arial", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}body{font-family:var(--font-text);background-color:var(--color-dark);color:var(--color-light);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-main);font-weight:600;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1rem}h6{font-size:.875rem}a{color:var(--color-secondary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary);text-decoration:underline}button{font-family:var(--font-ui);font-size:1rem;padding:var(--spacing-sm) var(--spacing-lg);border:2px solid var(--color-secondary);background:linear-gradient(135deg,var(--color-primary),var(--color-wood));color:var(--color-light);cursor:pointer;border-radius:4px;transition:all var(--transition-normal);box-shadow:var(--shadow-md);text-transform:uppercase;letter-spacing:1px;font-weight:600}button:hover:not(:disabled){background:linear-gradient(135deg,var(--color-wood),var(--color-primary));border-color:var(--color-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}button:disabled{opacity:.5;cursor:not-allowed}input[type=text],input[type=email],input[type=password],input[type=date],textarea,select{font-family:var(--font-text);font-size:1rem;padding:var(--spacing-sm);border:2px solid var(--color-primary);background-color:var(--color-parchment);color:var(--color-dark);border-radius:4px;transition:all var(--transition-fast);width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}input::placeholder,textarea::placeholder{color:#2c181080;font-style:italic}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--color-dark)}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:6px;border:2px solid var(--color-dark)}::-webkit-scrollbar-thumb:hover{background:var(--color-secondary)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.text-center{text-align:center}.hidden{display:none}.fade-in{animation:fadeIn var(--transition-slow)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-in-top{animation:slideInTop var(--transition-slow)}@keyframes slideInTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.spinner{border:4px solid var(--color-light);border-top:4px solid var(--color-secondary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-normal)}@media (max-width: 768px){:root{font-size:14px}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media print{body{background:#fff;color:#000}}
