@import "https://fonts.googleapis.com/css2?family=Marcellus&display=swap";*{box-sizing:border-box}:root{--primary:#6e16cd;--primary-hover:#560ca5;--secondary:#e60d0d;--secondary-hover:#c40a0a;--accent-orange:#fbac81;--accent-blue:#636ac4;--accent-light-blue:#b1c0de;--accent-gold:#e0ab5b;--accent-coral:#fd9079;--accent-pink:#fcd3ed;--stat-success:#2ecc71;--stat-warning:#f1c40f;--stat-danger:#e60d0d;--bg-color:#a9b7e3;--surface-color:#fff;--text-main:#2d3748;--text-muted:#718096;--border-color:#e2e8f0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Nunito,Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}html,body{width:100%;margin:0;padding:0;overflow-x:hidden}body{background-color:var(--bg-color);min-height:100vh;color:var(--text-main)}#root{width:100%}h1,h2,h3,h4,h5,h6{color:var(--primary);letter-spacing:-.02em;margin-top:0;margin-bottom:.5em;font-weight:800}h1:not(:first-child),h2:not(:first-child),h3:not(:first-child),h4:not(:first-child),h5:not(:first-child),h6:not(:first-child){margin-top:1.5rem}h1{font-size:2.3rem}h2{font-size:1.725rem}h3{font-size:1.35rem}h4{font-size:1.15rem}h5{font-size:.95rem}h6{font-size:.77rem}.heroic-btn{background-color:var(--primary);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:12px;padding:12px 24px;font-size:1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 6px #6e16cd33}.heroic-btn:hover{background-color:var(--primary-hover);box-shadow:0 6px 12px #6e16cd4d}.heroic-btn.secondary{background-color:var(--secondary);box-shadow:0 4px 6px #e60d0d33}.heroic-btn.secondary:hover{background-color:var(--secondary-hover);box-shadow:0 6px 12px #e60d0d4d}.card{background-color:var(--surface-color);border:2px solid var(--accent-light-blue);border-radius:16px;padding:24px;transition:transform .2s;box-shadow:0 10px 25px #0000000d}.card:hover{border-color:var(--accent-blue)}.app-container{flex-direction:column;width:100%;min-height:100vh;display:flex}.content{box-sizing:border-box;flex:1;width:100%;max-width:1000px;min-height:100vh;margin:0 auto;padding:8rem 0 2rem}.main-footer{text-align:center;border-top:1px solid var(--border-color);width:100%;color:var(--text-muted);background-color:#f7fafc;margin-top:auto;padding:1.5rem;font-size:.875rem}.arsenal-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin-top:1.5rem;display:grid}.arsenal-modal{flex-direction:column;display:flex;max-width:1000px!important}.modal-body-scroll{flex:1;margin-top:1rem;padding:1rem 0;overflow-y:auto}.untrained-item{opacity:.8;background-color:#fcfcfc!important;border-style:dashed!important}.untrained-label{color:#fff;background-color:#f6ad55;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.inventory-notification{z-index:100;margin-bottom:1rem;position:sticky;top:0;box-shadow:0 4px 12px #0000001a;color:#155724!important;background-color:#d4edda!important;border:2px solid #c3e6cb!important}.inventory-grid{grid-template-columns:1fr;gap:1rem;display:grid}.untrained-tag{color:#fff;background-color:#f6ad55;border-radius:4px;margin-left:.5rem;padding:2px 4px;font-size:.6rem}.inventory-item-card.untrained{opacity:.9;border-style:dotted}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;justify-content:center;align-items:center;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:1rem;height:1rem;margin-right:.5rem;animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.modal-content{border:4px solid var(--primary);background-color:#fff;border-radius:1rem;width:90%;max-width:800px;max-height:90vh;padding:2rem;position:relative;overflow-y:auto;box-shadow:0 0 25px #6e16cd80}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:1.5rem;position:absolute;top:1rem;right:1rem}.trait-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1rem;display:grid}.trait-card{border:2px solid var(--border-color);cursor:pointer;background-color:#f8fafc;border-radius:.5rem;padding:1rem;transition:all .2s;position:relative}.trait-card:hover{border-color:var(--primary);background-color:#f1f5f9}.trait-card.selected{border-color:var(--primary);background-color:var(--accent-light-blue);box-shadow:0 0 10px #6e16cd33}.trait-card.selected:after{content:"✓";color:var(--primary);font-size:1.2rem;font-weight:900;position:absolute;top:5px;right:10px}.trait-card h4{align-items:center;gap:.5rem;margin:0 0 .5rem;display:flex}.trait-cost{background-color:var(--primary);color:#fff;border-radius:1rem;padding:.1rem .5rem;font-size:.8rem}.tab-btn{background-color:var(--secondary);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:700;transition:all .2s;box-shadow:0 4px 6px #e60d0d33}.tab-btn:hover{background-color:var(--secondary-hover);transform:translateY(-1px)}.tab-btn.active{background-color:var(--primary);box-shadow:0 4px 6px #6e16cd33}.tab-btn.active:hover{background-color:var(--primary-hover)}.budget-sticky{border-bottom:2px solid var(--border-color);z-index:10;background-color:#fff;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem 0;display:flex;position:sticky;top:-2rem}.budget-count{color:var(--primary);font-size:1.25rem;font-weight:800}.budget-count.error{color:#e53e3e}.toggle-container{background-color:#f1f5f9;border-radius:.5rem;align-items:center;gap:1rem;margin:1rem 0;padding:1rem;display:flex}.heroic-toggle{width:60px;height:34px;display:inline-block;position:relative}.heroic-toggle input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#cbd5e1;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:26px;height:26px;transition:all .4s;position:absolute;bottom:4px;left:4px}input:checked+.slider{background-color:var(--primary)}input:checked+.slider:before{transform:translate(26px)}.review-grid{align-items:start;gap:1.5rem;width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr))!important}@media (width<=1024px){.review-grid{grid-template-columns:repeat(2,1fr)!important}}@media (width<=768px){.review-grid{grid-template-columns:1fr!important}}.review-sheet-card{height:100%}.character-banner{z-index:1000;background-color:var(--primary);color:#fff;border-bottom:2px solid var(--accent-gold);box-sizing:border-box;justify-content:space-around;width:100%;max-width:1000px;padding:.75rem 2rem;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #0000004d}.stat-item{flex-direction:column;align-items:center;transition:transform 3s;display:flex}.stat-item .label{text-transform:uppercase;color:var(--accent-orange);font-size:.75rem;font-weight:800}.stat-item .value{font-size:1.5rem;font-weight:900}.stat-item.flash-positive{color:#2ecc71}.stat-item.flash-negative{color:#e74c3c}@keyframes flash-glow-positive{0%{text-shadow:0 0 #2ecc71}50%{text-shadow:0 0 25px #2ecc71}to{text-shadow:0 0 #2ecc71}}@keyframes flash-glow-negative{0%{text-shadow:0 0 #e74c3c}50%{text-shadow:0 0 25px #e74c3c}to{text-shadow:0 0 #e74c3c}}.stat-item.flash-positive .value{animation:3s flash-glow-positive}.stat-item.flash-negative .value{animation:3s flash-glow-negative}.wizard-container{flex-direction:column;width:100%;min-height:500px;display:flex;overflow:hidden;background-color:#74bce2!important}.wizard-outer{width:100%}.wizard-navigation{justify-content:space-between;align-items:center;width:100%;margin-bottom:1rem;padding:1rem;display:flex}.nav-dots{align-items:center;gap:1rem;display:flex}.nav-dot{cursor:pointer;background-color:#fff;border:2px solid #0000;border-radius:50%;width:12px;height:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-dot:hover{background-color:var(--primary);transform:scale(1.2)}.nav-dot.active{background-color:var(--primary);transform:scale(1.4);box-shadow:0 0 15px #6e16cd66}.nav-dot.incomplete-glow{background-color:#ff4d4d;animation:1.5s infinite alternate red-glow}@keyframes red-glow{0%{box-shadow:0 0 5px red,0 0 10px red}to{box-shadow:0 0 15px red,0 0 25px red}}.nav-arrow{border:2px solid var(--border-color);color:var(--primary);cursor:pointer;background:0 0;border-radius:50%;width:40px;height:40px;padding:0;transition:all .2s;position:relative}.nav-arrow-content{width:20px;height:20px}.nav-arrow:hover:not(:disabled){border-color:var(--primary);background-color:var(--accent-light-blue);transform:scale(1.1)}.nav-arrow:disabled{opacity:.3;cursor:not-allowed}.heroic-input{box-sizing:border-box;border:2px solid var(--border-color);width:100%;color:var(--secondary);background-color:#fff;border-radius:12px;padding:1rem 1.5rem;font-family:inherit;font-size:1.1rem;font-weight:700;transition:all .2s;box-shadow:inset 0 2px 4px #0000000d}.heroic-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--accent-light-blue);outline:none;transform:translateY(-1px)}.heroic-input:focus::placeholder{color:#0000}.input-group label{text-transform:uppercase;color:var(--primary);letter-spacing:.05em;margin-bottom:.5rem;font-size:.875rem;font-weight:800;display:block}.personal-details{background:linear-gradient(135deg,#fff 0%,#f9f9ff 100%);margin-bottom:2rem;padding:2rem}.review-sheet{grid-template-columns:1fr 1fr 1.2fr;gap:1.5rem;margin-top:1rem;display:grid}@media (width<=1000px){.review-sheet{grid-template-columns:1fr 1fr}}@media (width<=700px){.review-sheet{grid-template-columns:1fr}}.sheet-section{flex-direction:column;gap:1rem;display:flex}.sheet-card{border:2px solid var(--border-color);background:#fff;border-radius:12px;padding:1.25rem}.sheet-card h4{color:var(--primary);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--accent-light-blue);margin:0 0 1rem;padding-bottom:.5rem;font-size:1.035rem}.stat-box-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.stat-box{background-color:var(--accent-light-blue);text-align:center;border-radius:8px;flex-direction:column;padding:.75rem;display:flex}.stat-box .label{text-transform:uppercase;color:var(--primary);font-size:.7rem;font-weight:800}.stat-box .value{color:var(--secondary);font-size:1.5rem;font-weight:900}.resource-bar{margin-bottom:1rem}.resource-label{justify-content:space-between;margin-bottom:.25rem;font-size:.8rem;font-weight:800;display:flex}.resource-track{background-color:#eee;border-radius:6px;height:12px;overflow:hidden}.resource-fill{height:100%}.resource-fill.hp{background-color:var(--vibrant-red)}.resource-fill.sp{background-color:var(--primary)}.resource-fill.mp{background-color:var(--accent-light-blue)}.wizard-header{border-bottom:2px solid var(--accent-light-blue);text-align:center;margin-bottom:2rem;padding-bottom:1rem}.wizard-header h2{color:#fff;text-shadow:2px 2px #0000001a;text-transform:uppercase;letter-spacing:-.01em;margin:0;font-size:2.5rem;line-height:1}.step-indicator{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-size:.875rem;font-weight:800}.step-content{flex:1}.warning-banner{border:2px solid var(--vibrant-red);background:linear-gradient(135deg,#fff5f5 0%,#ffe8e8 100%);align-items:flex-start;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;display:flex}.warning-icon{font-size:2rem}.warning-content strong{color:var(--vibrant-red);margin-bottom:.5rem;font-size:1.1rem;display:block}.warning-text{color:#c53030;margin:.25rem 0;font-weight:600}.inventory-item-card.equipped{border-color:var(--primary);background-color:var(--accent-light-blue)}.wizard-footer{border-top:1px solid var(--border-color);justify-content:space-between;margin-top:2rem;padding-top:1.5rem;display:flex}.loading{color:var(--primary);text-align:center;padding:4rem;font-size:1.5rem;font-weight:700}.step-divider{color:var(--secondary);text-transform:uppercase;letter-spacing:.15em;align-items:center;margin:3rem 0 1.5rem;font-size:1rem;font-weight:900;display:flex}.step-divider:before,.step-divider:after{content:"";background-color:var(--accent-light-blue);flex:1;height:2px}.step-divider span{background-color:var(--surface-color);border:2px solid var(--accent-light-blue);border-radius:30px;padding:0 2rem}.step-intro{text-align:center;color:#636ac2;max-width:650px;margin:0 auto 2rem;font-size:1.1rem;line-height:1.6}.step-section{margin-bottom:2.5rem}.active-step-section{border:2px solid var(--primary);background-color:#6e16cd08;border-radius:16px;margin-bottom:1.5rem;padding:1rem}.passive-step-section{opacity:.6;filter:grayscale(.5);pointer-events:none}.landing-step{flex-direction:column;align-items:center;padding:2rem 0;display:flex}.book-cover-image{object-fit:cover;object-position:center calc(50% + 40px);border-radius:14px 14px 0 0;width:calc(100% + 48px);height:350px;margin:-56px -24px 3rem;animation:.8s ease-out fadeIn;box-shadow:0 4px 15px #0000001a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hero-branding{text-align:center;margin-bottom:3rem;animation:.8s ease-out fadeInDown}.hero-title{color:var(--primary);text-shadow:0 0 20px #6e16cd33;letter-spacing:-1px;margin-top:0;margin-bottom:0;font-size:4rem;line-height:3.3rem}.hero-tagline{margin-top:2.1rem}.hero-subtitle{color:var(--text-main);opacity:.8;margin-top:0;font-family:Marcellus,serif;font-size:1.5rem}.cover-card{border:2px solid var(--primary);background:#fff;width:100%;max-width:600px;padding:3rem;box-shadow:0 20px 40px #0000001a}.heroic-input{border:2px solid var(--primary);color:var(--text-main);background:#fff;border-radius:8px;width:100%;padding:.8rem 1.2rem;font-family:inherit;font-weight:700;transition:all .3s;box-shadow:inset 0 2px 4px #0000000d}.heroic-input:focus{border-color:var(--accent-orange);outline:none;box-shadow:0 0 10px #fbac814d,inset 0 2px 4px #0000000d}.heroic-input.large{text-align:center;color:var(--secondary);padding:1.2rem;font-size:1.8rem}.level-selector-grid{grid-template-columns:repeat(5,1fr);gap:.8rem;margin-top:1rem;display:grid}.level-btn{border:2px solid var(--accent-light-blue);color:var(--primary);cursor:pointer;background:#fff;border-radius:8px;padding:1rem;font-size:1.2rem;font-weight:800;transition:all .3s cubic-bezier(.4,0,.2,1)}.level-btn:hover{background:var(--accent-pink);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.level-btn.active{background:var(--primary);color:#fff;border-color:var(--accent-orange);box-shadow:0 0 15px #6e16cd66}.feature-badges{gap:3rem;margin-top:4rem;display:flex}.feature-badges .badge{color:var(--color-accent-text);flex-direction:column;align-items:center;gap:.5rem;font-weight:700;display:flex}.feature-badges .icon{margin-bottom:.5rem;font-size:2.5rem}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.attribute-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1.5rem 0;display:grid}.attribute-control{text-align:center;flex-direction:column;align-items:center;padding:1rem;display:flex}.attribute-control label{color:var(--primary);margin-bottom:.5rem;font-weight:800}.control-group{align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.attr-value{min-width:2.5rem;font-size:1.5rem;font-weight:900}.heroic-btn.mini{border-radius:8px;padding:4px 12px}.attr-description{color:var(--text-muted);font-size:.75rem;line-height:1.2}.attr-impacts{color:var(--primary);text-transform:uppercase;margin-top:.5rem;font-size:.7rem;font-weight:700}.method-selector{text-align:center;margin-bottom:1.5rem}.method-selector h3{margin-top:0;font-size:1rem}.points-display{text-align:center;color:var(--primary);margin-bottom:1rem;font-size:1.25rem;font-weight:800}.points-display .error{color:var(--secondary)}.prime-info p{margin:0;font-size:.875rem}.saves-list{flex-direction:column;gap:1rem;display:flex}.save-item{border:2px solid var(--accent-light-blue);justify-content:space-between;align-items:center;padding:1.25rem;transition:all .3s;display:flex}.save-item.flash-positive{background-color:#2ecc711a;border-color:#2ecc71;box-shadow:0 0 15px #2ecc714d}.save-item.flash-negative{background-color:#e74c3c1a;border-color:#e74c3c;box-shadow:0 0 15px #e74c3c4d}.save-info h3{margin:0 0 .25rem}.save-desc{color:var(--text-muted);margin:0;font-size:.875rem}.save-calc{align-items:center;gap:.75rem;display:flex}.calc-text{color:var(--text-muted);font-size:.875rem}.total-bonus{color:var(--primary);background-color:var(--accent-pink);text-align:center;border-radius:12px;min-width:3.5rem;padding:.5rem 1rem;font-size:1.5rem;font-weight:900}.save-item.flash-positive .total-bonus{color:#fff;background-color:#2ecc71;animation:3s flash-glow-positive}.save-item.flash-negative .total-bonus{color:#fff;background-color:#e74c3c;animation:3s flash-glow-negative}.points-header{background-color:var(--accent-light-blue);color:var(--primary);justify-content:space-around;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;display:flex}.point-info{text-align:center;flex-direction:column;flex:1;align-items:center;display:flex}.point-count{color:var(--secondary);font-size:2rem;font-weight:900;line-height:1}.point-label{text-transform:uppercase;margin:.5rem 0;font-size:.875rem;font-weight:800}.point-desc{color:var(--text-main);opacity:.8;max-width:200px;margin:0;font-size:.75rem}.skill-groups{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;display:grid}.skill-group h4{border-bottom:1px solid var(--border-color);margin-bottom:.75rem}.chip-container{flex-wrap:wrap;gap:.5rem;display:flex}.chip{background-color:var(--surface-color);border:2px solid var(--border-color);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:.875rem;font-weight:700}.chip:hover{border-color:var(--accent-blue)}.chip.active{background-color:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 6px #6e16cd33}.chip.recommended{border:2px dashed var(--accent-gold);background-color:#e0ab5b14}.chip.recommended:hover{border-color:var(--accent-gold);background-color:#e0ab5b26}.chip.recommended.active{background-color:var(--primary);border-color:var(--accent-gold);border-style:solid}.stat-calc{background-color:#f8fafc;border-radius:12px;justify-content:center;align-items:center;gap:1rem;padding:1rem;font-size:1.1rem;display:flex}.total-stat{color:var(--primary);font-size:2rem;font-weight:900}.total-stat.highlight{color:var(--secondary)}.path-selector.large{justify-content:center;gap:1.5rem;margin:2rem 0;display:flex}.path-selector.large .heroic-btn{flex:1;max-width:200px;padding:1.5rem;font-size:1.2rem}.path-selector{justify-content:center;gap:1rem;margin:1.5rem 0;display:flex}.resource-grid{grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem;display:grid}.resource-item{background-color:var(--surface-color);border:2px solid var(--border-color);opacity:.5;border-radius:16px;flex-direction:column;align-items:center;padding:1.5rem;transition:all .3s;display:flex}.resource-item.active{background-color:var(--accent-light-blue);border-color:var(--primary);opacity:1;transform:scale(1.05)}.resource-item.active .value{color:#fff}.resource-item .label{color:var(--primary);text-align:center;margin-bottom:.5rem;font-weight:800}.resource-item .value{color:var(--secondary);font-size:2.5rem;font-weight:900}.defense-grid{flex-direction:column;gap:1.5rem;display:flex}.defense-item h4{text-align:center;margin:0 0 .75rem}.selection-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.selection-card{cursor:pointer;border:2px solid var(--border-color);position:relative;overflow:hidden}.selection-card:hover{border-color:var(--accent-blue)}.selection-card.selected{border-color:var(--primary);background-color:var(--accent-pink);box-shadow:0 15px 30px #6e16cd26}.selection-card.selected:after,.selection-card.active:after{content:"✓";color:var(--primary);font-size:1.5rem;font-weight:900;position:absolute;top:10px;right:15px}.selection-card .description{color:var(--text-muted);margin-bottom:1rem;font-size:.875rem}.features-preview{background-color:#ffffff80;border-radius:8px;padding:.75rem;font-size:.75rem}.features-preview ul{margin:.25rem 0 0;padding-left:1.25rem}.modifier-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.inventory-tabs{justify-content:center;gap:1rem;margin-bottom:2rem;display:flex}.equipment-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.equipment-card{background-color:var(--surface-color);border:2px solid var(--border-color);cursor:pointer;border-radius:12px;padding:1.5rem;transition:all .2s;position:relative}.equipment-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.equipment-card.active{border-color:var(--primary);background-color:var(--accent-light-blue);box-shadow:0 4px 12px #6e16cd1a}.equipment-card.active:after{content:"✓";color:var(--primary);font-size:1.25rem;font-weight:900;position:absolute;top:15px;right:15px}.equipment-card h4{color:var(--primary);margin:0 0 1rem;padding-right:1.5rem}.eq-stats{flex-direction:column;gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:flex}.eq-props{flex-wrap:wrap;gap:.5rem;display:flex}.prop-badge{background-color:var(--accent-pink);color:var(--primary);border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:700}.eq-penalty{color:var(--secondary);margin-top:1rem;font-size:.875rem;font-weight:700}.inventory-step{width:100%}.backpack-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.backpack-grid{flex-direction:column;gap:1rem;display:flex}.inventory-item-card{background-color:var(--surface-color);border:2px solid var(--border-color);border-radius:12px;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.item-info-main{flex-direction:column;display:flex}.item-name{color:var(--primary);font-size:1.1rem;font-weight:800}.item-type-tag{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:.75rem}.item-controls{align-items:center;gap:1.5rem;display:flex}.quantity-control{background-color:var(--accent-light-blue);border-radius:20px;align-items:center;gap:.75rem;padding:.25rem .75rem;display:flex}.quantity-value{text-align:center;min-width:1.5rem;font-weight:900}.equip-slots{gap:.5rem;display:flex}.modal-overlay{z-index:1000;background-color:#000000bf;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--surface-color);border:3px solid var(--primary);border-radius:24px;flex-direction:column;width:95%;max-width:1200px;height:90%;display:flex;overflow:hidden;box-shadow:0 20px 50px #00000080}@media (width<=768px){.modal-overlay{padding:0}.modal-content{border-radius:0;width:100%;height:100%}}.modal-header{background-color:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{color:#fff;margin:0}.close-modal-btn{color:#fff;cursor:pointer;background:0 0;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;display:flex}.modal-body{flex:1;padding:2rem;overflow-y:auto}.arsenal-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;display:flex}.inventory-badge{background-color:var(--secondary);color:#fff;border-radius:10px;margin-left:.5rem;padding:2px 8px;font-size:.7rem}.loadout-summary{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.loadout-slot{background-color:var(--accent-light-blue);border:2px dashed var(--primary);text-align:center;border-radius:12px;padding:1rem}.loadout-slot.filled{background-color:#fff;border-style:solid}.slot-label{text-transform:uppercase;color:var(--primary);margin-bottom:.25rem;font-size:.75rem;font-weight:800;display:block}.slot-value{color:var(--secondary);font-weight:700}.spell-disciplines-step .disciplines-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.spell-disciplines-step .discipline-card{cursor:pointer;border:2px solid var(--border-color);padding:1.5rem;transition:all .2s;position:relative}.spell-disciplines-step .discipline-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #6e16cd33}.spell-disciplines-step .discipline-card.selected{border-color:var(--primary);background-color:var(--accent-light-purple)}.spell-disciplines-step .discipline-card h4{color:var(--primary);margin-bottom:.5rem;font-size:1.44rem}.spell-disciplines-step .discipline-card .description{color:var(--text-color);margin-bottom:1rem;line-height:1.5}.spell-disciplines-step .discipline-card .benefits-list{margin:0;padding:0;list-style:none}.spell-disciplines-step .discipline-card .benefits-list li{color:var(--text-color);padding:.25rem 0 .25rem 1.25rem;font-size:.9rem;position:relative}.spell-disciplines-step .discipline-card .benefits-list li:before{content:"•";color:var(--accent-orange);font-weight:700;position:absolute;left:0}.spell-disciplines-step .discipline-card .selected-badge{background-color:var(--primary);color:#fff;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:700;position:absolute;top:1rem;right:1rem}.spell-disciplines-step .selection-count{color:var(--primary);font-size:1.1rem;font-weight:700}.spell-disciplines-step .warning{background-color:var(--accent-light-red);border-color:var(--accent-red)}.spells-step{margin-top:1.5rem}.spells-step .selection-count{color:var(--primary);margin:.5rem 0;font-size:1.1rem;font-weight:700}.spells-step .spell-list-info{color:var(--text-secondary);background-color:var(--accent-light-purple);border-radius:8px;margin:.5rem 0 1rem;padding:.75rem;font-size:.9rem}.spells-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem;margin-top:1rem;display:grid}.spell-card{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;transition:all .2s;position:relative;overflow:hidden}.spell-card:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #6e16cd26}.spell-card.selected{border-color:var(--primary);background-color:#6e16cd0d}.spell-card.selected:after{content:"✓";color:var(--primary);pointer-events:none;font-size:1.5rem;font-weight:900;position:absolute;top:10px;right:15px}.spell-header{cursor:pointer;padding:1rem}.spell-header h4{color:var(--primary);margin:0 0 .5rem;font-size:1.38rem}.spell-meta{flex-wrap:wrap;gap:.5rem;margin:.5rem 0;display:flex}.spell-source,.spell-school{background-color:var(--accent-light-blue);color:var(--primary);border-radius:4px;padding:.25rem .5rem;font-size:.8rem;font-weight:500}.spell-tags{flex-wrap:wrap;gap:.25rem;margin:.5rem 0;display:flex}.spell-tags .tag{background-color:var(--accent-light-orange);color:var(--text-primary);border-radius:4px;padding:.2rem .4rem;font-size:.75rem}.spell-basic{color:var(--text-secondary);flex-wrap:wrap;gap:.75rem;margin:.75rem 0;font-size:.85rem;display:flex}.spell-cost,.spell-range,.spell-duration{font-weight:500}.select-button{background-color:var(--accent-blue);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:.75rem;padding:.5rem;font-weight:700;transition:all .2s}.select-button:hover,.select-button.selected{background-color:var(--primary)}.spell-details{border-top:2px solid var(--border-color);background-color:#6e16cd08;padding:1rem}.spell-description{color:var(--text-primary);margin:0 0 1rem;line-height:1.5}.spell-enhancements{margin-top:1rem}.spell-enhancements h5{color:var(--primary);margin:0 0 .75rem;font-size:1rem}.enhancement{background-color:var(--card-bg);border-left:3px solid var(--accent-blue);border-radius:6px;margin-bottom:.5rem;padding:.5rem}.enhancement-name{color:var(--primary);margin-right:.5rem;font-weight:700}.enhancement-cost{color:var(--accent-orange);margin-right:.5rem;font-weight:500}.enhancement-description{color:var(--text-secondary);font-size:.9rem}.hero-banner{background-color:var(--primary);color:#fff;text-align:center;margin-bottom:2rem;padding:2rem}.hero-banner h1{color:#fff;margin:0;font-size:3rem}.review-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem;display:grid}.review-card h4{text-align:center;margin:0 0 1rem}.stat-row{border-bottom:1px solid var(--border-color);justify-content:space-between;padding:.5rem 0;display:flex}.final-actions{text-align:center;background-color:var(--accent-light-blue);border-radius:16px;padding:1.5rem}@media (width<=768px){.modifier-grid{grid-template-columns:1fr;gap:1rem}}.maneuvers-section{border-top:3px dashed var(--border-color);margin-top:2rem;padding-top:2rem}.maneuvers-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.maneuver-card{border:3px solid var(--border-color);background-color:var(--card-bg);border-radius:16px;flex-direction:column;transition:all .2s ease-in-out;display:flex;overflow:hidden}.maneuver-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.maneuver-card.selected{border-color:var(--accent-orange);background-color:#fbac810d}.maneuver-header{cursor:pointer;flex-direction:column;flex:1;padding:1.25rem;display:flex}.maneuver-header h4{color:var(--primary);margin:0 0 .5rem;font-size:1.38rem}.maneuver-meta{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.maneuver-meta .badge{background-color:var(--accent-light-blue);color:var(--primary);text-transform:uppercase;border-radius:8px;padding:.25rem .5rem;font-size:.75rem;font-weight:700}.maneuver-meta .badge.cost{color:var(--secondary);background-color:#e60d0d1a}.maneuver-body{padding:0 1.25rem 1.25rem;font-size:.9rem;line-height:1.4}.maneuver-description{color:var(--text-primary);white-space:pre-wrap;margin-bottom:1rem}.maneuver-enhancements{border-top:1px dashed var(--border-color);margin-top:1rem;padding-top:1rem}.maneuver-enhancements h5{color:var(--primary);margin:0 0 .5rem;font-size:.95rem}.maneuver-card .select-btn{background-color:var(--border-color);width:100%;color:var(--text-secondary);cursor:pointer;text-transform:uppercase;border:none;padding:.75rem;font-weight:700;transition:all .2s}.maneuver-card .select-btn:hover{background-color:var(--primary);color:#fff}.maneuver-card.selected .select-btn{background-color:var(--accent-orange);color:#fff}.image-nav-btn{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:transform .2s cubic-bezier(.175,.885,.32,1.275),filter .2s;display:flex}.image-nav-btn:hover{filter:brightness(1.12)drop-shadow(0 4px 8px #6e16cd40);transform:scale(1.08)}.image-nav-btn:active{filter:brightness(.9);transform:scale(.95)}.class-guidance-pill{text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;padding:3px 10px;font-size:.72rem;font-weight:800;display:inline-block}.class-guidance-pill.recommended{color:#2ecc71;background-color:#2ecc7126;border:2px solid #2ecc71}.class-guidance-pill.suitable{color:#b7791f;background-color:#f1c40f26;border:2px solid #f1c40f}.class-guidance-pill.unusual{color:#e60d0d;background-color:#e60d0d1a;border:2px solid #e60d0d}.class-guidance-panel{animation:.4s fadeInDown}.class-guidance-panel h4{border-bottom:2px dashed #0000001a;padding-bottom:.4rem;font-family:Marcellus,serif;font-weight:800}.text-good{color:#27af5a!important}.text-sufficient{color:#b7791f!important}.dashboard-outer{box-sizing:border-box;width:100%;max-width:1000px;margin:0 auto;padding:2rem 1rem}.dashboard-card{border:4px solid var(--accent-gold);background-color:#f7ebd3;border-radius:20px;width:100%;padding:0;transition:border-color .3s,box-shadow .3s;overflow:hidden;box-shadow:0 15px 35px #00000040}.dashboard-card:hover{border-color:#f0c375;box-shadow:0 20px 45px #0000004d}.dashboard-banner-wrapper{background-color:var(--primary);width:100%;height:240px;position:relative;overflow:hidden}.dashboard-banner-image{object-fit:cover;width:100%;height:100%;display:block}.dashboard-banner-overlay{background:linear-gradient(#00000026 0%,#f7ebd3 100%);position:absolute;inset:0}.dashboard-content{padding:2rem}@media (width<=600px){.dashboard-banner-wrapper{height:180px}.dashboard-content{padding:1.25rem}}.dashboard-empty-state{text-align:center;max-width:600px;margin:0 auto;padding:3rem 1.5rem}.dashboard-empty-title{color:var(--primary);text-shadow:1px 1px #ffffffb3,2px 2px 4px #0000000d;margin-top:0;margin-bottom:1rem;font-family:Marcellus,serif;font-size:2rem;font-weight:800}.dashboard-empty-subtitle{color:#4a5568;margin-bottom:2rem;font-size:1.05rem;line-height:1.6}.dashboard-card .character-card{border:2px solid var(--accent-light-blue);border-radius:14px;padding:1.5rem;transition:transform .2s,border-color .2s,box-shadow .2s;box-shadow:0 4px 10px #0000000a;background-color:#fff!important}.dashboard-card .character-card:hover{border-color:var(--accent-blue);transform:translateY(-3px);box-shadow:0 8px 20px #00000014}.character-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.5rem;width:100%;display:grid}.dashboard-card .layout-select{border:2px solid var(--accent-light-blue);color:#2d3748;font-family:inherit;font-size:.85rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.dashboard-card .layout-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6e16cd26}.landing-outer{background-color:var(--bg-color);justify-content:center;align-items:center;min-height:calc(100vh - 120px);padding:2rem;display:flex}.landing-card{border:4px solid var(--accent-gold);background-color:#f7ebd3;border-radius:20px;width:100%;max-width:500px;padding:0;transition:transform .3s,box-shadow .3s;overflow:hidden;transform:translateY(0);box-shadow:0 15px 35px #00000040}.landing-card:hover{border-color:#f0c375;transform:translateY(-4px);box-shadow:0 20px 45px #0000004d}.landing-banner-wrapper{width:100%;height:220px;position:relative;overflow:hidden}.landing-banner-image{object-fit:cover;width:100%;height:100%;display:block}.landing-banner-overlay{background:linear-gradient(#0000001a 0%,#f7ebd3 100%);position:absolute;inset:0}.landing-content{text-align:center;padding:2rem}.landing-title{color:var(--primary);text-shadow:1px 1px #ffffffb3,2px 2px 4px #0000001a;letter-spacing:.05em;margin-top:.5rem;margin-bottom:1rem;font-family:Marcellus,serif;font-size:2.1rem;font-weight:800;line-height:1.2}.landing-subtitle{color:#4a5568;margin-bottom:2rem;font-size:1rem;line-height:1.6}.auth-buttons-container{flex-direction:column;align-items:center;gap:1.25rem;width:100%;margin-top:1rem;display:flex}.auth-btn-wrapper{justify-content:center;width:100%;display:flex}.discord-btn{color:#fff;text-transform:none;letter-spacing:normal;background-color:#5865f2;border-radius:9999px;justify-content:center;align-items:center;gap:12px;width:280px;height:44px;padding:0 24px;font-size:.95rem;font-weight:600;transition:background-color .2s,transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 6px #5865f233}.discord-btn:hover{background-color:#4752c4;transform:translateY(-1px);box-shadow:0 6px 12px #5865f24d}.discord-btn:active{transform:translateY(1px)}.discord-icon{width:22px;height:22px}.google-btn-container{justify-content:center;align-items:center;min-height:44px;display:flex}.landing-loading{flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;display:flex}.landing-loading p{color:var(--primary);font-family:Marcellus,serif;font-size:1.1rem;font-weight:700}.spinner{border:5px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}.btn-local-bypass{color:#1e1e1e;cursor:pointer;background-color:#e0ab5b;border:2px solid #6e16cd;border-radius:9999px;justify-content:center;align-items:center;width:280px;height:44px;padding:0 24px;font-family:inherit;font-size:.95rem;font-weight:700;transition:background-color .2s,transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 6px #6e16cd40}.btn-local-bypass:hover{background-color:#fbac81;transform:translateY(-1.5px);box-shadow:0 6px 12px #6e16cd66}.btn-local-bypass:active{transform:translateY(1px)}.settings-card{border:2px solid var(--accent-light-blue);background-color:var(--surface-color);border-radius:16px;padding:2rem;box-shadow:0 10px 25px #0000000d}.form-group{flex-direction:column;margin-bottom:1.5rem;display:flex}.form-group label{color:var(--primary);margin-bottom:.5rem;font-size:.95rem;font-weight:700}.form-group input{border:2px solid var(--border-color);color:var(--text-main);background-color:#fcfdfd;border-radius:12px;padding:12px 16px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:var(--accent-blue);outline:none;box-shadow:0 0 0 3px #636ac426}.info-block{border-top:2px dashed var(--border-color);margin-top:2rem;padding-top:1.5rem}.info-block h3{color:var(--primary);margin-bottom:1rem;font-family:Marcellus,serif;font-size:1.2rem}.info-row{color:var(--text-main);font-size:.95rem}.connected-methods{flex-direction:column;gap:.5rem;margin:.75rem 0 0;padding:0;list-style:none;display:flex}.method-item{color:#4a5568;align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.method-item .icon{color:var(--stat-success);font-size:1.1rem;font-weight:800}.method-item.discord{color:#4752c4}.method-item.google{color:#4285f4}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.toast{pointer-events:auto;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;justify-content:space-between;align-items:center;min-width:300px;max-width:450px;padding:1rem 1.25rem;transition:transform .2s;animation:.3s ease-out toast-in;display:flex;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.toast:hover{transform:translateY(-2px)}.toast-content{align-items:center;gap:.75rem;display:flex}.toast-message{color:#2d3748;font-size:.95rem;font-weight:600}.toast-message strong{font-weight:900}.toast-icon{font-size:1.2rem}.toast-close{color:#a0aec0;cursor:pointer;background:0 0;border:none;margin-left:1rem;padding:0;font-size:1.5rem;line-height:1}.toast-close:hover{color:#4a5568}.toast-success{background:#f0fff4;border-color:#48bb78}.toast-error{background:#fff5f5;border-color:#f56565}.toast-warning{background:#fffaf0;border-color:#ed8936}.toast-info{background:#ebf8ff;border-color:#4299e1}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}
