@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Cinzel:wght@400;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;min-height:100vh;color:#2d3748}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{line-height:1.2}p{line-height:1.6}.home{max-width:1200px;margin:2rem auto;padding:2rem;text-align:center;position:relative}.home-header{position:absolute;top:1rem;right:1rem}.home h1{font-size:3rem;margin-bottom:1rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.2);font-weight:700}.home button{padding:1.25rem 2.5rem;font-size:1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;margin-top:2rem;box-shadow:0 4px 15px #667eea66;transition:all .3s ease;font-weight:600}.home button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.character-library{margin-top:3rem;text-align:left}.character-library h2{text-align:center;margin-bottom:1.5rem;color:#fff;font-size:2rem;font-weight:600}.character-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.character-card{padding:1.5rem;background:#fff;border:none;border-radius:16px;text-decoration:none;color:inherit;transition:all .3s ease;display:block;box-shadow:0 4px 6px #0000001a}.character-card.profile-character-card{border:2px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:1rem;height:100%}.character-card.profile-character-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.character-card:hover:not(.profile-character-card){box-shadow:0 10px 25px #00000026;transform:translateY(-4px)}.character-card h3:not(.profile-character-card h3){background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;font-size:1.5rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.character-card p{margin:.25rem 0;color:#666}.character-card-avatar{width:80px;height:80px;margin:0 auto 1rem;border-radius:50%;overflow:hidden;border:3px solid #667eea;box-shadow:0 2px 8px #667eea33;flex-shrink:0}.character-card-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.character-card-avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.character-card-subclass-icon{font-size:2.5rem;line-height:1}.character-card-wrapper{position:relative}.character-card-wrapper .character-card{position:relative;z-index:1}.character-actions{position:absolute;bottom:1rem;right:1rem;display:flex;gap:.5rem;z-index:10;pointer-events:auto}.character-actions button{background:#ffffffe6;border:none;border-radius:8px;padding:.5rem;cursor:pointer;font-size:1.2rem;transition:all .2s ease;box-shadow:0 2px 6px #0000001a}.character-actions button:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.visibility-toggle.public{background:#48bb7833}.visibility-toggle.private{background:#f5656533}.delete-button{background:#f5656533!important}.delete-confirm{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffffa;border-radius:16px;padding:2rem;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:20;box-shadow:0 8px 24px #0003}.delete-confirm p{margin-bottom:1rem;font-weight:600;color:#2d3748}.delete-confirm-buttons{display:flex;gap:1rem}.confirm-delete,.cancel-delete{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease}.confirm-delete{background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff}.confirm-delete:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5656566}.cancel-delete{background:#e2e8f0;color:#2d3748}.cancel-delete:hover{background:#cbd5e0}.characters-filters{display:flex;flex-wrap:wrap;gap:1rem;margin:2rem 0;padding:1.5rem;background:#fffffff2;border-radius:16px;box-shadow:0 4px 12px #0000001a}.search-box{flex:1;min-width:250px}.search-input{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:600;color:#4a5568}.filter-group select{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer;transition:all .2s ease}.filter-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.home-dashboard{max-width:1200px;margin:2rem auto;padding:2rem}.dashboard-header{text-align:center;margin-bottom:3rem}.dashboard-header h1{font-size:3.5rem;margin-bottom:1rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.2);font-weight:700}.dashboard-subtitle{font-size:1.25rem;color:#ffffffe6;text-shadow:0 1px 5px rgba(0,0,0,.2)}.dashboard-section{margin-bottom:3rem;background:#fffffff2;border-radius:20px;padding:2rem;box-shadow:0 8px 24px #0000001a}.dashboard-section h2{font-size:2rem;margin-bottom:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.action-card{padding:2rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;text-decoration:none;color:inherit;transition:all .3s ease;border:2px solid #e2e8f0;display:flex;flex-direction:column;align-items:center;text-align:center}.action-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000026;border-color:#667eea}.action-card.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.action-card.primary h3,.action-card.primary p{color:#fff}.action-icon{font-size:3rem;margin-bottom:1rem}.action-card h3{font-size:1.5rem;margin-bottom:.5rem;color:#2d3748}.action-card p{color:#718096;font-size:.95rem}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.info-card{padding:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border-left:4px solid #667eea}.info-card h3{font-size:1.25rem;margin-bottom:.75rem;color:#2d3748}.info-card p{color:#4a5568;line-height:1.6}.announcement-card{padding:2rem;background:linear-gradient(135deg,#fff5f5,#fed7d7);border-radius:12px;border-left:4px solid #e53e3e}.announcement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.announcement-badge{background:#e53e3e;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.announcement-date{color:#718096;font-size:.875rem}.announcement-card h3{font-size:1.5rem;margin-bottom:0;color:#2d3748}.announcement-card p{margin-bottom:.75rem;color:#4a5568}.announcement-card ul{margin-left:1.5rem;color:#4a5568}.announcement-card li{margin-bottom:.5rem}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.tip-card{padding:1.5rem;background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-radius:12px;border-left:4px solid #48bb78}.tip-card h4{font-size:1.1rem;margin-bottom:.75rem;color:#2d3748}.tip-card p{color:#4a5568;font-size:.95rem;line-height:1.6}.domain-browser{width:100%;padding:0}.domain-browser h1,.domain-browser h2{font-size:2rem;margin-bottom:.5rem;color:#2d3748;font-weight:700;text-align:center}.dark-mode .domain-browser h1,.dark-mode .domain-browser h2{color:#e2e8f0}.browser-subtitle{text-align:center;color:#4a5568;font-size:1.1rem;margin-bottom:2rem}.dark-mode .browser-subtitle{color:#ffffffe6}.browser-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#fffffff2;border-radius:16px;box-shadow:0 4px 12px #0000001a}.browser-stats{text-align:center;margin-bottom:1.5rem;color:#fff;font-size:1.1rem;font-weight:600}.domain-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.domain-card-browser{padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;transition:all .3s ease;border-left:4px solid #667eea}.domain-card-browser:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0}.card-domain{display:flex;align-items:center;gap:.5rem}.domain-icon{font-size:1.5rem}.domain-name{font-weight:700;color:#2d3748;font-size:1.1rem}.card-level{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:700}.card-name{font-size:1.5rem;margin-bottom:.75rem;color:#2d3748;font-weight:700}.card-description{color:#4a5568;margin-bottom:.75rem;line-height:1.6}.card-cost,.card-range,.card-damage{font-size:.9rem;color:#718096;margin-bottom:.5rem;font-weight:600}.card-effect{margin-top:.75rem;padding:.75rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;color:#2d3748;font-size:.9rem;line-height:1.6}.card-type-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase}.card-feature{margin-top:.75rem;padding:.75rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px}.feature-label{font-size:.75rem;font-weight:700;color:#718096;text-transform:uppercase;margin-bottom:.25rem}.feature-text{color:#2d3748;font-size:.9rem;line-height:1.6}.card-stats{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.card-stat{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.stat-label{font-size:.85rem;color:#718096;font-weight:600}.stat-value{font-size:1rem;color:#2d3748;font-weight:700}.no-results{text-align:center;padding:3rem;color:#fff;font-size:1.25rem}.dark-mode .characters-filters,.dark-mode .browser-filters{background:#1a202cf2;border:1px solid #4a5568}.dark-mode .search-input,.dark-mode .filter-group select{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .browser-stats{color:#e2e8f0}.dark-mode .filter-group label{color:#cbd5e0}.dark-mode .character-actions button{background:#1a202ce6}.dark-mode .delete-confirm{background:#1a202cfa}.dark-mode .delete-confirm p{color:#e2e8f0}.dark-mode .cancel-delete{background:#4a5568;color:#e2e8f0}.dark-mode .cancel-delete:hover{background:#2d3748}.dark-mode .dashboard-section{background:#1a202cf2;border:1px solid #4a5568}.dark-mode .dashboard-section h2{color:#e2e8f0}.dark-mode .action-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .action-card h3,.dark-mode .action-card p{color:#e2e8f0}.dark-mode .info-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-left-color:#667eea}.dark-mode .info-card h3,.dark-mode .info-card p{color:#e2e8f0}.dark-mode .announcement-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-left-color:#e53e3e}.dark-mode .announcement-card h3,.dark-mode .announcement-card p,.dark-mode .announcement-card li{color:#e2e8f0}.dark-mode .tip-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-left-color:#48bb78}.dark-mode .tip-card h4,.dark-mode .tip-card p{color:#e2e8f0}.dark-mode .domain-card-browser{background:#2d3748;border-left-color:#667eea}.dark-mode .domain-card-browser .card-header{border-bottom-color:#4a5568}.dark-mode .domain-name,.dark-mode .card-name{color:#e2e8f0}.dark-mode .card-description,.dark-mode .card-cost,.dark-mode .card-range,.dark-mode .card-damage{color:#cbd5e0}.dark-mode .card-effect{background:linear-gradient(135deg,#1a202c,#2d3748);color:#e2e8f0}.equipment-browser{max-width:1600px;margin:2rem auto;padding:2rem}.equipment-browser h1{font-size:3rem;margin-bottom:.5rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.2);font-weight:700;text-align:center}.equipment-tabs{display:flex;gap:1rem;margin:2rem 0;justify-content:center}.tab-button{padding:1rem 2rem;background:#ffffffe6;border:2px solid #e2e8f0;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:#2d3748}.tab-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 15px #667eea66}.equipment-table-container{overflow-x:auto;margin-top:2rem;background:#fffffff2;border-radius:16px;padding:1.5rem;box-shadow:0 4px 12px #0000001a}.equipment-table{width:100%;border-collapse:collapse}.equipment-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.equipment-table th{padding:1rem;text-align:left;font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.equipment-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background .2s ease}.equipment-table tbody tr:hover{background:linear-gradient(135deg,#f7fafc,#edf2f7)}.equipment-table td{padding:1rem;color:#2d3748;font-size:.95rem}.equipment-name-cell{display:flex;align-items:center;gap:.75rem}.equipment-icon{font-size:1.5rem}.equipment-name{font-weight:600;color:#2d3748}.damage-cell{font-weight:700;color:#e53e3e;font-family:Courier New,monospace}.stat-cell{font-weight:600;text-align:center}.damage-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.damage-type-badge.phy{background:linear-gradient(135deg,#fed7d7,#feb2b2);color:#742a2a}.damage-type-badge.mag{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d}.category-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;background:linear-gradient(135deg,#e6fffa,#b2f5ea);color:#234e52;text-transform:capitalize}.feature-cell{max-width:300px}.feature-name{font-weight:700;color:#667eea;margin-bottom:.25rem;font-size:.9rem}.feature-desc{color:#4a5568;font-size:.85rem;line-height:1.4}.no-feature{color:#cbd5e0;font-style:italic}.tier-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.tier-badge.tier-1{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d}.tier-badge.tier-2{background:linear-gradient(135deg,#bee3f8,#90cdf4);color:#2c5282}.tier-badge.tier-3{background:linear-gradient(135deg,#fbb6ce,#f687b3);color:#702459}.tier-badge.tier-4{background:linear-gradient(135deg,#faf089,#f6e05e);color:#744210}.dark-mode .tier-badge.tier-1{background:linear-gradient(135deg,#68d3914d,#68d39133);color:#68d391}.dark-mode .tier-badge.tier-2{background:linear-gradient(135deg,#5acdf44d,#5acdf433);color:#63b3ed}.dark-mode .tier-badge.tier-3{background:linear-gradient(135deg,#f687b34d,#f687b333);color:#f687b3}.dark-mode .tier-badge.tier-4{background:linear-gradient(135deg,#f6e05e4d,#f6e05e33);color:#f6e05e}.site-footer{background:linear-gradient(135deg,#2d3748,#1a202c);color:#e2e8f0;padding:2rem 0 1rem;margin-top:auto;border-top:3px solid #667eea}.footer-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.footer-section h4{font-size:1.1rem;margin-bottom:.75rem;color:#cbd5e0;font-weight:700}.footer-section p{font-size:.9rem;line-height:1.6;color:#a0aec0}.footer-section strong{color:#e2e8f0}.footer-bottom{max-width:1200px;margin:2rem auto 0;padding:1rem 2rem;border-top:1px solid #4a5568;text-align:center}.footer-bottom p{font-size:.85rem;color:#718096}.dark-mode .site-footer{background:linear-gradient(135deg,#1a202c,#0d1117);border-top-color:#764ba2}.dark-mode .footer-section h4{color:#e2e8f0}.dark-mode .footer-section p{color:#cbd5e0}.dark-mode .footer-section strong{color:#f7fafc}.dark-mode .footer-bottom{border-top-color:#2d3748}.dark-mode .footer-bottom p{color:#a0aec0}.dark-mode .equipment-table-container{background:#1a202cf2;border:1px solid #4a5568}.dark-mode .equipment-table thead{background:linear-gradient(135deg,#764ba2,#667eea)}.dark-mode .equipment-table tbody tr{border-bottom-color:#4a5568}.dark-mode .equipment-table tbody tr:hover{background:linear-gradient(135deg,#2d3748,#1a202c)}.dark-mode .equipment-table td,.dark-mode .equipment-name{color:#e2e8f0}.dark-mode .damage-cell{color:#fc8181}.dark-mode .feature-name{color:#9f7aea}.dark-mode .no-feature{color:#718096}.dark-mode .tab-button{background:#1a202ce6;border-color:#4a5568;color:#e2e8f0}.dark-mode .tab-button:hover{background:#1a202c}.dark-mode .tab-button.active{background:linear-gradient(135deg,#764ba2,#667eea);color:#fff}.dark-mode .card-feature{background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .feature-label{color:#a0aec0}.dark-mode .feature-text{color:#e2e8f0}.dark-mode .card-stats{border-top-color:#4a5568}.character-creation{max-width:1400px;margin:2rem auto;padding:3rem;background:linear-gradient(to bottom,#fff,#fafbfc);border-radius:32px;box-shadow:0 24px 72px #00000040,0 8px 24px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.9);position:relative;overflow:hidden}.character-creation:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#667eea,#764ba2,#667eea);background-size:200% 100%;animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.validation-errors{margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#fed7d7,#feb2b2);border-radius:16px;border-left:5px solid #e53e3e;box-shadow:0 4px 12px #e53e3e33;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.validation-errors h3{color:#742a2a;font-size:1.2rem;font-weight:700;margin-bottom:1rem}.validation-errors ul{list-style:none;padding:0;margin:0}.validation-errors li{color:#742a2a;padding:.5rem 0;font-size:1rem}.validation-errors li strong{font-weight:700;text-transform:capitalize}.debug-toggle{padding:.5rem 1rem;background:#718096;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;margin-bottom:1rem;transition:all .2s ease}.debug-toggle:hover{background:#4a5568}.debug-panel{margin-bottom:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border:2px solid #e2e8f0}.debug-panel h4{color:#2d3748;font-size:1.2rem;font-weight:700;margin-bottom:1.5rem;font-family:Cinzel,serif;text-transform:uppercase;letter-spacing:.5px}.debug-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;align-items:start;grid-auto-flow:row}.debug-section{background:#fff;padding:1.25rem;border-radius:10px;border:1px solid #e2e8f0;position:relative;z-index:1}.debug-section-wide{grid-column:span 1;min-width:400px;max-width:500px;box-sizing:border-box;overflow:hidden}.debug-grid>*{min-width:0}.debug-section-wide .debug-item{flex-wrap:nowrap}.debug-section-wide .debug-value{white-space:normal;word-break:break-word;text-align:right;flex:1;margin-left:1rem}.debug-section h5{color:#2d3748;font-size:1rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #667eea;text-transform:uppercase;letter-spacing:.5px;font-size:.9rem}.debug-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f7fafc}.debug-item:last-child{border-bottom:none}.debug-label{color:#718096;font-size:.9rem;font-weight:600}.debug-value{color:#48bb78;font-weight:700;font-size:.95rem}.debug-missing{color:#f56565;font-weight:600;font-size:.95rem}.debug-traits{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.debug-trait-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f7fafc;border-radius:6px}.main-navigation{background:linear-gradient(135deg,#fffffff2,#f7fafcf2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid rgba(102,126,234,.1);padding:1rem 0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px #0000001a;isolation:isolate}.nav-container{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;position:relative}.nav-brand{display:flex;align-items:center}.nav-logo{font-size:1.5rem;font-weight:700;color:#667eea;text-decoration:none;font-family:Cinzel,serif;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;gap:2rem;align-items:center}.nav-actions{display:flex;align-items:center;gap:1rem}.nav-links a{color:#4a5568;text-decoration:none;font-weight:600;font-size:1rem;padding:.5rem 1rem;border-radius:8px;transition:all .2s ease;display:inline-block}.nav-links a:hover{color:#667eea;background:#667eea1a}.nav-links a.active{color:#667eea;background:linear-gradient(135deg,#667eea26,#764ba226)}.nav-links a[href="/login"],.nav-links a[href="/register"]{padding:.5rem 1rem;font-weight:600;font-size:1rem;border-radius:8px;text-align:center;min-width:auto}.main-navigation .theme-toggle{padding:.5rem 1rem;font-size:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.main-navigation .theme-toggle:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.mobile-menu-toggle{display:none;background:transparent;border:none;cursor:pointer;padding:.5rem;min-width:44px;min-height:44px;align-items:center;justify-content:center;flex-direction:column;gap:4px}.hamburger{display:flex;flex-direction:column;gap:4px;width:24px;height:18px;position:relative}.hamburger span{display:block;width:100%;height:2px;background:#4a5568;border-radius:2px;transition:all .3s ease;transform-origin:center}.dark-mode .hamburger span{background:#e2e8f0}.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-nav-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:9999;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;pointer-events:none}.mobile-nav-menu.open{pointer-events:auto}.mobile-nav-menu.open{opacity:1;visibility:visible}.mobile-nav-links{position:absolute;top:0;right:0;width:280px;max-width:85vw;height:100%;background:linear-gradient(to bottom,#fff,#fafbfc);box-shadow:-4px 0 20px #00000026;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;transform:translate(100%);transition:transform .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:1;pointer-events:auto}.dark-mode .mobile-nav-links{background:linear-gradient(to bottom,#1a202c,#2d3748)}.mobile-nav-menu.open .mobile-nav-links{transform:translate(0)}.mobile-nav-links a{display:block;padding:1rem 1.25rem;color:#4a5568;text-decoration:none;font-weight:600;font-size:1.1rem;border-radius:8px;transition:all .2s ease;min-height:44px;display:flex;align-items:center}.dark-mode .mobile-nav-links a{color:#e2e8f0}.mobile-nav-links a:hover{background:#667eea1a;color:#667eea}.mobile-nav-links a.active{color:#667eea;background:linear-gradient(135deg,#667eea26,#764ba226)}.mobile-account-menu{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(102,126,234,.1)}@media (min-width: 769px){.desktop-nav{display:flex}.mobile-menu-toggle,.mobile-nav-menu,.nav-brand{display:none}}.creation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(102,126,234,.1)}.header-left{flex:1}.creation-header h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2rem;font-weight:800;font-family:Cinzel,serif;letter-spacing:1px;text-transform:uppercase;margin:0 0 .5rem;text-align:center}.step-indicator-inline{display:flex;align-items:center;justify-content:center}.step-indicator-text{font-size:1rem;font-weight:600;color:#4a5568}.step-subtitle{flex:1;text-align:center;color:#718096;font-size:.95rem;font-style:italic;padding:0 1rem}.header-right{display:flex;gap:1rem;align-items:center}.random-button{padding:.75rem;font-size:1.5rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:10px;cursor:pointer;box-shadow:0 2px 8px #f5576c4d;transition:all .2s ease;font-weight:600;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.random-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.debug-toggle{padding:.75rem 1.5rem;font-size:.95rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;cursor:pointer;box-shadow:0 2px 8px #667eea4d;transition:all .2s ease;font-weight:600}.debug-toggle:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.step-indicator{margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap}.step-number{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;font-size:1rem;font-weight:600;color:#718096;background:#f7fafc;border:2px solid #e2e8f0;border-radius:50%;transition:all .2s ease}.step-number.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.step-number.completed{background:#48bb78;color:#fff;border-color:#48bb78}.step-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.progress-bar{width:100%;height:12px;background-color:#e2e8f0;border-radius:12px;margin-bottom:2.5rem;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #667eea80}.step-content-wrapper{min-height:450px;margin-bottom:2rem}.step-content h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:.75rem;text-align:center}.step-content>p{color:#718096;font-size:1.1rem;text-align:center;margin-bottom:2rem}.step-navigation{display:flex;justify-content:space-between;gap:1rem;align-items:center}.step-navigation.top{margin-top:0;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.step-navigation.bottom{margin-top:2rem;padding-top:1.5rem;border-top:2px solid #e2e8f0}.step-navigation button{padding:1rem 2rem;font-size:1.1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #667eea4d;transition:all .3s ease;font-weight:600;white-space:nowrap}.step-navigation.top button{flex:0 0 auto}.step-navigation button:disabled{background:#cbd5e0;cursor:not-allowed;box-shadow:none;opacity:.6}.step-navigation button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.step-navigation button.next-button{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 4px 15px #48bb784d}.step-navigation button.next-button:hover:not(:disabled){box-shadow:0 6px 20px #48bb7866}.step-navigation button.next-button.disabled,.step-navigation button.next-button:disabled{background:#cbd5e0;cursor:not-allowed;box-shadow:none;opacity:.6}.step-navigation button.next-button.disabled:hover,.step-navigation button.next-button:disabled:hover{transform:none;box-shadow:none}.list-detail-container{display:grid;grid-template-columns:355px 1fr;gap:2rem;margin:2rem 0;min-height:500px}.list-detail-container.subclass-section,.list-detail-container.community-section,.list-detail-container.secondary-weapon-section,.list-detail-container.armor-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #e2e8f0}.equipment-hint{font-size:.9rem;color:#718096;margin:.5rem 0 1rem;font-style:italic}.equipment-hint-header{font-size:.9rem;color:#718096;margin:0 0 1rem;font-style:italic;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.equipment-search-box{margin-bottom:.75rem;padding:0 .5rem}.equipment-filters{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:0 .5rem;width:100%;box-sizing:border-box}.equipment-search-input{width:100%;padding:.5rem .75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#fff;transition:all .2s ease}.equipment-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.equipment-filter-group{display:flex;align-items:center;gap:.125rem}.equipment-filter-group label{font-size:.85rem;font-weight:600;color:#4a5568;min-width:auto;width:auto;margin:0;padding:0;margin-right:.125rem;flex-shrink:0}@media (min-width: 480px){.equipment-filters{flex-direction:row;align-items:center;gap:.75rem}.equipment-filter-group{flex:1 1 0;min-width:0}}.equipment-filter-select{width:100%;max-width:100%;padding:.5rem .75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#fff;color:#2d3748;cursor:pointer;transition:all .2s ease;box-sizing:border-box}.equipment-filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.dark-mode .equipment-search-input,.dark-mode .equipment-filter-select{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .equipment-search-input:focus,.dark-mode .equipment-filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.dark-mode .equipment-filter-group label{color:#cbd5e0}.dark-mode .equipment-hint-header{color:#cbd5e0;border-bottom-color:#4a5568}.no-results-message{padding:2rem;text-align:center;color:#718096;font-style:italic}.dark-mode .no-results-message{color:#a0aec0}.detail-header-with-hint{margin-bottom:1rem}.weapon-section-header{font-size:.85rem;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin:1.5rem 0 .75rem;padding-top:1rem;border-top:1px solid #e2e8f0}.weapon-section-header:first-of-type{margin-top:.5rem;padding-top:0;border-top:none}.selection-list{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:1.5rem;box-shadow:0 4px 12px #00000014;border:1px solid rgba(102,126,234,.1);height:fit-content;max-height:600px;display:flex;flex-direction:column}.dark-mode .selection-list{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0;flex-wrap:wrap;gap:.5rem}.list-header.invalid{border-bottom-color:#f56565;background:linear-gradient(135deg,#f565650d,#f5656505);padding:.75rem;border-radius:8px}.validation-error{font-size:.85rem;color:#f56565;font-weight:600;margin-left:auto}.validation-error-banner{background:linear-gradient(135deg,#f565651a,#f565650d);border:2px solid #f56565;border-radius:10px;padding:1rem;margin-bottom:1.5rem;color:#f56565;font-weight:600;text-align:center}.validation-error-inline{font-size:.85rem;color:#f56565;font-weight:600;margin-top:.5rem;display:block}.invalid-input{border-color:#f56565!important;background:linear-gradient(135deg,#fffffff2,#f565650d)!important}.invalid-input:focus{border-color:#f56565!important;box-shadow:0 0 0 3px #f5656533!important}.list-header h3{margin:0;font-size:1.3rem;font-weight:700;color:#2d3748}.dark-mode .list-header{border-bottom-color:#4a5568}.dark-mode .list-header h3{color:#e2e8f0}.list-items{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;padding-right:.5rem}.list-items::-webkit-scrollbar{width:6px}.list-items::-webkit-scrollbar-track{background:#f7fafc;border-radius:10px}.list-items::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#667eea,#764ba2);border-radius:10px}.list-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff;border-radius:12px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.list-item:hover{border-color:#667eea4d;transform:translate(4px);box-shadow:0 2px 8px #667eea26}.list-item.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:#667eea;box-shadow:0 4px 12px #667eea40}.list-item-icon{font-size:1.75rem;flex-shrink:0}.list-item-name{flex:1;font-weight:600;color:#2d3748;font-size:1.05rem}.list-item-burden{font-size:.75rem;font-weight:700;color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);padding:.25rem .5rem;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.list-item-check{color:#48bb78;font-size:1.25rem;font-weight:700}.dark-mode .list-item{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .list-item:hover{border-color:#667eea80;box-shadow:0 2px 8px #667eea4d}.dark-mode .list-item.selected{background:linear-gradient(135deg,#2c5282,#434190);border-color:#667eea;box-shadow:0 4px 12px #4299e14d}.dark-mode .list-item-name{color:#e2e8f0}.dark-mode .list-items::-webkit-scrollbar-track{background:#2d3748}.selection-detail{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:2rem;box-shadow:0 4px 12px #00000014;border:1px solid rgba(102,126,234,.1);min-height:500px;display:flex;flex-direction:column}.detail-header{display:flex;align-items:center;gap:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.detail-icon{font-size:4rem;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 12px #667eea4d}.detail-header h3{margin:0;font-size:2rem;font-weight:800;color:#2d3748;font-family:Cinzel,serif}.detail-subtitle{color:#718096;font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.dark-mode .detail-header{border-bottom-color:#4a5568}.dark-mode .detail-header h3{color:#e2e8f0}.dark-mode .detail-subtitle{color:#cbd5e0}.detail-content{flex:1}.detail-description{font-size:1.05rem;line-height:1.7;color:#4a5568;margin-bottom:2rem;padding-left:1rem;border-left:3px solid #667eea}.dark-mode .detail-description{color:#cbd5e0}.detail-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-stat-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);padding:1.25rem;border-radius:12px;border:1px solid #e2e8f0;transition:all .2s ease}.detail-stat-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.detail-stat-label{font-size:.85rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.dark-mode .detail-stat-card{background:linear-gradient(135deg,#1a202c,#2d3748);border-color:#4a5568}.dark-mode .detail-stat-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.dark-mode .detail-stat-label{color:#cbd5e0}.detail-stat-value{font-size:1.25rem;font-weight:700;color:#2d3748}.dark-mode .detail-stat-value{color:#e2e8f0}.detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#a0aec0}.placeholder-icon{font-size:5rem;margin-bottom:1rem;opacity:.3}.detail-placeholder p{font-size:1.1rem;font-weight:600;color:#718096}.dark-mode .detail-placeholder p{color:#cbd5e0}.selection-detail .features-list{margin-top:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0}.selection-detail .features-header{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;text-transform:uppercase;letter-spacing:.5px}.selection-detail .feature-item{padding:1rem;background:#fff;border-radius:8px;margin-bottom:.75rem;border-left:3px solid #667eea}.selection-detail .feature-item:last-child{margin-bottom:0}.selection-detail .feature-name{font-weight:700;color:#2d3748;margin-bottom:.5rem;font-size:1.05rem}.selection-detail .feature-desc{color:#4a5568;line-height:1.6;font-size:.95rem}.selection-detail .feature-box{margin-top:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;padding:1.25rem;border:1px solid #e2e8f0;border-left:3px solid #667eea}.selection-detail .feature-box .feature-name{font-weight:700;color:#2d3748;margin-bottom:.5rem;font-size:1.05rem}.selection-detail .feature-box .feature-desc{color:#4a5568;line-height:1.6;font-size:.95rem}.dark-mode .selection-detail{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .selection-detail .features-list{background:linear-gradient(135deg,#1a202c,#2d3748);border-color:#4a5568}.dark-mode .selection-detail .feature-item{background:#2d3748;border-left-color:#667eea}.dark-mode .selection-detail .feature-box{background:linear-gradient(135deg,#1a202c,#2d3748);border-color:#4a5568;border-left-color:#667eea}.dark-mode .selection-detail .feature-name,.dark-mode .selection-detail .feature-box .feature-name{color:#e2e8f0}.dark-mode .selection-detail .feature-desc,.dark-mode .selection-detail .feature-box .feature-desc{color:#cbd5e0}.dark-mode .selection-detail .features-header{color:#e2e8f0}.detail-stat-value.damage{background:linear-gradient(135deg,#f687b3,#f56565);color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:700}.carousel-section{margin:2.5rem 0}.subclass-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #e2e8f0;animation:slideDown .4s ease-out}.carousel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.carousel-header h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0}.required-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#fed7d7,#feb2b2);color:#742a2a;border-radius:20px;font-size:.875rem;font-weight:700;box-shadow:0 2px 6px #e53e3e33}.validated-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d;border-radius:20px;font-size:.875rem;font-weight:700;box-shadow:0 2px 6px #48bb7833}.required-badge-inline,.validated-badge-inline{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:700}.required-badge-inline{color:#f56565}.validated-badge-inline{color:#48bb78}.input-with-validation{position:relative}.trait-validation-header,.experiences-validation-header,.domain-validation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem}.domain-validation-header{flex-wrap:wrap;gap:.5rem}.completed-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d;border-radius:20px;font-size:.875rem;font-weight:700;box-shadow:0 2px 6px #48bb7833}.carousel-container{position:relative;display:flex;align-items:center;gap:1rem}.carousel-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-behavior:smooth;padding:1rem .5rem;flex:1;scrollbar-width:thin;scrollbar-color:#cbd5e0 #f7fafc}.carousel-track::-webkit-scrollbar{height:8px}.carousel-track::-webkit-scrollbar-track{background:#f7fafc;border-radius:10px}.carousel-track::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px}.carousel-track::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#764ba2,#667eea)}.carousel-button{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:2rem;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #667eea4d;transition:all .3s ease;z-index:10}.carousel-button:hover{transform:scale(1.1);box-shadow:0 6px 16px #667eea66}.carousel-button:active{transform:scale(.95)}.carousel-card{flex:0 0 420px;min-height:360px;padding:0;border-radius:24px;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#fff,#f7fafc);box-shadow:0 8px 24px #0000001f,0 2px 6px #00000014;position:relative;overflow:hidden;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.8)}.carousel-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eea0d,#764ba20d);opacity:0;transition:opacity .4s ease;pointer-events:none}.carousel-card:after{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .4s ease}.carousel-card:hover{transform:translateY(-12px) scale(1.03);box-shadow:0 20px 40px #667eea40,0 8px 16px #00000026;border-color:#667eea4d}.carousel-card:hover:before,.carousel-card:hover:after{opacity:1}.carousel-card.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);box-shadow:0 12px 24px #667eea4d;transform:translateY(-4px) scale(1.05);border:3px solid transparent;background-clip:padding-box;position:relative}.carousel-card.selected:before{opacity:1;height:8px}.carousel-card.selected:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:20px;padding:3px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.card-header-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;font-size:1.6rem;font-weight:800;text-align:center;letter-spacing:1px;font-family:Cinzel,serif;text-transform:uppercase;position:relative;box-shadow:0 4px 12px #0003}.card-header-badge:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);pointer-events:none}.card-image-placeholder{width:100%;height:180px;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#ffffff4d}.card-image-placeholder:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.card-image-overlay{position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);display:flex;align-items:flex-end;padding:.75rem 1rem}.card-image-title{color:#fff;font-size:1.3rem;font-weight:700;font-family:Cinzel,serif;text-shadow:0 2px 4px rgba(0,0,0,.5)}.card-content{padding:1.75rem;flex:1;display:flex;flex-direction:column;gap:1.25rem;background:linear-gradient(to bottom,#fff,#fafbfc)}.card-description{color:#4a5568;line-height:1.7;font-size:.975rem;flex:1;font-weight:500;position:relative;padding-left:1rem}.card-description:before{content:"";position:absolute;left:0;top:.25rem;bottom:.25rem;width:3px;background:linear-gradient(180deg,#667eea,#764ba2);border-radius:2px}.card-stats{display:flex;flex-direction:column;gap:.75rem;margin-top:auto}.stat-row{display:flex;gap:.75rem}.stat-item{display:flex;flex-direction:column;gap:.25rem;flex:1}.stat-label{font-size:.75rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.05rem;font-weight:700;color:#2d3748;padding:.625rem .75rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:10px;text-align:center;box-shadow:0 2px 6px #00000014,inset 0 1px 2px #ffffff80;border:1px solid rgba(102,126,234,.1);transition:all .2s ease}.carousel-card:hover .stat-value{border-color:#667eea4d;box-shadow:0 3px 8px #0000001f,inset 0 1px 2px #ffffff80}.selected-indicator{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;padding:1rem;text-align:center;font-weight:800;font-size:1.1rem;letter-spacing:1px;text-transform:uppercase;font-family:Cinzel,serif;box-shadow:0 -4px 12px #48bb784d;position:relative}.selected-indicator:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%);pointer-events:none}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.selection-card{padding:2rem;border:none;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#fff,#f7fafc);box-shadow:0 4px 6px #00000012;position:relative;overflow:hidden}.selection-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .3s ease}.selection-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.selection-card:hover:before{opacity:1}.selection-card.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);box-shadow:0 8px 16px #667eea40;transform:translateY(-2px)}.selection-card.selected:before{opacity:1;height:6px}.selection-card h3,.selection-card h4{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:.75rem}.selection-card p{color:#4a5568;line-height:1.6}.heritage-card{flex:0 0 400px;min-height:320px}.features-list{margin-top:1rem}.features-header{font-size:.875rem;font-weight:700;color:#667eea;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.feature-item{margin-bottom:.75rem;padding:.75rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.feature-name{font-weight:700;color:#2d3748;margin-bottom:.25rem;font-size:.95rem}.feature-desc{color:#4a5568;font-size:.875rem;line-height:1.5}.equipment-card{flex:0 0 360px;min-height:300px}.equipment-stats{display:flex;flex-direction:column;gap:.75rem}.equipment-hint{color:#718096;font-size:.9rem;font-style:italic;margin-top:.5rem;margin-bottom:1rem}.stat-value.damage{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.feature-box{margin-top:.75rem;padding:.75rem;background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-radius:8px;border-left:3px solid #667eea}.feature-box .feature-name{font-size:.875rem;font-weight:700;color:#667eea;margin-bottom:.25rem}.feature-box .feature-desc{font-size:.825rem;color:#4a5568;line-height:1.4}.trait-assignment{margin-top:1.5rem}.available-modifiers{margin-bottom:2.5rem;text-align:center;padding:2rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px;box-shadow:0 4px 12px #0000000d}.available-modifiers.compact{margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.available-modifiers.compact .modifier-label{font-weight:600;color:#4a5568;font-size:.95rem}.available-modifiers h3{color:#2d3748;font-size:1.3rem;font-weight:700;margin-bottom:1.25rem}.modifier-pool{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;align-items:center}.available-modifiers.compact .modifier-pool{gap:.5rem;min-height:auto}.modifier-badge{padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:14px;font-weight:700;font-size:1.2rem;box-shadow:0 4px 12px #667eea59;animation:pulse 2s ease-in-out infinite;display:inline-block}.all-assigned-message{padding:.875rem 1.75rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-radius:14px;font-weight:700;font-size:1.2rem;box-shadow:0 4px 12px #48bb7859;display:inline-block}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 4px 12px #667eea59}50%{transform:scale(1.05);box-shadow:0 6px 16px #667eea80}}.trait-list{display:flex;flex-direction:column;gap:1rem}.trait-row{display:flex;flex-direction:column;gap:1rem;padding:1.75rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;box-shadow:0 2px 8px #0000000f;transition:all .3s ease;border:2px solid transparent}.trait-row:hover{box-shadow:0 6px 16px #0000001a;border-color:#667eea33}.trait-info{display:flex;justify-content:space-between;align-items:center;gap:1rem}.trait-name{font-weight:600;color:#2d3748;font-size:1.1rem;flex:1}.current-value{font-weight:700;font-size:1.4rem;color:#fff;padding:.5rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 2px 8px #667eea4d;min-width:70px;text-align:center}.modifier-selector{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.modifier-button{padding:.875rem 1.5rem;border:2px solid #e2e8f0;background:#fff;border-radius:12px;cursor:pointer;transition:all .2s ease;font-weight:700;font-size:1.1rem;min-width:70px;box-shadow:0 2px 4px #0000000d}.modifier-button:hover:not(:disabled){border-color:#667eea;background:linear-gradient(135deg,#e0e7ff,#ede9fe);transform:translateY(-2px);box-shadow:0 4px 10px #667eea40}.modifier-button.selected{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-color:transparent;box-shadow:0 4px 12px #48bb7866;transform:scale(1.05)}.modifier-button.unavailable{opacity:.3;cursor:not-allowed;background:#f7fafc}.modifier-button:disabled{cursor:not-allowed}.dark-mode .modifier-button{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .modifier-button:hover:not(:disabled){background:linear-gradient(135deg,#2c5282,#434190);border-color:#667eea}.success-message{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border-radius:16px;text-align:center;box-shadow:0 4px 12px #48bb7833}.success-message p{color:#22543d;font-weight:700;font-size:1.2rem;margin:0}.modifier-hint{text-align:center;color:#718096;font-size:.9rem;font-style:italic;margin-top:.75rem}.modifier-badge.clickable{cursor:pointer;transition:all .2s ease}.modifier-badge.clickable:hover{transform:scale(1.1);box-shadow:0 6px 18px #667eea80}.trait-list.two-column{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.trait-row.compact{padding:1.25rem}.trait-row.compact .trait-info{margin-bottom:.75rem}.trait-row.compact .modifier-selector{justify-content:flex-start;gap:.5rem}.modifier-button.available{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;min-width:55px;padding:.625rem 1rem;font-size:1rem}.modifier-button.available:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #667eea66}.modifier-button.selected{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;min-width:70px}.modifier-button.selected:hover{background:linear-gradient(135deg,#f093fb,#f5576c)}.potion-selection{margin:2.5rem 0;padding:2rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px}.potion-header{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem}.potion-selection h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0;text-align:center}.potion-options{display:flex;gap:1.5rem;margin-top:1rem}.potion-button{flex:1;padding:1.75rem;border:3px solid #e2e8f0;background:#fff;border-radius:16px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem;box-shadow:0 4px 8px #0000000f}.potion-button:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001f;border-color:#667eea}.potion-button.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:#667eea;box-shadow:0 8px 16px #667eea40;transform:translateY(-2px)}.potion-icon{font-size:3rem}.potion-name{font-size:1.1rem;font-weight:700;color:#2d3748}.potion-effect{font-size:.9rem;color:#718096;font-style:italic}.starting-inventory{margin:2.5rem 0;padding:2rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px}.starting-inventory h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.inventory-item{padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 6px #0000000d;font-weight:600;color:#4a5568;text-align:center;transition:all .2s ease}.inventory-item:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0000001a}.inventory-item.highlight{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d;font-weight:700}.dark-mode .inventory-item{background:#2d3748;color:#e2e8f0;border-color:#4a5568}.dark-mode .inventory-item.highlight{background:linear-gradient(135deg,#c6f6d54d,#9ae6b44d);color:#9ae6b4}.background-form{display:flex;flex-direction:column;gap:2rem}.form-field{display:flex;flex-direction:column;gap:.75rem}.form-field label{font-weight:600;display:flex;justify-content:space-between;align-items:center;color:#2d3748;font-size:1.05rem}.required-indicator{color:#f56565;font-weight:700;margin-left:.25rem}.suggest-button{padding:.5rem 1rem;font-size:.9rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;cursor:pointer;box-shadow:0 2px 8px #f5576c4d;transition:all .2s ease;font-weight:600}.suggest-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.form-field input,.form-field textarea{padding:1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff;width:100%;max-width:100%}.background-form .form-field input,.background-form .form-field textarea,.connections-form .form-field input,.connections-form .form-field textarea,.connections-form .question-field textarea,.connections-form .connection-field textarea{max-width:100%;width:100%}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-field textarea{resize:vertical;min-height:120px}.experiences-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-top:2rem}.experience-card{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:2rem;box-shadow:0 4px 12px #00000014;border:1px solid rgba(102,126,234,.1);transition:all .3s ease}.experience-card:hover{box-shadow:0 8px 24px #667eea26;transform:translateY(-2px)}.experience-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.experience-card-header h3{margin:0;font-size:1.5rem;font-weight:700;color:#2d3748;font-family:Cinzel,serif}.experience-modifier{display:inline-block;margin-top:.5rem;padding:.4rem 1rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-radius:20px;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.suggest-button{padding:.6rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d;font-size:.9rem}.suggest-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.experience-card-content{display:flex;flex-direction:column;gap:1rem}.experience-input{width:100%;padding:1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s ease;background:#fff}.experience-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.suggestions{margin-top:.5rem}.suggestions-summary{padding:.75rem 1rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:10px;cursor:pointer;font-weight:600;color:#4a5568;transition:all .2s ease;border:1px solid #e2e8f0}.suggestions-summary:hover{background:linear-gradient(135deg,#edf2f7,#e2e8f0);border-color:#667eea}.suggestion-categories{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem;padding:1rem;background:#fff;border-radius:10px;border:1px solid #e2e8f0}.suggestion-category{display:flex;flex-direction:column;gap:.75rem}.suggestion-category strong{color:#2d3748;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.suggestion-tags{display:flex;flex-wrap:wrap;gap:.75rem}.suggestion-tag{padding:.6rem 1rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000f;font-weight:500;color:#4a5568;font-size:.9rem;border:1px solid #e2e8f0}.suggestion-tag:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d;border-color:transparent}.domain-cards-selection{margin-top:1.5rem}.domain-section{margin-bottom:2.5rem}.domain-section h3,.domain-section-title{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1rem;display:inline-block;padding-bottom:.5rem;border-bottom:3px solid;border-image:linear-gradient(90deg,#667eea,#764ba2) 1}.dark-mode .domain-section h3,.dark-mode .domain-section-title{color:#e2e8f0;border-image:linear-gradient(90deg,#667eea,#764ba2) 1}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem}.domain-card{padding:1.75rem;border:none;border-radius:16px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#fff,#f7fafc);box-shadow:0 4px 6px #00000012;position:relative;overflow:hidden}.domain-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .3s ease}.domain-card:hover:not(.disabled){transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.domain-card:hover:not(.disabled):before{opacity:1}.domain-card.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);box-shadow:0 8px 16px #667eea40;transform:translateY(-2px)}.domain-card.selected:before{opacity:1;height:6px}.domain-card.disabled{opacity:.5;cursor:not-allowed}.card-header{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.9rem;color:#718096;font-weight:600}.domain-card h4{color:#2d3748;font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.card-type{font-style:italic;color:#718096;margin:.5rem 0;font-size:.95rem}.card-feature{margin-top:.75rem;font-size:.95rem;color:#4a5568;line-height:1.6}.dark-mode .domain-card{background:linear-gradient(135deg,#2d3748,#1a202c);box-shadow:0 4px 6px #0000004d}.dark-mode .domain-card:hover:not(.disabled){box-shadow:0 12px 24px #0006}.dark-mode .domain-card.selected{background:linear-gradient(135deg,#3d4a5c,#2d3748);box-shadow:0 8px 16px #667eea4d}.dark-mode .domain-card h4{color:#e2e8f0}.dark-mode .card-header,.dark-mode .card-level,.dark-mode .card-recall{color:#a0aec0}.dark-mode .info-text{color:#cbd5e0}.character-sheet{max-width:1400px;margin:2rem auto;padding:3rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:24px;box-shadow:0 20px 60px #0000004d;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.unsaved-banner{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 12px #f59e0b33;flex-wrap:wrap;gap:1rem}.unsaved-message{display:flex;align-items:center;gap:.75rem;flex:1 1 auto;min-width:200px}.unsaved-actions{display:flex;align-items:center;gap:1rem;flex-wrap:nowrap;flex-shrink:0;max-width:100%}.unsaved-actions .random-button{padding:.75rem;font-size:1.5rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #f5576c4d;transition:all .3s ease;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:48px;height:48px;box-sizing:border-box}.unsaved-actions .random-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5576c66}.dark-mode .unsaved-actions .random-button{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 15px #f5576c4d}.dark-mode .unsaved-actions .random-button:hover{box-shadow:0 6px 20px #f5576c66}.unsaved-actions .previous-button{padding:1rem 2rem;font-size:1.1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #667eea4d;transition:all .3s ease;font-weight:600;white-space:nowrap;display:flex;align-items:center;justify-content:center;flex-shrink:0;max-width:100%;box-sizing:border-box}.unsaved-actions .previous-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.unsaved-icon{font-size:1.25rem}.unsaved-actions .save-character-button{padding:1rem 2rem;font-size:1.1rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #48bb784d;transition:all .3s ease;font-weight:600;white-space:nowrap;display:flex;align-items:center;justify-content:center;flex-shrink:0;max-width:100%;box-sizing:border-box}.save-character-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.save-character-button:disabled{opacity:.6;cursor:not-allowed}.dark-mode .unsaved-banner{background:linear-gradient(135deg,#78350f,#92400e);border-color:#f59e0b}.dark-mode .unsaved-message{color:#fde68a}.dark-mode .unsaved-actions .previous-button{background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 4px 15px #4299e14d}.dark-mode .unsaved-actions .previous-button:hover{box-shadow:0 6px 20px #4299e166}.dark-mode .unsaved-actions .save-character-button{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 4px 15px #48bb784d}.dark-mode .unsaved-actions .save-character-button:hover:not(:disabled){box-shadow:0 6px 20px #48bb7866}.sheet-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:3px solid;border-image:linear-gradient(90deg,#667eea,#764ba2) 1}.sheet-header-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:2rem}.character-avatar-display{flex-shrink:0;position:relative;width:120px;height:120px;display:inline-block}.character-avatar-image{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #667eea;box-shadow:0 4px 12px #667eea4d;display:block}.character-avatar-edit-overlay{position:absolute;top:0;left:0;width:120px;height:120px;border-radius:50%;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;pointer-events:none}.character-avatar-display:hover .character-avatar-edit-overlay{opacity:1;pointer-events:auto}.character-avatar-edit-controls{display:flex;flex-direction:column;gap:.5rem;align-items:center}.character-avatar-edit-button{padding:.4rem .8rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:transform .2s}.character-avatar-edit-button:hover:not(:disabled){transform:translateY(-2px)}.character-avatar-edit-button:disabled{opacity:.6;cursor:not-allowed}.character-avatar-edit-button.remove{background:#e53e3e}.character-avatar-edit-button.remove:hover:not(:disabled){background:#c53030}.character-avatar-placeholder-edit{width:auto;min-width:280px;max-width:100%;min-height:auto;border-radius:12px;border:2px solid #667eea;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);position:relative}.character-avatar-placeholder-edit .character-avatar-add-button{margin-bottom:.5rem}.character-avatar-placeholder-edit .restriction-text{color:#fff;font-size:.75rem;line-height:1.4;text-align:center;margin:0;opacity:.95}.character-avatar-placeholder-edit .restriction-text strong{font-weight:600;display:block;margin-bottom:.25rem}.character-avatar-placeholder-edit .avatar-error-message{background:#e53e3ef2;color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.8rem;text-align:center;margin-top:.5rem;max-width:100%;word-wrap:break-word;border:1px solid rgba(255,255,255,.3)}.character-avatar-add-button{padding:.6rem 1.2rem;background:#fff;color:#667eea;border:2px solid white;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #00000026}.character-avatar-add-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000040;background:#f7fafc}.character-avatar-add-button:active:not(:disabled){transform:translateY(0)}.character-avatar-add-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.character-avatar-add-trigger{position:absolute;bottom:-4px;right:-4px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:3px solid white;border-radius:50%;width:40px;height:40px;font-size:1.2rem;font-weight:400;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;line-height:1;box-shadow:0 4px 12px #667eea66;z-index:10}.character-avatar-add-trigger:hover{transform:scale(1.15) rotate(5deg);box-shadow:0 6px 16px #667eea99;background:linear-gradient(135deg,#764ba2,#667eea)}.character-avatar-add-trigger:active{transform:scale(1.05) rotate(0)}.sheet-header-text{flex:1}.sheet-header-main h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:3rem;font-weight:800;font-family:Cinzel,serif;margin:0 0 .25rem;text-transform:uppercase;letter-spacing:1px}.sheet-header-info{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.sheet-level{padding:.5rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px}.sheet-ancestry-community{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.sheet-class-subclass{color:#4a5568;font-weight:600;font-size:1.1rem;font-style:italic}.multiclass-badge{color:#667eea;font-weight:700;margin-left:.5rem}.dark-mode .sheet-class-subclass{color:#cbd5e0}.dark-mode .multiclass-badge{color:#90cdf4}.sheet-header-details{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:1rem}.sheet-ancestry,.sheet-community,.sheet-pronouns{padding:.4rem 1rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;font-weight:600;color:#4a5568;font-size:.95rem}.sheet-content{display:flex;flex-direction:column;gap:2rem}.sheet-main-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.sheet-column-left,.sheet-column-right{display:flex;flex-direction:column;gap:2rem}.sheet-section{padding:2rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;box-shadow:0 4px 12px #00000014;border:1px solid rgba(102,126,234,.1)}.sheet-section.experiences-section{padding:1.25rem 1.5rem}.sheet-section h2{margin-bottom:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.75rem;font-weight:700;font-family:Cinzel,serif;text-transform:uppercase;letter-spacing:.5px;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0}.sheet-section.experiences-section h2{margin-bottom:.75rem;font-size:1.5rem;padding-bottom:.5rem}.traits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.trait-item{padding:1.25rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border:1px solid #e2e8f0;transition:all .2s ease}.trait-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.trait-name{font-weight:700;color:#2d3748;font-size:1.1rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.trait-value{font-size:2rem;font-weight:800;color:#667eea;margin-bottom:.5rem}.trait-actions{font-size:.85rem;color:#718096;font-style:italic}.combat-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.combat-stat{padding:1.25rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border:1px solid #e2e8f0;text-align:center}.combat-stat-label{font-size:.9rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.combat-stat-value{font-size:1.75rem;font-weight:800;color:#2d3748}.thresholds-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.threshold-item{padding:1.25rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border:1px solid #e2e8f0;text-align:center}.threshold-label{font-size:.9rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.threshold-value{font-size:2rem;font-weight:800;color:#f56565;margin-bottom:.5rem}.threshold-desc{font-size:.85rem;color:#718096}.equipment-list{display:flex;flex-direction:column;gap:1rem}.equipment-item{padding:1rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:10px;border-left:3px solid #667eea}.equipment-label{font-weight:700;color:#2d3748;margin-bottom:.5rem;text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.equipment-value{color:#4a5568;font-size:.95rem}.equipment-value .empty{color:#a0aec0;font-style:italic}.domain-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.domain-cards-subsection{margin-bottom:2rem}.domain-cards-subsection:last-child{margin-bottom:0}.domain-cards-subsection h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #667eea}.domain-cards-vault{margin-top:2.5rem;padding-top:2rem;border-top:2px solid #e2e8f0}.dark-mode .domain-cards-subsection h3{color:#e2e8f0}.dark-mode .domain-cards-vault{border-top-color:#4a5568}.domain-card-display{padding:1.5rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:12px;border-left:4px solid;border-image:linear-gradient(180deg,#667eea,#764ba2) 1;box-shadow:0 4px 12px #00000014;transition:all .2s ease}.domain-card-display:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea33}.domain-card-header h4{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#2d3748;font-family:Cinzel,serif}.domain-card-meta{font-size:.85rem;color:#718096;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.domain-card-body{margin-top:1rem}.domain-card-feature{color:#4a5568;line-height:1.6;margin-bottom:.75rem}.domain-card-recall{font-size:.9rem;color:#667eea;font-weight:600}.experiences-list{display:flex;flex-direction:column;gap:.5rem}.experience-display{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;border-left:3px solid #48bb78}.experience-name{font-weight:700;color:#2d3748;font-size:.95rem}.experience-modifier{padding:.35rem .75rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-radius:16px;font-weight:700;font-size:.9rem}.inventory-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.inventory-items h3,.inventory-gold h3{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.inventory-items ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.inventory-items li{padding:.75rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;color:#4a5568}.gold-display{display:flex;flex-direction:column;gap:.75rem}.gold-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px}.gold-label{font-weight:600;color:#4a5568}.gold-value{font-weight:700;color:#f6ad55;font-size:1.1rem}.class-features-content{display:flex;flex-direction:column;gap:2rem}.feature-group{padding:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border:1px solid #e2e8f0;margin-bottom:1.5rem}.feature-group h3{margin:0 0 1.25rem;font-size:1.25rem;font-weight:700;color:#2d3748;font-family:Cinzel,serif;text-transform:uppercase;letter-spacing:.5px;padding-bottom:.75rem;border-bottom:2px solid #667eea}.feature-group.multiclass-features{border-left:4px solid #667eea;background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.feature-item{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #e2e8f0}.feature-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.feature-item-label{font-size:.9rem;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.feature-item-value{color:#4a5568;line-height:1.6;font-size:.95rem}.sheet-actions{display:flex;gap:1.5rem;justify-content:center;margin-top:2.5rem;padding-top:2rem;border-top:3px solid;border-image:linear-gradient(90deg,#667eea,#764ba2) 1}.sheet-actions button{padding:1rem 2rem;font-size:1.1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #667eea4d;transition:all .3s ease;font-weight:600}.sheet-actions button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.info-note{color:#718096;font-size:.9rem;margin-left:.5rem;font-style:italic}.step-content h3{color:#2d3748;font-size:1.4rem;font-weight:700;margin-top:2rem;margin-bottom:1rem}.dark-mode .background-questions h3,.dark-mode .party-connections h3{color:#e2e8f0}.expansion-selector{margin-bottom:20px;padding:15px;border:1px solid #e2e8f0;border-radius:8px;background:#fff}.expansion-selector h4{margin-top:0;margin-bottom:10px;color:#2d3748;font-size:1.1rem;font-weight:600}.expansion-checkboxes{display:flex;flex-wrap:wrap;gap:15px}.expansion-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;color:#2d3748;font-size:.95rem}.expansion-checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:#667eea}.expansion-checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.expansion-checkbox-label.locked{opacity:.8;position:relative}.locked-badge{margin-left:4px;font-size:14px;opacity:.7}.expansion-icon-large{font-size:18px}.dark-mode .expansion-selector{background:#2d3748;border-color:#4a5568}.dark-mode .expansion-selector h4,.dark-mode .expansion-checkbox-label{color:#e2e8f0}.dark-mode .expansion-checkbox-label.locked{opacity:.7}@media (max-width: 768px){html{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}body{-webkit-overflow-scrolling:touch;overflow-x:hidden}.character-creation,.character-sheet{margin:.5rem;padding:1rem;border-radius:16px}.sheet-main-grid{grid-template-columns:1fr}.sheet-header-main{flex-direction:column;gap:1rem}.sheet-header-main h1{font-size:2rem}.sheet-header-info{align-items:flex-start}.traits-grid,.combat-stats-grid,.thresholds-grid,.inventory-content,.domain-cards-grid,.list-detail-container,.experiences-grid{grid-template-columns:1fr}.creation-header{flex-direction:column;gap:1rem}.creation-header h1{font-size:2rem}.carousel-button{width:40px;height:40px;font-size:1.5rem}.carousel-card{flex:0 0 300px;min-height:260px}.card-header-badge{font-size:1.2rem;padding:1rem}.selection-grid,.weapon-grid,.armor-grid,.cards-grid{grid-template-columns:1fr}.trait-row{flex-direction:column;align-items:flex-start}.trait-info{width:100%}.trait-row label{min-width:auto}.current-value{margin-left:0}.step-navigation{flex-direction:column;gap:.75rem}.step-navigation button{max-width:100%;width:100%;padding:1.25rem 1.5rem;font-size:1rem;min-height:48px;-webkit-tap-highlight-color:rgba(102,126,234,.3);touch-action:manipulation}.step-content h2{font-size:1.5rem;margin-bottom:.5rem}.step-content>p{font-size:1rem;margin-bottom:1.5rem}.step-content-wrapper{min-height:auto;margin-bottom:1.5rem}input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{font-size:16px;-webkit-appearance:none;border-radius:8px}button,a,.clickable{min-height:44px;min-width:44px}.step-content,.character-creation{-webkit-overflow-scrolling:touch}.character-creation{scroll-margin-top:0;padding-top:1rem}.main-navigation{position:sticky;top:0;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.75rem 0}.dark-mode .main-navigation{background:#1a202cf2}.nav-container{padding:0 1rem;flex-wrap:nowrap;gap:.5rem}.desktop-nav{display:none}.mobile-menu-toggle{display:flex}.mobile-nav-menu{display:block}.nav-logo{font-size:1.25rem}.nav-actions{gap:.5rem}.theme-toggle{padding:.5rem;font-size:1.1rem}.creation-header{margin-bottom:1rem}.step-indicator{margin-bottom:1rem;gap:.5rem}.step-number{width:2rem;height:2rem;font-size:.9rem}.progress-bar{margin-bottom:1.5rem}.card,.domain-card,.weapon-card,.armor-card{padding:1rem}.form-field{margin-bottom:1.25rem}.form-field label{font-size:.95rem;margin-bottom:.5rem}.carousel-container{padding:.5rem}.carousel-card{min-width:280px}.selection-list,.weapon-list,.armor-list{gap:.75rem}.unsaved-banner{flex-direction:column;align-items:stretch}.unsaved-message{min-width:auto;margin-bottom:.5rem}.unsaved-actions{flex-direction:column;width:100%}.unsaved-actions .previous-button,.unsaved-actions .random-button,.unsaved-actions .save-character-button{width:100%;justify-content:center}.step-navigation.top{margin-bottom:1.5rem;padding-bottom:1rem}.step-navigation.bottom{margin-top:1.5rem;padding-top:1rem}.carousel-header{flex-direction:column;align-items:flex-start;gap:.75rem}.trait-list.two-column{grid-template-columns:1fr}.potion-options{flex-direction:column}.inventory-grid{grid-template-columns:1fr}}body.dark-mode{background:linear-gradient(135deg,#1a202c,#2d3748);color:#e2e8f0}.dark-mode .character-creation,.dark-mode .character-sheet{background:linear-gradient(135deg,#1a202c,#2d3748);box-shadow:0 20px 60px #0009}.dark-mode .main-navigation{background:linear-gradient(135deg,#1a202cf2,#2d3748f2);border-bottom-color:#4a5568}.dark-mode .nav-links a{color:#cbd5e0}.dark-mode .nav-links a:hover{color:#90cdf4;background:#4299e126}.dark-mode .nav-links a.active{color:#90cdf4;background:linear-gradient(135deg,#4299e133,#b794f433)}.dark-mode .nav-links a[href="/login"],.dark-mode .nav-links a[href="/register"]{color:#cbd5e0}.dark-mode .creation-header{border-bottom-color:#4a5568}.dark-mode .creation-header h1,.dark-mode .sheet-header-main h1{background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dark-mode .step-indicator-text{color:#cbd5e0}.dark-mode .step-subtitle{color:#a0aec0}.dark-mode .sheet-section{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .sheet-section h2{border-color:#4a5568}.dark-mode .trait-item,.dark-mode .combat-stat,.dark-mode .threshold-item,.dark-mode .equipment-item,.dark-mode .domain-card-display,.dark-mode .experience-display{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .trait-name,.dark-mode .combat-stat-value,.dark-mode .equipment-label,.dark-mode .experience-name{color:#e2e8f0}.dark-mode .trait-actions,.dark-mode .combat-stat-label,.dark-mode .threshold-label,.dark-mode .equipment-value,.dark-mode .domain-card-meta{color:#a0aec0}.dark-mode .domain-card-header h4{color:#e2e8f0}.dark-mode .sheet-ancestry,.dark-mode .sheet-community,.dark-mode .sheet-pronouns,.dark-mode .inventory-items li,.dark-mode .gold-item{background:linear-gradient(135deg,#2d3748,#1a202c);color:#cbd5e0}.dark-mode .inventory-items h3,.dark-mode .inventory-gold h3{color:#e2e8f0}.dark-mode .gold-label{color:#cbd5e0}.dark-mode .gold-value{color:#f6ad55}.dark-mode .feature-group{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .feature-group h3{color:#e2e8f0;border-color:#667eea}.dark-mode .feature-group.multiclass-features{background:linear-gradient(135deg,#2d3748,#1e3a5f);border-left-color:#667eea}.dark-mode .feature-item{border-color:#4a5568}.dark-mode .feature-item-label{color:#90cdf4}.dark-mode .feature-item-value{color:#cbd5e0}.dark-mode .step-title{background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dark-mode .step-number{color:#a0aec0}.dark-mode .list-header.invalid{border-bottom-color:#fc8181;background:linear-gradient(135deg,#fc81811a,#fc81810d)}.dark-mode .validation-error,.dark-mode .validation-error-banner,.dark-mode .validation-error-inline{color:#fc8181}.dark-mode .validation-error-banner{border-color:#fc8181;background:linear-gradient(135deg,#fc818126,#fc818114)}.dark-mode .invalid-input{border-color:#fc8181!important;background:linear-gradient(135deg,#1a202cf2,#fc81811a)!important}.dark-mode .validated-badge{color:#68d391;background:linear-gradient(135deg,#68d39126,#68d39114);border-color:#68d39166}.dark-mode .required-badge-inline{color:#fc8181}.dark-mode .validated-badge-inline{color:#68d391}.dark-mode .invalid-input:focus{border-color:#fc8181!important;box-shadow:0 0 0 3px #fc81814d!important}.dark-mode .progress-bar{background-color:#2d3748}.dark-mode .progress-fill{background:linear-gradient(90deg,#90cdf4,#b794f4);box-shadow:0 0 10px #90cdf480}.header-buttons{display:flex;gap:1rem;align-items:center}.theme-toggle{width:48px;height:48px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #667eea4d;transition:all .3s ease}.theme-toggle:hover{transform:scale(1.1) rotate(15deg);box-shadow:0 6px 16px #667eea66}.dark-mode .theme-toggle{background:linear-gradient(135deg,#f6ad55,#ed8936);box-shadow:0 4px 12px #f6ad554d}.dark-mode .theme-toggle:hover{box-shadow:0 6px 16px #f6ad5566}.dark-mode .validation-errors{background:linear-gradient(135deg,#742a2a,#9b2c2c);border-left-color:#fc8181;box-shadow:0 4px 12px #fc81814d}.dark-mode .validation-errors h3,.dark-mode .validation-errors li{color:#feb2b2}.dark-mode .debug-toggle{background:#4a5568;color:#e2e8f0}.dark-mode .debug-toggle:hover{background:#2d3748}.dark-mode .debug-panel{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .debug-panel h4{color:#e2e8f0}.dark-mode .debug-section{background:#1a202c;border-color:#4a5568}.dark-mode .debug-section h5{color:#e2e8f0;border-color:#667eea}.dark-mode .debug-item{border-color:#2d3748}.dark-mode .debug-label{color:#a0aec0}.dark-mode .debug-value{color:#68d391}.dark-mode .debug-missing{color:#fc8181}.dark-mode .debug-trait-item{background:#2d3748}.dark-mode .step-navigation{border-color:#4a5568}.dark-mode .step-navigation button{background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 4px 15px #4299e14d}.dark-mode .step-navigation button:hover:not(:disabled){box-shadow:0 6px 20px #4299e166}.dark-mode .step-navigation button.next-button{background:linear-gradient(135deg,#48bb78,#38a169)}.dark-mode .step-navigation button:disabled{background:#4a5568}.dark-mode .carousel-section{border-top-color:#4a5568}.dark-mode .carousel-header h3{color:#e2e8f0}.dark-mode .carousel-track::-webkit-scrollbar-track{background:#2d3748}.dark-mode .carousel-track::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#4299e1,#667eea)}.dark-mode .carousel-button{background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 4px 12px #4299e14d}.dark-mode .carousel-button:hover{box-shadow:0 6px 16px #4299e166}.dark-mode .carousel-card{background:linear-gradient(135deg,#2d3748,#1a202c);box-shadow:0 6px 12px #0000004d}.dark-mode .carousel-card:before{background:linear-gradient(90deg,#4299e1,#667eea)}.dark-mode .carousel-card:hover{box-shadow:0 16px 32px #0006}.dark-mode .carousel-card.selected{background:linear-gradient(135deg,#2c5282,#434190);box-shadow:0 12px 24px #4299e14d}.dark-mode .card-header-badge{background:linear-gradient(135deg,#4299e1,#667eea)}.dark-mode .card-description{color:#cbd5e0}.dark-mode .stat-value{color:#e2e8f0;background:#1a202c}.dark-mode .feature-item,.dark-mode .feature-box{background:#2d3748}.dark-mode .feature-name{color:#90cdf4}.dark-mode .feature-desc{color:#cbd5e0}.dark-mode .features-header{color:#90cdf4}.dark-mode .available-modifiers{background:linear-gradient(135deg,#2d3748,#1a202c);box-shadow:0 4px 12px #0000004d}.dark-mode .available-modifiers h3{color:#e2e8f0}.dark-mode .modifier-hint{color:#a0aec0}.dark-mode .modifier-badge{background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 4px 12px #4299e159}.dark-mode .trait-row{background:linear-gradient(135deg,#2d3748,#1a202c);box-shadow:0 2px 8px #0003;border-color:transparent}.dark-mode .trait-row:hover{box-shadow:0 6px 16px #0000004d;border-color:#4299e14d}.dark-mode .trait-name{color:#e2e8f0}.dark-mode .current-value{background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 2px 8px #4299e14d}.dark-mode .modifier-button.available{background:linear-gradient(135deg,#4299e1,#667eea)}.dark-mode .modifier-button.unavailable{background:#2d3748}.dark-mode .success-message{background:linear-gradient(135deg,#2f855a,#276749);box-shadow:0 4px 12px #48bb784d}.dark-mode .success-message p{color:#9ae6b4}.dark-mode .equipment-hint{color:#a0aec0}.dark-mode .potion-selection,.dark-mode .starting-inventory{background:linear-gradient(135deg,#2d3748,#1a202c)}.dark-mode .potion-selection h3,.dark-mode .starting-inventory h3{color:#e2e8f0}.dark-mode .potion-button{background:#2d3748;border-color:#4a5568;box-shadow:0 4px 8px #0003}.dark-mode .potion-button:hover{border-color:#4299e1;box-shadow:0 12px 24px #0000004d}.dark-mode .potion-button.selected{background:linear-gradient(135deg,#2c5282,#434190);border-color:#4299e1;box-shadow:0 8px 16px #4299e14d}.dark-mode .potion-name{color:#e2e8f0}.dark-mode .potion-effect{color:#a0aec0}.dark-mode .inventory-item{background:#2d3748;color:#cbd5e0;box-shadow:0 2px 6px #0003}.dark-mode .inventory-item:hover{box-shadow:0 4px 10px #0000004d}.dark-mode .inventory-item.highlight{background:linear-gradient(135deg,#2f855a,#276749);color:#9ae6b4}.dark-mode .form-field label{color:#e2e8f0}.dark-mode .form-field input,.dark-mode .form-field textarea{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .form-field input:focus,.dark-mode .form-field textarea:focus{border-color:#4299e1;box-shadow:0 0 0 3px #4299e133}.character-avatar-upload-section{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.character-avatar-preview-container{width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid #667eea;box-shadow:0 4px 12px #667eea33;flex-shrink:0}.character-avatar-preview{width:100%;height:100%;object-fit:cover}.character-avatar-placeholder{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff;border:4px solid #667eea;box-shadow:0 4px 12px #667eea4d;position:relative}.character-avatar-subclass-icon .subclass-icon-display{font-size:3.5rem;line-height:1;display:block}.character-avatar-upload-controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.character-avatar-upload-button{padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s;display:inline-block}.character-avatar-upload-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.character-avatar-upload-button:disabled{opacity:.6;cursor:not-allowed}.character-avatar-remove-button{padding:.6rem 1.2rem;background:#e53e3e;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.character-avatar-remove-button:hover:not(:disabled){background:#c53030}.character-avatar-remove-button:disabled{opacity:.6;cursor:not-allowed}.character-avatar-restrictions{margin-top:.75rem;padding:.75rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;width:100%}.character-avatar-restrictions .restriction-text{display:block;color:#4a5568;font-size:.85rem;line-height:1.6;margin-bottom:.5rem}.character-avatar-restrictions .restriction-text strong{color:#2d3748;font-weight:600}.avatar-error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:.5rem .75rem;border-radius:6px;font-size:.8rem;margin-top:.5rem;word-wrap:break-word}.dark-mode .character-avatar-preview-container{border-color:#667eea}.dark-mode .character-avatar-restrictions{background:#2d3748;border-color:#4a5568}.dark-mode .character-avatar-restrictions .restriction-text{color:#cbd5e0}.dark-mode .character-avatar-restrictions .restriction-text strong{color:#e2e8f0}.dark-mode .avatar-error-message{background:#e53e3e33;border-color:#e53e3e;color:#fc8181}.dark-mode .character-avatar-placeholder-edit .avatar-error-message{background:#e53e3ee6;border-color:#c53030;color:#fff}.dark-mode .character-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .character-avatar-image,.dark-mode .character-card-avatar{border-color:#667eea}.dark-mode .character-card-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .character-avatar-add-trigger{border-color:#2d3748;box-shadow:0 4px 12px #667eea80}.dark-mode .character-avatar-add-trigger:hover{box-shadow:0 6px 16px #667eeab3}.dark-mode .character-avatar-add-button{background:#2d3748;color:#e2e8f0;border-color:#4a5568;box-shadow:0 2px 8px #0000004d}.dark-mode .character-avatar-add-button:hover:not(:disabled){background:#374151;box-shadow:0 4px 12px #0006}.dark-mode .suggest-button{background:linear-gradient(135deg,#ed64a6,#d53f8c);box-shadow:0 2px 8px #ed64a64d}.dark-mode .suggest-button:hover{box-shadow:0 4px 12px #ed64a666}.dark-mode .experience-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .experience-card-header{border-color:#4a5568}.dark-mode .experience-card-header h3{color:#e2e8f0}.dark-mode .experience-input{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .experience-input:focus{border-color:#667eea}.dark-mode .suggestions-summary{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568;color:#cbd5e0}.dark-mode .suggestions-summary:hover{background:linear-gradient(135deg,#1a202c,#2d3748);border-color:#667eea}.dark-mode .suggestion-categories{background:#1a202c;border-color:#4a5568}.dark-mode .suggestion-category strong{color:#e2e8f0}.dark-mode .suggestion-tag{background:linear-gradient(135deg,#2d3748,#1a202c);color:#cbd5e0;border-color:#4a5568}.dark-mode .suggestion-tag:hover{background:linear-gradient(135deg,#4299e1,#667eea);color:#fff;box-shadow:0 4px 8px #4299e14d}.dark-mode .domain-section h3{color:#e2e8f0;border-image:linear-gradient(90deg,#4299e1,#667eea) 1}.dark-mode .card-type{color:#a0aec0}.dark-mode .card-feature{color:#cbd5e0}.dark-mode .sheet-section{background:linear-gradient(135deg,#2d3748,#1a202c);box-shadow:0 4px 6px #0003}.dark-mode .sheet-section h2{background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dark-mode .trait-item{background:#1a202c;box-shadow:0 2px 4px #0003}.dark-mode .domain-card-display{background:#1a202c;border-image:linear-gradient(180deg,#4299e1,#667eea) 1;box-shadow:0 2px 6px #0003}.dark-mode .domain-card-feature{color:#cbd5e0}.dark-mode .domain-card-recall{color:#90cdf4}.dark-mode .selection-card{background:linear-gradient(135deg,#2d3748,#1a202c);box-shadow:0 4px 6px #0003}.dark-mode .selection-card:before{background:linear-gradient(90deg,#4299e1,#667eea)}.dark-mode .selection-card:hover{box-shadow:0 12px 24px #0000004d}.dark-mode .selection-card.selected{background:linear-gradient(135deg,#2c5282,#434190);box-shadow:0 8px 16px #4299e14d}.dark-mode .selection-card h3,.dark-mode .selection-card h4{color:#e2e8f0}.dark-mode .selection-card p{color:#cbd5e0}.dark-mode .home h1,.dark-mode .character-library h2{color:#fff}.dark-mode .character-card{background:#2d3748;box-shadow:0 4px 6px #0003}.dark-mode .character-card:hover{box-shadow:0 10px 25px #0000004d}.dark-mode .character-card h3{background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dark-mode .character-card p{color:#cbd5e0}@media (max-width: 768px){.header-buttons{flex-direction:row;justify-content:space-between;width:100%}.theme-toggle{width:44px;height:44px;font-size:1.3rem}}.loading{text-align:center;padding:3rem;color:#718096;font-size:1.2rem}.error{padding:1.5rem;background:linear-gradient(135deg,#fed7d7,#feb2b2);border-radius:12px;color:#742a2a;margin:1rem 0;box-shadow:0 4px 6px #0000000d}.success{padding:1.5rem;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border-radius:12px;color:#22543d;margin:1rem 0;box-shadow:0 4px 6px #0000000d}.tables-container{max-width:1400px;margin:0 auto;padding:2rem}.tables-header{margin-bottom:2rem}.tables-header h1{font-size:2.5rem;font-weight:700;color:#2d3748;margin-bottom:.5rem;font-family:Cinzel,serif}.tables-subtitle{font-size:1.1rem;color:#718096;margin:0}.tables-nav{display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0;flex-wrap:wrap}.table-nav-link{padding:.75rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;text-decoration:none;color:#4a5568;font-weight:600;transition:all .2s ease;font-size:1rem}.table-nav-link:hover{border-color:#667eea;color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.table-nav-link.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.tables-content{margin-top:2rem}.tables-welcome{text-align:center;padding:4rem 2rem;color:#718096;font-size:1.2rem}.loot-generator{max-width:1200px;margin:0 auto}.generator-subtitle{color:#718096;margin-bottom:2rem}.dark-mode .generator-subtitle{color:#cbd5e0}.generator-controls{display:flex;gap:2rem;align-items:flex-end;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-weight:600;color:#4a5568;font-size:.9rem}.dark-mode .control-group label{color:#cbd5e0}.button-group{display:flex;gap:.5rem}.type-button{padding:.75rem 1.5rem;border:2px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;color:#4a5568}.type-button:hover{border-color:#667eea;color:#667eea}.type-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.dark-mode .type-button{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .type-button:hover{border-color:#667eea;color:#667eea}.dark-mode .type-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.rarity-select{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;font-weight:600}.dark-mode .rarity-select{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.generate-button{padding:.75rem 2rem;background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #f565654d}.generate-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f5656566}.generated-result{margin:2rem 0}.result-card{padding:2rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;background:#fff}.result-card.rarity-common{border-left:4px solid #a0aec0}.result-card.rarity-uncommon{border-left:4px solid #48bb78}.result-card.rarity-rare{border-left:4px solid #4299e1}.result-card.rarity-legendary{border-left:4px solid #ed8936}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.result-header h3{margin:0;font-size:1.5rem;color:#2d3748}.dark-mode .result-header h3{color:#e2e8f0}.result-roll{font-size:.9rem;color:#667eea;font-weight:600;margin-bottom:.75rem;padding:.5rem;background:#e6f3ff;border-radius:6px;display:inline-block}.rarity-badge{padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:700;text-transform:uppercase}.rarity-badge.rarity-common{background:#e2e8f0;color:#4a5568}.rarity-badge.rarity-uncommon{background:#c6f6d5;color:#22543d}.rarity-badge.rarity-rare{background:#bee3f8;color:#2c5282}.rarity-badge.rarity-legendary{background:#feebc8;color:#7c2d12}.dark-mode .rarity-badge.rarity-common{background:#e2e8f033;color:#e2e8f0}.dark-mode .rarity-badge.rarity-uncommon{background:#c6f6d533;color:#9ae6b4}.dark-mode .rarity-badge.rarity-rare{background:#bee3f833;color:#90cdf4}.dark-mode .rarity-badge.rarity-legendary{background:#feebc833;color:#fbd38d}.result-description{color:#4a5568;margin:.5rem 0}.dark-mode .result-description{color:#cbd5e0}.result-type{display:inline-block;margin-top:.5rem;padding:.3rem .8rem;background:#f7fafc;border-radius:6px;font-size:.85rem;color:#718096}.dark-mode .result-type{background:#2d374880;color:#cbd5e0}.loot-tables{margin-top:3rem}.loot-tables h2{font-size:2rem;color:#2d3748;margin-bottom:1.5rem;font-family:Cinzel,serif}.dark-mode .loot-tables h2{color:#e2e8f0}.loot-table-section{margin-bottom:2rem}.rarity-header{font-size:1.3rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.dark-mode .rarity-header{color:#e2e8f0;border-bottom-color:#4a5568}.loot-table-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.loot-table-item{padding:1rem;background:#fff;border-radius:8px;border:1px solid #e2e8f0}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.item-name{font-weight:700;color:#2d3748;flex:1}.item-roll{font-size:.85rem;color:#667eea;font-weight:600;padding:.25rem .5rem;background:#e6f3ff;border-radius:6px}.item-description{color:#718096;font-size:.9rem;margin-bottom:.5rem;line-height:1.5}.item-type{font-size:.85rem;color:#a0aec0}.beast-feast{max-width:1200px;margin:0 auto}.beast-feast h1{font-size:2.5rem;color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif}.dark-mode .beast-feast h1{color:#e2e8f0}.beast-feast h2{font-size:2rem;color:#2d3748;margin-top:3rem;margin-bottom:1rem;font-family:Cinzel,serif}.dark-mode .beast-feast h2{color:#e2e8f0}.beast-feast h3{font-size:1.5rem;color:#2d3748;margin-top:2rem;margin-bottom:1rem;font-weight:700}.dark-mode .beast-feast h3{color:#e2e8f0}.ingredient-generator-section{margin-bottom:4rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.dark-mode .ingredient-generator-section{background:#2d3748}.ingredient-tables{margin-top:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.ingredient-table-section{margin-bottom:2rem}.ingredient-table-section h3{font-size:1.3rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.dark-mode .ingredient-table-section h3{color:#e2e8f0;border-bottom-color:#4a5568}.ingredient-table-list{display:flex;flex-direction:column;gap:.5rem}.ingredient-table-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0}.dark-mode .ingredient-table-item{background:#2d374880;border-color:#4a5568}.ingredient-table-item .item-roll{min-width:2.5rem;text-align:center;font-weight:700;color:#667eea;padding:.25rem .5rem;background:#e6f3ff;border-radius:6px;font-size:.9rem}.dark-mode .ingredient-table-item .item-roll{background:#667eea33;color:#9f7aea}.ingredient-table-item .item-name{flex:1;color:#2d3748;font-weight:500}.dark-mode .ingredient-table-item .item-name{color:#e2e8f0}.table-description{font-size:.9rem;color:#718096;margin-bottom:1rem;font-style:italic}.dark-mode .table-description{color:#cbd5e0}.bloom-flavor-table{margin:2rem 0}.bloom-flavor-table table{width:100%;max-width:500px;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.dark-mode .bloom-flavor-table table{background:#2d3748}.bloom-flavor-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.bloom-flavor-table th{padding:1rem;text-align:left;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.bloom-flavor-table tbody tr{border-bottom:1px solid #e2e8f0}.dark-mode .bloom-flavor-table tbody tr{border-bottom-color:#4a5568}.bloom-flavor-table tbody tr:last-child{border-bottom:none}.bloom-flavor-table tbody tr:hover{background:#f7fafc}.dark-mode .bloom-flavor-table tbody tr:hover{background:#2d3748b3}.bloom-flavor-table td{padding:1rem;color:#2d3748;font-size:.95rem}.dark-mode .bloom-flavor-table td{color:#e2e8f0}.equipment-tables-section{margin-top:4rem}.equipment-table-section{margin-bottom:3rem}.equipment-table-section table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.dark-mode .equipment-table-section table{background:#2d3748}.equipment-table-section thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.equipment-table-section th{padding:1rem;text-align:left;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.equipment-table-section tbody tr{border-bottom:1px solid #e2e8f0}.dark-mode .equipment-table-section tbody tr{border-bottom-color:#4a5568}.equipment-table-section tbody tr:last-child{border-bottom:none}.equipment-table-section tbody tr:hover{background:#f7fafc}.dark-mode .equipment-table-section tbody tr:hover{background:#2d3748b3}.equipment-table-section td{padding:1rem;color:#2d3748;font-size:.95rem}.dark-mode .equipment-table-section td{color:#e2e8f0}.equipment-table-section td strong{color:#2d3748;font-weight:700}.dark-mode .equipment-table-section td strong{color:#e2e8f0}.adversary-table{max-width:1400px;margin:0 auto}.table-subtitle{color:#718096;margin-bottom:2rem}.dark-mode .table-subtitle{color:#cbd5e0}.table-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.table-stats{margin-bottom:1rem;color:#718096;font-size:.9rem}.dark-mode .table-stats{color:#cbd5e0}.adversary-table-container{overflow-x:auto}.adversary-data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.adversary-data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.adversary-data-table th{padding:1rem;text-align:left;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.adversary-data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.adversary-data-table th.sortable:hover{background:#ffffff1a}.adversary-data-table td{padding:1rem;border-bottom:1px solid #e2e8f0;vertical-align:top}.adversary-data-table tbody tr:hover{background:#f7fafc}.adversary-name-cell{min-width:200px}.adversary-description{font-size:.85rem;color:#718096;margin-top:.5rem}.attacks-list,.features-list{display:flex;flex-direction:column;gap:.5rem}.attack-item,.feature-item{font-size:.85rem;color:#4a5568}.environments-comparison{max-width:1600px;margin:0 auto;padding:2rem}.comparison-subtitle{color:#718096;margin-bottom:2rem}.dark-mode .comparison-subtitle{color:#cbd5e0}.environments-layout{display:grid;grid-template-columns:400px 1fr;gap:2rem;margin-top:2rem;align-items:stretch}.environments-sidebar{display:flex;flex-direction:column;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d;height:100%;max-height:calc(100vh - 200px);overflow-y:auto}.environments-list{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;flex:1;padding-right:.5rem}.environment-list-item{padding:1rem;background:#f7fafc;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s ease}.environment-list-item:hover{background:#edf2f7;border-color:#cbd5e0}.environment-list-item.selected{background:#e6f3ff;border-color:#667eea;box-shadow:0 2px 8px #667eea33}.environment-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.environment-list-header strong{color:#2d3748;font-size:1rem}.environment-list-meta{display:flex;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.type-badge{padding:.25rem .6rem;background:#e6f3ff;color:#2c5282;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.difficulty-badge{padding:.25rem .6rem;background:#fef5e7;color:#744210;border-radius:12px;font-size:.75rem;font-weight:600}.dark-mode .difficulty-badge{background:#f6ad5533;color:#f6ad55}.environment-list-description{color:#718096;font-size:.9rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.environment-details{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000d;height:100%;max-height:calc(100vh - 200px);overflow-y:auto;display:flex;flex-direction:column}.environment-detail-content{display:flex;flex-direction:column;gap:2rem}.environment-detail-header{display:flex;flex-direction:column;gap:1rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.environment-detail-header h2{margin:0;color:#2d3748;font-size:2rem;font-family:Cinzel,serif}.environment-detail-badges{display:flex;gap:.75rem;flex-wrap:wrap}.environment-detail-section{display:flex;flex-direction:column;gap:.75rem}.environment-detail-section h3{margin:0;color:#2d3748;font-size:1.3rem;font-family:Cinzel,serif;font-weight:700}.environment-detail-section p{margin:0;color:#4a5568;line-height:1.6}.impulses-text{font-style:italic;color:#718096}.dark-mode .impulses-text{color:#cbd5e0}.difficulty-text{font-weight:600;color:#2d3748;font-size:1.1rem}.dark-mode .difficulty-text{color:#e2e8f0}.adversaries-list{margin:0;padding-left:1.5rem;list-style:disc}.adversaries-list li{margin:.5rem 0;color:#4a5568;line-height:1.5}.dark-mode .adversaries-list li{color:#cbd5e0}.no-selection{text-align:center;padding:4rem 2rem;color:#718096;font-size:1.1rem}.no-results{text-align:center;padding:2rem;color:#718096;font-size:.95rem}.feature-questions{margin-top:.75rem;padding:.75rem;background:#fef5e7;border-radius:8px;border-left:3px solid #f6ad55}.feature-questions em{display:block;margin-bottom:.5rem;color:#744210;font-weight:600}.feature-questions ul{margin:0;padding-left:1.5rem;list-style:disc}.feature-questions li{margin:.25rem 0;color:#744210;line-height:1.5}.dark-mode .environments-sidebar,.dark-mode .environment-details{background:#2d3748;color:#e2e8f0}.dark-mode .environment-list-item{background:#4a5568;color:#e2e8f0}.dark-mode .environment-list-item:hover{background:#5a6578}.dark-mode .environment-list-item.selected{background:#3a4a6a;border-color:#667eea}.dark-mode .environment-list-header strong{color:#e2e8f0}.dark-mode .environment-list-description{color:#cbd5e0}.dark-mode .environment-detail-header h2,.dark-mode .environment-detail-section h3{color:#e2e8f0}.dark-mode .environment-detail-section p{color:#cbd5e0}.dark-mode .environments-sidebar .search-input,.dark-mode .environments-sidebar .filter-group select{background:#4a5568;border-color:#5a6578;color:#e2e8f0}.dark-mode .feature-questions{background:#5a4a2a;border-left-color:#f6ad55}.dark-mode .feature-questions em,.dark-mode .feature-questions li{color:#f6ad55}@media (max-width: 1200px){.environments-layout{grid-template-columns:350px 1fr}}@media (max-width: 968px){.environments-layout{grid-template-columns:1fr}.environments-sidebar{max-height:400px}.environment-details{max-height:none}}.detail-section{margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0}.detail-section h4{font-size:1.2rem;font-weight:700;color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif}.dark-mode .detail-section{border-top-color:#4a5568}.class-items-list{list-style:none;padding:0;margin:0}.class-items-list li{padding:.75rem;background:#f7fafc;border-radius:8px;margin-bottom:.5rem;color:#4a5568;cursor:default;-webkit-user-select:text;user-select:text}.class-item-choice{margin-top:1rem;margin-bottom:1rem}.choice-label{font-weight:600;color:#2d3748;margin-bottom:.5rem;font-size:.9rem}.choice-options{display:flex;flex-direction:column;gap:.5rem}.choice-button{padding:.75rem 1rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;text-align:left;color:#4a5568;display:flex;align-items:center;justify-content:space-between}.choice-button:hover{background:#edf2f7;border-color:#cbd5e0}.choice-button.selected{background:#e6fffa;border-color:#38b2ac;color:#2d3748}.choice-check{color:#38b2ac;font-weight:700;margin-left:.5rem}.feature-text{padding:1rem;background:#f7fafc;border-radius:8px;color:#4a5568;line-height:1.6;white-space:pre-wrap}.subclasses-list{display:flex;flex-direction:column;gap:1.5rem}.subclass-item{padding:1.5rem;background:#f7fafc;border-radius:12px;border-left:4px solid #667eea}.subclass-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.subclass-header strong{font-size:1.1rem;color:#2d3748}.dark-mode .subclass-header strong{color:#e2e8f0}.spellcast-trait{padding:.3rem .8rem;background:#e6fffa;color:#234e52;border-radius:6px;font-size:.85rem;font-weight:600}.subclass-description{color:#718096;margin-bottom:1rem;font-style:italic}.dark-mode .subclass-description{color:#cbd5e0}.subclass-feature{margin-top:.75rem;padding:.75rem;background:#fff;border-radius:8px;color:#4a5568;line-height:1.6}.subclass-feature strong{color:#2d3748;display:block;margin-bottom:.5rem}.dark-mode .tables-header h1{color:#fff}.dark-mode .tables-subtitle{color:#cbd5e0}.dark-mode .table-nav-link{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .table-nav-link:hover{border-color:#667eea;color:#667eea}.dark-mode .table-nav-link.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.dark-mode .generator-controls,.dark-mode .result-card,.dark-mode .loot-table-item,.dark-mode .adversary-data-table,.dark-mode .comparison-table,.dark-mode .environment-selector{background:#2d3748;color:#e2e8f0}.dark-mode .item-name{color:#e2e8f0}.dark-mode .item-roll,.dark-mode .result-roll{color:#9f7aea;background:#4a2c5a}.dark-mode .adversary-data-table thead,.dark-mode .comparison-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .adversary-data-table td,.dark-mode .comparison-table td{border-color:#4a5568}.dark-mode .adversary-data-table tbody tr:hover,.dark-mode .comparison-table tbody tr:hover{background:#374151}.dark-mode .detail-section h4{color:#e2e8f0}.dark-mode .class-items-list li{background:#2d3748;color:#e2e8f0}.dark-mode .class-item-choice .choice-label{color:#e2e8f0}.dark-mode .choice-button{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .choice-button:hover{background:#374151;border-color:#6b7280}.dark-mode .choice-button.selected{background:#1a4d4a;border-color:#38b2ac;color:#e2e8f0}.dark-mode .feature-text,.dark-mode .subclass-item{background:#374151;color:#cbd5e0}.dark-mode .subclass-feature{background:#4a5568;color:#e2e8f0}.adversary-motives{font-size:.85rem;color:#a0aec0;margin-top:.5rem;font-style:italic}.thresholds-cell{font-size:.9rem;color:#4a5568}.standard-attack-cell{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem}.standard-attack-cell strong{color:#2d3748;font-size:.95rem}.dark-mode .standard-attack-cell{color:#cbd5e0}.feature-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.feature-type-badge{padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.feature-type-badge.feature-type-action{background:#fed7d7;color:#742a2a}.feature-type-badge.feature-type-reaction{background:#feebc8;color:#7c2d12}.feature-type-badge.feature-type-passive{background:#c6f6d5;color:#22543d}.feature-type-badge.feature-type-fear-feature{background:#e9d8fd;color:#553c9a}.feature-description{color:#718096;font-size:.85rem;line-height:1.5}.dark-mode .adversary-motives{color:#a0aec0}.dark-mode .thresholds-cell{color:#cbd5e0}.dark-mode .standard-attack-cell strong{color:#e2e8f0}.dark-mode .feature-type-badge.feature-type-action{background:#742a2a;color:#fed7d7}.dark-mode .feature-type-badge.feature-type-reaction{background:#7c2d12;color:#feebc8}.dark-mode .feature-type-badge.feature-type-passive{background:#22543d;color:#c6f6d5}.dark-mode .feature-type-badge.feature-type-fear-feature{background:#553c9a;color:#e9d8fd}.dark-mode .feature-description{color:#cbd5e0}.expandable-row{transition:background-color .2s ease}.expandable-row:hover{background:#f0f4ff!important}.dark-mode .expandable-row:hover{background:#2d3748!important}.expand-indicator{font-size:.75rem;color:#667eea;min-width:24px;display:inline-flex;align-items:center;justify-content:center}.dark-mode .expand-indicator{color:#90cdf4}.feature-sub-row{background:#f7fafc}.feature-sub-row td{padding:0!important;border-bottom:1px solid #e2e8f0}.features-expanded{padding:1.5rem;background:#f7fafc;border-left:4px solid #667eea}.features-expanded-title{font-size:1rem;font-weight:700;color:#2d3748;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.features-expanded .features-list{display:flex;flex-direction:column;gap:1rem}.features-expanded .feature-item{padding:1rem;background:#fff;border-radius:8px;border-left:3px solid #667eea;box-shadow:0 2px 4px #0000000d}.features-expanded .feature-item:last-child{margin-bottom:0}.features-expanded .feature-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.features-expanded .feature-header strong{color:#2d3748;font-size:1rem}.features-expanded .feature-description{color:#4a5568;font-size:.9rem;line-height:1.6}.dark-mode .feature-sub-row{background:#1a202c}.dark-mode .feature-sub-row td{border-color:#4a5568}.dark-mode .features-expanded{background:#1a202c;border-left-color:#667eea}.dark-mode .features-expanded-title{color:#e2e8f0}.dark-mode .features-expanded .feature-item{background:#2d3748;border-left-color:#667eea}.dark-mode .features-expanded .feature-header strong{color:#e2e8f0}.dark-mode .features-expanded .feature-description{color:#cbd5e0}.colossus-segments{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.colossus-segment{padding:1.5rem;background:#fff;border-radius:8px;border-left:4px solid #ed8936;box-shadow:0 2px 4px #0000000d}.segment-name{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.segment-details{display:flex;flex-direction:column;gap:.75rem;color:#4a5568;font-size:.9rem}.segment-details>div{line-height:1.6}.segment-attack{padding:.75rem;background:#f7fafc;border-radius:6px;margin-top:.5rem}.segment-features{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.segment-feature{padding:.75rem;background:#f7fafc;border-radius:6px;margin-top:.5rem;font-size:.85rem;line-height:1.5}.adversary-size{font-size:.85rem;color:#718096;margin-top:.5rem;font-style:italic}.dark-mode .colossus-segment{background:#2d3748;border-left-color:#ed8936}.dark-mode .segment-name{color:#e2e8f0;border-bottom-color:#4a5568}.dark-mode .segment-details{color:#cbd5e0}.dark-mode .segment-attack{background:#2d374880}.dark-mode .segment-features{border-top-color:#4a5568}.dark-mode .segment-feature{background:#2d374880}.dark-mode .adversary-size{color:#cbd5e0}.description-cell{max-width:500px;line-height:1.6;color:#4a5568}.dark-mode .description-cell{color:#cbd5e0}.auth-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:24px;box-shadow:0 20px 60px #0000004d;padding:3rem;max-width:500px;width:100%}.auth-card h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.5rem;margin-bottom:.5rem;text-align:center}.auth-subtitle{color:#718096;text-align:center;margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#2d3748;font-size:.95rem}.multiclass-selection{display:flex;flex-direction:column;gap:1rem}.multiclass-form-group{display:flex;flex-direction:column;gap:.5rem}.multiclass-label{font-weight:600;color:#2d3748;font-size:.95rem;margin-bottom:.25rem}.multiclass-select{padding:.75rem 2.5rem .75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;background:#fff;color:#2d3748;font-family:inherit;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234a5568' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px}.multiclass-select:hover{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.multiclass-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.multiclass-select:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.multiclass-select option{padding:.5rem}.dark-mode .multiclass-label{color:#e2e8f0}.dark-mode .multiclass-select{background:#2d3748;border-color:#4a5568;color:#e2e8f0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23e2e8f0' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px}.dark-mode .multiclass-select:hover{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.dark-mode .multiclass-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea4d}.dark-mode .multiclass-select:disabled{background-color:#1a202c;opacity:.6}.form-group input,.form-group textarea{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.disabled-input{background:#f7fafc;cursor:not-allowed}.form-group small{color:#718096;font-size:.85rem}.form-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.remember-me-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#4a5568;-webkit-user-select:none;user-select:none}.remember-me-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.remember-me-checkbox span{font-weight:500}.remember-me-checkbox:hover{color:#667eea}.forgot-password-link{color:#667eea;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.forgot-password-link:hover{text-decoration:underline}.auth-button{padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit}.auth-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.auth-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.auth-button.primary:disabled{opacity:.6;cursor:not-allowed}.auth-button.secondary{background:#e2e8f0;color:#2d3748}.auth-button.secondary:hover:not(:disabled){background:#cbd5e0}.auth-button.danger{background:#f56565;color:#fff}.auth-button.danger:hover:not(:disabled){background:#e53e3e}.auth-button.google{background:#fff;color:#2d3748;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.auth-button.google:hover{border-color:#cbd5e0;background:#f7fafc}.auth-divider{display:flex;align-items:center;text-align:center;margin:2rem 0;color:#718096}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #e2e8f0}.auth-divider span{padding:0 1rem}.auth-footer{text-align:center;margin-top:2rem;color:#718096}.auth-footer a{color:#667eea;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.auth-error{background:linear-gradient(135deg,#fed7d7,#feb2b2);border:2px solid #e53e3e;border-radius:8px;padding:1rem;color:#742a2a;margin-bottom:1.5rem}.auth-success{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border:2px solid #48bb78;border-radius:8px;padding:1rem;color:#22543d;margin-bottom:1.5rem}.nav-logout{background:transparent;border:2px solid #e53e3e;color:#e53e3e;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;font-family:inherit;font-size:1rem}.nav-logout:hover{background:#e53e3e;color:#fff}.account-container{max-width:1000px;margin:2rem auto;padding:2rem}.account-header{margin-bottom:2rem}.account-header h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.5rem;margin-bottom:.5rem}.account-content{display:flex;flex-direction:column;gap:2rem}.account-section{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000001a}.profile-image-and-name-section{display:flex;gap:2rem;align-items:flex-start;margin-bottom:1.5rem}.name-email-fields-group{display:flex;flex-direction:column;gap:1.5rem;flex:1;min-width:0}.form-group-narrow{max-width:400px}.avatar-upload-section{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.avatar-preview-container{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid #667eea;box-shadow:0 4px 12px #667eea33;flex-shrink:0}.avatar-preview{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;color:#fff}.avatar-upload-controls{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;width:100%}.avatar-upload-button{padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s;display:inline-block}.avatar-upload-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.avatar-upload-button:disabled{opacity:.6;cursor:not-allowed}.avatar-remove-button{padding:.6rem 1.2rem;background:#e53e3e;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.avatar-remove-button:hover:not(:disabled){background:#c53030}.avatar-remove-button:disabled{opacity:.6;cursor:not-allowed}.dark-mode .avatar-preview-container{border-color:#667eea}.dark-mode .avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}@media (max-width: 768px){.profile-image-and-name-section{flex-direction:column;gap:1.5rem}.form-group-narrow{max-width:100%}}.account-section h2{color:#2d3748;margin-bottom:1.5rem;font-size:1.5rem}.account-form{display:flex;flex-direction:column;gap:1.5rem}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.subscription-info{margin-bottom:1rem;padding:1rem;background:#f7fafc;border-radius:8px}.subscription-info p{margin:.5rem 0;color:#2d3748}.profile-container{max-width:1200px;margin:2rem auto;padding:2rem}.profile-header{display:flex;gap:2rem;align-items:flex-start;margin-bottom:3rem;padding:2rem;background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;box-shadow:0 4px 12px #0000001a}.profile-avatar-section{position:relative;flex-shrink:0}.profile-avatar{width:140px;height:140px;border-radius:50%;object-fit:cover;border:4px solid #667eea;box-shadow:0 4px 12px #667eea33}.profile-avatar-placeholder{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;color:#fff;border:4px solid #667eea;box-shadow:0 4px 12px #667eea33}.profile-edit-btn{position:absolute;bottom:0;right:0;background:#fff;border:2px solid #667eea;border-radius:20px;padding:.4rem .8rem;font-size:.85rem;color:#667eea;text-decoration:none;font-weight:500;transition:all .2s;box-shadow:0 2px 8px #0000001a}.profile-edit-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.profile-title-section{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.profile-info h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.5rem;margin:0}.profile-settings-link{font-size:.9rem;color:#718096;text-decoration:none;padding:.4rem .8rem;border-radius:8px;transition:all .2s;display:inline-flex;align-items:center;gap:.3rem}.profile-settings-link:hover{background:#f7fafc;color:#667eea}.profile-bio{color:#4a5568;font-size:1.1rem;line-height:1.6;margin:1rem 0}.profile-meta{color:#718096;font-size:.9rem}.profile-stats{display:flex;gap:2rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0;flex-wrap:wrap}.profile-stat{display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:#667eea}.stat-label{font-size:.85rem;color:#718096;text-transform:uppercase;letter-spacing:.5px}.profile-content{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000001a}.profile-content-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.profile-content-header h2{color:#2d3748;margin:0;font-size:1.8rem;display:flex;align-items:center;gap:.75rem}.content-icon{font-size:1.5rem}.profile-characters{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.profile-character-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;flex-direction:column;gap:1rem;height:100%}.profile-character-card-avatar{width:100px;height:100px;margin:0 auto;border-radius:50%;overflow:hidden;border:3px solid #667eea;box-shadow:0 2px 8px #667eea33;flex-shrink:0}.profile-character-card-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.profile-character-card-avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.profile-character-card-subclass-icon{font-size:3rem;line-height:1}.profile-character-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.character-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;min-width:0}.character-card-header h3{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.profile-character-card h3{color:#2d3748;margin:0;font-size:1.3rem;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.character-level{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;white-space:nowrap;flex-shrink:0}.character-card-info{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;font-size:.9rem;min-width:0}.character-info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{color:#718096;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.info-value{color:#2d3748;font-weight:500}.character-card-footer{margin-top:auto;padding-top:1rem;border-top:1px solid #e2e8f0}.character-date{color:#718096;font-size:.85rem}.character-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tag{background:#edf2f7;color:#4a5568;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.profile-loading{text-align:center;padding:4rem 2rem;color:#718096;display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.profile-error{text-align:center;padding:4rem 2rem;color:#e53e3e;display:flex;flex-direction:column;align-items:center;gap:1rem}.error-icon{font-size:4rem;margin-bottom:1rem}.profile-error h2{color:#e53e3e;margin:0}.profile-error-banner{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;color:#c33}.error-close{background:none;border:none;font-size:1.5rem;color:#c33;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.error-close:hover{background:#cc33331a}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px;color:#718096}.dark-mode .auth-card{background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .auth-card h1{color:#e2e8f0;-webkit-text-fill-color:#e2e8f0}.dark-mode .auth-subtitle{color:#a0aec0}.dark-mode .form-group label{color:#e2e8f0}.dark-mode .form-group input,.dark-mode .form-group textarea{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .form-group input:focus,.dark-mode .form-group textarea:focus{border-color:#667eea}.dark-mode .form-group input.disabled-input{background:#2d3748;color:#a0aec0}.dark-mode .form-group small{color:#a0aec0}.dark-mode .forgot-password-link{color:#90cdf4}.dark-mode .auth-button.google{background:#2d3748;color:#e2e8f0;border-color:#4a5568}.dark-mode .auth-button.google:hover{background:#4a5568;border-color:#667eea}.dark-mode .auth-divider{color:#a0aec0}.dark-mode .auth-divider:before,.dark-mode .auth-divider:after{border-color:#4a5568}.dark-mode .auth-footer{color:#a0aec0}.dark-mode .auth-footer a{color:#90cdf4}.dark-mode .account-section{background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .account-section h2{color:#e2e8f0}.dark-mode .subscription-info{background:#2d3748}.dark-mode .subscription-info p{color:#e2e8f0}.dark-mode .profile-header{background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .profile-info h1{color:#e2e8f0;-webkit-text-fill-color:#e2e8f0}.dark-mode .profile-bio{color:#cbd5e0}.dark-mode .profile-content{background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .profile-content h2{color:#e2e8f0}.dark-mode .profile-character-card{background:#2d3748;border-color:#4a5568}.dark-mode .profile-character-card h3{color:#e2e8f0}.dark-mode .profile-character-card p{color:#a0aec0}.dark-mode .profile-character-card-avatar{border-color:#667eea}.dark-mode .profile-character-card-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .tag{background:#4a5568}.profile-share-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.share-link-container{display:flex;flex-direction:column;gap:.5rem}.share-link-container label{font-size:.9rem;color:#718096;font-weight:500}.share-link-input-group{display:flex;gap:.5rem;align-items:stretch}.share-link-input{flex:1;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#fff;color:#2d3748;font-family:monospace}.share-link-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.share-link-remove-btn{padding:.5rem .75rem;background:#e53e3e;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:background .2s}.share-link-remove-btn:hover{background:#c53030}.share-link-copy-btn{padding:.5rem 1rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s,background .2s;white-space:nowrap}.share-link-copy-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #48bb784d}.share-link-copy-btn.success{background:linear-gradient(135deg,#48bb78,#38a169);animation:successPulse .3s ease-in-out}.generate-share-link-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:transform .2s,box-shadow .2s}.generate-share-link-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.generate-share-link-btn:disabled{opacity:.6;cursor:not-allowed}.profile-character-card-wrapper{position:relative;display:flex;flex-direction:column}.copy-character-btn{margin-top:.75rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s,background .2s;align-self:flex-start;width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem}.copy-character-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #48bb784d}.copy-character-btn:disabled{opacity:.6;cursor:not-allowed}.copy-character-btn.success{background:linear-gradient(135deg,#48bb78,#38a169);animation:successPulse .3s ease-in-out}@keyframes successPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.dark-mode .profile-share-section{border-top-color:#4a5568}.dark-mode .share-link-container label{color:#a0aec0}.dark-mode .share-link-input{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .share-link-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.dark-mode .remember-me-checkbox{color:#cbd5e0}.dark-mode .remember-me-checkbox:hover{color:#667eea}.profile-empty-state{text-align:center;padding:4rem 2rem;color:#718096}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.profile-empty-state h3{color:#2d3748;margin:1rem 0 .5rem;font-size:1.5rem}.profile-empty-state p{margin-bottom:1.5rem;font-size:1rem}.dark-mode .profile-error-banner{background:#3a1f1f;border-color:#5a2f2f;color:#ff6b6b}.dark-mode .error-close:hover{background:#ff6b6b1a}.dark-mode .profile-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .profile-edit-btn{background:#2d3748;border-color:#667eea;color:#667eea}.dark-mode .profile-edit-btn:hover{background:#667eea;color:#fff}.dark-mode .profile-settings-link:hover{background:#2d3748;color:#667eea}.dark-mode .profile-stats{border-top-color:#4a5568}.dark-mode .stat-value{color:#667eea}.dark-mode .profile-content-header h2{color:#e2e8f0}.dark-mode .character-level{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .info-label{color:#a0aec0}.dark-mode .info-value{color:#e2e8f0}.dark-mode .character-card-footer{border-top-color:#4a5568}.dark-mode .character-date{color:#a0aec0}.dark-mode .profile-empty-state h3{color:#e2e8f0}.dark-mode .profile-empty-state{color:#a0aec0}.tooltip{position:fixed;background:#1a202c;color:#f7fafc;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;line-height:1.4;max-width:300px;box-shadow:0 4px 12px #0000004d;pointer-events:none;z-index:10000;word-wrap:break-word}.tooltip:before{content:"";position:absolute;width:0;height:0;border:6px solid transparent}.tooltip-top:before{bottom:-12px;left:50%;transform:translate(-50%);border-top-color:#1a202c}.tooltip-bottom:before{top:-12px;left:50%;transform:translate(-50%);border-bottom-color:#1a202c}.tooltip-left:before{right:-12px;top:50%;transform:translateY(-50%);border-left-color:#1a202c}.tooltip-right:before{left:-12px;top:50%;transform:translateY(-50%);border-right-color:#1a202c}.dark-mode .tooltip{background:#2d3748;color:#e2e8f0;box-shadow:0 4px 12px #00000080}.dark-mode .tooltip-top:before{border-top-color:#2d3748}.dark-mode .tooltip-bottom:before{border-bottom-color:#2d3748}.dark-mode .tooltip-left:before{border-left-color:#2d3748}.dark-mode .tooltip-right:before{border-right-color:#2d3748}.help-text{display:inline-flex;align-items:center;gap:.25rem;color:#718096;font-size:.875rem;margin-left:.5rem}.help-icon{font-size:.875rem;cursor:help}.help-content{font-style:italic}.help-icon-inline{display:inline-block;cursor:help;font-size:.875rem;margin-left:.25rem;opacity:.7;transition:opacity .2s;vertical-align:middle}.help-icon-inline:hover{opacity:1}.dark-mode .help-text{color:#a0aec0}.dark-mode .help-icon-inline{opacity:.8}.dark-mode .help-icon-inline:hover{opacity:1}.account-menu{position:relative;display:inline-block}.account-menu-button{color:#4a5568;text-decoration:none;font-weight:600;font-size:1rem;padding:.5rem 1rem;border-radius:8px;transition:all .2s ease;display:inline-block;background:transparent;border:none;cursor:pointer;font-family:inherit}.account-menu-button:hover{color:#667eea;background:#667eea1a}.account-menu-button.active,.account-menu-button.active-page{color:#667eea;background:linear-gradient(135deg,#667eea26,#764ba226)}.account-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;overflow:hidden;border:1px solid rgba(102,126,234,.1)}.account-menu-item{display:block;padding:.75rem 1rem;color:#4a5568;text-decoration:none;font-weight:500;transition:all .2s ease;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;font-family:inherit;font-size:.95rem}.account-menu-item:hover{background:#667eea1a;color:#667eea}.account-menu-item.active{background:#667eea26;color:#667eea}.account-menu-logout{color:#e53e3e}.account-menu-logout:hover{background:#e53e3e1a;color:#c53030}.account-menu-divider{height:1px;background:#e2e8f0;margin:.5rem 0}.dark-mode .account-menu-button{color:#cbd5e0}.dark-mode .account-menu-button:hover{color:#90cdf4;background:#4299e126}.dark-mode .account-menu-button.active,.dark-mode .account-menu-button.active-page{color:#90cdf4;background:linear-gradient(135deg,#4299e133,#b794f433)}.dark-mode .account-menu-dropdown{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .account-menu-item{color:#cbd5e0}.dark-mode .account-menu-item:hover{background:#4299e126;color:#90cdf4}.dark-mode .account-menu-item.active{background:#4299e133;color:#90cdf4}.dark-mode .account-menu-divider{background:#4a5568}.toast-container{position:fixed;top:80px;right:2rem;z-index:10000;display:flex;flex-direction:column;gap:.75rem;max-width:400px;pointer-events:none}.toast{pointer-events:auto;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:1rem;min-width:300px;max-width:400px;border-left:4px solid;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:#48bb78;background:linear-gradient(135deg,#f0fff4,#fff)}.toast-error{border-left-color:#e53e3e;background:linear-gradient(135deg,#fff5f5,#fff)}.toast-warning{border-left-color:#ed8936;background:linear-gradient(135deg,#fffaf0,#fff)}.toast-info{border-left-color:#4299e1;background:linear-gradient(135deg,#ebf8ff,#fff)}.toast-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.toast-message{flex:1;color:#2d3748;font-size:.95rem;line-height:1.5}.toast-success .toast-message{color:#22543d}.toast-error .toast-message{color:#742a2a}.toast-warning .toast-message{color:#7c2d12}.toast-info .toast-message{color:#2c5282}.toast-close{background:transparent;border:none;color:#718096;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.toast-close:hover{background:#0000001a;color:#2d3748}.dark-mode .toast{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .toast-success{border-left-color:#48bb78;background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .toast-error{border-left-color:#e53e3e;background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .toast-warning{border-left-color:#ed8936;background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .toast-info{border-left-color:#4299e1;background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .toast-message{color:#e2e8f0}.dark-mode .toast-success .toast-message{color:#9ae6b4}.dark-mode .toast-error .toast-message{color:#fc8181}.dark-mode .toast-warning .toast-message{color:#fbd38d}.dark-mode .toast-info .toast-message{color:#90cdf4}.dark-mode .toast-close{color:#a0aec0}.dark-mode .toast-close:hover{background:#ffffff1a;color:#e2e8f0}.admin-dashboard{max-width:1400px;margin:2rem auto;padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid rgba(102,126,234,.2)}.admin-header h1{color:#fff;font-size:2.5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.admin-tabs{display:flex;gap:.5rem}.admin-tabs button{padding:.75rem 1.5rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;cursor:pointer;font-weight:600;transition:all .2s ease}.admin-tabs button:hover{background:#fff3;border-color:#ffffff4d}.admin-tabs button.active{background:#fff;color:#667eea;border-color:#fff}.admin-content{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000001a}.admin-section{margin-bottom:3rem}.admin-section h2{color:#2d3748;margin-bottom:1.5rem;font-size:1.75rem}.admin-overview-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.admin-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;text-align:center}.admin-card h3{color:#4a5568;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.admin-card-value{font-size:2.5rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.admin-card-subtitle{color:#718096;font-size:.9rem}.dark-mode .admin-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .admin-card h3{color:#a0aec0}.dark-mode .admin-card-subtitle{color:#718096}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem}.admin-stat-box{background:#f7fafc;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0}.admin-stat-box h4{color:#2d3748;margin-bottom:1rem;font-size:1.1rem}.stat-values{display:flex;flex-direction:column;gap:.5rem}.stat-values div{color:#4a5568;font-size:1rem}.dark-mode .admin-stat-box{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .admin-stat-box h4{color:#e2e8f0}.dark-mode .stat-values div{color:#a0aec0}.admin-resources-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.admin-resource-section{background:#f7fafc;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0}.admin-resource-section h3{color:#2d3748;margin-bottom:1rem;font-size:1.2rem}.resource-gauge{margin-bottom:1.5rem}.gauge-label{font-size:.9rem;color:#4a5568;margin-bottom:.5rem;font-weight:600}.gauge-value{font-size:2rem;font-weight:700;margin-bottom:.5rem}.gauge-bar{width:100%;height:20px;background:#e2e8f0;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.gauge-fill{height:100%;transition:width .3s ease;border-radius:10px}.gauge-max{font-size:.8rem;color:#718096}.resource-details{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.resource-details div{color:#4a5568;font-size:.95rem}.resource-item-with-details{margin-bottom:1.5rem}.resource-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:1rem}.resource-item-title{display:flex;flex-direction:column;gap:.25rem;flex:1}.resource-label{font-size:.9rem;color:#4a5568;font-weight:600}.resource-detail{font-size:.85rem;color:#718096}.resource-item-value{font-size:1rem;font-weight:600;white-space:nowrap;min-width:50px;text-align:right}.resource-item-with-details .gauge-bar{margin-top:.5rem;margin-bottom:0}.dark-mode .admin-resource-section{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .admin-resource-section h3{color:#e2e8f0}.dark-mode .gauge-label{color:#a0aec0}.dark-mode .gauge-bar{background:#4a5568}.dark-mode .gauge-max{color:#718096}.dark-mode .resource-details div{color:#a0aec0}.dark-mode .resource-label{color:#e2e8f0}.dark-mode .resource-detail{color:#a0aec0}.admin-table-container{overflow-x:auto;margin-top:1rem}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.admin-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.admin-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem}.admin-table td{padding:.75rem 1rem;border-bottom:1px solid #e2e8f0;font-size:.9rem}.admin-table tbody tr:hover{background:#f7fafc}.admin-table tbody tr:last-child td{border-bottom:none}.dark-mode .admin-table{background:#2d3748}.dark-mode .admin-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .admin-table td{border-bottom-color:#4a5568;color:#e2e8f0}.dark-mode .admin-table tbody tr:hover{background:#4a5568}.admin-filters{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-bottom:1.5rem}.admin-filters input,.admin-filters select{padding:.5rem;border-radius:4px;border:1px solid #e2e8f0;font-size:.9rem}.admin-filters input{flex:1;min-width:200px}.dark-mode .admin-filters input,.dark-mode .admin-filters select{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.admin-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-modal{background:#fff;padding:2rem;border-radius:8px;max-width:600px;max-height:80vh;overflow:auto;width:90%;box-shadow:0 4px 20px #0000004d}.dark-mode .admin-modal{background:#2d3748;color:#e2e8f0}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;border-bottom:1px solid #e2e8f0;padding-bottom:1rem}.dark-mode .admin-modal-header{border-bottom-color:#4a5568}.admin-modal-close{font-size:1.5rem;background:none;border:none;cursor:pointer;color:#4a5568;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.dark-mode .admin-modal-close{color:#a0aec0}.admin-modal-close:hover{color:#2d3748}.dark-mode .admin-modal-close:hover{color:#e2e8f0}.admin-action-button{padding:.25rem .5rem;font-size:.85rem;border:1px solid #e2e8f0;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s}.admin-action-button:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0}.admin-action-button:disabled{opacity:.5;cursor:not-allowed}.admin-action-button.danger{color:#e53e3e;border-color:#fc8181}.admin-action-button.danger:hover:not(:disabled){background:#fed7d7}.dark-mode .admin-action-button{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .admin-action-button:hover:not(:disabled){background:#4a5568}.dark-mode .admin-action-button.danger{color:#fc8181;border-color:#e53e3e}.dark-mode .admin-action-button.danger:hover:not(:disabled){background:#742a2a}.admin-owner-filter-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#e6f3ff;border-radius:4px;margin-left:auto}.dark-mode .admin-owner-filter-indicator{background:#2c5282;color:#e2e8f0}.banned-words-add,.banned-words-bulk{background:#f7fafc;border-radius:12px;padding:1.5rem;margin-bottom:2rem;border:1px solid #e2e8f0}.banned-words-add h3,.banned-words-bulk h3{color:#2d3748;margin-bottom:1rem;font-size:1.2rem}.banned-word-form{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.banned-word-form input,.banned-word-form select{flex:1;min-width:150px;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem}.banned-word-form button{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.banned-word-form button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.banned-word-form button:disabled{opacity:.5;cursor:not-allowed}.banned-words-bulk textarea{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:1rem}.bulk-import-controls{display:flex;gap:1rem;align-items:flex-end}.bulk-import-controls input,.bulk-import-controls select{flex:1;min-width:150px;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem}.bulk-import-controls button{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.bulk-import-controls button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.banned-words-list h3{color:#2d3748;margin-bottom:1rem;font-size:1.2rem}.banned-words-table{overflow-x:auto}.banned-words-table table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.banned-words-table thead{background:#667eea;color:#fff}.banned-words-table th{padding:1rem;text-align:left;font-weight:600}.banned-words-table td{padding:1rem;border-bottom:1px solid #e2e8f0;color:#4a5568}.banned-words-table tbody tr:hover{background:#f7fafc}.delete-btn{padding:.5rem 1rem;background:#e53e3e;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.delete-btn:hover{background:#c53030;transform:translateY(-1px);box-shadow:0 2px 4px #e53e3e4d}.dark-mode .admin-content{background:linear-gradient(135deg,#2d3748,#1a202c)}.dark-mode .admin-section h2{color:#e2e8f0}.dark-mode .banned-words-add,.dark-mode .banned-words-bulk{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .banned-words-add h3,.dark-mode .banned-words-bulk h3,.dark-mode .banned-words-list h3{color:#e2e8f0}.dark-mode .banned-word-form input,.dark-mode .banned-word-form select,.dark-mode .banned-words-bulk textarea,.dark-mode .bulk-import-controls input,.dark-mode .bulk-import-controls select{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .banned-words-table{background:#1a202c}.dark-mode .banned-words-table thead{background:#434190}.dark-mode .banned-words-table td{border-color:#4a5568;color:#a0aec0}.dark-mode .banned-words-table tbody tr:hover{background:#2d3748}.dark-mode .banned-words-add input[type=text],.dark-mode .banned-words-add input[type=number],.dark-mode .banned-words-add textarea{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .banned-words-add input[type=checkbox]{accent-color:#667eea}.dark-mode .banned-words-add label{color:#e2e8f0}.dark-mode .badge-button{background:#2d3748!important;border-color:#4a5568!important;color:#e2e8f0!important}.dark-mode .badge-button:hover{border-color:#667eea!important;background:#4a5568!important}.dark-mode .badge-button-selected{background:#2d3748!important;border-color:#667eea!important;color:#9f7aea!important}.dark-mode .badge-button-selected:hover{background:#3d4a5c!important}.dark-mode .announcement-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .announcement-card h3,.dark-mode .announcement-card p,.dark-mode .announcement-card div,.dark-mode .announcement-card ul,.dark-mode .announcement-card li{color:#e2e8f0}.level-up-actions{display:flex;gap:.5rem;align-items:center}.level-up-button{padding:.5rem 1rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem}.level-up-button:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 4px 8px #48bb784d}.history-button{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem}.history-button:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.level-up-info{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:2rem 0}.info-section{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #e2e8f0}.info-section h3{color:#667eea;margin-bottom:1rem;font-family:Cinzel,serif}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}.stat-item{display:flex;justify-content:space-between;padding:.75rem;background:#f7fafc;border-radius:8px}.stat-label{color:#718096;font-weight:600}.stat-value{color:#2d3748;font-weight:700;font-size:1.1rem}.automatic-changes,.choices-needed{margin-top:1.5rem}.automatic-changes h4,.choices-needed h4{color:#4a5568;margin-bottom:.5rem;font-size:1rem}.automatic-changes ul,.choices-needed ul{list-style:none;padding-left:0}.automatic-changes li,.choices-needed li{padding:.5rem 0 .5rem 1.5rem;position:relative}.automatic-changes li:before,.choices-needed li:before{content:"✓";position:absolute;left:0;color:#48bb78;font-weight:700}.tier-achievement-benefits{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.benefit-item{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #e2e8f0}.benefit-item h3{color:#667eea;margin-bottom:.75rem;font-family:Cinzel,serif}.marked-traits-list{margin-top:1rem;padding:1rem;background:#fef5e7;border-radius:8px;border-left:4px solid #f6ad55}.marked-traits-list ul{list-style:none;padding-left:0;margin-top:.5rem}.marked-traits-list li{padding:.25rem 0;color:#744210;font-weight:600}.location-selection{display:flex;gap:1rem;margin:1.5rem 0;padding:1rem;background:#f7fafc;border-radius:8px}.location-selection label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.75rem 1rem;background:#fff;border-radius:8px;border:2px solid #e2e8f0;transition:all .2s ease;flex:1}.location-selection label:hover{border-color:#667eea;background:#f0f4ff}.location-selection input[type=radio]:checked+span{color:#667eea;font-weight:600}.exchange-warning{margin:1.5rem 0;padding:1rem;background:#fef5e7;border-radius:8px;border-left:4px solid #f6ad55}.exchange-warning p{color:#744210;font-weight:600;margin-bottom:1rem}.loadout-cards{margin-top:1rem}.loadout-cards h4{margin-bottom:.75rem;color:#4a5568}.exchange-card-button{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem;margin-bottom:.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease}.exchange-card-button:hover{border-color:#667eea;background:#f0f4ff}.exchange-card-button.selected{border-color:#667eea;background:#eef2ff;box-shadow:0 0 0 3px #667eea1a}.current-loadout{margin:1.5rem 0;padding:1rem;background:#f0f4ff;border-radius:8px}.current-loadout h4{margin-bottom:.75rem;color:#4a5568}.loadout-list{display:flex;flex-direction:column;gap:.5rem}.loadout-card-item{display:flex;justify-content:space-between;padding:.75rem;background:#fff;border-radius:6px;border:1px solid #cbd5e0}.advancements-selection{margin:2rem 0}.selected-count{text-align:center;padding:1rem;background:#f7fafc;border-radius:8px;margin-bottom:1.5rem;font-weight:600;color:#4a5568}.advancements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.advancement-option{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #e2e8f0;transition:all .2s ease}.advancement-option:hover{border-color:#cbd5e0}.advancement-option.selected{border-color:#667eea;background:#f0f4ff;box-shadow:0 0 0 3px #667eea1a}.advancement-option.special{border-color:#9f7aea;background:#faf5ff}.advancement-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;margin-bottom:1rem}.advancement-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.advancement-name{font-weight:600;color:#2d3748;font-size:1.05rem}.advancement-details{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.trait-selection{margin-top:1rem}.traits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.75rem}.trait-button{padding:.75rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:600;position:relative}.trait-button:hover:not(:disabled){border-color:#667eea;background:#f0f4ff}.trait-button.selected{border-color:#667eea;background:#eef2ff;box-shadow:0 0 0 3px #667eea1a}.trait-button.marked{opacity:.5;cursor:not-allowed;background:#f7fafc}.trait-button:disabled{cursor:not-allowed;opacity:.5}.marked-badge{position:absolute;top:.25rem;right:.25rem;font-size:.7rem;background:#f6ad55;color:#fff;padding:.25rem .5rem;border-radius:4px;font-weight:700}.review-section{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #e2e8f0;margin-bottom:1.5rem}.review-section h3{color:#667eea;margin-bottom:1rem;font-family:Cinzel,serif}.review-item{padding:1rem;background:#f7fafc;border-radius:8px;margin-top:.75rem}.exchange-note{color:#f6ad55;font-weight:600;font-size:.9rem;margin-top:.5rem}.complete-button{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .2s ease}.complete-button:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-2px);box-shadow:0 4px 12px #48bb7866}.complete-button:disabled{opacity:.6;cursor:not-allowed}.in-loadout-badge{display:inline-block;padding:.25rem .5rem;background:#c6f6d5;color:#22543d;border-radius:4px;font-size:.75rem;font-weight:600;margin-left:.5rem}.in-vault-badge{display:inline-block;padding:.25rem .5rem;background:#bee3f8;color:#2c5282;border-radius:4px;font-size:.75rem;font-weight:600;margin-left:.5rem}.owned-badge{display:inline-block;padding:.25rem .5rem;background:#fed7d7;color:#742a2a;border-radius:4px;font-size:.75rem;font-weight:600;margin-left:.5rem}.domain-card.owned{opacity:.6;cursor:not-allowed;position:relative}.domain-card.owned:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;border-radius:16px;pointer-events:none}.dark-mode .in-vault-badge{background:#2c5282;color:#bee3f8}.dark-mode .owned-badge{background:#742a2a;color:#fed7d7}.info-box{padding:1rem;background:#eef2ff;border-left:4px solid #667eea;border-radius:8px;margin-bottom:1.5rem}.error-text{color:#e53e3e;font-size:.9rem;margin-top:.5rem;font-weight:600}.step-actions{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:2px solid #e2e8f0}.step-actions .previous-button,.step-actions .next-button{padding:1rem 2rem;font-size:1.1rem;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:600;white-space:nowrap}.step-actions .previous-button{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d}.step-actions .previous-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.step-actions .next-button{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 4px 15px #48bb784d}.step-actions .next-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #48bb7866}.step-actions .previous-button:disabled,.step-actions .next-button:disabled{background:#cbd5e0;cursor:not-allowed;box-shadow:none;opacity:.6}.step-actions .previous-button:disabled:hover,.step-actions .next-button:disabled:hover{transform:none;box-shadow:none}.dark-mode .step-indicator{background:transparent}.dark-mode .step-number{background:#2d3748;border-color:#4a5568;color:#a0aec0}.dark-mode .step-number.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea66}.dark-mode .step-number.completed{background:#48bb78;color:#fff;border-color:#48bb78}.dark-mode .step-actions{border-top-color:#4a5568}.dark-mode .step-actions .previous-button{background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 4px 15px #4299e14d}.dark-mode .step-actions .previous-button:hover:not(:disabled){box-shadow:0 6px 20px #4299e166}.dark-mode .step-actions .next-button{background:linear-gradient(135deg,#48bb78,#38a169)}.dark-mode .step-actions .previous-button:disabled,.dark-mode .step-actions .next-button:disabled{background:#4a5568;color:#718096}.dark-mode .step-content h2{color:#e2e8f0}.dark-mode .step-content>p{color:#a0aec0}.dark-mode .info-section,.dark-mode .benefit-item,.dark-mode .review-section{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .info-section h3,.dark-mode .benefit-item h3,.dark-mode .review-section h3{color:#e2e8f0}.dark-mode .review-section h4,.dark-mode .review-section p,.dark-mode .review-section ul,.dark-mode .review-section li{color:#cbd5e0}.dark-mode .review-item{background:#1a202c;border:1px solid #4a5568;color:#e2e8f0}.dark-mode .review-item p{color:#e2e8f0}.dark-mode .review-item strong{color:#f7fafc}.dark-mode .review-item code{background:#2d3748;color:#fbb6ce;padding:.2rem .4rem;border-radius:4px;font-size:.9em;border:1px solid #4a5568}.dark-mode .review-item>div{color:#e2e8f0}.dark-mode .review-item>div p{color:#e2e8f0}.dark-mode .review-item>div strong{color:#f7fafc}.dark-mode .exchange-note{color:#f6ad55;background:#f6ad551a;padding:.5rem;border-radius:4px;border-left:3px solid #f6ad55}.dark-mode .error-text{color:#fc8181;background:#fc81811a;padding:.5rem;border-radius:4px;border-left:3px solid #fc8181}.dark-mode .stat-item{background:#1a202c;border-color:#4a5568}.dark-mode .stat-label{color:#a0aec0}.dark-mode .stat-value{color:#e2e8f0}.dark-mode .location-selection{background:#2d3748;border-color:#4a5568}.dark-mode .location-selection label{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .location-selection label:hover{background:#2d3748;border-color:#667eea}.dark-mode .exchange-warning{background:#744210;border-left-color:#f6ad55}.dark-mode .exchange-warning p{color:#fef5e7}.dark-mode .current-loadout{background:#1a2e3d;border-color:#4a5568}.dark-mode .current-loadout h4{color:#e2e8f0}.dark-mode .loadout-card-item{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.dark-mode .exchange-card-button{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .exchange-card-button:hover{background:#2d3748;border-color:#667eea}.dark-mode .exchange-card-button.selected{background:#2d3748;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.dark-mode .advancement-option{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .advancement-option:hover{border-color:#718096}.dark-mode .advancement-option.selected{border-color:#667eea;background:linear-gradient(135deg,#3d4a5c,#2d3748);box-shadow:0 0 0 3px #667eea33}.dark-mode .advancement-name{color:#e2e8f0}.info-box{margin:1rem 0;padding:1rem 1.5rem;background:#f0f4ff;border-radius:8px;border-left:4px solid #667eea}.info-box p{margin:0;color:#2d3748;font-weight:500}.info-box strong{color:#667eea;font-weight:700}.dark-mode .info-box{background:#2d3748;border-left-color:#667eea}.dark-mode .info-box p{color:#e2e8f0}.dark-mode .info-box strong{color:#9f7aea}.dark-mode .advancement-details{border-top-color:#4a5568}.advancement-option.at-limit{opacity:.6;background:#f7fafc}.dark-mode .advancement-option.at-limit{background:#2d3748}.advancement-limit{font-size:.75rem;color:#718096;font-weight:500}.dark-mode .advancement-limit{color:#a0aec0}.dark-mode .tier-limits-info{background:#2d3748!important;border-color:#4a5568!important;color:#e2e8f0!important}.dark-mode .tier-limits-info h4{color:#e2e8f0!important}.dark-mode .tier-limits-info>div{color:#e2e8f0!important}.tier-limit-item{color:#2d3748}.tier-limit-item.at-limit{color:#718096}.tier-limit-item.over-limit{color:#f56565}.dark-mode .tier-limit-item{color:#e2e8f0!important}.dark-mode .tier-limit-item.at-limit{color:#a0aec0!important}.dark-mode .tier-limit-item.over-limit{color:#fc8181!important}.dark-mode .trait-button{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .trait-button:hover:not(:disabled){background:#2d3748;border-color:#667eea}.dark-mode .trait-button.selected{background:#2d3748;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.dark-mode .trait-button.marked{background:#1a202c;opacity:.5}.dark-mode .selected-count{background:#2d3748;color:#a0aec0}.dark-mode .search-input{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .search-input:focus{border-color:#667eea;background:#2d3748}.dark-mode .complete-button{background:linear-gradient(135deg,#48bb78,#38a169)}.dark-mode .complete-button:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a)}.cards-by-domain{margin-top:2rem}.domain-card-selection{margin-top:1.5rem}.domain-card-selection .search-box{margin-bottom:1.5rem}.domain-card-selection .search-input{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease}.domain-card-selection .search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.domain-card-selection .domain-card{position:relative;z-index:1;-webkit-user-select:none;user-select:none}.domain-card-selection .domain-card *{pointer-events:none}.domain-card-selection .domain-card{pointer-events:auto}.dark-mode .domain-card-selection .search-input{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .domain-card-selection .search-input:focus{border-color:#667eea;background:#2d3748}.dark-mode .no-cards{color:#a0aec0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172ad9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.level-up-history-modal{background:#fff;border-radius:16px;max-width:800px;max-height:90vh;width:100%;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.modal-content{background:#fff;border-radius:16px;max-width:720px;max-height:90vh;width:100%;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;overflow:hidden}.modal-header{padding:1.5rem 2rem;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-header h2{margin:0;font-family:Cinzel,serif;font-size:1.5rem}.modal-close{background:#fff3;border:none;color:#fff;font-size:2rem;width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body{padding:2rem;overflow-y:auto;flex:1;background:#f7fafc}.modal-footer{padding:1rem 2rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:.75rem;background:#f7fafc}.section-header-with-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem}.manage-button{padding:.4rem .9rem;border-radius:999px;border:1px solid #cbd5f5;background:#edf2ff;color:#4c51bf;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .05s ease}.manage-button:hover{background:#e2e8ff;border-color:#667eea;transform:translateY(-1px)}.inventory-list-editable{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.75rem}.inventory-edit-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem;border-radius:8px;background:#fff;border:1px solid #e2e8f0;font-size:.9rem;transition:all .2s ease;box-shadow:0 1px 3px #00000014}.inventory-edit-item:hover{border-color:var(--accent-color);box-shadow:0 2px 6px #0000001f;transform:translateY(-1px)}.inventory-edit-item .remove-button{border:none;background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff;border-radius:6px;padding:.5rem .75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:2.5rem;box-shadow:0 2px 4px #e53e3e4d}.inventory-edit-item .remove-button:hover{background:linear-gradient(135deg,#c53030,#a02626);box-shadow:0 3px 6px #e53e3e66;transform:translateY(-1px)}.inventory-edit-item .remove-button:active{transform:translateY(0)}.loadout-management-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:1rem}.loadout-column h3{font-size:1rem;font-weight:700;color:#2d3748;margin-bottom:.75rem}.loadout-card-list{display:flex;flex-direction:column;gap:.5rem}.loadout-card-pill{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.5rem .75rem;border-radius:999px;border:1px solid #cbd5f5;background:#ebf4ff;color:#2c5282;font-size:.85rem;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .05s ease;text-align:left}.loadout-card-pill .card-name{font-weight:600}.loadout-card-pill .card-meta{font-size:.8rem;opacity:.85}.loadout-card-pill.vault{background:#edf2f7;border-color:#cbd5e0;color:#2d3748}.loadout-card-pill:hover{background:#dde8ff;border-color:#667eea;transform:translateY(-1px)}.dark-mode .modal-content{background:#1a202c;color:#e2e8f0}.dark-mode .modal-body{background:#111827}.dark-mode .modal-footer{background:#111827;border-top-color:#4b5563}.dark-mode .manage-button{background:#1f2937;border-color:#4b5563;color:#c3dafe}.dark-mode .manage-button:hover{background:#111827;border-color:#667eea}.dark-mode .inventory-edit-item{background:#1f2937;border-color:#4b5563;color:#e2e8f0;box-shadow:0 1px 3px #0000004d}.dark-mode .inventory-edit-item:hover{border-color:#667eea;box-shadow:0 2px 6px #667eea4d}.dark-mode .inventory-edit-item .remove-button{background:linear-gradient(135deg,#c53030,#a02626);color:#fff;box-shadow:0 2px 4px #c5303066}.dark-mode .inventory-edit-item .remove-button:hover{background:linear-gradient(135deg,#a02626,#7a1e1e);box-shadow:0 3px 6px #c5303080}.dark-mode .loadout-card-pill{background:#1f2937;border-color:#4b5563;color:#c3dafe}.dark-mode .loadout-card-pill.vault{background:#111827;border-color:#4b5563;color:#e2e8f0}.no-history{text-align:center;color:#718096;padding:3rem;font-style:italic}.history-list{display:flex;flex-direction:column;gap:2rem}.history-entry{background:#f7fafc;border-radius:12px;padding:1.5rem;border-left:4px solid #667eea}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.history-header h3{margin:0;color:#667eea;font-family:Cinzel,serif;font-size:1.25rem}.history-date{color:#718096;font-size:.9rem}.history-section{margin-top:1rem}.history-section h4{color:#2d3748;font-size:1rem;margin-bottom:.5rem;font-weight:600}.history-section ul{list-style:none;padding:0;margin:.5rem 0}.history-section li{padding:.25rem 0;color:#4a5568}.history-section p{margin:.5rem 0;color:#4a5568}.exchange-note{color:#f6ad55;font-style:italic;font-size:.9rem}.dark-mode .level-up-history-modal{background:#1a202c;color:#e2e8f0}.dark-mode .modal-header{background:linear-gradient(135deg,#4a5568,#2d3748);border-bottom-color:#4a5568}.dark-mode .history-entry{background:#2d3748;border-left-color:#667eea}.dark-mode .history-header{border-bottom-color:#4a5568}.dark-mode .history-header h3{color:#90cdf4}.dark-mode .history-date{color:#a0aec0}.dark-mode .history-section h4{color:#e2e8f0}.dark-mode .history-section li,.dark-mode .history-section p{color:#cbd5e0}.dark-mode .no-history{color:#a0aec0}.history-header-actions{display:flex;align-items:center;gap:1rem}.revert-button{padding:.4rem .8rem;background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease}.revert-button:hover:not(:disabled){background:linear-gradient(135deg,#e53e3e,#c53030);transform:translateY(-1px);box-shadow:0 4px 8px #f565654d}.revert-button:disabled{opacity:.5;cursor:not-allowed}.revert-confirmation{margin-top:1rem;padding:1rem;background:#fff5f5;border:2px solid #feb2b2;border-radius:8px}.revert-confirmation p{margin:0 0 1rem;color:#742a2a;font-weight:500}.revert-confirmation-actions{display:flex;gap:.75rem}.confirm-revert-button{padding:.5rem 1rem;background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.confirm-revert-button:hover:not(:disabled){background:linear-gradient(135deg,#e53e3e,#c53030)}.confirm-revert-button:disabled{opacity:.5;cursor:not-allowed}.cancel-revert-button{padding:.5rem 1rem;background:#e2e8f0;color:#2d3748;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-revert-button:hover:not(:disabled){background:#cbd5e0}.cancel-revert-button:disabled{opacity:.5;cursor:not-allowed}.dark-mode .revert-confirmation{background:#2d1b1b;border-color:#742a2a}.dark-mode .revert-confirmation p{color:#fc8181}.dark-mode .cancel-revert-button{background:#4a5568;color:#e2e8f0}.dark-mode .cancel-revert-button:hover:not(:disabled){background:#2d3748}.login-link{color:#fff!important;background:linear-gradient(135deg,#667eea,#764ba2)!important;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;transition:all .3s ease;display:inline-block}.login-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;color:#fff!important}.dark-mode .login-link{color:#fff!important;background:linear-gradient(135deg,#667eea,#764ba2)!important}.dark-mode .login-link:hover{color:#fff!important;box-shadow:0 4px 12px #667eea99}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.app-content{flex:1}html{scroll-behavior:smooth}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2,#667eea)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-content{animation:fadeIn .5s ease-out}.text-gradient{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid rgba(102,126,234,.5);outline-offset:2px}
