@import url(https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Crimson+Text:ital,wght@0,400;0,600;1,400&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&display=swap);:root{--primary-bg:#2a2d47;--panel-bg:#3d4166;--card-bg:#4a4e73;--border-color:#52566d;--accent-primary:#8b7cf6;--accent-secondary:#f59e0b;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--shadow-dark:#0000004d;--shadow-accent:#8b7cf64d}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;background-color:#2a2d47;background-color:var(--primary-bg);background-image:url(/static/media/login-bg.84e5483fa9b993f72353.png),linear-gradient(#0000001a 1px,#0000 0),linear-gradient(90deg,#0000001a 1px,#0000 0);background-position:50%,0 0,0 0;background-repeat:no-repeat,repeat,repeat;background-size:cover,40px 40px,40px 40px;color:#e2e8f0}.panel{background-color:#3d4166;background-color:var(--panel-bg);border:1px solid #52566d;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 6px #0000004d;box-shadow:0 4px 6px var(--shadow-dark);margin:1rem 0;padding:1.5rem}.card{background-color:#4a4e73;background-color:var(--card-bg);border:1px solid #52566d;border:1px solid var(--border-color);border-radius:6px;margin:.75rem 0;padding:1.25rem;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:0 6px 12px #0000004d;box-shadow:0 6px 12px var(--shadow-dark);transform:translateY(-2px)}h1,h2,h3,h4,h5,h6{color:#e2e8f0;color:var(--text-primary);margin-top:0}h1{font-size:2.25rem}h2{font-size:1.875rem}div,li,p{color:#e2e8f0;color:var(--text-primary);line-height:1.7}a{color:#8b7cf6;color:var(--accent-primary);text-decoration:none;transition:color .2s}a:hover{color:#f59e0b;color:var(--accent-secondary);text-decoration:underline}.btn{font-weight:500;padding:.5rem 1.25rem;transition:all .2s}.btn-primary{background-color:#8b7cf6;background-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:#7a6ae4;transform:translateY(-1px)}.btn-secondary{background-color:#f59e0b;background-color:var(--accent-secondary);color:#1e293b}.btn-secondary:hover{background-color:#e69009;transform:translateY(-1px)}input,select,textarea{background-color:#ffffff0d;border:1px solid #52566d;border:1px solid var(--border-color);border-radius:4px;color:#e2e8f0;color:var(--text-primary);margin-bottom:1rem;padding:.5rem .75rem;width:100%}input:focus,select:focus,textarea:focus{border-color:#8b7cf6;border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b7cf64d;box-shadow:0 0 0 2px var(--shadow-accent);outline:none}.text-accent{color:#8b7cf6;color:var(--accent-primary)}.text-secondary{color:#94a3b8;color:var(--text-secondary)}.bg-panel{background-color:#3d4166;background-color:var(--panel-bg)}.bg-card{background-color:#4a4e73;background-color:var(--card-bg)}.shadow{box-shadow:0 4px 6px #0000004d;box-shadow:0 4px 6px var(--shadow-dark)}code{border-radius:4px;color:#f8f8f2;font-family:Fira Code,monospace;font-size:.9em;padding:.2em .4em}code,pre{background:#0003}pre{border-radius:6px;overflow-x:auto;padding:1rem}pre code{background:none;padding:0}.home-container{align-items:center;background:url(/static/media/login-bg.84e5483fa9b993f72353.png) 50%/cover no-repeat fixed;box-sizing:border-box;color:var(--text-primary);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.decorative-icon{color:var(--text-accent);opacity:.08;pointer-events:none;position:absolute;z-index:0}.decorative-icon.sword{animation:float 6s ease-in-out infinite;left:5%;top:10%;transform:rotate(-15deg)}.decorative-icon.castle{animation:float 7s ease-in-out infinite reverse;right:8%;top:20%;transform:rotate(25deg)}.decorative-icon.scroll{animation:float 5.5s ease-in-out infinite;bottom:15%;left:8%;transform:rotate(-10deg)}.home-card{animation:fadeInUp .8s ease-out;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--container-primary);border:2px solid #ffd7004d;box-shadow:0 8px 32px #ffd70033;margin:var(--container-margin);max-width:var(--container-max-width);position:relative;width:100%;z-index:1}.home-header{color:var(--text-primary);overflow:hidden;padding:2.5rem 2rem 1.5rem;position:relative;text-align:center}.floating-icon{animation:float 3s ease-in-out infinite;color:var(--text-accent);opacity:.3;position:absolute;z-index:2}.floating-icon.crown-icon{font-size:2rem;right:20px;top:10px}.floating-icon.scroll-icon{animation:float 2.5s ease-in-out infinite;font-size:1.5rem;left:20px;top:20px}.title-container{position:relative;z-index:2}.title-wrapper{align-items:center;display:flex;flex-direction:column;gap:.5rem;padding:1rem 0}.dragon-icon{color:var(--text-accent);font-size:2.25rem}.title-wrapper span{color:var(--text-primary);font-family:var(--font-primary);font-size:2.2rem;font-weight:600;letter-spacing:1px;margin-top:.5rem;text-shadow:3px 3px 6px #000000b3}.decorative-line{background:#ffd700cc;border-radius:2px;height:3px;margin:1rem auto;position:relative;width:120px}.decorative-dot{background:var(--text-accent);border-radius:50%;height:8px;left:50%;position:absolute;top:-2px;transform:translateX(-50%);width:8px}.subtitle{align-items:center;animation:fadeInUp 1.2s ease-out;color:var(--text-primary);display:flex;font-family:var(--font-secondary);font-size:1.2rem;font-style:italic;gap:.5rem;justify-content:center;margin:0;opacity:.95;position:relative;width:100%}.spellbook-icon{color:var(--text-accent);font-size:1.5rem}.main-content{background:#0000;padding:0 2rem 2.5rem}.welcome-text{animation:fadeInUp 1.4s ease-out;color:var(--text-muted);font-size:1.1rem;font-weight:300;line-height:1.7;margin:0 auto 2rem;max-width:90%;text-align:center}.action-buttons{animation:fadeInUp 1.6s ease-out;display:flex;flex-direction:column;gap:1rem;margin:var(--container-margin);margin-bottom:2rem;max-width:400px;width:100%}.primary-btn{background:var(--gradient-primary)!important;border:2px solid #ffffff4d!important;box-shadow:0 6px 20px #4f46e566!important;color:#fff!important;text-shadow:0 2px 4px #0000004d!important}.primary-btn:hover{box-shadow:0 8px 25px #4f46e599!important;transform:translateY(-3px) scale(1.02)!important}.secondary-btn{-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;background:var(--container-secondary)!important;border:2px solid #ffd70066!important;box-shadow:0 6px 20px #ffd7001a!important;color:var(--text-primary)!important;text-shadow:0 2px 4px #0000004d!important}.secondary-btn:hover{background:var(--container-accent)!important;border-color:#ffd70099!important;box-shadow:0 8px 25px #ffd70033!important;transform:translateY(-3px) scale(1.02)!important}.btn-icon{color:var(--text-accent)}.features-section{animation:fadeInUp 1.8s ease-out;border-top:1px solid #ffd7001a;margin-top:2.5rem;padding-top:2rem}.features-title{align-items:center;color:var(--text-primary);display:flex;font-family:var(--font-primary);font-size:1.3rem;font-weight:500;gap:.8rem;justify-content:center;letter-spacing:.5px;margin-bottom:1.5rem;text-align:center}.crown-icon{color:var(--text-accent)}.features-grid{grid-gap:1.2rem;color:var(--text-muted);display:grid;font-size:.95rem;gap:1.2rem;grid-template-columns:1fr 1fr}.feature-column{text-align:center}.feature-item{align-items:center;background:var(--container-light);border:1px solid #ffd7001a;border-radius:6px;display:flex;gap:.6rem;justify-content:center;margin-bottom:.8rem;padding:.8rem;transition:all .3s ease}.feature-item:hover{background:var(--container-secondary);border-color:#ffd70033;box-shadow:0 4px 12px #ffd7001a;transform:translateY(-2px)}.feature-icon{color:var(--text-accent);font-size:1.2rem}@media (max-width:768px){.home-card{margin:1rem;max-width:calc(100% - 2rem);padding:1rem!important}.title-wrapper{flex-direction:column;gap:.5rem!important}.dragon-icon,.title-wrapper span{font-size:2rem}.features-grid{grid-template-columns:1fr}.main-content{padding:0 1rem 2rem}.home-header{padding:2rem 1rem 1rem}.action-buttons{max-width:100%}}@media (max-width:480px){.title-wrapper span{font-size:1.8rem}.subtitle{font-size:1.1rem}.welcome-text{font-size:1rem}.home-container{padding:1rem}}:root{--primary-bg:#0f0529;--secondary-bg:#1a103d;--accent-bg:#2a1b5e;--surface-bg:#3a2a7a;--card-bg:#4a3a8a;--container-primary:#4b0082cc;--container-secondary:#4b0082b3;--container-light:#4b008266;--container-accent:#4b008299;--text-primary:#fff;--text-secondary:#fff;--text-accent:gold;--text-muted:#b8a9ff;--primary-color:#2a1b5e;--primary-hover:#3a2a7a;--secondary-color:gold;--success-color:#4caf50;--danger-color:#f44336;--warning-color:#ff9800;--border-color:#4a3a8a;--border-accent:#7b5cff;--shadow-dark:#0009;--shadow-accent:#7b5cff4d;--shadow-yellow:#ffd70080;--container-xxl-width:1400px;--container-xl-width:1200px;--container-max-width:900px;--container-medium-width:600px;--container-small-width:500px;--container-margin:0 auto;--container-padding:2rem 1rem;--font-primary:"Cinzel","Georgia",serif;--font-secondary:"Crimson Text","Times New Roman",serif;--font-body:"Libre Baskerville","Georgia",serif}*{box-sizing:border-box}body{color:#fff;color:var(--text-primary);font-family:Libre Baskerville,Georgia,serif;font-family:var(--font-body);font-size:16px;line-height:1.6;margin:0;min-height:100vh;overflow-x:hidden;padding:0}h1,h2,h3,h4,h5,h6{color:gold;color:var(--text-accent);font-family:Cinzel,Georgia,serif;font-family:var(--font-primary);font-weight:600;margin-bottom:1rem;text-shadow:2px 2px 4px #0009;text-shadow:2px 2px 4px var(--shadow-dark)}h1{font-size:2.5rem;font-weight:700}h2{font-size:2rem}h3{font-size:1.5rem}.fantasy-card{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 8px 32px #ffd70033,inset 0 1px 0 #ffffff1a;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.container-primary,.fantasy-card{background:#4b0082cc;background:var(--container-primary);border:2px solid #ffd7004d;border-radius:12px}.container-primary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #ffd70033}.container-secondary{background:#4b0082b3;background:var(--container-secondary);box-shadow:0 4px 16px #ffd7001a}.container-light,.container-secondary{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid #ffd70033;border-radius:8px}.container-light{background:#4b008266;background:var(--container-light)}.container-accent{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#4b008299;background:var(--container-accent);border:2px solid #ffd70066;border-radius:10px;box-shadow:0 6px 24px #ffd70026}.fantasy-card:before{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.fantasy-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff4d;border-radius:8px;box-shadow:0 4px 15px #0000004d,inset 0 1px 0 #ffffff1a;color:gold;color:var(--text-accent);cursor:pointer;display:inline-flex;font-family:Cinzel,Georgia,serif;font-family:var(--font-primary);font-size:1rem;font-weight:700;justify-content:center;letter-spacing:1px;overflow:hidden;padding:12px 24px;position:relative;text-align:center;text-decoration:none;text-transform:uppercase;z-index:1}.fantasy-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.fantasy-btn:hover{background:#ffffff26;border-color:#ffffff80;box-shadow:0 8px 25px #00000080,inset 0 1px 0 #fff3;transform:translateY(-3px) scale(1.02)}.fantasy-btn:hover:before{left:100%}.fantasy-btn:active{transform:translateY(0)}.fantasy-btn.secondary{background:#ffffff0d;border:1px solid #fff3;box-shadow:0 4px 15px #0000004d,inset 0 1px 0 #ffffff0d;color:gold;color:var(--text-accent)}.fantasy-btn.secondary:hover{background:#ffffff1a;border-color:#fff6;box-shadow:0 6px 20px #0006,inset 0 1px 0 #ffffff26;transform:translateY(-2px) scale(1.01)}.fantasy-btn:disabled{box-shadow:0 2px 8px #0000004d!important;cursor:not-allowed;opacity:.6;position:relative;transform:none!important}.fantasy-btn:disabled:hover:after{background:#f44336e6;border:2px solid #f44336;border-radius:4px;bottom:100%;box-shadow:0 2px 10px #0003;color:#fff;content:"Compila tutti i campi obbligatori";font-family:Libre Baskerville,Georgia,serif;font-family:var(--font-body);font-size:.8rem;left:50%;letter-spacing:normal;margin-bottom:8px;padding:8px 12px;position:absolute;text-transform:none;transform:translateX(-50%);white-space:nowrap;z-index:100}.fantasy-btn:disabled:hover:before{border:6px solid #0000;border-top-color:#f44336;bottom:100%;content:"";left:50%;margin-bottom:2px;position:absolute;transform:translateX(-50%)}svg{fill:gold!important;fill:var(--text-accent)!important;color:gold!important;color:var(--text-accent)!important}input,label,select,textarea{color:#fff!important;color:var(--text-primary)!important}::placeholder{color:#b8a9ff!important;color:var(--text-muted)!important}.fantasy-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #fff3;box-shadow:inset 0 2px 4px #0003,inset 0 1px 0 #ffffff1a;color:#fff;font-family:Libre Baskerville,Georgia,serif;font-family:var(--font-body);padding:12px 16px}.fantasy-input:focus{background:#ffffff1f;border-color:#ffffff80;box-shadow:inset 0 2px 4px #0003,inset 0 1px 0 #fff3,0 0 0 3px #ffffff1a}.fantasy-input::placeholder{color:#b8a9ff}.fantasy-form{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#4a3a8a;background:var(--card-bg);border:2px solid #4a3a8a;border:2px solid var(--border-color);border-radius:16px;box-shadow:0 12px 35px #0009,inset 0 1px 0 #ffffff1a;box-shadow:0 12px 35px var(--shadow-dark),inset 0 1px 0 #ffffff1a;padding:2rem;position:relative}.fantasy-form:before{background:linear-gradient(45deg,#7b5cff,gold,#7b5cff);background:linear-gradient(45deg,var(--border-accent),var(--secondary-color),var(--border-accent));border-radius:18px;bottom:-2px;content:"";left:-2px;opacity:.7;position:absolute;right:-2px;top:-2px;z-index:-1}.form-group{margin-bottom:1.5rem}.form-label{color:#fff;color:var(--text-primary);display:block;font-family:Cinzel,Georgia,serif;font-family:var(--font-primary);font-size:.9rem;font-weight:500;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.fantasy-nav{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff1a;border-bottom:2px solid #ffffff4d;box-shadow:0 10px 40px #000000e6,inset 0 1px 0 #fff3;position:relative}.fantasy-nav:after{background:linear-gradient(90deg,#0000 10%,#fff9 50%,#0000 90%);bottom:-2px;box-shadow:0 0 5px #ffffff4d;content:"";height:1px;left:0;position:absolute;right:0}.status-message{border:2px solid;border-radius:8px;font-family:Crimson Text,Times New Roman,serif;font-family:var(--font-secondary);font-weight:600;margin:1rem 0;padding:1rem 1.5rem}.status-message.success{background:#32cd321a;border-color:#4caf50;border-color:var(--success-color);color:#d4edda}.status-message.error{background:#dc35451a;border-color:#f44336;border-color:var(--danger-color);color:#f8d7da}.status-message.info{background:#ffd7001a;border-color:#2a1b5e;border-color:var(--primary-color);color:gold;color:var(--text-accent)}.loading-spinner{border:3px solid #4a3a8a;border-top:3px solid #2a1b5e;border:3px solid var(--border-color);border-top-color:var(--primary-color);display:inline-block;height:24px;margin-right:8px;width:24px}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#0f0529;background:var(--primary-bg)}::-webkit-scrollbar-thumb{background:#2a1b5e;background:var(--primary-color);border:2px solid #0f0529;border:2px solid var(--primary-bg);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:gold;background:var(--secondary-color)}@media (max-width:768px){h1{font-size:2rem}h2{font-size:1.5rem}.fantasy-form{margin:1rem;padding:1.5rem}.fantasy-btn{font-size:.9rem;padding:10px 20px}.fantasy-card{padding:1rem!important}div[style*="gridTemplateColumns: 'repeat(auto-fit, minmax(350px, 1fr))"]{grid-template-columns:1fr!important}div[style*="maxWidth: '800px'"]{padding:0 .5rem!important}}.copyright-footer{bottom:10px;color:#b8a9ff;color:var(--text-muted);font-family:Crimson Text,Times New Roman,serif;font-family:var(--font-secondary);font-size:.75rem;opacity:.7;position:fixed;right:15px;z-index:999}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.fantasy-card{transition:all .3s ease}.fantasy-card:hover{box-shadow:0 15px 40px #0009;box-shadow:0 15px 40px var(--shadow-dark);transform:translateY(-5px)}.fantasy-btn,.fantasy-input{transition:all .3s ease}.fantasy-btn:hover{animation:pulse 2s infinite}.container-xxl{max-width:1400px;max-width:var(--container-xxl-width)}.container-xl,.container-xxl{margin:0 auto;margin:var(--container-margin);padding:2rem 1rem;padding:var(--container-padding)}.container-xl{max-width:1200px;max-width:var(--container-xl-width)}.container-large{max-width:900px;max-width:var(--container-max-width)}.container-large,.container-medium{margin:0 auto;margin:var(--container-margin);padding:2rem 1rem;padding:var(--container-padding)}.container-medium{max-width:600px;max-width:var(--container-medium-width)}.container-small{max-width:500px;max-width:var(--container-small-width)}.container-full,.container-small{margin:0 auto;margin:var(--container-margin);padding:2rem 1rem;padding:var(--container-padding)}.text-center{text-align:center}.text-accent{color:gold;color:var(--text-accent)}.text-muted{color:#b8a9ff;color:var(--text-muted)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.auth-container{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-form{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:400px;padding:2rem;width:100%}.auth-form h2{color:#333;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1.2rem;text-align:left}.form-group label{color:#444;display:block;font-weight:500;margin-bottom:.5rem}.auth-form input[type=date],.auth-form input[type=email],.auth-form input[type=password],.auth-form input[type=text]{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s,box-shadow .3s;width:100%}.auth-form input:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf5033;outline:none}.auth-button{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;margin-top:1rem;padding:.75rem;transition:background-color .3s;width:100%}.auth-button:hover:not(:disabled){background-color:#45a049}.auth-button:disabled{background-color:#a5d6a7;cursor:not-allowed}.error-message{background-color:#fde8e8;color:#d32f2f}.error-message,.success-message{border-radius:4px;font-size:.9rem;margin:1rem 0;padding:.75rem 1rem;text-align:left}.success-message{background-color:#e8f5e9;color:#2e7d32}.auth-links{color:#666;font-size:.9rem;margin-top:1.5rem;text-align:center}.auth-links a{color:#4caf50;font-weight:500;margin-left:.25rem;text-decoration:none}.auth-links a:hover{text-decoration:underline}.dashboard{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;margin:2rem auto;max-width:800px;padding:2rem}.logout-button{background-color:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:1rem;padding:.5rem 1rem;transition:background-color .3s}.logout-button:hover{background-color:#d32f2f}@media (max-width:480px){.auth-form{padding:1.5rem}.auth-form h2{font-size:1.5rem}}.confirm-email-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:4rem auto;max-width:400px;padding:2rem;text-align:center}.status-message{background:#f8f9fa;border-radius:4px;color:#333;line-height:1.5;margin:1.5rem 0;padding:1rem}.status-message.success{background:#e6f7e6;border-left:4px solid #4caf50;color:#2e7d32}.status-message.error{background:#ffebee;border-left:4px solid #f44336;color:#c62828}.resend-form,.resend-section{margin:1.5rem 0}.resend-form{display:flex;flex-direction:column;gap:1rem}.email-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.btn{background:#4f46e5;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;margin:.5rem 0;padding:.75rem 1.5rem;text-decoration:none;transition:background-color .2s}.btn:hover{background:#4338ca}.btn:disabled{background:#a5b4fc;cursor:not-allowed}.login-link{display:inline-block;margin-top:1.5rem}.login-link,.login-link a{color:#4f46e5;text-decoration:none}.login-link a{font-weight:500}.login-link a:hover{text-decoration:underline}@media (max-width:991px){.clickable,button{min-height:48px;min-width:48px}.touch-friendly{margin:1rem;margin:var(--spacing-md);padding:1.5rem;padding:var(--spacing-lg)}.responsive-button:hover,.responsive-card:hover,.responsive-nav-item:hover{transform:none}.clickable:focus,button:focus,input:focus{outline:3px solid #d4af37;outline-offset:2px}.responsive-grid{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible;padding-bottom:1rem;padding-bottom:var(--spacing-md);scroll-snap-type:x mandatory}.responsive-grid.mobile-horizontal{display:flex;flex-direction:row;gap:1rem;gap:var(--spacing-md);width:100%}.responsive-grid.mobile-horizontal>*{flex:0 0 280px;scroll-snap-align:start}.mobile-scroll-container{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:hidden;padding:1rem 0;padding:var(--spacing-md) 0;scroll-behavior:smooth}.mobile-scroll-indicator{animation:pulse 2s infinite;bottom:-10px;color:#fff9;font-size:.75rem;font-size:var(--font-xs);left:50%;position:absolute;text-align:center;transform:translateX(-50%)}}.story-library-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:1000}.story-library-modal{border:2px solid #d4af37;border-radius:20px;box-shadow:0 20px 60px #d4af374d;color:beige;flex-direction:column;max-height:95vh;max-width:100vw;overflow-y:auto;width:100%}.story-library-header,.story-library-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex}.story-library-header{align-items:center;border-bottom:2px solid #d4af37;flex-shrink:0;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-lg);position:-webkit-sticky;position:sticky;top:0;z-index:10}.story-library-header h2{color:#d4af37;font-size:var(--font-xl);font-weight:700;margin:0;text-shadow:0 0 10px #d4af3780}.close-button{align-items:center;background:none;border:2px solid #dc2626;border-radius:50%;color:#dc2626;cursor:pointer;display:flex;flex-shrink:0;font-size:var(--font-lg);justify-content:center;min-height:48px;min-width:48px;transition:all .3s ease}.close-button:hover{background:#dc2626;color:#fff;transform:scale(1.1)}.character-info{align-items:center;background:#d4af371a;border-bottom:1px solid #d4af374d;display:flex;flex-shrink:0;flex-wrap:wrap;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg)}.character-name{color:#d4af37;font-size:1.2rem;font-weight:700}.character-level{background:linear-gradient(45deg,#8b5cf6,#a855f7)}.character-class,.character-level{border-radius:12px;color:#fff;font-size:.9rem;font-weight:700;padding:4px 12px}.character-class{background:linear-gradient(45deg,#059669,#10b981)}.category-filters{border-bottom:1px solid #d4af374d;display:flex;flex-wrap:wrap;gap:15px;padding:20px 30px}.category-filter{background:#d4af371a;border:2px solid #d4af374d;border-radius:20px;color:beige;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.category-filter:hover{background:#d4af3733;border-color:#d4af3780;transform:translateY(-2px)}.category-filter.active{background:linear-gradient(45deg,#d4af37,#f1c40f);border-color:#d4af37;color:#1a1a2e;font-weight:700}.stories-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));padding:30px}.no-stories{color:#9ca3af;grid-column:1/-1;padding:60px 20px;text-align:center}.no-stories p{font-size:1.1rem;margin:10px 0}.story-card{background:linear-gradient(135deg,#2d3748,#1a202c);border:2px solid #d4af374d;border-radius:15px;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.story-card:hover{border-color:#d4af37;box-shadow:0 10px 30px #d4af3733;transform:translateY(-5px)}.story-card.disabled{opacity:.6;pointer-events:none}.story-card.completed{background:linear-gradient(135deg,#065f46,#047857);border-color:#10b981}.story-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.story-title{color:#d4af37;flex:1 1;font-size:1.3rem;font-weight:700;margin:0 15px 0 0}.difficulty-badge{border-radius:12px;color:#fff;font-size:.8rem;font-weight:700;padding:4px 12px;text-shadow:0 1px 2px #00000080}.story-description{color:#e2e8f0;font-size:.95rem;line-height:1.5;margin-bottom:20px}.story-meta{margin-bottom:15px}.meta-row{display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:8px}.meta-label{color:#9ca3af;font-weight:500}.meta-value{color:beige;font-weight:700}.repeatable-badge{background:linear-gradient(45deg,#3b82f6,#1d4ed8);border-radius:10px;color:#fff;font-size:.8rem;font-weight:700;padding:4px 10px}.story-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.story-tag{background:#8b5cf64d;border:1px solid #8b5cf680;border-radius:8px;color:#c4b5fd;font-size:.8rem;padding:3px 8px}.story-actions{margin-top:auto}.story-action-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:1rem;font-weight:700;gap:8px;justify-content:center;padding:12px;transition:all .3s ease;width:100%}.story-action-button.primary{background:linear-gradient(45deg,#d4af37,#f1c40f);color:#1a1a2e}.story-action-button.primary:hover{box-shadow:0 5px 15px #d4af3766;transform:translateY(-2px)}.story-action-button.secondary{background:linear-gradient(45deg,#3b82f6,#1d4ed8);color:#fff}.story-action-button.secondary:hover{box-shadow:0 5px 15px #3b82f666;transform:translateY(-2px)}.story-action-button:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.completed-indicator{color:#10b981;font-size:1.1rem;font-weight:700;padding:12px;text-align:center}.lock-overlay{align-items:center;background:#000c;border-radius:15px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}.lock-reason{background:#dc2626;border-radius:10px;color:#fff;font-weight:700;padding:8px 16px;text-align:center}.story-preview-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1100}.story-preview-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #d4af37;border-radius:20px;box-shadow:0 20px 60px #d4af374d;color:beige;max-height:80vh;max-width:600px;overflow-y:auto;width:100%}.preview-header{align-items:center;border-bottom:2px solid #d4af37;display:flex;justify-content:space-between;padding:20px 30px}.preview-header h3{color:#d4af37;font-size:1.5rem;font-weight:700;margin:0}.preview-content{padding:30px}.preview-description{color:#e2e8f0;font-size:1.1rem;line-height:1.6;margin-bottom:30px}.preview-details{grid-gap:25px;display:grid;gap:25px}.detail-section h4{align-items:center;color:#d4af37;display:flex;font-size:1.2rem;gap:8px;margin-bottom:15px}.detail-section ul{list-style:none;margin:0;padding:0}.detail-section li{border-bottom:1px solid #d4af3733;color:#e2e8f0;padding:8px 0}.detail-section li:last-child{border-bottom:none}.preview-warning{background:#fbbf241a;border:1px solid #fbbf244d;border-radius:10px;margin-top:25px;padding:15px}.preview-warning p{color:#fbbf24;margin:0}.preview-actions{border-top:1px solid #d4af374d;display:flex;gap:15px;justify-content:flex-end;padding:20px 30px}.preview-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:1rem;font-weight:700;gap:8px;padding:12px 24px;transition:all .3s ease}.preview-button.secondary{background:#6b7280;color:#fff}.preview-button.secondary:hover{background:#4b5563;transform:translateY(-2px)}.preview-button.primary{background:linear-gradient(45deg,#d4af37,#f1c40f);color:#1a1a2e}.preview-button.primary:hover{box-shadow:0 5px 15px #d4af3766;transform:translateY(-2px)}.loading-container{align-items:center;color:#d4af37;display:flex;flex-direction:column;gap:20px;padding:60px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #d4af374d;border-left-color:#d4af37;border-radius:50%;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (min-width:768px) and (max-width:991px){.story-library-modal{max-height:90vh;max-width:90vw}.story-library-header h2{font-size:var(--font-2xl)}.character-info{gap:var(--spacing-lg)}.category-filters,.character-info{padding:var(--spacing-lg) var(--spacing-xl)}.category-filters{gap:var(--spacing-md)}.stories-grid{gap:var(--spacing-xl);grid-template-columns:repeat(2,1fr)}.stories-grid,.story-card{padding:var(--spacing-xl)}.story-title{font-size:var(--font-xl)}.story-description{font-size:var(--font-base)}.story-action-button{font-size:var(--font-lg);padding:var(--spacing-lg) var(--spacing-xl)}.story-preview-modal{max-width:80vw;width:600px}.preview-content{padding:var(--spacing-xl)}.preview-actions{flex-direction:row;justify-content:flex-end}}@media (min-width:992px){.story-library-modal{max-height:85vh;max-width:1200px;width:85vw}.story-library-header{padding:var(--spacing-xl) var(--spacing-xxl)}.story-library-header h2{font-size:var(--font-3xl)}.character-info{gap:var(--spacing-xl);padding:var(--spacing-xl) var(--spacing-xxl)}.character-name{font-size:var(--font-xl)}.category-filters{gap:var(--spacing-lg);padding:var(--spacing-xl) var(--spacing-xxl)}.category-filter{font-size:var(--font-base);padding:var(--spacing-md) var(--spacing-lg)}.stories-grid{gap:var(--spacing-xxl);grid-template-columns:repeat(3,1fr);padding:var(--spacing-xxl)}.story-card{padding:var(--spacing-xl)}.story-title{font-size:var(--font-2xl)}.story-description{font-size:var(--font-lg);line-height:1.6}.meta-row{font-size:var(--font-base)}.story-action-button{font-size:var(--font-lg);padding:var(--spacing-lg) var(--spacing-xxl)}.story-preview-modal{max-width:700px;width:50vw}.preview-header{padding:var(--spacing-xl) var(--spacing-xxl)}.preview-content{padding:var(--spacing-xxl)}.preview-actions{padding:var(--spacing-xl) var(--spacing-xxl)}}@media (min-width:1200px){.story-library-modal{max-width:1400px;width:80vw}.stories-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));max-width:none}.story-card{max-width:400px}}@media (min-width:768px) and (max-width:991px) and (orientation:landscape){.story-library-modal{max-height:95vh}.stories-grid{grid-template-columns:repeat(3,1fr)}.character-info{padding:var(--spacing-md) var(--spacing-xl)}}@media (max-width:991px){.category-filter:hover,.close-button:hover,.story-action-button:hover,.story-card:hover{transform:none}.category-filter,.close-button,.story-action-button{min-height:48px;min-width:48px}.category-filter:focus,.close-button:focus,.story-action-button:focus{outline:3px solid #d4af37;outline-offset:2px}.story-library-modal{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.stories-grid{scroll-snap-type:y mandatory}.story-card{scroll-snap-align:start}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.category-filter,.story-action-button,.story-card,.story-library-modal{border-width:1px}}@media (prefers-reduced-motion:reduce){.category-filter,.close-button,.story-action-button,.story-card{transition:none}.story-action-button:hover,.story-card:hover{transform:none}.loading-spinner{animation:none}}@media (prefers-color-scheme:dark){.story-library-modal{background:linear-gradient(135deg,#0a0a0f,#0d1117)}.story-card{background:linear-gradient(135deg,#1c1c28,#151519)}}:root{--breakpoint-mobile:480px;--breakpoint-tablet:768px;--breakpoint-laptop:992px;--breakpoint-desktop:1200px;--breakpoint-large:1400px;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-xxl:3rem;--font-xs:0.75rem;--font-sm:0.875rem;--font-base:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:2rem;--font-4xl:2.5rem}.mobile-only{display:block}.desktop-only,.tablet-only{display:none}.responsive-container{margin:0 auto;max-width:1400px;padding:0 1rem;padding:0 var(--spacing-md);width:100%}.responsive-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:1fr}.responsive-flex{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md)}.responsive-card{background:linear-gradient(135deg,#2d3748,#1a202c);border:2px solid #d4af374d;border-radius:15px;padding:1.5rem;padding:var(--spacing-lg);transition:all .3s ease}.responsive-title{color:#d4af37;font-size:1.5rem;font-size:var(--font-2xl);font-weight:700;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.responsive-subtitle{color:beige;font-size:1.25rem;font-size:var(--font-xl);font-weight:600;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.responsive-text{color:#e2e8f0;line-height:1.6}.responsive-button,.responsive-text{font-size:1rem;font-size:var(--font-base)}.responsive-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-weight:700;gap:.5rem;gap:var(--spacing-sm);justify-content:center;min-height:48px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);transition:all .3s ease}.responsive-button:hover:not(:disabled){transform:translateY(-2px)}.responsive-button:disabled{cursor:not-allowed;opacity:.5}.responsive-modal{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:1000}.responsive-modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #d4af37;border-radius:20px;box-shadow:0 20px 60px #d4af374d;color:beige;max-height:90vh;max-width:100%;overflow-y:auto;width:100%}.responsive-nav{align-items:center;background:#d4af371a;border-bottom:1px solid #d4af374d;display:flex;justify-content:space-between;padding:1rem;padding:var(--spacing-md)}.responsive-nav-menu{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm)}.responsive-nav-item{align-items:center;border-radius:10px;cursor:pointer;display:flex;font-size:.875rem;font-size:var(--font-sm);min-height:40px;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .3s ease}.responsive-form{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg);max-width:100%}.responsive-input{background:#ffffff1a;border:2px solid #d4af374d;border-radius:10px;color:beige;font-size:1rem;font-size:var(--font-base);min-height:48px;padding:1rem;padding:var(--spacing-md)}@media (min-width:768px) and (max-width:991px){.mobile-only{display:none}.tablet-only{display:block}.desktop-only{display:none}.responsive-container{padding:0 1.5rem;padding:0 var(--spacing-lg)}.responsive-grid{gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}.responsive-flex{align-items:center;flex-direction:row;flex-wrap:wrap}.responsive-title{font-size:2rem;font-size:var(--font-3xl)}.responsive-subtitle{font-size:1.5rem;font-size:var(--font-2xl)}.responsive-button{font-size:1.125rem;font-size:var(--font-lg);padding:1.5rem 2rem;padding:var(--spacing-lg) var(--spacing-xl)}.responsive-modal-content{max-width:90%;width:700px}.responsive-nav-menu{gap:1rem;gap:var(--spacing-md)}.responsive-nav-item{font-size:1rem;font-size:var(--font-base);padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg)}}@media (min-width:992px){.mobile-only,.tablet-only{display:none}.desktop-only{display:block}.responsive-container{padding:0 2rem;padding:0 var(--spacing-xl)}.responsive-grid{gap:2rem;gap:var(--spacing-xl);grid-template-columns:repeat(3,1fr)}.responsive-flex{align-items:center;flex-direction:row;justify-content:space-between}.responsive-title{font-size:2.5rem;font-size:var(--font-4xl);text-align:left}.responsive-subtitle{font-size:1.5rem;font-size:var(--font-2xl)}.responsive-button,.responsive-text{font-size:1.125rem;font-size:var(--font-lg)}.responsive-button{max-width:-webkit-fit-content;max-width:fit-content;padding:1.5rem 3rem;padding:var(--spacing-lg) var(--spacing-xxl)}.responsive-modal-content{max-width:1200px;width:80%}.responsive-nav-menu{gap:1.5rem;gap:var(--spacing-lg)}.responsive-nav-item{font-size:1.125rem;font-size:var(--font-lg);padding:1rem 2rem;padding:var(--spacing-md) var(--spacing-xl)}.desktop-grid-4{grid-template-columns:repeat(4,1fr)}.desktop-grid-auto{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (min-width:1200px){.responsive-grid{grid-template-columns:repeat(4,1fr)}.responsive-modal-content{max-width:1400px}}@media (max-width:991px){.clickable,button{min-height:48px;min-width:48px}.touch-friendly{margin:1rem;margin:var(--spacing-md);padding:1.5rem;padding:var(--spacing-lg)}.responsive-button:hover,.responsive-card:hover,.responsive-nav-item:hover{transform:none}.clickable:focus,button:focus,input:focus{outline:3px solid #d4af37;outline-offset:2px}.responsive-grid{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible;padding-bottom:1rem;padding-bottom:var(--spacing-md);scroll-snap-type:x mandatory}.responsive-grid.mobile-horizontal{display:flex;flex-direction:row;gap:1rem;gap:var(--spacing-md);width:100%}.responsive-grid.mobile-horizontal>*{flex:0 0 280px;scroll-snap-align:start}.mobile-scroll-container{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:hidden;padding:1rem 0;padding:var(--spacing-md) 0;scroll-behavior:smooth}.mobile-scroll-indicator{animation:pulse 2s infinite;bottom:-10px;color:#fff9;font-size:.75rem;font-size:var(--font-xs);left:50%;position:absolute;text-align:center;transform:translateX(-50%)}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}}@media (min-width:768px) and (max-width:991px) and (orientation:landscape){.responsive-grid{grid-template-columns:repeat(3,1fr)}.responsive-modal-content{max-height:95vh}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.responsive-button,.responsive-card{border-width:1px}}@media (prefers-color-scheme:dark){:root{--text-primary:beige;--text-secondary:#e2e8f0;--bg-primary:#1a1a2e;--bg-secondary:#16213e;--accent:#d4af37}}@media (prefers-reduced-motion:reduce){.responsive-button,.responsive-card,.responsive-nav-item{transition:none}.responsive-button:hover{transform:none}}.fullscreen-mode{background:#000!important;height:100vh!important;left:0!important;overflow:auto!important;position:fixed!important;top:0!important;width:100vw!important;z-index:9999!important}.fullscreen-toggle{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#d4af37e6;border:none;border-radius:50%;color:#000;cursor:pointer;display:flex;font-size:1.2rem;height:50px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .3s ease;width:50px;z-index:10000}.fullscreen-toggle:hover{background:#d4af37;transform:scale(1.1)}.fullscreen-content{-webkit-overflow-scrolling:touch;height:100%;overflow-y:auto;width:100%}@media (max-width:768px){.fullscreen-toggle{font-size:1.4rem;height:60px;right:15px;top:15px;width:60px}}@media print{.fullscreen-toggle,.responsive-modal,.responsive-nav,button{display:none}.responsive-container{max-width:none;padding:0}.responsive-card{border:1px solid #000;break-inside:avoid;page-break-inside:avoid}}.section-container{display:flex;gap:2rem;margin:var(--container-margin);max-width:var(--container-xxl-width);padding:var(--container-padding);width:100%}.section-panel{background:var(--container-primary);border:1px solid #ffd70033;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;flex:1 1;flex-direction:column;min-width:0;padding:1.5rem;width:0}.section-panel>*{box-sizing:border-box;max-width:100%;min-width:0}.section-panel table{border-collapse:initial;border-spacing:0 .5rem;table-layout:fixed;width:100%}.section-panel td,.section-panel th{overflow:hidden;padding:.75rem;text-align:left;text-overflow:ellipsis;white-space:nowrap}.class-carousel::-webkit-scrollbar,.portrait-carousel::-webkit-scrollbar,.race-carousel::-webkit-scrollbar{height:8px}.class-carousel::-webkit-scrollbar-track,.portrait-carousel::-webkit-scrollbar-track,.race-carousel::-webkit-scrollbar-track{background:#0003;border-radius:4px}.class-carousel::-webkit-scrollbar-thumb,.portrait-carousel::-webkit-scrollbar-thumb,.race-carousel::-webkit-scrollbar-thumb{background:#ffd70066;border-radius:4px}.class-carousel::-webkit-scrollbar-thumb:hover,.portrait-carousel::-webkit-scrollbar-thumb:hover,.race-carousel::-webkit-scrollbar-thumb:hover{background:#ffd70099}.class-carousel-container,.portrait-carousel-container,.race-carousel-container{align-items:center;background:var(--container-secondary);border:1px solid #ffd7004d;border-radius:10px;display:flex;gap:1rem;overflow:hidden;padding:1rem}.class-selected,.portrait-selected,.race-selected{align-items:center;display:flex;flex-direction:column;flex-shrink:0;min-width:100px}.class-options,.portrait-options,.race-options{flex:1 1;min-width:0}.class-carousel,.portrait-carousel,.race-carousel{display:flex;gap:.75rem;min-height:-webkit-fit-content;min-height:fit-content;overflow-x:auto;padding:.5rem 0;scrollbar-color:#ffd7004d #0000;scrollbar-width:thin}@media (max-width:768px){.compact-form-grid{gap:.75rem!important;grid-template-columns:1fr!important}.compact-form-grid .form-group{margin-bottom:.75rem!important}.class-carousel-container,.portrait-carousel-container,.race-carousel-container{flex-direction:column!important;gap:.75rem!important}.class-selected,.portrait-selected,.race-selected{order:2!important}.class-options,.portrait-options,.race-options{order:1!important}}@media (max-width:480px){.portrait-grid{gap:.5rem!important;grid-template-columns:repeat(3,1fr)!important}.portrait-card{padding:.5rem .25rem!important}.portrait-emoji{font-size:1.5rem!important}.portrait-name{font-size:.7rem!important}.portrait-desc{display:none!important}}@media (max-width:992px){.section-container{flex-direction:column}.section-panel{width:100%}}.fantasy-input{background:var(--container-secondary);border:2px solid #ffd7004d;border-radius:8px;box-shadow:0 4px 12px #ffd70033;color:var(--text-primary);font-size:1rem;font-weight:500;padding:.875rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.fantasy-input:focus{background:var(--container-primary);border-color:var(--text-accent);box-shadow:0 0 0 3px #ffd70033,0 4px 20px #ffd70033;outline:none;transform:translateY(-2px)}.fantasy-input::placeholder{color:var(--text-muted);font-style:italic}.fantasy-input option{background:var(--container-primary);border:none;color:var(--text-primary);padding:.5rem}.fantasy-input option:hover{background:var(--container-accent);color:var(--text-accent)}.fantasy-input option:checked,.fantasy-input option:selected{background:var(--container-accent);color:var(--text-accent);font-weight:600}select.fantasy-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='gold' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .7rem center;background-repeat:no-repeat;background-size:1em;padding-right:2.5rem}@-moz-document url-prefix(){select.fantasy-input{background-image:none;padding-right:1rem}}select.fantasy-input option{background-color:#4b0082cc!important;color:#ffffffe6!important}select.fantasy-input option:hover{background-color:#4b008299!important;color:gold!important}.characteristics-container{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.method-selector{display:flex;gap:.5rem;margin-bottom:1.5rem}.method-selector .fantasy-btn{flex:1 1;font-size:.9rem;padding:.75rem}.abilities-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--container-light);border:2px solid #ffd7004d;border-radius:12px;margin-top:1rem;padding:1.5rem}.ability-legend-header{align-items:center;background:var(--container-secondary);border:1px solid #ffd70066;border-radius:8px;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.legend-item{color:var(--text-accent);flex:1 1}.legend-scores{align-items:center;display:flex;flex:2 1;gap:1rem;justify-content:flex-end}.legend-base,.legend-equals,.legend-mod,.legend-modifier,.legend-plus,.legend-total{color:var(--text-primary);font-size:.8rem;letter-spacing:.5px;min-width:40px;text-align:center;text-transform:uppercase}.legend-equals,.legend-plus{color:var(--text-accent);font-weight:700;min-width:20px}.legend-mod{color:var(--success-color)}.legend-modifier,.legend-total{color:var(--text-accent)}.ability-row.enhanced{align-items:center;background:var(--container-secondary);border:1px solid #ffd70033;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:1rem;transition:all .3s ease}.ability-row.enhanced:hover{border-color:#ffd70066;box-shadow:0 2px 8px #ffd7001a;transform:translateY(-1px)}.ability-name{color:var(--text-accent);flex:1 1;font-size:1rem}.ability-scores{align-items:center;display:flex;flex:2 1;gap:.5rem;justify-content:flex-end}.score-container{align-items:center;display:flex;justify-content:center;min-width:40px}.score-container.equals-sign,.score-container.plus-sign{min-width:20px}.base-score{position:relative}.point-buy-controls{align-items:center;display:flex;gap:.25rem}.score-adjust-btn{align-items:center;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.8rem;font-weight:600;height:22px;justify-content:center;transition:all .2s ease;width:22px}.score-adjust-btn.decrease{background:var(--danger-color)}.score-adjust-btn.decrease:hover:not(:disabled){background:#e53e3e;transform:scale(1.1)}.score-adjust-btn.increase{background:var(--success-color)}.score-adjust-btn.increase:hover:not(:disabled){background:#38a169;transform:scale(1.1)}.score-adjust-btn:disabled{background:var(--border-color);cursor:not-allowed;opacity:.5}.base-score-value{background:#0000004d;border:1px solid #fff3;border-radius:4px;color:#ffffffe6;font-size:1rem;font-weight:600;min-width:30px;padding:.25rem .5rem;text-align:center}.base-score-value.random{background:#64646466;border-color:#ffffff4d}.equals-symbol,.plus-symbol{color:var(--text-accent);font-size:1.1rem;font-weight:700;text-shadow:0 1px 2px #00000080}.mod-value{background:#4caf5026;border:1px solid #4caf504d;border-radius:4px;color:var(--success-color);font-size:.95rem;min-width:25px;padding:.25rem .4rem}.mod-value,.total-score-value{font-weight:700;text-align:center;text-shadow:0 1px 2px #00000080}.total-score-value{border:2px solid #ffd70066;border-radius:6px;font-size:1.1rem;padding:.3rem .5rem}.modifier-value,.total-score-value{background:#ffd70026;color:var(--text-accent);min-width:35px}.modifier-value{border:1px solid #ffd7004d;border-radius:4px;font-size:.9rem;font-weight:700;padding:.25rem .5rem;text-align:center;text-shadow:0 1px 2px #00000080}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.enhanced-button-primary{align-items:center;background:var(--gradient-primary);border:2px solid #ffffff4d;border-radius:8px;box-shadow:0 4px 15px #4f46e566;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;min-height:48px;padding:.875rem 1.5rem;text-decoration:none;text-shadow:0 0 5px #0000004d;transition:all .3s cubic-bezier(.4,0,.2,1)}.enhanced-button-primary:hover:not(:disabled){box-shadow:0 6px 25px #4f46e599;transform:translateY(-2px) scale(1.02)}.enhanced-button-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.enhanced-button-secondary{align-items:center;background:var(--container-secondary);border:2px solid #ffd7004d;border-radius:8px;box-shadow:0 4px 15px #ffd70033;color:var(--text-accent);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;min-height:48px;padding:.875rem 1.5rem;text-decoration:none;text-shadow:0 0 5px #ffd7004d;transition:all .3s cubic-bezier(.4,0,.2,1)}.enhanced-button-secondary:hover:not(:disabled){background:var(--container-primary);box-shadow:0 6px 25px #ffd7004d;transform:translateY(-2px) scale(1.02)}.enhanced-button-secondary:disabled{cursor:not-allowed;opacity:.6;transform:none}.button-row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem}.button-row .enhanced-button-primary,.button-row .enhanced-button-secondary{flex:1 1;min-width:150px}.nav-button-back,.nav-button-cancel,.nav-button-next{align-items:center;background:var(--container-secondary);border:2px solid #ffd7004d;border-radius:8px;box-shadow:0 4px 15px #ffd70033;color:var(--text-accent);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;min-height:48px;padding:.875rem 1.5rem;text-decoration:none;text-shadow:0 0 5px #ffd7004d;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-button-next{background:var(--gradient-primary);border:2px solid #ffffff4d;box-shadow:0 4px 15px #4f46e566;color:#fff;text-shadow:0 0 5px #0000004d}.nav-button-back:hover:not(:disabled),.nav-button-cancel:hover:not(:disabled){background:var(--container-primary);box-shadow:0 6px 25px #ffd7004d;transform:translateY(-2px) scale(1.02)}.nav-button-next:hover:not(:disabled){box-shadow:0 6px 25px #4f46e599;transform:translateY(-2px) scale(1.02)}.nav-button-back:disabled,.nav-button-cancel:disabled,.nav-button-next:disabled{cursor:not-allowed;opacity:.6;transform:none}.save-character-button{align-items:center;background:var(--gradient-primary);border:2px solid #ffffff4d;border-radius:8px;box-shadow:0 4px 15px #4f46e566;color:#fff;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:1.5rem;min-height:52px;padding:1rem 1.5rem;text-decoration:none;text-shadow:0 0 5px #0000004d;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.save-character-button:hover:not(:disabled){box-shadow:0 6px 25px #4f46e599;transform:translateY(-2px) scale(1.02)}.save-character-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.step-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--container-primary);border:2px solid #ffd7004d;border-radius:12px;border-radius:var(--border-radius,12px);box-shadow:0 8px 32px #ffd70033;margin:0 auto;max-width:700px;padding:2rem;width:100%}.step-title{color:var(--text-accent);font-family:var(--font-primary);font-size:1.75rem;font-weight:700;margin-bottom:2rem;text-align:center;text-shadow:0 0 15px #ffd70066}.progress-steps{background:var(--container-secondary);border:2px solid #ffd7004d;border-radius:12px;justify-content:space-between;margin-bottom:1rem;padding:1.5rem}.progress-steps,.step-circle{align-items:center;display:flex}.step-circle{border-radius:50%;font-size:1.1rem;font-weight:600;height:50px;justify-content:center;margin-bottom:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:50px}.step-circle.active{background:var(--container-primary);border:2px solid var(--text-accent);box-shadow:0 8px 25px #ffd70033;color:var(--text-accent)}.step-circle.inactive{border:1px solid #ffd7004d;color:var(--text-muted)}.info-card,.step-circle.inactive{background:var(--container-light)}.info-card{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid #ffd70033;border-radius:8px;margin-top:1rem;padding:1.5rem}.info-card h4{color:var(--text-accent);font-family:var(--font-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem;text-shadow:0 0 8px #ffd70066}.info-card p{color:var(--text-muted);line-height:1.6;margin-bottom:1rem}.info-card strong{color:var(--text-accent);font-weight:600}.characteristics-section{background:var(--container-light);border:1px solid #ffd7004d;border-radius:12px;padding:1.5rem}.characteristics-header{background:var(--container-secondary);border:1px solid #ffd7004d;border-radius:8px;color:var(--text-accent);font-family:var(--font-primary);font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;padding:.75rem;text-align:center}.summary-section{background:var(--container-light);border:1px solid #ffd7004d;border-radius:12px;padding:1.5rem}.character-name{color:var(--text-accent);font-family:var(--font-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem;text-align:center}.summary-item{border-bottom:1px solid #ffd7004d;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:.5rem 0}.summary-label{color:var(--text-accent);font-weight:600}.summary-value{color:var(--text-primary)}.navigation-container{background:var(--container-secondary);border:1px solid #ffd7004d;border-radius:12px;margin-top:2rem;padding:1.5rem}.points-display{background:var(--container-secondary);border:1px solid #ffd7004d;border-radius:8px;margin-bottom:1rem;padding:1rem;text-align:center}.points-remaining{color:var(--text-accent);font-size:1.1rem;font-weight:600}.ability-row{align-items:center;border-bottom:1px solid #ffd7004d;display:flex;justify-content:space-between;padding:.75rem 0}.ability-name{color:var(--text-primary);font-weight:600;min-width:120px}.final-score{min-width:30px}.final-score,.modifier{color:var(--text-accent);font-weight:600;text-align:center}.modifier{font-size:.9rem;min-width:50px}.ability-score{min-width:30px;text-align:center}.adjust-btn{align-items:center;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-weight:600;height:28px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:28px}.adjust-btn.decrease{background:var(--danger-color)}.adjust-btn.increase{background:var(--success-color)}.adjust-btn:hover:not(:disabled){transform:scale(1.1)}.adjust-btn:disabled{background:#6b7280;cursor:not-allowed}@media (max-width:768px){.step-container{padding:1.5rem}.characteristics-container{gap:1.5rem;grid-template-columns:1fr}.progress-steps{padding:1rem}.step-circle{font-size:1rem;height:40px;width:40px}.ability-row{align-items:flex-start;flex-direction:column;gap:.5rem}.ability-controls{justify-content:space-between;width:100%}.button-row{flex-direction:column;gap:.75rem}.button-row .enhanced-button-primary,.button-row .enhanced-button-secondary{min-width:auto;width:100%}.enhanced-button-primary,.enhanced-button-secondary,.nav-button-back,.nav-button-cancel,.nav-button-next,.save-character-button{font-size:.9rem;padding:.75rem 1rem}.navigation-buttons{flex-direction:column;gap:.75rem}.navigation-buttons button{width:100%}}@media (max-width:480px){.step-title{font-size:1.5rem}.step-container{padding:1rem}}.story-container{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:300px 1fr 300px;margin:0 auto;max-width:1400px;padding:0 1rem}.character-panel{max-height:calc(100vh - 10rem);overflow-y:auto;position:-webkit-sticky;position:sticky;top:8rem}.character-visual{grid-gap:.5rem;background:var(--container-secondary);border-radius:8px;display:grid;gap:.5rem;grid-template-columns:1fr 80px 1fr;grid-template-rows:repeat(4,40px);margin-bottom:1.5rem;padding:1rem}.equipment-slot{align-items:center;background:var(--surface-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;font-size:.7rem;justify-content:center;transition:all .3s ease}.equipment-slot:hover{background:var(--container-primary);border-color:var(--text-accent)}.character-avatar{align-items:center;background:var(--primary-color);border:2px solid var(--text-accent);border-radius:8px;display:flex;font-size:2rem;justify-content:center}.character-stats{margin-bottom:1.5rem}.stat-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.stat-box{background:var(--container-secondary);border-radius:4px;padding:.5rem;text-align:center}.stat-value{color:var(--text-accent);font-size:1.2rem;font-weight:600}.stat-label{color:var(--text-muted);font-size:.8rem}.abilities-grid{grid-gap:.25rem;display:grid;font-size:.8rem;gap:.25rem;grid-template-columns:repeat(3,1fr)}.ability-box{background:var(--surface-bg);border-radius:4px;padding:.25rem;text-align:center}.ability-score{color:var(--text-primary);font-weight:600}.ability-name{color:var(--text-muted);font-size:.7rem}.ability-modifier{color:var(--text-accent);font-size:.7rem}.story-panel{max-width:100%}.story-text{color:var(--text-primary);font-size:1.1rem;line-height:1.8;white-space:pre-line}.choices-container{display:flex;flex-direction:column;gap:.75rem}.choice-button{border-radius:8px;font-size:1rem;line-height:1.4;padding:1rem;text-align:left;transition:all .3s ease}.choice-requirement{color:var(--text-accent);font-size:.8rem;font-weight:600;margin-right:.5rem}.choice-button:hover{box-shadow:0 4px 15px #ffd7004d;transform:translateY(-2px)}.inventory-panel{max-height:calc(100vh - 10rem);overflow-y:auto;position:-webkit-sticky;position:sticky;top:8rem}.gold-display{background:var(--container-secondary);border-radius:8px;margin-bottom:1.5rem;padding:1rem;text-align:center}.gold-amount{color:gold;font-size:1.5rem;font-weight:600}.gold-label{color:var(--text-muted);font-size:.8rem}.inventory-items{max-height:400px;overflow-y:auto}.inventory-item{align-items:center;background:var(--surface-bg);border:1px solid var(--border-color);border-radius:4px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.5rem;transition:all .3s ease}.inventory-item.equipped{background:#ffd7001a;border:1px solid var(--text-accent)}.inventory-item:hover{background:var(--container-primary);border-color:var(--text-accent)}.item-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.item-equipped{color:var(--text-accent);font-size:.7rem;margin-left:.5rem}.item-type{color:var(--text-muted);font-size:.7rem}.item-quantity{color:var(--text-accent);font-size:.8rem;font-weight:600}@media (max-width:1200px){.story-container{gap:1.5rem;grid-template-columns:250px 1fr 250px}}@media (max-width:992px){.story-container{gap:2rem;grid-template-columns:1fr}.character-panel,.inventory-panel{max-height:none;position:static}.character-visual{grid-template-columns:1fr 60px 1fr;grid-template-rows:repeat(4,35px)}.character-avatar{font-size:1.5rem}}@media (max-width:768px){.story-container{gap:1.5rem;padding:0 .5rem}.choice-button{font-size:.9rem;padding:.75rem}.abilities-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.character-visual{gap:.25rem;grid-template-columns:1fr 50px 1fr;grid-template-rows:repeat(4,30px)}.character-avatar{font-size:1.2rem}.equipment-slot{font-size:.6rem}.stat-grid{grid-template-columns:1fr}}.character-panel::-webkit-scrollbar,.inventory-items::-webkit-scrollbar,.inventory-panel::-webkit-scrollbar{width:6px}.character-panel::-webkit-scrollbar-track,.inventory-items::-webkit-scrollbar-track,.inventory-panel::-webkit-scrollbar-track{background:#0003;border-radius:3px}.character-panel::-webkit-scrollbar-thumb,.inventory-items::-webkit-scrollbar-thumb,.inventory-panel::-webkit-scrollbar-thumb{background:#ffd70066;border-radius:3px}.character-panel::-webkit-scrollbar-thumb:hover,.inventory-items::-webkit-scrollbar-thumb:hover,.inventory-panel::-webkit-scrollbar-thumb:hover{background:#ffd70099}.story-text{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.choice-button{animation:fadeInLeft .4s ease-out;animation-fill-mode:backwards}.choice-button:first-child{animation-delay:.1s}.choice-button:nth-child(2){animation-delay:.2s}.choice-button:nth-child(3){animation-delay:.3s}.choice-button:nth-child(4){animation-delay:.4s}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.footer{background-color:#282c34;bottom:0;color:#fff;margin-top:40px;padding:20px 0;position:relative;text-align:center;width:100%}.footer-content{margin:0 auto;max-width:1200px;padding:0 20px}.footer p{color:#e0e0e0;font-size:.9rem;margin:0}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.32eb206c.css.map*/