:root{--primary-color:#7e57c2;--primary-dark:#5e35b1;--accent-color:#ff9800;--accent-dark:#f57c00;--text-light:#f5f5f5;--text-dark:#212121;--bg-dark:#121212;--bg-card:rgba(30,30,40,0.8);--bg-card-premium:rgba(50,40,80,0.9);--success:#4caf50;--danger:#f44336;--shadow:0 5px 20px rgba(0,0,0,0.3);--shadow-heavy:0 8px 30px rgba(0,0,0,0.5);--font-title:"Cinzel",serif;--font-body:"Spectral",serif;--primary-color:#007bff;--primary-dark:#0056b3;--secondary-color:#6c757d;--background-light:#f8f9fa;--background-dark:#343a40;--text-light:#f8f9fa;--text-dark:#212529;--accent-color:#ffc107;--success-color:#28a745;--danger-color:#dc3545;--border-color:#dee2e6;--card-bg:#ffffff;--scrollbar-bg:rgba(20,20,35,0.6);--scrollbar-thumb:rgba(240,167,66,0.7);--scrollbar-thumb-hover:rgba(240,167,66,0.9)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text-light);background-color:var(--bg-dark);overflow-x:hidden;line-height:1.6}.body-blur .bg-container,.body-blur footer,.body-blur main{filter:blur(5px);transition:filter .3s ease;pointer-events:none}.hide-header header{display:none!important}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--scrollbar-bg);border-radius:10px}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px;-webkit-transition:all .3s ease;transition:all .3s ease}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-bg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);font-weight:700;margin-bottom:1rem}h1{font-size:3rem;font-weight:900;letter-spacing:1px}h2{font-size:2.5rem;margin-bottom:1.5rem}h3{font-size:1.5rem}p{margin-bottom:1.5rem;font-size:1.1rem}a{color:var(--text-light);text-decoration:none;transition:all .3s ease}ul{list-style:none}.container{width:85%;max-width:1200px;margin:0 auto;padding:2rem 0}section{padding:5rem 0}.btn{display:inline-block;padding:12px 28px;background-color:var(--primary-color);color:var(--text-light);border-radius:50px;font-family:var(--font-title);font-size:1.1rem;font-weight:600;letter-spacing:.5px;cursor:pointer;box-shadow:var(--shadow);transition:all .3s ease;border:none;text-align:center}.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-heavy);background-color:var(--primary-dark)}.primary-btn{background-color:var(--accent-color);font-size:1.2rem;padding:15px 32px}.primary-btn:hover{background-color:var(--accent-dark)}.secondary-btn{background-color:transparent;border:2px solid var(--primary-color)}.secondary-btn:hover{background-color:var(--primary-color)}.bg-container{position:fixed;top:0;left:0;width:100%;height:100vh;z-index:-1;overflow:hidden}.moving-bg{position:absolute;top:-50px;left:0;width:100%;height:calc(100% + 100px);background-image:url(/images/dragon-bg.svg);background-size:cover;background-position:50%;animation:float 20s ease-in-out infinite;filter:brightness(.4)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-30px)}}header{position:fixed;top:0;left:0;width:100%;padding:1.5rem 5%;display:flex;justify-content:space-between;align-items:center;z-index:1400;transition:all .4s ease;background-color:rgba(10,10,15,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}header.scrolled{padding:1rem 5%;background-color:rgba(10,10,15,.95)}.logo h1{font-size:1.8rem;margin:0;letter-spacing:1px;font-weight:700}.logo span{color:var(--accent-color)}nav ul{display:flex;gap:2rem}nav a{font-family:var(--font-title);font-size:1rem;letter-spacing:.5px;position:relative;padding:.5rem 0}nav a:after{content:"";position:absolute;width:0;height:2px;bottom:0;left:0;background-color:var(--accent-color);transition:width .3s ease}nav a:hover:after{width:100%}.start-btn{background-color:var(--accent-color);padding:.5rem 1.5rem;border-radius:50px}.start-btn:hover{background-color:var(--accent-dark)}.start-btn:after{display:none}.hero{height:100vh;display:flex;align-items:center;position:relative}.hero-content{max-width:700px;margin-left:10%}.hero h1{font-size:3.5rem;margin-bottom:1.5rem;text-shadow:0 2px 5px rgba(0,0,0,.5);line-height:1.2}.hero p{font-size:1.3rem;margin-bottom:2.5rem;text-shadow:0 2px 4px rgba(0,0,0,.5);max-width:550px}.ai-color,.ai-highlight{background:linear-gradient(45deg,#4287f5,#42c5f5);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}.cta-buttons{display:flex;gap:1.5rem}.rules-teaser{background-color:rgba(20,20,30,.9);text-align:center}.rules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:2rem;gap:2rem;margin:3rem 0}.rule-card{background-color:var(--bg-card);padding:2rem;border-radius:15px;box-shadow:var(--shadow);transition:all .3s ease}.rule-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-heavy)}.rule-card svg{font-size:2.5rem;color:var(--accent-color);margin-bottom:1rem}.plans{text-align:center;position:relative;background-color:rgba(15,15,25,.9)}.plan-cards{display:flex;justify-content:center;gap:2.5rem;margin-top:4rem;flex-wrap:wrap}.plan-card{background-color:var(--bg-card);border-radius:15px;width:300px;padding:2.5rem 2rem;box-shadow:var(--shadow);transition:all .3s ease;position:relative;overflow:hidden}.plan-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-heavy)}.plan-card.premium{background-color:var(--bg-card-premium);border:2px solid var(--accent-color);transform:scale(1.05)}.plan-card.premium:hover{transform:scale(1.05) translateY(-10px)}.popular-tag{position:absolute;top:20px;right:-30px;transform:rotate(45deg);background-color:var(--accent-color);color:var(--text-dark);padding:.5rem 3rem;font-family:var(--font-title);font-weight:700;font-size:.9rem}.plan-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.price{font-size:2.5rem;font-weight:700;color:var(--text-light);font-family:var(--font-title)}.price span{font-size:1rem;color:rgba(255,255,255,.6)}.plan-features{text-align:left;margin-bottom:2rem}.feature{display:flex;align-items:center;margin-bottom:1rem}.feature svg{color:var(--success);font-size:1.2rem;margin-right:1rem;width:20px;text-align:center}.feature.negative svg{color:var(--danger)}.plan-btn{width:100%;text-align:center}footer{background-color:rgba(10,10,15,.95);padding:4rem 0 2rem;position:relative;border-top:1px solid rgba(255,255,255,.1)}.footer-content{display:flex;justify-content:space-between;flex-wrap:wrap;gap:3rem;margin-bottom:3rem}.footer-logo h2{margin-bottom:.5rem;color:var(--accent-color)}.footer-logo p{color:rgba(255,255,255,.7);max-width:300px}.footer-links{display:flex;gap:4rem;flex-wrap:wrap}.link-group{display:flex;flex-direction:column}.link-group h3{margin-bottom:1rem;color:var(--text-light);font-size:1.2rem}.link-group a{margin-bottom:.8rem;color:rgba(255,255,255,.7);transition:all .2s ease}.link-group a:hover{color:var(--accent-color);transform:translateX(3px)}.copyright{text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}.copyright p{font-size:.9rem;color:rgba(255,255,255,.6);margin-bottom:0}.rules-page,.start-page{min-height:100vh;padding-top:120px;display:flex;align-items:center;justify-content:center;text-align:center}@media screen and (max-width:992px){h1{font-size:2.5rem}h2{font-size:2rem}.hero-content{margin-left:5%}.hero h1{font-size:3rem}.cta-buttons{flex-direction:column;gap:1rem;max-width:300px}.footer-content{flex-direction:column;gap:2rem}}@media screen and (max-width:768px){header{padding:1rem 5%}nav ul{gap:1rem}.hero h1{font-size:2.5rem}.hero p{font-size:1.1rem}.plan-cards{gap:1.5rem}.plan-card{width:100%;max-width:350px}.plan-card.premium{transform:none}.plan-card.premium:hover{transform:translateY(-10px)}.footer-links{gap:2rem}}@media screen and (max-width:576px){header{flex-direction:column;padding:1rem 0}.logo{margin-bottom:1rem}nav ul{gap:.8rem;font-size:.9rem}.hero{text-align:center}.hero-content{margin:0 auto;padding:0 1rem}.cta-buttons{justify-content:center;margin:0 auto}.rules-grid{grid-template-columns:1fr}}.about-section{padding:5rem 0;background-color:rgba(20,20,35,.7);position:relative}.about-section h2{text-align:center;font-size:2.5rem;margin-bottom:1rem;color:#f0a742;font-family:Cinzel,serif}.about-section .divider{height:4px;width:100px;background:linear-gradient(90deg,transparent,#f0a742,transparent);margin:0 auto 3rem}.about-content{display:flex;flex-direction:column;gap:3rem;max-width:1200px;margin:0 auto}.about-text{text-align:center;max-width:800px;margin:0 auto}.about-text p{color:#e0e0e0;font-size:1.1rem;line-height:1.7;margin-bottom:1.5rem}.about-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:2rem;gap:2rem;padding:0 1rem}.feature-card{background:rgba(30,30,50,.6);border-radius:12px;padding:2rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease;border:1px solid rgba(255,255,255,.1)}.feature-card:hover{transform:translateY(-10px);box-shadow:0 15px 30px rgba(0,0,0,.4)}.feature-icon{font-size:2.5rem;color:#f0a742;margin-bottom:1.5rem}.feature-card h3{color:#f0a742;font-size:1.3rem;margin-bottom:1rem;font-family:Cinzel,serif}.feature-card p{color:#ddd;font-size:.95rem;line-height:1.6}@media (max-width:768px){.about-section h2{font-size:2rem}.about-text p{font-size:1rem}.feature-card{padding:1.5rem}}.rulebook-container{max-width:1200px;margin:0 auto;padding:2rem 0;color:#e0e0e0}.rulebook-container h1{text-align:center;margin-bottom:2rem;font-size:2.5rem;color:#ffa500;text-shadow:0 0 10px rgba(255,165,0,.3)}.rulebook-tabs{display:flex;justify-content:center;margin-bottom:2rem;border-bottom:2px solid #444}.tab-button{background:rgba(0,0,0,.4);border:none;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;color:#ccc;margin:0 5px;border-radius:5px 5px 0 0}.tab-button.active{color:#ffa500;background:rgba(0,0,0,.7)}.tab-button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background-color:#ffa500}.tab-button:hover{color:#ffa500;background:rgba(0,0,0,.6)}.rulebook-content{background:rgba(26,26,46,.9);box-shadow:0 2px 15px rgba(0,0,0,.5);border-radius:8px;padding:2rem;border:1px solid rgba(255,165,0,.2)}.rulebook-section h2{font-size:2rem;margin-bottom:1rem;border-bottom:2px solid #444;padding-bottom:.5rem;color:#ffa500}.rulebook-section>p{font-size:1.1rem;color:#ccc;margin-bottom:2rem;line-height:1.6}.class-card,.item-card,.language-card,.race-card,.spell-card{background:rgba(30,30,50,.7);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 8px rgba(0,0,0,.3);transition:transform .2s ease,box-shadow .2s ease;border:1px solid rgba(255,165,0,.1)}.class-card:hover,.item-card:hover,.language-card:hover,.race-card:hover,.spell-card:hover{transform:translateY(-3px);box-shadow:0 6px 12px rgba(0,0,0,.4);border-color:rgba(255,165,0,.3)}.class-card h3,.item-card h3,.language-card h3,.race-card h3,.spell-card h3{font-size:1.5rem;margin-bottom:.5rem;color:#ffa500}.description{font-size:1.1rem;color:#ddd;margin-bottom:1.5rem;line-height:1.7;font-family:Roboto,sans-serif;padding:.8rem;background:rgba(20,20,35,.5);border-radius:6px;border-left:3px solid rgba(255,165,0,.5)}h4{font-size:1.2rem;margin:1.5rem 0 .8rem;color:#ffa500;border-bottom:1px solid rgba(255,165,0,.3);padding-bottom:.3rem}.detail-item{display:flex;margin-bottom:.8rem;background:rgba(20,20,35,.4);padding:.7rem;border-radius:4px}.detail-label{font-weight:600;min-width:150px;color:#ffa500}.detail-value{color:#ddd;font-family:Roboto,sans-serif}.abilities-list,.equipment-list,.features-list,.stat-bonuses,.traits-list{list-style:disc;padding-left:1.5rem;margin-bottom:1.5rem;color:#ddd;font-family:Roboto,sans-serif}.abilities-list li,.equipment-list li,.features-list li,.stat-bonuses li,.traits-list li{margin-bottom:.7rem;line-height:1.6}.abilities-list li,.features-list li{background:rgba(20,20,35,.4);padding:.8rem;border-radius:4px;list-style-position:inside;margin-bottom:.8rem}.abilities-list li strong,.features-list li strong{color:#ffa500;font-weight:600}.race-card .lore{font-style:italic;color:#bbb;border-left:3px solid #ffa500;padding:1rem;margin-top:1.2rem;background:rgba(20,20,35,.4);border-radius:0 6px 6px 0;line-height:1.7;font-family:Roboto,sans-serif}.items-section{margin-bottom:2rem}.item-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;background-color:rgba(30,30,40,.7);border-radius:8px;padding:1rem;box-shadow:0 2px 8px rgba(0,0,0,.3)}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem}.item-card{background-color:rgba(30,30,40,.7);border-radius:8px;padding:1.2rem;box-shadow:0 3px 10px rgba(0,0,0,.3);border-left:3px solid #d0a85c;transition:transform .2s ease,box-shadow .2s ease}.item-card:hover{transform:translateY(-3px);box-shadow:0 5px 15px rgba(0,0,0,.4)}.item-card h3{color:#d0a85c;margin-top:0;margin-bottom:.5rem;font-size:1.3rem;border-bottom:1px solid rgba(208,168,92,.3);padding-bottom:.5rem}.item-type{font-style:italic;color:#aaa}.item-card .description,.item-type{margin-bottom:1rem;font-size:.95rem}.item-card .description{color:#bbb;line-height:1.5;background-color:rgba(20,20,30,.3);padding:.8rem;border-radius:6px;border-left:2px solid rgba(208,168,92,.5)}.item-details{background-color:rgba(20,20,30,.5);padding:.8rem;border-radius:6px}.item-card .detail-item{margin-bottom:.5rem;display:flex;flex-wrap:wrap}.item-card .detail-label{min-width:120px;font-weight:700;color:#d0a85c}.item-card .detail-value{flex:1 1;color:#ddd}.spells-section{margin-bottom:2rem}.spell-filters{background-color:rgba(30,30,40,.7);border-radius:8px;padding:1rem;margin-bottom:1.5rem;box-shadow:0 2px 8px rgba(0,0,0,.3)}.filter-group{margin-bottom:1rem}.filter-group label{display:block;font-weight:700;margin-bottom:.5rem;color:#d0a85c;font-size:1.1rem}.button-group{display:flex;flex-wrap:wrap;gap:.5rem}.filter-button{background-color:rgba(40,40,50,.8);border:1px solid #444;color:#ccc;padding:.4rem .8rem;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.filter-button:hover{background-color:rgba(60,60,70,.8);border-color:#666}.filter-button.active{background-color:#d0a85c;color:#222;border-color:#d0a85c;font-weight:700}.spells-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem}.spell-card{background-color:rgba(30,30,40,.7);border-radius:8px;padding:1.2rem;box-shadow:0 3px 10px rgba(0,0,0,.3);border-left:3px solid #d0a85c;transition:transform .2s ease,box-shadow .2s ease}.spell-card:hover{transform:translateY(-3px);box-shadow:0 5px 15px rgba(0,0,0,.4)}.spell-card h3{color:#d0a85c;margin-top:0;margin-bottom:.5rem;font-size:1.3rem;border-bottom:1px solid rgba(208,168,92,.3);padding-bottom:.5rem}.spell-level{font-style:italic;color:#aaa;margin-bottom:1rem;font-size:.95rem}.concentration-tag,.ritual-tag{color:#d0a85c;font-weight:700}.spell-details{margin-bottom:1rem;background-color:rgba(20,20,30,.5);padding:.8rem;border-radius:6px}.spell-card .detail-item{margin-bottom:.5rem;display:flex;flex-wrap:wrap}.spell-card .detail-label{min-width:120px;font-weight:700;color:#d0a85c}.spell-card .detail-value{flex:1 1;color:#ddd}.spell-card .description{color:#bbb;line-height:1.5;font-size:.95rem;background-color:rgba(20,20,30,.3);padding:.8rem;border-radius:6px;border-left:2px solid rgba(208,168,92,.5)}.class-detail-grid{display:flex;flex-direction:column;margin:1.5rem 0;gap:.8rem;background:rgba(20,20,35,.2);padding:1rem;border-radius:8px}.centered-details{align-items:center;display:flex;flex-direction:column}.centered-details .detail-item{width:100%;max-width:600px;margin-left:auto;margin-right:auto;display:flex;align-items:center;border-bottom:1px solid rgba(255,165,0,.1);padding:.8rem 1rem;background:rgba(20,20,35,.2)}.centered-details .detail-label{text-align:right;padding-right:20px;flex:0 0 180px;border-right:2px solid rgba(255,165,0,.3);color:#ffa500}.centered-details .detail-value{text-align:left;flex:1 1;padding-left:20px;color:#ddd}.class-header,.race-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s ease}.class-header:hover,.race-header:hover{background-color:rgba(255,165,0,.1)}.toggle-icon{font-size:1.5rem;color:#ffa500;font-weight:700}@media (max-width:768px){.rulebook-tabs{flex-wrap:wrap}.tab-button{font-size:.9rem;padding:.8rem 1rem}.items-grid{grid-template-columns:1fr}.detail-item{flex-direction:column}.detail-label{margin-bottom:.3rem}.class-detail-grid,.spells-list{grid-template-columns:1fr}.button-group{flex-direction:column;gap:.3rem}.filter-button{width:100%;text-align:center}.item-filters{flex-direction:column;gap:.3rem}.item-filters .filter-button{width:100%;text-align:center}.centered-details .detail-item{flex-direction:column;text-align:center;border-bottom:1px solid rgba(255,165,0,.2)}.centered-details .detail-label{text-align:center;border-right:none;border-bottom:1px solid rgba(255,165,0,.2);padding:0 0 8px;margin-bottom:8px;flex:0 0 auto}.centered-details .detail-value{text-align:center;padding-left:0}}.scenarios-section{padding:2rem 0}.scenarios-section h2{color:#ffa500;font-size:2rem;margin-bottom:1rem;text-align:center}.section-description{text-align:center;color:#ccc;margin-bottom:2rem;font-size:1.1rem;line-height:1.6}.scenarios-list{display:flex;flex-direction:column;gap:1rem}.scenario-item{background:rgba(20,20,35,.8);border:1px solid rgba(255,165,0,.2);border-radius:12px;overflow:hidden;transition:all .3s ease}.scenario-item:hover{border-color:rgba(255,165,0,.4);box-shadow:0 4px 16px rgba(255,165,0,.1)}.scenario-header{padding:1.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.scenario-header:hover{background:rgba(255,165,0,.05)}.scenario-title{color:#ffa500;font-size:1.4rem;font-weight:700;margin:0}.expand-icon{color:#ffa500;font-size:1.2rem;transition:transform .3s ease}.expand-icon.expanded{transform:rotate(180deg)}.scenario-details{padding:0 1.5rem 1.5rem;border-top:1px solid rgba(255,165,0,.1);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scenario-goals,.scenario-hooks,.scenario-premise{margin-bottom:1.5rem}.scenario-details h4{color:#ffa500;font-size:1.1rem;margin-bottom:.5rem;font-weight:600}.scenario-details p{color:#ddd;line-height:1.6;margin-bottom:1rem}.scenario-details ul{list-style:none;padding:0;margin:0}.scenario-details li{color:#ccc;padding:.3rem 0 .3rem 1.5rem;position:relative}.scenario-details li:before{content:"•";color:#ffa500;font-weight:700;position:absolute;left:0}.character-creator{max-width:800px;margin:0 auto;padding:2rem 0}.creator-header{text-align:center;margin-bottom:2rem}.creator-header h1{font-size:2.5rem;margin-bottom:1.5rem}.steps-progress{display:flex;justify-content:space-between;margin:0 auto 2rem;max-width:600px;position:relative}.steps-progress:before{content:"";position:absolute;top:15px;left:50px;right:50px;height:2px;background:#e0e0e0;z-index:-1}.step{background:#fff;border:2px solid #e0e0e0;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:0;position:relative;transition:all .3s ease}.step:after{content:attr(data-step);position:absolute;top:40px;left:50%;transform:translateX(-50%);font-size:.9rem;white-space:nowrap}.step.active{background:#007bff;border-color:#007bff;color:white}.creator-content{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.1);border-radius:8px;padding:2rem}.creator-step h2{font-size:1.8rem;margin-bottom:1.5rem;border-bottom:2px solid #e0e0e0;padding-bottom:.5rem}.creator-step>p{color:#666}.creator-step>p,.form-group{margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem;font-weight:600}.form-group input,.form-group select{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 3px rgba(0,123,255,.25)}.selected-class-info,.selected-race-info{background:#f9f9f9;border-radius:8px;padding:1.5rem;margin:1.5rem 0}.selected-class-info h3,.selected-race-info h3{margin-bottom:1rem;font-size:1.3rem}.selected-class-info h4,.selected-race-info h4{margin:1rem 0 .5rem;font-size:1.1rem}.selected-race-info ul{list-style:disc;padding-left:1.5rem}.abilities-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.ability-item{background:#f9f9f9;border-radius:6px;padding:1rem}.ability-item label{display:block;font-weight:600;margin-bottom:.5rem}.ability-controls{display:flex;align-items:center;margin-bottom:.5rem}.ability-controls button{width:36px;height:36px;border:none;background:#007bff;color:white;font-size:1.2rem;border-radius:4px;cursor:pointer}.ability-controls button:disabled{background:#ccc;cursor:not-allowed}.ability-controls input{width:60px;text-align:center;margin:0 .5rem;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1.1rem;font-weight:600}.ability-modifier{font-size:.9rem;color:#666}.character-summary{background:#f9f9f9;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.character-summary h3{margin-bottom:.5rem}.character-summary h4{margin:1rem 0 .5rem}.abilities-summary{display:flex;flex-wrap:wrap;gap:.8rem}.ability-summary-item{background:#fff;border:1px solid #ddd;border-radius:6px;width:70px;height:70px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem;text-align:center}.ability-name{font-size:.8rem;color:#777;text-transform:uppercase}.ability-score{font-size:1.4rem;font-weight:700;margin:.2rem 0}.ability-mod{font-size:1rem;color:#007bff}.character-sheet{background:#fff;border:1px solid #ddd;border-radius:8px;padding:2rem;box-shadow:0 4px 12px rgba(0,0,0,.1)}.character-sheet h3{font-size:1.8rem;margin-bottom:.5rem}.character-type{font-size:1.1rem;color:#666}.character-abilities,.character-type{margin-bottom:1.5rem}.character-details{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.detail-column h4{margin-bottom:1rem;border-bottom:1px solid #eee;padding-bottom:.5rem}.detail-column ul{list-style:disc;padding-left:1.2rem}.detail-column li{margin-bottom:.5rem}.character-actions{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.form-actions{display:flex;justify-content:space-between;margin-top:2rem}@media (max-width:768px){.abilities-grid,.character-details{grid-template-columns:1fr}.form-actions{flex-direction:column;gap:1rem}.form-actions button{width:100%}.steps-progress{display:none}}.racialBonus{margin-left:2px}.totalScore{font-size:1.3rem;font-weight:700;color:#ffffff;border-top:1px solid rgba(240,167,66,.3);padding-top:.3rem;margin-top:.3rem}.abilitiesList,.traitsList{list-style-type:disc;padding-left:1.5rem;margin-bottom:1.5rem}.abilitiesList li{margin-bottom:.5rem}.sectionHeader{margin:1.8rem 0 1rem;padding-bottom:.5rem}.abilitySummaryItem{border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 6px rgba(0,0,0,.1)}.abilitySummaryItem:hover{border-color:rgba(240,167,66,.3)}.abilityName{font-size:1.1rem;letter-spacing:1px}.abilityBreakdown{font-size:.9rem;color:#bbb;margin:.2rem 0;opacity:.8}.abilityMod{padding:.3rem .8rem}.modifierValue{font-size:1.2rem}.abilitiesList,.languagesList,.traitsList{padding-left:1.5rem;margin-bottom:1.5rem}.abilitiesList li,.languagesList li{margin-bottom:.6rem}.backgroundText{color:#ddd;font-style:italic;line-height:1.7;background:rgba(20,20,35,.4);padding:1rem;border-radius:8px;border-left:3px solid rgba(240,167,66,.4)}.sectionHeader{color:#f0a742;font-size:1.6rem;border-bottom:2px solid rgba(240,167,66,.3);text-shadow:0 1px 2px rgba(0,0,0,.25)}.abilitiesSummary{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1.2rem;gap:1.2rem;margin-bottom:2rem}.abilitySummaryItem{background:rgba(30,30,50,.7);border-radius:10px;padding:1.2rem .8rem;text-align:center;border:1px solid rgba(240,167,66,.2);box-shadow:0 4px 6px rgba(0,0,0,.15);display:flex;flex-direction:column;align-items:center;transition:transform .2s ease}.abilitySummaryItem:hover{transform:translateY(-3px);box-shadow:0 6px 12px rgba(0,0,0,.2);border-color:rgba(240,167,66,.4)}.abilityName{font-weight:700;color:#f0a742;text-transform:uppercase;font-size:1.2rem;letter-spacing:1.5px;margin-bottom:.5rem}.abilityValue{display:flex;flex-direction:column;align-items:center;margin-bottom:.5rem}.abilityTotal{font-size:2.2rem;font-weight:700;color:#ffffff;line-height:1;margin-bottom:.3rem}.abilityDetails{font-size:.9rem;color:#bbb;margin:.2rem 0}.racialBonus{font-size:.9rem;color:#f0a742;margin-left:3px;font-weight:600}.abilityMod{display:flex;flex-direction:column;align-items:center;background:rgba(20,20,35,.5);border-radius:4px;padding:.4rem .8rem;margin-top:.5rem;border-top:1px solid rgba(240,167,66,.2)}.modifierLabel{font-size:.7rem;color:#aaa;text-transform:uppercase;letter-spacing:.5px}.modifierValue{font-size:1.3rem;font-weight:700;color:#f0a742}.abilitiesList,.languagesList,.traitsList{list-style-type:disc;padding-left:1.8rem;margin-bottom:2rem;color:#e0e0e0;line-height:1.6}.abilitiesList li,.languagesList li{margin-bottom:.8rem}.abilitiesList strong{color:#f0a742;font-weight:600}.sectionHeader{margin:2rem 0 1rem;color:#ff9800;font-size:1.5rem;font-weight:700;letter-spacing:.5px;border-bottom:2px solid rgba(255,152,0,.4);padding-bottom:.6rem;text-shadow:0 1px 2px rgba(0,0,0,.2);position:relative}.sectionHeader:after{content:"";position:absolute;left:0;bottom:-2px;width:60px;height:2px;background-color:#ff9800}.modalBackdrop,.modalOverlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{position:relative;width:90%;max-width:450px;background-color:var(--bg-card);border-radius:15px;box-shadow:var(--shadow-heavy);margin:auto;z-index:10000;filter:none!important}.modal-close-btn{position:absolute;top:15px;right:15px;background:transparent;border:none;color:var(--text-light);cursor:pointer;z-index:10001;padding:5px}.modal-close-btn:hover{color:var(--accent-color)}.auth-form-container{padding:30px;max-height:80vh;overflow-y:auto}.auth-form h2{text-align:center;margin-bottom:30px;color:var(--text-light);font-size:1.8rem}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:.95rem;color:var(--text-light);opacity:.9}.form-group input{width:100%;padding:12px 15px;background-color:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:8px;color:var(--text-light);font-size:1rem;transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(126,87,194,.3)}.form-group input.error{border-color:var(--danger)}.error-text{display:block;color:var(--danger);font-size:.85rem;margin-top:5px}.error-message{background-color:rgba(244,67,54,.1);border:1px solid rgba(244,67,54,.3);color:var(--danger);padding:12px 15px;border-radius:8px;margin-bottom:20px;font-size:.95rem}.form-options{justify-content:space-between;margin-bottom:20px;font-size:.9rem}.checkbox-group,.form-options{display:flex;align-items:center}.checkbox-group input[type=checkbox]{margin-right:8px;width:auto}.forgot-password{color:var(--primary-color);text-decoration:none}.forgot-password:hover{text-decoration:underline}.auth-form button[type=submit]{margin-top:15px;padding:12px 0;height:auto}.auth-form{display:flex;flex-direction:column}.auth-separator{display:flex;align-items:center;text-align:center;margin:25px 0;color:var(--text-light);opacity:.6}@media screen and (max-width:576px){.auth-modal{width:95%;max-height:85vh}.auth-form-container{padding:25px 15px}.verification-code-inputs{display:flex;justify-content:center;gap:10px;margin:20px 0}.verification-code-inputs input{width:40px;height:50px;font-size:1.3rem}}.verification-code-container{display:flex;flex-direction:column;align-items:center;text-align:center}.auth-separator:after,.auth-separator:before{content:"";flex:1 1;border-bottom:1px solid rgba(255,255,255,.3)}.auth-separator span{margin:0 15px;font-size:.9rem}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;background-color:#fff!important;color:#333!important;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.google-btn:hover{background-color:#f5f5f5!important;box-shadow:0 2px 5px rgba(0,0,0,.2);transform:translateY(-2px)}.auth-switch{text-align:center;margin-top:20px;font-size:.9rem;color:var(--text-light);opacity:.9}.auth-switch a{color:var(--primary-color);font-weight:600}.auth-switch a:hover{text-decoration:underline}.verification-form h2{margin-bottom:15px}.verification-info{text-align:center;margin-bottom:25px;font-size:1rem;line-height:1.5;color:var(--text-light);opacity:.9}.verification-code-inputs{display:flex;justify-content:center;gap:10px;margin-bottom:25px}.verification-code-inputs input{width:45px;height:55px;text-align:center;font-size:1.5rem;font-weight:700;background-color:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:8px;color:var(--text-light)}.timer-container{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:25px;font-size:.9rem;color:var(--text-light);opacity:.8}.timer{font-weight:700;color:var(--accent-color)}.resend-btn{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:0}.resend-btn:hover{text-decoration:underline}.resend-btn:disabled{color:var(--text-light);opacity:.5;cursor:not-allowed}.password-strength{margin-top:8px;font-size:.85rem}.strength-meter{height:4px;background-color:rgba(255,255,255,.1);border-radius:2px;margin-bottom:8px}.strength-meter-fill{height:100%;border-radius:2px;transition:width .3s ease}.strength-meter-fill.very-weak{width:20%;background-color:var(--danger)}.strength-meter-fill.weak{width:40%;background-color:#ff9800}.strength-meter-fill.medium{width:60%;background-color:#ffeb3b}.strength-meter-fill.strong{width:80%;background-color:#8bc34a}.strength-meter-fill.very-strong{width:100%;background-color:var(--success)}.strength-text{margin-bottom:5px}.strength-text .very-weak{color:var(--danger)}.strength-text .weak{color:#ff9800}.strength-text .medium{color:#ffeb3b}.strength-text .strong{color:#8bc34a}.strength-text .very-strong{color:var(--success)}.strength-feedback{list-style-type:disc;padding-left:20px;color:rgba(255,255,255,.7);margin-top:5px}.strength-feedback li{margin-bottom:3px}.profile-menu-container{position:relative;z-index:1500}.profile-button{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center}.profile-image{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-color);transition:all .3s ease}.profile-button:hover .profile-image{border-color:var(--accent-color);transform:scale(1.05)}.profile-dropdown-menu{position:absolute;top:calc(100% + 10px);right:0;width:280px;background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-heavy);z-index:1500;max-height:none;overflow:visible;transform:translateZ(0)}.dropdown-header{padding:15px;display:flex;align-items:center}.dropdown-profile-image{width:50px;height:50px;border-radius:50%;object-fit:cover}.user-info{margin-left:15px;overflow:hidden}.username{font-weight:600;color:var(--text-light)}.email,.username{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.email{color:rgba(255,255,255,.7);font-size:.85rem}.dropdown-divider{height:1px;background-color:rgba(255,255,255,.1)}.dropdown-menu{list-style:none;padding:10px 0;margin:0}.dropdown-menu li a,.dropdown-menu li button{display:flex;align-items:center;padding:10px 15px;color:var(--text-light);transition:background-color .2s;text-decoration:none;font-size:.95rem;width:100%;text-align:left}.dropdown-menu li{width:100%}.dropdown-menu li a svg,.dropdown-menu li button svg{margin-right:10px;width:18px;height:18px}.dropdown-menu li a:hover,.dropdown-menu li button:hover{background-color:rgba(255,255,255,.05)}.dropdown-menu li svg,.logout-button svg,.logout-button:hover{margin-right:10px;width:18px;height:18px}.logout-button{padding:10px 15px;width:100%;text-decoration:none;font-size:.95rem;transition:background-color .2s;background:none;color:var(--danger);text-align:left}.back-button,.logout-button{display:flex;align-items:center;border:none;cursor:pointer}.back-button{position:absolute;top:5px;left:15px;background:transparent;color:var(--text-light);gap:5px;font-size:.9rem;padding:5px;transition:color .2s;z-index:2}.back-button:hover{color:var(--primary-color)}.verification-form{position:relative;padding-top:30px}.email-highlight{font-weight:700;color:var(--accent-color)}.start-page .hero-section{background:linear-gradient(rgba(0,0,0,.7),rgba(0,0,0,.7)),url(/images/hero-bg.jpg) no-repeat 50%;background-size:cover;padding:5rem 0;text-align:center;color:white;margin-bottom:3rem}.start-page .hero-section h1{font-size:3rem;margin-bottom:.5rem;color:#ffa500;text-shadow:0 0 10px rgba(255,165,0,.5)}.start-page .subtitle{font-size:1.5rem;opacity:.9;color:#e0e0e0}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2rem;gap:2rem;margin-bottom:3rem}.option-card{background:rgba(26,26,46,.9);border-radius:8px;padding:2rem;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,.3);transition:all .3s ease;text-decoration:none;color:#e0e0e0;display:flex;flex-direction:column;align-items:center;border:1px solid rgba(255,165,0,.2)}.option-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px rgba(255,165,0,.2);border-color:rgba(255,165,0,.5)}.icon-wrapper{background:rgba(0,0,0,.4);width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:#ffa500;border:2px solid rgba(255,165,0,.3)}.option-card h2{font-size:1.5rem;margin-bottom:.8rem;color:#ffa500}.option-card p{color:#ccc;line-height:1.5}.tips-section{margin-bottom:3rem}.tips-toggle{background:none;border:none;color:#ffa500;font-size:1rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:0;transition:all .2s ease}.tips-toggle:hover{color:#ffcc00;text-shadow:0 0 5px rgba(255,165,0,.5)}.tips-content{background:rgba(26,26,46,.8);border-left:4px solid #ffa500;padding:1.5rem;border-radius:0 8px 8px 0;color:#e0e0e0;box-shadow:0 4px 12px rgba(0,0,0,.2)}.tips-content h3{font-size:1.3rem;margin-bottom:1rem;color:#ffa500}.tips-content ul{list-style-type:disc;padding-left:1.5rem}.tips-content li{margin-bottom:.8rem;line-height:1.5;color:#ccc}@media (max-width:768px){.start-page .hero-section{padding:3rem 0}.start-page .hero-section h1{font-size:2.5rem}.start-page .subtitle{font-size:1.2rem}}:host,:root{--fa-font-solid:normal 900 1em/1 "Font Awesome 6 Free";--fa-font-regular:normal 400 1em/1 "Font Awesome 6 Free";--fa-font-light:normal 300 1em/1 "Font Awesome 6 Pro";--fa-font-thin:normal 100 1em/1 "Font Awesome 6 Pro";--fa-font-duotone:normal 900 1em/1 "Font Awesome 6 Duotone";--fa-font-duotone-regular:normal 400 1em/1 "Font Awesome 6 Duotone";--fa-font-duotone-light:normal 300 1em/1 "Font Awesome 6 Duotone";--fa-font-duotone-thin:normal 100 1em/1 "Font Awesome 6 Duotone";--fa-font-brands:normal 400 1em/1 "Font Awesome 6 Brands";--fa-font-sharp-solid:normal 900 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-regular:normal 400 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-light:normal 300 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-thin:normal 100 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-duotone-solid:normal 900 1em/1 "Font Awesome 6 Sharp Duotone";--fa-font-sharp-duotone-regular:normal 400 1em/1 "Font Awesome 6 Sharp Duotone";--fa-font-sharp-duotone-light:normal 300 1em/1 "Font Awesome 6 Sharp Duotone";--fa-font-sharp-duotone-thin:normal 100 1em/1 "Font Awesome 6 Sharp Duotone"}svg.svg-inline--fa:not(:host),svg.svg-inline--fa:not(:root){overflow:visible;box-sizing:content-box}.svg-inline--fa{display:var(--fa-display,inline-block);height:1em;overflow:visible;vertical-align:-.125em}.svg-inline--fa.fa-2xs{vertical-align:.1em}.svg-inline--fa.fa-xs{vertical-align:0}.svg-inline--fa.fa-sm{vertical-align:-.07143em}.svg-inline--fa.fa-lg{vertical-align:-.2em}.svg-inline--fa.fa-xl{vertical-align:-.25em}.svg-inline--fa.fa-2xl{vertical-align:-.3125em}.svg-inline--fa.fa-pull-left{margin-right:var(--fa-pull-margin,.3em);width:auto}.svg-inline--fa.fa-pull-right{margin-left:var(--fa-pull-margin,.3em);width:auto}.svg-inline--fa.fa-li{width:var(--fa-li-width,2em);top:.25em}.svg-inline--fa.fa-fw{width:var(--fa-fw-width,1.25em)}.fa-layers svg.svg-inline--fa{bottom:0;left:0;margin:auto;position:absolute;right:0;top:0}.fa-layers-counter,.fa-layers-text{display:inline-block;position:absolute;text-align:center}.fa-layers{display:inline-block;height:1em;position:relative;text-align:center;vertical-align:-.125em;width:1em}.fa-layers svg.svg-inline--fa{transform-origin:center center}.fa-layers-text{left:50%;top:50%;transform:translate(-50%,-50%);transform-origin:center center}.fa-layers-counter{background-color:var(--fa-counter-background-color,#ff253a);border-radius:var(--fa-counter-border-radius,1em);box-sizing:border-box;color:var(--fa-inverse,#fff);line-height:var(--fa-counter-line-height,1);max-width:var(--fa-counter-max-width,5em);min-width:var(--fa-counter-min-width,1.5em);overflow:hidden;padding:var(--fa-counter-padding,.25em .5em);right:var(--fa-right,0);text-overflow:ellipsis;top:var(--fa-top,0);transform:scale(var(--fa-counter-scale,.25));transform-origin:top right}.fa-layers-bottom-right{bottom:var(--fa-bottom,0);right:var(--fa-right,0);top:auto;transform:scale(var(--fa-layers-scale,.25));transform-origin:bottom right}.fa-layers-bottom-left{bottom:var(--fa-bottom,0);left:var(--fa-left,0);right:auto;top:auto;transform:scale(var(--fa-layers-scale,.25));transform-origin:bottom left}.fa-layers-top-right{top:var(--fa-top,0);right:var(--fa-right,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:top right}.fa-layers-top-left{left:var(--fa-left,0);right:auto;top:var(--fa-top,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:top left}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-6x{font-size:6em}.fa-7x{font-size:7em}.fa-8x{font-size:8em}.fa-9x{font-size:9em}.fa-10x{font-size:10em}.fa-2xs{font-size:.625em;line-height:.1em;vertical-align:.225em}.fa-xs{font-size:.75em;line-height:.08333em;vertical-align:.125em}.fa-sm{font-size:.875em;line-height:.07143em;vertical-align:.05357em}.fa-lg{font-size:1.25em;line-height:.05em;vertical-align:-.075em}.fa-xl{font-size:1.5em;line-height:.04167em;vertical-align:-.125em}.fa-2xl{font-size:2em;line-height:.03125em;vertical-align:-.1875em}.fa-fw{text-align:center;width:1.25em}.fa-ul{list-style-type:none;margin-left:var(--fa-li-margin,2.5em);padding-left:0}.fa-ul>li{position:relative}.fa-li{left:calc(-1 * var(--fa-li-width, 2em));position:absolute;text-align:center;width:var(--fa-li-width,2em);line-height:inherit}.fa-border{border-color:var(--fa-border-color,#eee);border-radius:var(--fa-border-radius,.1em);border-style:var(--fa-border-style,solid);border-width:var(--fa-border-width,.08em);padding:var(--fa-border-padding,.2em .25em .15em)}.fa-pull-left{float:left;margin-right:var(--fa-pull-margin,.3em)}.fa-pull-right{float:right;margin-left:var(--fa-pull-margin,.3em)}.fa-beat{animation-name:fa-beat;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-bounce{animation-name:fa-bounce;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.28,.84,.42,1))}.fa-fade{animation-name:fa-fade;animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1))}.fa-beat-fade,.fa-fade{animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s)}.fa-beat-fade{animation-name:fa-beat-fade;animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1))}.fa-flip{animation-name:fa-flip;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-shake{animation-name:fa-shake;animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,linear)}.fa-shake,.fa-spin{animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal)}.fa-spin{animation-name:fa-spin;animation-duration:var(--fa-animation-duration,2s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,linear)}.fa-spin-reverse{--fa-animation-direction:reverse}.fa-pulse,.fa-spin-pulse{animation-name:fa-spin;animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,steps(8))}@media (prefers-reduced-motion:reduce){.fa-beat,.fa-beat-fade,.fa-bounce,.fa-fade,.fa-flip,.fa-pulse,.fa-shake,.fa-spin,.fa-spin-pulse{animation-delay:-1ms;animation-duration:1ms;animation-iteration-count:1;transition-delay:0s;transition-duration:0s}}@keyframes fa-beat{0%,90%{transform:scale(1)}45%{transform:scale(var(--fa-beat-scale,1.25))}}@keyframes fa-bounce{0%{transform:scale(1) translateY(0)}10%{transform:scale(var(--fa-bounce-start-scale-x,1.1),var(--fa-bounce-start-scale-y,.9)) translateY(0)}30%{transform:scale(var(--fa-bounce-jump-scale-x,.9),var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em))}50%{transform:scale(var(--fa-bounce-land-scale-x,1.05),var(--fa-bounce-land-scale-y,.95)) translateY(0)}57%{transform:scale(1) translateY(var(--fa-bounce-rebound,-.125em))}64%{transform:scale(1) translateY(0)}to{transform:scale(1) translateY(0)}}@keyframes fa-fade{50%{opacity:var(--fa-fade-opacity,.4)}}@keyframes fa-beat-fade{0%,to{opacity:var(--fa-beat-fade-opacity,.4);transform:scale(1)}50%{opacity:1;transform:scale(var(--fa-beat-fade-scale,1.125))}}@keyframes fa-flip{50%{transform:rotate3d(var(--fa-flip-x,0),var(--fa-flip-y,1),var(--fa-flip-z,0),var(--fa-flip-angle,-180deg))}}@keyframes fa-shake{0%{transform:rotate(-15deg)}4%{transform:rotate(15deg)}24%,8%{transform:rotate(-18deg)}12%,28%{transform:rotate(18deg)}16%{transform:rotate(-22deg)}20%{transform:rotate(22deg)}32%{transform:rotate(-12deg)}36%{transform:rotate(12deg)}40%,to{transform:rotate(0deg)}}@keyframes fa-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.fa-rotate-90{transform:rotate(90deg)}.fa-rotate-180{transform:rotate(180deg)}.fa-rotate-270{transform:rotate(270deg)}.fa-flip-horizontal{transform:scaleX(-1)}.fa-flip-vertical{transform:scaleY(-1)}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical{transform:scale(-1)}.fa-rotate-by{transform:rotate(var(--fa-rotate-angle,0))}.fa-stack{display:inline-block;vertical-align:middle;height:2em;position:relative;width:2.5em}.fa-stack-1x,.fa-stack-2x{bottom:0;left:0;margin:auto;position:absolute;right:0;top:0;z-index:var(--fa-stack-z-index,auto)}.svg-inline--fa.fa-stack-1x{height:1em;width:1.25em}.svg-inline--fa.fa-stack-2x{height:2em;width:2.5em}.fa-inverse{color:var(--fa-inverse,#fff)}.fa-sr-only,.fa-sr-only-focusable:not(:focus),.sr-only,.sr-only-focusable:not(:focus){position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.svg-inline--fa .fa-primary{fill:var(--fa-primary-color,currentColor);opacity:var(--fa-primary-opacity,1)}.svg-inline--fa .fa-secondary{fill:var(--fa-secondary-color,currentColor)}.svg-inline--fa .fa-secondary,.svg-inline--fa.fa-swap-opacity .fa-primary{opacity:var(--fa-secondary-opacity,.4)}.svg-inline--fa.fa-swap-opacity .fa-secondary{opacity:var(--fa-primary-opacity,1)}.svg-inline--fa mask .fa-primary,.svg-inline--fa mask .fa-secondary{fill:black}