@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Cinzel:wght@400;600;700&display=swap";/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.z-40{z-index:40}.z-50{z-index:50}.container{width:100%}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.list-item{display:list-item}.table{display:table}.h-full{height:100%}.w-full{width:100%}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.items-center{align-items:center}.justify-between{justify-content:space-between}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.bg-transparent{background-color:#0000}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-300{--tw-duration:.3s;transition-duration:.3s}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}:root{--card-bg:#1a1a1a;--input-bg:#2a2a2a;--border-color:#333;--text-primary:#fff;--text-secondary:#aaa;--button-secondary-bg:#3a3a3a}body:not(.dark-mode){--card-bg:#fff;--input-bg:#f7fafc;--border-color:#e2e8f0;--text-primary:#2d3748;--text-secondary:#4a5568;--button-secondary-bg:#edf2f7}.dark-mode{--card-bg:#1a1a1a;--input-bg:#2a2a2a;--border-color:#333;--text-primary:#fff;--text-secondary:#aaa;--button-secondary-bg:#3a3a3a}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2d3748;background:linear-gradient(135deg,#667eea,#764ba2) fixed;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}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{text-align:center;max-width:1200px;margin:2rem auto;padding:2rem;position:relative}.home-header{position:absolute;top:1rem;right:1rem}.home h1{color:#fff;text-shadow:0 2px 10px #0003;margin-bottom:1rem;font-size:3rem;font-weight:700}.home button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;margin-top:2rem;padding:1.25rem 2.5rem;font-size:1.2rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #667eea66}.home button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.character-library{text-align:left;margin-top:3rem}.character-library h2{text-align:center;color:#fff;margin-bottom:1.5rem;font-size:2rem;font-weight:600}.character-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.character-card{color:inherit;background:#fff;border:none;border-radius:16px;padding:1.5rem;text-decoration:none;transition:all .3s;display:block;box-shadow:0 4px 6px #0000001a}.character-card.profile-character-card{border:2px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:1rem;height:100%;display:flex}.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){transform:translateY(-4px);box-shadow:0 10px 25px #00000026}.character-card h3:not(.profile-character-card h3){-webkit-text-fill-color:transparent;text-overflow:ellipsis;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:1.5rem;font-weight:700;overflow:hidden}.character-card p{color:#666;margin:.25rem 0}.character-card-avatar{border:3px solid #667eea;border-radius:50%;flex-shrink:0;width:80px;height:80px;margin:0 auto 1rem;overflow:hidden;box-shadow:0 2px 8px #667eea33}.character-card-avatar-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}.character-card-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.character-card-subclass-icon{font-size:2.5rem;line-height:1}.character-card-wrapper{position:relative}.character-card-wrapper .character-card{z-index:1;position:relative}.character-actions{z-index:10;pointer-events:auto;gap:.5rem;display:flex;position:absolute;bottom:1rem;right:1rem}.character-actions button{cursor:pointer;background:#ffffffe6;border:none;border-radius:8px;padding:.5rem;font-size:1.2rem;transition:all .2s;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{z-index:20;background:#fffffffa;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex;position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:0 8px 24px #0003}.delete-confirm p{color:#2d3748;margin-bottom:1rem;font-weight:600}.delete-confirm-buttons{gap:1rem;display:flex}.confirm-delete,.cancel-delete{cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.confirm-delete{color:#fff;background:linear-gradient(135deg,#f56565,#e53e3e)}.confirm-delete:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5656566}.cancel-delete{color:#2d3748;background:#e2e8f0}.cancel-delete:hover{background:#cbd5e0}.characters-filters{background:#fffffff2;border-radius:16px;flex-wrap:wrap;gap:1rem;margin:2rem 0;padding:1.5rem;display:flex;box-shadow:0 4px 12px #0000001a}.search-box{flex:1;min-width:250px}.search-input{border:2px solid #e2e8f0;border-radius:8px;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .2s}.search-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.filter-group{flex-direction:column;gap:.5rem;display:flex}.filter-group label{color:#4a5568;font-size:.875rem;font-weight:600}.filter-group select{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;font-size:.9rem;transition:all .2s}.filter-group select:focus{border-color:#667eea;outline:none;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{color:#fff;text-shadow:0 2px 10px #0003;margin-bottom:1rem;font-size:3.5rem;font-weight:700}.dashboard-subtitle{color:#ffffffe6;text-shadow:0 1px 5px #0003;font-size:1.25rem}.dashboard-section{background:#fffffff2;border-radius:20px;margin-bottom:3rem;padding:2rem;box-shadow:0 8px 24px #0000001a}.dashboard-section h2{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:2rem}.action-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.action-card{color:inherit;text-align:center;background:linear-gradient(135deg,#fff,#f7fafc);border:2px solid #e2e8f0;border-radius:16px;flex-direction:column;align-items:center;padding:2rem;text-decoration:none;transition:all .3s;display:flex}.action-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 12px 32px #00000026}.action-card.primary{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000}.action-card.primary h3,.action-card.primary p{color:#fff}.action-icon{margin-bottom:1rem;font-size:3rem}.action-card h3{color:#2d3748;margin-bottom:.5rem;font-size:1.5rem}.action-card p{color:#718096;font-size:.95rem}.info-cards{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.info-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:4px solid #667eea;border-radius:12px;padding:1.5rem}.info-card h3{color:#2d3748;margin-bottom:.75rem;font-size:1.25rem}.info-card p{color:#4a5568;line-height:1.6}.announcements-section{padding:2.5rem}.section-header-with-icon{align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.announcements-grid{scrollbar-width:thin;scrollbar-color:var(--accent-color,#667eea)transparent;flex-direction:column;gap:1.5rem;max-height:800px;padding-right:.5rem;display:flex;overflow-y:auto}.announcements-grid::-webkit-scrollbar{width:8px}.announcements-grid::-webkit-scrollbar-track{background:0 0;border-radius:4px}.announcements-grid::-webkit-scrollbar-thumb{background:var(--accent-color,#667eea);border-radius:4px}.announcements-grid::-webkit-scrollbar-thumb:hover{background:var(--accent-color-hover,#5a6fd6)}.announcement-card{background:linear-gradient(135deg,#fff,#f7fafc);border:2px solid #e2e8f0;border-left:5px solid #667eea;border-radius:16px;padding:2rem;transition:all .3s;position:relative;overflow:visible;box-shadow:0 4px 12px #00000014}.announcement-card:before{content:"";background:linear-gradient(#667eea,#764ba2);width:5px;height:100%;transition:width .3s;position:absolute;top:0;left:0}.announcement-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 8px 24px #667eea26}.announcement-card.recent{background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-left-color:#48bb78}.announcement-card.recent:before{background:linear-gradient(#48bb78,#38a169)}.announcement-header{border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:1.25rem;padding-bottom:1rem;display:flex}.announcement-title-group{flex-wrap:wrap;flex:1;align-items:center;gap:.75rem;display:flex}.announcement-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:.4rem .9rem;font-size:.75rem;font-weight:700;box-shadow:0 2px 8px #667eea4d}.announcement-card.recent .announcement-badge{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 2px 8px #48bb784d}.announcement-card h3{color:#2d3748;flex:1;min-width:200px;margin:0;font-size:1.5rem;font-weight:700;line-height:1.3}.announcement-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.5rem;display:flex}.announcement-date{color:#718096;white-space:nowrap;align-items:center;gap:.4rem;font-size:.875rem;display:flex}.date-icon{opacity:.7;font-size:.9rem}.announcement-new-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:12px;padding:.25rem .6rem;font-size:.7rem;font-weight:700;animation:2s ease-in-out infinite pulse;box-shadow:0 2px 6px #48bb784d}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 4px 12px #667eea59}50%{transform:scale(1.05);box-shadow:0 6px 16px #667eea80}}.announcement-content{color:#4a5568;font-size:1rem;line-height:1.7}.announcement-content p{color:#4a5568;margin-bottom:1rem}.announcement-content p:last-child{margin-bottom:0}.announcement-content ul,.announcement-content ol{color:#4a5568;margin-bottom:1rem;margin-left:1.5rem}.announcement-content li{margin-bottom:.5rem;line-height:1.6}.announcement-content strong{color:#2d3748;font-weight:600}.announcement-content a{color:#667eea;border-bottom:1px solid #0000;font-weight:500;text-decoration:none;transition:border-color .2s}.announcement-content a:hover{border-bottom-color:#667eea}.announcement-content code{color:#e53e3e;background:#edf2f7;border-radius:4px;padding:.2rem .4rem;font-family:Courier New,monospace;font-size:.9em}.announcement-content blockquote{color:#718096;border-left:4px solid #667eea;margin:1rem 0;padding-left:1rem;font-style:italic}.tips-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.tip-card{background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-left:4px solid #48bb78;border-radius:12px;padding:1.5rem}.tip-card h4{color:#2d3748;margin-bottom:.75rem;font-size:1.1rem}.tip-card p{color:#4a5568;font-size:.95rem;line-height:1.6}.domain-browser{width:100%;padding:0}.domain-browser h1,.domain-browser h2{color:#2d3748;text-align:center;margin-bottom:.5rem;font-size:2rem;font-weight:700}.dark-mode .domain-browser h1,.dark-mode .domain-browser h2{color:#e2e8f0}.browser-subtitle{text-align:center;color:#4a5568;margin-bottom:2rem;font-size:1.1rem}.dark-mode .browser-subtitle{color:#ffffffe6}.browser-filters{background:#fffffff2;border-radius:16px;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem;display:flex;box-shadow:0 4px 12px #0000001a}.browser-stats{text-align:center;color:#fff;margin-bottom:1.5rem;font-size:1.1rem;font-weight:600}.domain-card-browser{background:#fff;border-left:4px solid #667eea;border-radius:16px;padding:1.5rem;transition:all .3s;box-shadow:0 4px 12px #0000001a}.domain-card-browser:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.card-header{border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.card-domain{align-items:center;gap:.5rem;display:flex}.domain-icon{font-size:1.5rem}.domain-name{color:#2d3748;font-size:1.1rem;font-weight:700}.card-level{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:700}.card-name{color:#2d3748;margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.card-description{color:#4a5568;margin-bottom:.75rem;line-height:1.6}.card-cost,.card-range,.card-damage{color:#718096;margin-bottom:.5rem;font-size:.9rem;font-weight:600}.card-effect{color:#2d3748;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;margin-top:.75rem;padding:.75rem;font-size:.9rem;line-height:1.6}.card-type-badge{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-block}.card-feature{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;margin-top:.75rem;padding:.75rem}.feature-label{color:#718096;text-transform:uppercase;margin-bottom:.25rem;font-size:.75rem;font-weight:700}.feature-text{color:#2d3748;font-size:.9rem;line-height:1.6}.card-stats{border-top:1px solid #e2e8f0;margin-top:.75rem;padding-top:.75rem}.card-stat{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.stat-label{color:#718096;font-size:.85rem;font-weight:600}.dark-mode .characters-filters,.dark-mode .browser-filters{background:#1a202cf2;border:1px solid #4a5568}.dark-mode .search-input,.dark-mode .filter-group select{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.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{color:#e2e8f0;background:#4a5568}.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-color:#4a5568 #4a5568 #4a5568 #667eea}.dark-mode .announcement-card.recent{background:linear-gradient(135deg,#1a3a2e,#22543d);border-left-color:#48bb78}.dark-mode .announcement-card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea40}.dark-mode .announcement-header{border-bottom-color:#4a5568}.dark-mode .announcement-card h3{color:#e2e8f0}.dark-mode .announcement-date{color:#a0aec0}.dark-mode .announcement-content,.dark-mode .announcement-content p,.dark-mode .announcement-content ul,.dark-mode .announcement-content ol,.dark-mode .announcement-content li{color:#cbd5e0}.dark-mode .announcement-content strong{color:#e2e8f0}.dark-mode .announcement-content a{color:#90cdf4}.dark-mode .announcement-content a:hover{border-bottom-color:#90cdf4}.dark-mode .announcement-content code{color:#fc8181;background:#1a202c}.dark-mode .announcement-content blockquote{color:#a0aec0;border-left-color:#667eea}.dark-mode .announcements-grid{scrollbar-color:#667eea #2d3748}.dark-mode .announcements-grid::-webkit-scrollbar-track{background:#2d3748}.dark-mode .announcements-grid::-webkit-scrollbar-thumb{background:#667eea}.dark-mode .announcements-grid::-webkit-scrollbar-thumb:hover{background:#7c8cf5}.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{color:#e2e8f0;background:linear-gradient(135deg,#1a202c,#2d3748)}.equipment-browser{max-width:1600px;margin:2rem auto;padding:2rem}.equipment-browser h1{color:#fff;text-shadow:0 2px 10px #0003;text-align:center;margin-bottom:.5rem;font-size:3rem;font-weight:700}.equipment-tabs{justify-content:center;gap:1rem;margin:2rem 0;display:flex}.tab-button{cursor:pointer;color:#2d3748;background:#ffffffe6;border:2px solid #e2e8f0;border-radius:12px;align-items:center;gap:.5rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex}.tab-icon{font-size:1.3rem;line-height:1}.tab-label{white-space:nowrap}.tab-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.tab-button.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 15px #667eea66}.equipment-table-container{background:#fffffff2;border-radius:16px;margin-top:2rem;padding:1.5rem;overflow-x:auto;box-shadow:0 4px 12px #0000001a}.equipment-table{border-collapse:collapse;width:100%}.equipment-table thead{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.equipment-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:1rem;font-size:.95rem;font-weight:700}.equipment-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background .2s}.equipment-table tbody tr:hover{background:linear-gradient(135deg,#f7fafc,#edf2f7)}.equipment-table td{color:#2d3748;padding:1rem;font-size:.95rem}.equipment-name-cell{align-items:center;gap:.75rem;display:flex}.equipment-icon{font-size:1.5rem}.equipment-name{color:#2d3748;font-weight:600}.damage-cell{color:#e53e3e;font-family:Courier New,monospace;font-weight:700}.stat-cell{text-align:center;font-weight:600}.damage-type-badge{text-transform:uppercase;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-block}.damage-type-badge.phy{color:#742a2a;background:linear-gradient(135deg,#fed7d7,#feb2b2)}.damage-type-badge.mag{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4)}.category-badge{color:#234e52;text-transform:capitalize;background:linear-gradient(135deg,#e6fffa,#b2f5ea);border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.feature-cell{max-width:300px}.no-feature{color:#cbd5e0;font-style:italic}.tier-badge{text-transform:uppercase;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-block}.tier-badge.tier-1{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4)}.tier-badge.tier-2{color:#2c5282;background:linear-gradient(135deg,#bee3f8,#90cdf4)}.tier-badge.tier-3{color:#702459;background:linear-gradient(135deg,#fbb6ce,#f687b3)}.tier-badge.tier-4{color:#744210;background:linear-gradient(135deg,#faf089,#f6e05e)}.dark-mode .tier-badge.tier-1{color:#68d391;background:linear-gradient(135deg,#68d3914d,#68d39133)}.dark-mode .tier-badge.tier-2{color:#63b3ed;background:linear-gradient(135deg,#5acdf44d,#5acdf433)}.dark-mode .tier-badge.tier-3{color:#f687b3;background:linear-gradient(135deg,#f687b34d,#f687b333)}.dark-mode .tier-badge.tier-4{color:#f6e05e;background:linear-gradient(135deg,#f6e05e4d,#f6e05e33)}.site-footer{color:#e2e8f0;background:linear-gradient(135deg,#2d3748,#1a202c);border-top:3px solid #667eea;margin-top:auto;padding:2rem 0 1rem}.footer-content{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1200px;margin:0 auto;padding:0 2rem;display:grid}.footer-section h4{color:#cbd5e0;margin-bottom:.75rem;font-size:1.1rem;font-weight:700}.footer-section p{color:#a0aec0;font-size:.9rem;line-height:1.6}.footer-section strong{color:#e2e8f0}.footer-bottom{text-align:center;border-top:1px solid #4a5568;max-width:1200px;margin:2rem auto 0;padding:1rem 2rem}.footer-bottom p{color:#718096;font-size:.85rem}.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}.footer-toggle{display:none}.site-footer.mobile{padding:0}.site-footer.mobile .footer-toggle{color:#e2e8f0;cursor:pointer;background:linear-gradient(135deg,#2d3748,#1a202c);border:none;border-top:3px solid #667eea;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.site-footer.mobile .footer-toggle:hover{background:linear-gradient(135deg,#3d4758,#2a303c)}.footer-toggle-text{align-items:center;gap:.5rem;display:flex}.footer-toggle-icon{font-size:.8rem;transition:transform .3s}.site-footer.mobile.collapsed .footer-toggle-icon{transform:rotate(180deg)}.site-footer.mobile .footer-content,.site-footer.mobile .footer-bottom{transition:all .3s;overflow:hidden}.site-footer.mobile .footer-content.hidden,.site-footer.mobile .footer-bottom.hidden{opacity:0;visibility:hidden;max-height:0;margin:0;padding:0}.site-footer.mobile .footer-content:not(.hidden){opacity:1;visibility:visible;max-height:2000px;padding:1.5rem 1rem}.site-footer.mobile .footer-bottom:not(.hidden){opacity:1;visibility:visible;max-height:100px;padding:1rem}.dark-mode .site-footer.mobile .footer-toggle{background:linear-gradient(135deg,#1a202c,#0d1117);border-top-color:#764ba2}.dark-mode .site-footer.mobile .footer-toggle:hover{background:linear-gradient(135deg,#2a303c,#1d2127)}.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 .no-feature{color:#718096}.dark-mode .tab-button{color:#e2e8f0;background:#1a202ce6;border-color:#4a5568}.dark-mode .tab-button:hover{background:#1a202c}.dark-mode .tab-button.active{color:#fff;background:linear-gradient(135deg,#764ba2,#667eea)}.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{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(#fff,#fafbfc);border:1px solid #ffffffe6;border-radius:32px;max-width:1400px;margin:2rem auto;padding:3rem;position:relative;overflow:hidden;box-shadow:0 24px 72px #00000040,0 8px 24px #00000026}.character-creation:before{content:"";background:linear-gradient(90deg,#667eea,#764ba2,#667eea) 0 0/200% 100%;height:6px;animation:3s infinite gradientShift;position:absolute;top:0;left:0;right:0}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}.validation-errors{background:linear-gradient(135deg,#fed7d7,#feb2b2);border-left:5px solid #e53e3e;border-radius:16px;margin-bottom:2rem;padding:1.5rem;animation:.3s ease-out slideDown;box-shadow:0 4px 12px #e53e3e33}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.validation-errors h3{color:#742a2a;margin-bottom:1rem;font-size:1.2rem;font-weight:700}.validation-errors ul{margin:0;padding:0;list-style:none}.validation-errors li{color:#742a2a;padding:.5rem 0;font-size:1rem}.validation-errors li strong{text-transform:capitalize;font-weight:700}.debug-toggle{color:#fff;cursor:pointer;background:#718096;border:none;border-radius:8px;margin-bottom:1rem;padding:.5rem 1rem;font-size:.9rem;transition:all .2s}.debug-toggle:hover{background:#4a5568}.debug-panel{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.debug-panel h4{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1.5rem;font-family:Cinzel,serif;font-size:1.2rem;font-weight:700}.debug-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-auto-flow:row;align-items:start;gap:1.5rem;display:grid}.debug-section{z-index:1;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:1.25rem;position:relative}.debug-section-wide{box-sizing:border-box;grid-column:span 1;min-width:400px;max-width:500px;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;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #667eea;margin-bottom:1rem;padding-bottom:.5rem;font-size:.9rem;font-weight:700}.debug-item{border-bottom:1px solid #f7fafc;justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.debug-item:last-child{border-bottom:none}.debug-label{color:#718096;font-size:.9rem;font-weight:600}.debug-value{color:#48bb78;font-size:.95rem;font-weight:700}.debug-missing{color:#f56565;font-size:.95rem;font-weight:600}.debug-traits{grid-template-columns:repeat(2,1fr);gap:.5rem;display:grid}.debug-trait-item{background:#f7fafc;border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem;display:flex}.main-navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;isolation:isolate;background:linear-gradient(135deg,#fffffff2,#f7fafcf2);border-bottom:2px solid #667eea1a;padding:1rem 0;position:sticky;top:0;box-shadow:0 2px 8px #0000001a}.dark-mode .main-navigation{background:linear-gradient(135deg,#1a202cf2,#2d3748f2);border-bottom-color:#4a5568;box-shadow:0 2px 8px #0000004d}.nav-container{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;position:relative}.nav-brand{align-items:center;display:flex}.nav-logo{color:#667eea;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-family:Cinzel,serif;font-size:1.5rem;font-weight:700;text-decoration:none}.nav-links{align-items:center;gap:2rem;display:flex}.nav-actions{align-items:center;gap:1rem;display:flex}.nav-links a{color:#4a5568;border-radius:8px;padding:.5rem 1rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s;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"]{text-align:center;border-radius:8px;min-width:auto;padding:.5rem 1rem;font-size:1rem;font-weight:600}.main-navigation .theme-toggle{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.5rem 1rem;font-size:1.25rem;transition:all .2s;display:flex;box-shadow:0 2px 8px #667eea4d}.main-navigation .theme-toggle:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.mobile-menu-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:44px;min-height:44px;padding:.5rem;display:none}.hamburger{flex-direction:column;gap:4px;width:24px;height:18px;display:flex;position:relative}.hamburger span{transform-origin:50%;background:#4a5568;border-radius:2px;width:100%;height:2px;transition:all .3s;display:block}.dark-mode .hamburger span{background:#e2e8f0}.hamburger.open span:first-child{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{z-index:9999;opacity:0;visibility:hidden;pointer-events:none;background:#00000080;transition:opacity .3s,visibility .3s;display:none;position:fixed;top:0;right:0;bottom:0;left:0}.mobile-nav-menu.open{pointer-events:auto;opacity:1;visibility:visible}.mobile-nav-links{-webkit-overflow-scrolling:touch;z-index:1;pointer-events:auto;background:linear-gradient(#fff,#fafbfc);flex-direction:column;gap:.5rem;width:280px;max-width:85vw;height:100%;padding:2rem 1.5rem;transition:transform .3s;display:flex;position:absolute;top:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 20px #00000026}.dark-mode .mobile-nav-links{background:linear-gradient(#1a202c,#2d3748)}.mobile-nav-menu.open .mobile-nav-links{transform:translate(0)}.mobile-nav-links a{color:#4a5568;border-radius:8px;align-items:center;min-height:44px;padding:1rem 1.25rem;font-size:1.1rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.dark-mode .mobile-nav-links a{color:#e2e8f0}.mobile-nav-links a:hover{color:#667eea;background:#667eea1a}.mobile-nav-links a.active{color:#667eea;background:linear-gradient(135deg,#667eea26,#764ba226)}.mobile-account-menu{border-top:1px solid #667eea1a;margin-top:.5rem;padding-top:.5rem;position:relative}.mobile-account-menu .account-menu{width:100%;position:static}.mobile-account-menu .account-menu-button{text-align:left;border-radius:8px;width:100%;padding:1rem 1.25rem}.mobile-account-menu .account-menu-dropdown{width:100%;min-width:auto;box-shadow:none;background:0 0;border:none;border-radius:0;margin-top:.5rem;margin-left:0;position:static;top:auto;left:0;right:auto}.mobile-account-menu .account-menu-item{border-radius:6px;margin-bottom:.25rem;padding:.75rem 1.25rem .75rem 2rem}.dark-mode .mobile-account-menu .account-menu-dropdown{background:0 0;border:none}@media (min-width:769px){.desktop-nav{display:flex}.mobile-menu-toggle,.mobile-nav-menu,.nav-brand{display:none}}.creation-header{border-bottom:2px solid #667eea1a;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.header-left{flex:1}.creation-header h1{-webkit-text-fill-color:transparent;letter-spacing:1px;text-transform:uppercase;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-family:Cinzel,serif;font-size:2rem;font-weight:800}.step-indicator-inline{justify-content:center;align-items:center;display:flex}.step-indicator-text{color:#4a5568;font-size:1rem;font-weight:600}.step-subtitle{text-align:center;color:#718096;flex:1;padding:0 1rem;font-size:.95rem;font-style:italic}.header-right{align-items:center;gap:1rem;display:flex}.random-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;padding:.75rem;font-size:1.5rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #f5576c4d}.random-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.debug-toggle{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #667eea4d}.debug-toggle:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.step-indicator{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.step-number{color:#718096;background:#f7fafc;border:2px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex}.step-number.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.step-number.completed{color:#fff;background:#48bb78;border-color:#48bb78}.step-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.progress-bar{background-color:#e2e8f0;border-radius:12px;width:100%;height:12px;margin-bottom:2.5rem;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;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;text-align:center;margin-bottom:.75rem;font-size:2rem;font-weight:700}.step-content>p{color:#718096;text-align:center;margin-bottom:2rem;font-size:1.1rem}.step-navigation{justify-content:space-between;align-items:center;gap:1rem;display:flex}.step-navigation.top{border-bottom:2px solid #e2e8f0;margin-top:0;margin-bottom:2rem;padding-bottom:1.5rem}.step-navigation.bottom{border-top:2px solid #e2e8f0;margin-top:2rem;padding-top:1.5rem}.step-navigation button{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #667eea4d}.step-navigation.top button{flex:none}.step-navigation button:disabled{cursor:not-allowed;box-shadow:none;opacity:.6;background:#cbd5e0}.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{cursor:not-allowed;box-shadow:none;opacity:.6;background:#cbd5e0}.step-navigation button.next-button.disabled:hover,.step-navigation button.next-button:disabled:hover{box-shadow:none;transform:none}.list-detail-container{grid-template-columns:355px 1fr;gap:2rem;min-height:500px;margin:2rem 0;display:grid}.list-detail-container.subclass-section,.list-detail-container.community-section,.list-detail-container.secondary-weapon-section,.list-detail-container.armor-section{border-top:2px solid #e2e8f0;margin-top:3rem;padding-top:2rem}.equipment-hint{color:#718096;margin:.5rem 0 1rem;font-size:.9rem;font-style:italic}.equipment-hint-header{color:#718096;border-bottom:1px solid #e2e8f0;margin:0 0 1rem;padding-bottom:1rem;font-size:.9rem;font-style:italic}.equipment-legend{color:#f59e0be6;margin-bottom:.5rem;padding:0 .5rem;font-size:.85rem}body.dark-mode .equipment-legend{color:#fbbf24e6}.equipment-legend .legend-text{align-items:center;gap:.25rem;font-weight:500;display:flex}.equipment-search-box{margin-bottom:.75rem;padding:0 .5rem}.equipment-filters{box-sizing:border-box;flex-direction:column;gap:.75rem;width:100%;margin-bottom:1rem;padding:0 .5rem;display:flex}.equipment-search-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;width:100%;padding:.5rem .75rem;font-size:.9rem;transition:all .2s}.equipment-search-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.equipment-filter-group{align-items:center;gap:.125rem;display:flex}.equipment-filter-group label{color:#4a5568;flex-shrink:0;width:auto;min-width:auto;margin:0 .125rem 0 0;padding:0;font-size:.85rem;font-weight:600}@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{color:#2d3748;cursor:pointer;box-sizing:border-box;background:#fff;border:2px solid #e2e8f0;border-radius:8px;width:100%;max-width:100%;padding:.5rem .75rem;font-size:.9rem;transition:all .2s}.equipment-filter-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.dark-mode .equipment-search-input,.dark-mode .equipment-filter-select{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.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{text-align:center;color:#718096;padding:2rem;font-style:italic}.dark-mode .no-results-message{color:#a0aec0}.detail-header-with-hint{margin-bottom:1rem}.weapon-section-header{color:#667eea;text-transform:uppercase;letter-spacing:.5px;border-top:1px solid #e2e8f0;margin:1.5rem 0 .75rem;padding-top:1rem;font-size:.85rem;font-weight:700}.weapon-section-header:first-of-type{border-top:none;margin-top:.5rem;padding-top:0}.selection-list{background:linear-gradient(135deg,#fff,#f7fafc);border:1px solid #667eea1a;border-radius:16px;flex-direction:column;height:-moz-fit-content;height:fit-content;max-height:600px;padding:1.5rem;display:flex;box-shadow:0 4px 12px #00000014}.dark-mode .selection-list{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.list-header{border-bottom:2px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;display:flex}.list-header.invalid{background:linear-gradient(135deg,#f565650d,#f5656505);border-bottom-color:#f56565;border-radius:8px;padding:.75rem}.validation-error{color:#f56565;margin-left:auto;font-size:.85rem;font-weight:600}.validation-error-banner{color:#f56565;text-align:center;background:linear-gradient(135deg,#f565651a,#f565650d);border:2px solid #f56565;border-radius:10px;margin-bottom:1.5rem;padding:1rem;font-weight:600}.validation-error-inline{color:#f56565;margin-top:.5rem;font-size:.85rem;font-weight:600;display:block}.invalid-input{background:linear-gradient(135deg,#fffffff2,#f565650d)!important;border-color:#f56565!important}.invalid-input:focus{border-color:#f56565!important;box-shadow:0 0 0 3px #f5656533!important}.list-header h3{color:#2d3748;margin:0;font-size:1.3rem;font-weight:700}.dark-mode .list-header{border-bottom-color:#4a5568}.dark-mode .list-header h3{color:#e2e8f0}.list-items{flex-direction:column;gap:.5rem;padding-right:.5rem;display:flex;overflow-y:auto}.list-items::-webkit-scrollbar{width:6px}.list-items::-webkit-scrollbar-track{background:#f7fafc;border-radius:10px}.list-items::-webkit-scrollbar-thumb{background:linear-gradient(#667eea,#764ba2);border-radius:10px}.list-item{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;align-items:center;gap:.75rem;padding:1rem;transition:all .2s;display:flex}.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{flex-shrink:0;font-size:1.75rem}.list-item-name{color:#2d3748;flex:1;font-size:1.05rem;font-weight:600}.list-item-burden{color:#667eea;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:6px;padding:.25rem .5rem;font-size:.75rem;font-weight:700}.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:1px solid #667eea1a;border-radius:16px;flex-direction:column;min-height:500px;padding:2rem;display:flex;box-shadow:0 4px 12px #00000014}.detail-header{border-bottom:2px solid #e2e8f0;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;display:flex}.detail-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;justify-content:center;align-items:center;width:80px;height:80px;font-size:4rem;display:flex;box-shadow:0 4px 12px #667eea4d}.detail-header h3{color:#2d3748;margin:0;font-family:Cinzel,serif;font-size:2rem;font-weight:800}.detail-subtitle{color:#718096;text-transform:uppercase;letter-spacing:.5px;font-size:.95rem;font-weight:600}.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{color:#4a5568;border-left:3px solid #667eea;margin-bottom:2rem;padding-left:1rem;font-size:1.05rem;line-height:1.7}.dark-mode .detail-description{color:#cbd5e0}.detail-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.detail-stat-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;transition:all .2s}.detail-stat-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.detail-stat-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.85rem;font-weight:600}.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{color:#2d3748;font-size:1.25rem;font-weight:700}.dark-mode .detail-stat-value{color:#e2e8f0}.detail-placeholder{color:#a0aec0;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.placeholder-icon{opacity:.3;margin-bottom:1rem;font-size:5rem}.detail-placeholder p{color:#718096;font-size:1.1rem;font-weight:600}.dark-mode .detail-placeholder p{color:#cbd5e0}.selection-detail .features-list{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:12px;margin-top:1.5rem;padding:1.5rem}.selection-detail .features-header{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;font-family:Cinzel,serif;font-size:1.1rem;font-weight:700}.selection-detail .feature-item{background:#fff;border-left:3px solid #667eea;border-radius:8px;margin-bottom:.75rem;padding:1rem}.selection-detail .feature-item:last-child{margin-bottom:0}.selection-detail .feature-name{color:#2d3748;margin-bottom:.5rem;font-size:1.05rem;font-weight:700}.selection-detail .feature-desc{color:#4a5568;font-size:.95rem;line-height:1.6}.selection-detail .feature-box{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-left:3px solid #667eea;border-radius:12px;margin-top:1.5rem;padding:1.25rem}.selection-detail .feature-box .feature-name{color:#2d3748;margin-bottom:.5rem;font-size:1.05rem;font-weight:700}.selection-detail .feature-box .feature-desc{color:#4a5568;font-size:.95rem;line-height:1.6}.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 #4a5568 #4a5568 #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{color:#fff;background:linear-gradient(135deg,#f687b3,#f56565);border-radius:8px;padding:.5rem 1rem;font-weight:700}.carousel-section{margin:2.5rem 0}.subclass-section{border-top:2px solid #e2e8f0;margin-top:3rem;padding-top:2rem;animation:.4s ease-out slideDown}.carousel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.carousel-header h3{color:#2d3748;margin:0;font-size:1.5rem;font-weight:700}.required-badge{color:#742a2a;background:linear-gradient(135deg,#fed7d7,#feb2b2);border-radius:20px;padding:.5rem 1rem;font-size:.875rem;font-weight:700;box-shadow:0 2px 6px #e53e3e33}.validated-badge{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border-radius:20px;padding:.5rem 1rem;font-size:.875rem;font-weight:700;box-shadow:0 2px 6px #48bb7833}.required-badge-inline,.validated-badge-inline{font-size:.75rem;font-weight:700;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.required-badge-inline{color:#f56565}.validated-badge-inline{color:#48bb78}.input-with-validation{position:relative}.trait-validation-header,.experiences-validation-header,.domain-validation-header{justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.domain-validation-header{flex-wrap:wrap;gap:.5rem}.completed-badge{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border-radius:20px;padding:.5rem 1rem;font-size:.875rem;font-weight:700;box-shadow:0 2px 6px #48bb7833}.carousel-container{align-items:center;gap:1rem;display:flex;position:relative}.carousel-track{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#cbd5e0 #f7fafc;flex:1;gap:1.5rem;padding:1rem .5rem;display:flex;overflow-x:auto}.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{color:#fff;cursor:pointer;z-index:10;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:2rem;font-weight:300;transition:all .3s;display:flex;box-shadow:0 4px 12px #667eea4d}.carousel-button:hover{transform:scale(1.1);box-shadow:0 6px 16px #667eea66}.carousel-button:active{transform:scale(.95)}.carousel-card{cursor:pointer;background:linear-gradient(135deg,#fff,#f7fafc);border:1px solid #fffc;border-radius:24px;flex-direction:column;flex:0 0 420px;min-height:360px;padding:0;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 8px 24px #0000001f,0 2px 6px #00000014}.carousel-card:before{content:"";opacity:0;pointer-events:none;background:linear-gradient(135deg,#667eea0d,#764ba20d);transition:opacity .4s;position:absolute;top:0;right:0;bottom:0;left:0}.carousel-card:after{content:"";opacity:0;background:linear-gradient(90deg,#667eea,#764ba2);height:5px;transition:opacity .4s;position:absolute;top:0;left:0;right:0}.carousel-card:hover{border-color:#667eea4d;transform:translateY(-12px)scale(1.03);box-shadow:0 20px 40px #667eea40,0 8px 16px #00000026}.carousel-card:hover:before,.carousel-card:hover:after{opacity:1}.carousel-card.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe) padding-box padding-box;border:3px solid #0000;position:relative;transform:translateY(-4px)scale(1.05);box-shadow:0 12px 24px #667eea4d}.carousel-card.selected:before{opacity:1;height:8px}.carousel-card.selected:after{content:"";z-index:-1;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:3px;position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.card-header-badge{color:#fff;text-align:center;letter-spacing:1px;text-transform:uppercase;background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;font-family:Cinzel,serif;font-size:1.6rem;font-weight:800;position:relative;box-shadow:0 4px 12px #0003}.card-header-badge:before{content:"";pointer-events:none;background:linear-gradient(#ffffff1a,#0000);position:absolute;top:0;right:0;bottom:0;left:0}.card-image-placeholder{color:#ffffff4d;background:linear-gradient(135deg,#667eea,#764ba2);justify-content:center;align-items:center;width:100%;height:180px;font-size:4rem;display:flex;position:relative;overflow:hidden}.card-image-placeholder:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;animation:2s infinite shimmer;position:absolute;top:0;left:-100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.card-image-overlay{background:linear-gradient(#0000,#0009);align-items:flex-end;height:60px;padding:.75rem 1rem;display:flex;position:absolute;bottom:0;left:0;right:0}.card-image-title{color:#fff;text-shadow:0 2px 4px #00000080;font-family:Cinzel,serif;font-size:1.3rem;font-weight:700}.card-content{background:linear-gradient(#fff,#fafbfc);flex-direction:column;flex:1;gap:1.25rem;padding:1.75rem;display:flex}.card-description{color:#4a5568;flex:1;padding-left:1rem;font-size:.975rem;font-weight:500;line-height:1.7;position:relative}.card-description:before{content:"";background:linear-gradient(#667eea,#764ba2);border-radius:2px;width:3px;position:absolute;top:.25rem;bottom:.25rem;left:0}.card-stats{flex-direction:column;gap:.75rem;margin-top:auto;display:flex}.stat-row{gap:.75rem;display:flex}.stat-item{flex-direction:column;flex:1;gap:.25rem;display:flex}.stat-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.stat-value{color:#2d3748;text-align:center;background:linear-gradient(135deg,#fff,#f7fafc);border:1px solid #667eea1a;border-radius:10px;padding:.625rem .75rem;font-size:1.05rem;font-weight:700;transition:all .2s;box-shadow:0 2px 6px #00000014,inset 0 1px 2px #ffffff80}.carousel-card:hover .stat-value{border-color:#667eea4d;box-shadow:0 3px 8px #0000001f,inset 0 1px 2px #ffffff80}.selected-indicator{color:#fff;text-align:center;letter-spacing:1px;text-transform:uppercase;background:linear-gradient(135deg,#48bb78,#38a169);padding:1rem;font-family:Cinzel,serif;font-size:1.1rem;font-weight:800;position:relative;box-shadow:0 -4px 12px #48bb784d}.selected-indicator:before{content:"";pointer-events:none;background:linear-gradient(#fff3,#0000);position:absolute;top:0;right:0;bottom:0;left:0}.selection-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.selection-card{cursor:pointer;background:linear-gradient(135deg,#fff,#f7fafc);border:none;border-radius:16px;padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 6px #00000012}.selection-card:before{content:"";opacity:0;background:linear-gradient(90deg,#667eea,#764ba2);height:4px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.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);transform:translateY(-2px);box-shadow:0 8px 16px #667eea40}.selection-card.selected:before{opacity:1;height:6px}.selection-card h3,.selection-card h4{color:#2d3748;margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.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{color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.875rem;font-weight:700}.feature-item{background:#fff;border-radius:8px;margin-bottom:.75rem;padding:.75rem;box-shadow:0 2px 4px #0000000d}.feature-name{color:#2d3748;margin-bottom:.25rem;font-size:.95rem;font-weight:700}.feature-desc{color:#4a5568;font-size:.875rem;line-height:1.5}.equipment-card{flex:0 0 360px;min-height:300px}.equipment-stats{flex-direction:column;gap:.75rem;display:flex}.equipment-hint{color:#718096;margin-top:.5rem;margin-bottom:1rem;font-size:.9rem;font-style:italic}.stat-value.damage{color:#fff;background:linear-gradient(135deg,#f093fb,#f5576c)}.feature-box{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-left:3px solid #667eea;border-radius:8px;margin-top:.75rem;padding:.75rem}.feature-box .feature-name{color:#667eea;margin-bottom:.25rem;font-size:.875rem;font-weight:700}.feature-box .feature-desc{color:#4a5568;font-size:.825rem;line-height:1.4}.trait-assignment{margin-top:1.5rem}.available-modifiers{text-align:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px;margin-bottom:2.5rem;padding:2rem;box-shadow:0 4px 12px #0000000d}.available-modifiers.compact{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.available-modifiers.compact .modifier-label{color:#4a5568;align-items:center;gap:.25rem;font-size:.95rem;font-weight:600;display:flex}.available-modifiers h3{color:#2d3748;margin-bottom:1.25rem;font-size:1.3rem;font-weight:700}.modifier-pool{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.available-modifiers.compact .modifier-pool{gap:.5rem;min-height:auto}.modifier-badge{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;padding:.875rem 1.75rem;font-size:1.2rem;font-weight:700;animation:2s ease-in-out infinite pulse;display:inline-block;box-shadow:0 4px 12px #667eea59}.all-assigned-message{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:14px;padding:.875rem 1.75rem;font-size:1.2rem;font-weight:700;display:inline-block;box-shadow:0 4px 12px #48bb7859}.trait-list{flex-direction:column;gap:1rem;display:flex}.trait-row{background:linear-gradient(135deg,#fff,#f7fafc);border:2px solid #0000;border-radius:16px;flex-direction:column;gap:1rem;padding:1.75rem;transition:all .3s;display:flex;box-shadow:0 2px 8px #0000000f}.trait-row:hover{border-color:#667eea33;box-shadow:0 6px 16px #0000001a}.trait-info{justify-content:space-between;align-items:center;gap:1rem;display:flex}.trait-name{color:#2d3748;flex:1;align-items:center;gap:.25rem;font-size:1.1rem;font-weight:600;display:flex}.current-value{color:#fff;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;min-width:70px;padding:.5rem 1.25rem;font-size:1.4rem;font-weight:700;box-shadow:0 2px 8px #667eea4d}.modifier-selector{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.modifier-button{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:12px;min-width:70px;padding:.875rem 1.5rem;font-size:1.1rem;font-weight:700;transition:all .2s;box-shadow:0 2px 4px #0000000d}.modifier-button:hover:not(:disabled){background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 10px #667eea40}.modifier-button.selected{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border-color:#0000;transform:scale(1.05);box-shadow:0 4px 12px #48bb7866}.modifier-button.unavailable{opacity:.3;cursor:not-allowed;background:#f7fafc}.modifier-button:disabled{cursor:not-allowed}.dark-mode .modifier-button{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .modifier-button:hover:not(:disabled){background:linear-gradient(135deg,#2c5282,#434190);border-color:#667eea}.success-message{text-align:center;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border-radius:16px;margin-top:2rem;padding:1.5rem;box-shadow:0 4px 12px #48bb7833}.success-message p{color:#22543d;margin:0;font-size:1.2rem;font-weight:700}.modifier-hint{text-align:center;color:#718096;margin-top:.75rem;font-size:.9rem;font-style:italic}.modifier-badge.clickable{cursor:pointer;transition:all .2s}.modifier-badge.clickable:hover{transform:scale(1.1);box-shadow:0 6px 18px #667eea80}.trait-list.two-column{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.trait-row.compact{padding:1.25rem;position:relative}.trait-row.compact .trait-info{margin-bottom:.75rem}.trait-row.compact .modifier-selector{justify-content:flex-start;gap:.5rem}.trait-row-bottom-right{pointer-events:none;position:absolute;bottom:.5rem;right:.5rem}.suggested-trait-label-bottom-right{color:#f59e0be6;font-size:.85rem;font-weight:500}body.dark-mode .suggested-trait-label-bottom-right{color:#fbbf24e6}.spellcast-indicator-top-right{vertical-align:middle;opacity:.9;margin-left:.5rem;font-size:1rem;display:inline-block}.trait-row.spellcast-trait-row{background:linear-gradient(135deg,#b794f414,#667eea0d);border:2px solid #b794f480}.trait-row.required-trait{background:linear-gradient(135deg,#f5656514,#ed89360d);border-color:#f5656599}.trait-row.required-trait.spellcast-trait-row{background:linear-gradient(135deg,#b794f41f,#f5656514);border-color:#b794f4b3}.spellcast-indicator,.required-indicator{vertical-align:middle;opacity:.9;margin-left:.5rem;font-size:1rem;display:inline-block}.spellcast-requirement-notice{color:#667eea;background:linear-gradient(135deg,#b794f41a,#667eea14);border:2px solid #b794f466;border-radius:8px;margin-top:1.5rem;padding:1rem;font-size:.95rem;line-height:1.6}.spellcast-requirement-notice strong{color:#764ba2}.dark-mode .trait-row.spellcast-trait-row{background:linear-gradient(135deg,#b794f426,#667eea1a);border-color:#b794f499}.dark-mode .trait-row.required-trait{background:linear-gradient(135deg,#f5656526,#ed89361a);border-color:#f56565b3}.dark-mode .trait-row.required-trait.spellcast-trait-row{background:linear-gradient(135deg,#b794f433,#f5656526);border-color:#b794f4cc}.suggested-trait-label{color:#f59e0be6;margin-top:.25rem;margin-bottom:.25rem;font-size:.85rem;font-weight:500}body.dark-mode .suggested-trait-label{color:#fbbf24e6}.list-item.suggested-item{background:linear-gradient(90deg,#f59e0b0d,#0000);border-left:3px solid #f59e0b99}body.dark-mode .list-item.suggested-item{background:linear-gradient(90deg,#fbbf2414,#0000);border-left-color:#fbbf2499}.suggested-badge{color:#f59e0be6;vertical-align:middle;margin-left:.5rem;font-size:.9rem;display:inline-block}body.dark-mode .suggested-badge{color:#fbbf24e6}.dark-mode .spellcast-requirement-notice{color:#b794f4;background:linear-gradient(135deg,#b794f426,#667eea1f);border-color:#b794f480}.dark-mode .spellcast-requirement-notice strong{color:#c084fc}.modifier-button.available{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);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{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border:none;min-width:70px}.modifier-button.selected:hover{background:linear-gradient(135deg,#f093fb,#f5576c)}.potion-selection{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px;margin:2.5rem 0;padding:2rem}.potion-header{justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.potion-selection h3{color:#2d3748;text-align:center;margin:0;font-size:1.5rem;font-weight:700}.potion-options{gap:1.5rem;margin-top:1rem;display:flex}.potion-button{cursor:pointer;background:#fff;border:3px solid #e2e8f0;border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:.75rem;padding:1.75rem;transition:all .3s;display:flex;box-shadow:0 4px 8px #0000000f}.potion-button:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 12px 24px #0000001f}.potion-button.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:#667eea;transform:translateY(-2px);box-shadow:0 8px 16px #667eea40}.potion-icon{font-size:3rem}.potion-name{color:#2d3748;font-size:1.1rem;font-weight:700}.potion-effect{color:#718096;font-size:.9rem;font-style:italic}.starting-inventory{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:16px;margin:2.5rem 0;padding:2rem}.starting-inventory h3{color:#2d3748;text-align:center;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.inventory-item{color:#4a5568;text-align:center;background:#fff;border-radius:12px;padding:1rem;font-weight:600;transition:all .2s;box-shadow:0 2px 6px #0000000d}.inventory-item.highlight{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);font-weight:700}.dark-mode .inventory-item{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.background-form{flex-direction:column;gap:2rem;display:flex}.form-field{flex-direction:column;gap:.75rem;display:flex}.form-field label{color:#2d3748;justify-content:space-between;align-items:center;font-size:1.05rem;font-weight:600;display:flex}.required-indicator{color:#f56565;margin-left:.25rem;font-weight:700}.form-field input,.form-field textarea{background:#fff;border:2px solid #e2e8f0;border-radius:12px;width:100%;max-width:100%;padding:1rem;font-family:inherit;font-size:1rem;transition:all .2s}.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{width:100%;max-width:100%}.form-field input:focus,.form-field textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-field textarea{resize:vertical;min-height:120px}.experience-card{background:linear-gradient(135deg,#fff,#f7fafc);border:1px solid #667eea1a;border-radius:16px;padding:2rem;transition:all .3s;box-shadow:0 4px 12px #00000014}.experience-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea26}.experience-card-header{border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.experience-card-header h3{color:#2d3748;margin:0;font-family:Cinzel,serif;font-size:1.5rem;font-weight:700}.experience-modifier{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:20px;margin-top:.5rem;padding:.4rem 1rem;font-size:.85rem;font-weight:700;display:inline-block}.suggest-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #667eea4d}.suggest-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.experience-card-content{flex-direction:column;gap:1rem;display:flex}.experience-input{background:#fff;border:2px solid #e2e8f0;border-radius:10px;width:100%;padding:1rem;font-size:1rem;transition:all .2s}.experience-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.suggestions{margin-top:.5rem}.suggestions-summary{cursor:pointer;color:#4a5568;background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:10px;padding:.75rem 1rem;font-weight:600;transition:all .2s}.suggestions-summary:hover{background:linear-gradient(135deg,#edf2f7,#e2e8f0);border-color:#667eea}.suggestion-categories{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:1.5rem;margin-top:1rem;padding:1rem;display:flex}.suggestion-category{flex-direction:column;gap:.75rem;display:flex}.suggestion-category strong{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;font-size:.95rem;font-weight:700}.suggestion-tags{flex-wrap:wrap;gap:.75rem;display:flex}.suggestion-tag{cursor:pointer;color:#4a5568;background:linear-gradient(135deg,#fff,#f7fafc);border:1px solid #e2e8f0;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;box-shadow:0 2px 4px #0000000f}.suggestion-tag:hover{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.domain-cards-selection{margin-top:1.5rem}.domain-section{margin-bottom:2.5rem}.domain-section h3,.domain-section-title{color:#2d3748;border-bottom:3px solid;-o-border-image:linear-gradient(90deg,#667eea 0%,#764ba2 100%) 1;border-image:linear-gradient(90deg,#667eea,#764ba2) 1;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.5rem;font-weight:700;display:inline-block}.dark-mode .domain-section h3,.dark-mode .domain-section-title{color:#e2e8f0;-o-border-image:linear-gradient(90deg,#667eea 0%,#764ba2 100%) 1;border-image:linear-gradient(90deg,#667eea,#764ba2) 1}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.domain-card{cursor:pointer;background:linear-gradient(135deg,#fff,#f7fafc);border:none;border-radius:16px;padding:1.75rem;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 4px 6px #00000012}.domain-card:before{content:"";opacity:0;background:linear-gradient(90deg,#667eea,#764ba2);height:4px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.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);transform:translateY(-2px);box-shadow:0 8px 16px #667eea40}.domain-card.selected:before{opacity:1;height:6px}.domain-card.disabled{opacity:.5;cursor:not-allowed}.card-header{color:#718096;justify-content:space-between;margin-bottom:.75rem;font-size:.9rem;font-weight:600;display:flex}.domain-card h4{color:#2d3748;margin-bottom:.5rem;font-size:1.3rem;font-weight:700}.card-type{color:#718096;margin:.5rem 0;font-size:.95rem;font-style:italic}.card-feature{color:#4a5568;margin-top:.75rem;font-size:.95rem;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{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:24px;max-width:1400px;margin:2rem auto;padding:3rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;position:relative;overflow:hidden;box-shadow:0 20px 60px #0000004d}.character-sheet:before{content:"";pointer-events:none;mix-blend-mode:normal;background:radial-gradient(1200px 600px at 20% 10%,#667eea1a,#0000 55%),radial-gradient(1000px 700px at 80% 0,#764ba21a,#0000 55%),radial-gradient(900px 700px at 50% 100%,#48bb780f,#0000 60%);position:absolute;top:0;right:0;bottom:0;left:0}.sheet-header,.sheet-content{z-index:1;position:relative}.unsaved-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.25rem 2rem;display:flex;box-shadow:0 4px 12px #f59e0b33}.unsaved-message{flex:auto;align-items:center;gap:.75rem;min-width:200px;display:flex}.unsaved-actions{flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:1rem;max-width:100%;display:flex}.unsaved-actions .random-button{color:#fff;cursor:pointer;box-sizing:border-box;background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;padding:.75rem;font-size:1.5rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px #f5576c4d}.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{color:#fff;cursor:pointer;white-space:nowrap;box-sizing:border-box;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;max-width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px #667eea4d}.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{color:#fff;cursor:pointer;white-space:nowrap;box-sizing:border-box;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;max-width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px #48bb784d}.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{border-bottom:3px solid;-o-border-image:linear-gradient(90deg,#667eea 0%,#764ba2 100%) 1;border-image:linear-gradient(90deg,#667eea,#764ba2) 1;margin-bottom:3rem;padding-bottom:2rem;position:relative}.sheet-watermark{opacity:.08;pointer-events:none;z-index:0;filter:blur(1px);font-size:8rem;line-height:1;position:absolute;top:50%;right:2rem;transform:translateY(-50%)}.dark-mode .sheet-watermark{opacity:.12;filter:blur(.5px)}.sheet-header-main{justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1rem;display:flex}.character-avatar-display{flex-shrink:0;width:120px;height:120px;display:inline-block;position:relative;overflow:visible}.character-avatar-image{-o-object-fit:cover;object-fit:cover;border:4px solid #667eea;border-radius:50%;width:120px;height:120px;display:block;box-shadow:0 4px 12px #667eea4d}.character-avatar-edit-overlay{opacity:0;pointer-events:none;background:#0009;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;transition:opacity .2s;display:flex;position:absolute;top:0;left:0}.character-avatar-display:hover .character-avatar-edit-overlay{opacity:1;pointer-events:auto}.character-avatar-edit-controls{flex-direction:column;align-items:center;gap:.5rem;display:flex}.character-avatar-edit-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;padding:.4rem .8rem;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{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #667eea;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:auto;min-width:280px;max-width:100%;min-height:auto;padding:1.25rem;display:flex;position:relative}.character-avatar-placeholder-edit .character-avatar-add-button{margin-bottom:.5rem}.character-avatar-placeholder-edit .restriction-text{color:#fff;text-align:center;opacity:.95;margin:0;font-size:.75rem;line-height:1.4}.character-avatar-placeholder-edit .restriction-text strong{margin-bottom:.25rem;font-weight:600;display:block}.character-avatar-placeholder-edit .avatar-error-message{color:#fff;text-align:center;word-wrap:break-word;background:#e53e3ef2;border:1px solid #ffffff4d;border-radius:6px;max-width:100%;margin-top:.5rem;padding:.5rem .75rem;font-size:.8rem}.character-avatar-add-button{color:#667eea;cursor:pointer;background:#fff;border:2px solid #fff;border-radius:8px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;transition:all .3s;box-shadow:0 2px 8px #00000026}.character-avatar-add-button:hover:not(:disabled){background:#f7fafc;transform:translateY(-2px);box-shadow:0 4px 12px #00000040}.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{color:#fff;cursor:pointer;z-index:10;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:400;line-height:1;transition:all .3s;display:flex;position:absolute;bottom:-12px;right:-12px;box-shadow:0 4px 12px #667eea66}.character-avatar-add-trigger:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:scale(1.15)rotate(5deg);box-shadow:0 6px 16px #667eea99}.character-avatar-add-trigger:active{transform:scale(1.05)rotate(0)}.sheet-header-text{flex:1}.sheet-header-main h1{-webkit-text-fill-color:transparent;text-transform:uppercase;letter-spacing:1px;text-shadow:0 1px #0000000f;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin:0 0 .25rem;font-family:Cinzel,serif;font-size:3rem;font-weight:800}.sheet-header-info{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.sheet-level{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:.5rem 1.25rem;font-size:1.1rem;font-weight:700}.sheet-ancestry-community{flex-wrap:wrap;gap:1rem;margin-bottom:.75rem;display:flex}.sheet-class-subclass{color:#4a5568;font-size:1.1rem;font-style:italic;font-weight:600}.multiclass-badge{color:#667eea;margin-left:.5rem;font-weight:700}.dark-mode .sheet-class-subclass{color:#cbd5e0}.dark-mode .multiclass-badge{color:#90cdf4}.sheet-header-details{flex-wrap:wrap;gap:1.5rem;margin-top:1rem;display:flex}.sheet-ancestry,.sheet-community,.sheet-pronouns{color:#4a5568;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;padding:.4rem 1rem;font-size:.95rem;font-weight:600}.sheet-content{flex-direction:column;gap:2rem;display:flex}.sheet-main-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.sheet-column-left,.sheet-column-right{flex-direction:column;gap:2rem;display:flex}.sheet-section{background:linear-gradient(135deg,#fff,#f7fafc);border:1px solid #667eea1a;border-radius:16px;padding:2rem;position:relative;overflow:hidden;box-shadow:0 4px 12px #00000014}.sheet-section:before{content:"";opacity:.6;background:linear-gradient(90deg,#0000,#667eea4d 20%,#764ba24d 80%,#0000);height:3px;position:absolute;top:0;left:0;right:0}.sheet-section:after{content:"";background:linear-gradient(90deg,#0000,#667eea26,#0000);height:1px;position:absolute;bottom:0;left:0;right:0}.sheet-section.experiences-section{padding:1.25rem 1.5rem}.effects-section{margin-bottom:2rem}.effects-list{flex-direction:column;gap:.75rem;display:flex}.effect-item{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:all .2s;display:flex}.effect-item:hover{border-color:#7dd3fc;box-shadow:0 2px 8px #38bdf833}.effect-text{color:#0c4a6e;flex:1;font-size:.95rem;line-height:1.5}.effect-remove-button{color:#0c4a6e;cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:1.2rem;line-height:1;transition:all .2s}.effect-remove-button:hover{opacity:1;color:#dc2626;background:#dc26261a}.dark-mode .effect-item{background:linear-gradient(135deg,#1e3a5f,#1e40af);border-color:#3b82f6}.dark-mode .effect-item:hover{border-color:#60a5fa;box-shadow:0 2px 8px #60a5fa4d}.dark-mode .effect-text,.dark-mode .effect-remove-button{color:#dbeafe}.dark-mode .effect-remove-button:hover{color:#f87171;background:#dc262633}.fane-effect-section{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.fane-token-manager{margin-top:1rem}.fane-token-display{flex-direction:column;gap:1.25rem;display:flex}.fane-token-info{flex-direction:column;gap:.75rem;display:flex}.fane-token-header{background:linear-gradient(135deg,#fff,#f0fdf4);border:1px solid #bbf7d0;border-radius:10px;align-items:center;gap:1rem;padding:1rem;display:flex;box-shadow:0 2px 4px #22c55e1a}.fane-token-icon{filter:drop-shadow(0 2px 4px #22c55e33);font-size:2rem;line-height:1}.fane-token-stats{flex-direction:column;flex:1;gap:.25rem;display:flex}.fane-token-label{color:#166534;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.fane-token-value{color:#15803d;font-size:2rem;font-weight:700;line-height:1}.fane-token-max{color:#86efac;opacity:.8;font-size:1.25rem;font-weight:500}.fane-token-description{color:#166534;background:#fff9;border-left:3px solid #86efac;border-radius:8px;margin:0;padding:.75rem 1rem;font-size:.9rem;line-height:1.6}.fane-token-controls{flex-direction:column;gap:1rem;display:flex}.fane-token-counter{background:linear-gradient(135deg,#fff,#f0fdf4);border:2px solid #86efac;border-radius:12px;justify-content:center;align-items:center;gap:1.5rem;padding:1.25rem;display:flex;box-shadow:0 2px 8px #22c55e26}.fane-token-count-display{flex-direction:column;align-items:center;gap:.25rem;min-width:80px;display:flex}.fane-token-count-number{color:#15803d;font-size:2.5rem;font-weight:700;line-height:1}.fane-token-count-label{color:#166534;text-transform:uppercase;letter-spacing:.5px;opacity:.7;font-size:.75rem;font-weight:600}.fane-token-button{cursor:pointer;background:#fff;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 4px #0000001a}.fane-token-button-icon{line-height:1;display:block}.fane-token-button-add{color:#15803d;border-color:#22c55e}.fane-token-button-add:hover:not(:disabled){color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);transform:scale(1.1);box-shadow:0 4px 8px #22c55e4d}.fane-token-button-add:active:not(:disabled){transform:scale(.95)}.fane-token-button-remove{color:#d97706;border-color:#f59e0b}.fane-token-button-remove:hover:not(:disabled){color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);transform:scale(1.1);box-shadow:0 4px 8px #f59e0b4d}.fane-token-button-remove:active:not(:disabled){transform:scale(.95)}.fane-token-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.fane-token-reset{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #22c55e33}.fane-token-reset:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);transform:translateY(-1px);box-shadow:0 4px 8px #22c55e4d}.fane-token-reset:active:not(:disabled){transform:translateY(0)}.fane-token-reset:disabled{opacity:.5;cursor:not-allowed;transform:none}.dark-mode .fane-effect-section{background:linear-gradient(135deg,#1a2e1a,#0f1f0f);border-color:#22c55e}.dark-mode .fane-token-header{background:linear-gradient(135deg,#1f2937,#111827);border-color:#22c55e}.dark-mode .fane-token-label{color:#86efac}.dark-mode .fane-token-value{color:#4ade80}.dark-mode .fane-token-max{color:#22c55e}.dark-mode .fane-token-description{color:#d1fae5;background:#1f293780;border-left-color:#22c55e}.dark-mode .fane-token-counter{background:linear-gradient(135deg,#1f2937,#111827);border-color:#22c55e}.dark-mode .fane-token-count-number{color:#4ade80}.dark-mode .fane-token-count-label{color:#86efac}.dark-mode .fane-token-button{background:#1f2937}.dark-mode .fane-token-button-add{color:#4ade80;border-color:#22c55e}.dark-mode .fane-token-button-add:hover:not(:disabled){color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a)}.dark-mode .fane-token-button-remove{color:#fbbf24;border-color:#f59e0b}.dark-mode .fane-token-button-remove:hover:not(:disabled){color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706)}@media (max-width:768px){.fane-token-display{gap:1rem}.fane-token-header{text-align:center;flex-direction:column;padding:1rem}.fane-token-icon,.fane-token-value{font-size:1.75rem}.fane-token-counter{gap:1rem;padding:1rem}.fane-token-button{width:44px;height:44px;font-size:1.25rem}.fane-token-count-number{font-size:2rem}.fane-token-reset{width:100%;padding:.875rem;font-size:.95rem}}.sheet-section h2{-webkit-text-fill-color:transparent;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:.75rem;padding-left:1.5rem;font-family:Cinzel,serif;font-size:1.75rem;font-weight:700;position:relative}.sheet-section h2:before{content:"◆";opacity:.4;color:#667eea;font-size:1.2rem;line-height:1.75rem;position:absolute;top:.1rem;left:0}.sheet-section.experiences-section h2{margin-bottom:.75rem;padding-bottom:.5rem;font-size:1.5rem}.traits-grid{grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:1rem;display:grid}.trait-item{text-align:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;transition:all .2s;position:relative;overflow:hidden}.trait-item:before{content:"";pointer-events:none;opacity:.7;background:radial-gradient(280px 140px at 50% 0,#667eea26,#0000 60%),linear-gradient(#ffffff59,#0000 55%);position:absolute;top:0;right:0;bottom:0;left:0}.trait-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.trait-item.spellcast-trait{background:linear-gradient(135deg,#b794f41a,#667eea0d);border:2px solid #b794f499}.trait-item.spellcast-trait:before{background:linear-gradient(90deg,#b794f4cc,#667eea99)}.spellcast-badge{vertical-align:middle;opacity:.9;margin-left:.5rem;font-size:.9rem;display:inline-block}.spellcast-info{color:#667eea;background:#b794f41a;border:1px solid #b794f44d;border-radius:6px;margin-top:1rem;padding:.75rem;font-size:.9rem}.dark-mode .trait-item.spellcast-trait{background:linear-gradient(135deg,#b794f426,#667eea1a);border-color:#b794f4b3}.dark-mode .spellcast-info{color:#b794f4;background:#b794f426;border-color:#b794f466}.trait-name{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;z-index:1;flex-wrap:wrap;align-items:center;gap:.25rem;margin-bottom:.5rem;font-size:1.1rem;font-weight:700;display:flex;position:relative}.trait-value{color:#667eea;z-index:1;margin-bottom:.5rem;font-size:2rem;font-weight:800;position:relative}.trait-actions{color:#718096;z-index:1;font-size:.85rem;font-style:italic;position:relative}.combat-stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.combat-stat{text-align:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;position:relative;overflow:hidden}.combat-stat:before{content:"";pointer-events:none;opacity:.6;background:radial-gradient(320px 160px at 50% 0,#764ba21f,#0000 60%),linear-gradient(#ffffff4d,#0000 55%);position:absolute;top:0;right:0;bottom:0;left:0}.combat-stat-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;z-index:1;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:flex;position:relative}.combat-stat-value{color:#2d3748;z-index:1;flex-direction:column;align-items:center;gap:.6rem;font-size:1.75rem;font-weight:800;display:flex;position:relative}.combat-stat-value-text{line-height:1.1}.resource-track{flex-wrap:wrap;justify-content:center;gap:.35rem;max-width:260px;display:flex}.resource-pip{background:#ffffff40;border:1px solid #2d374840;border-radius:4px;width:18px;height:12px;transition:all .2s;box-shadow:inset 0 1px #fff6}.resource-pip.clickable-pip{cursor:pointer;z-index:2;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative}.resource-pip.clickable-pip:hover{border-color:#667eea99;transform:scale(1.15);box-shadow:0 2px 8px #667eea4d}.resource-pip.clickable-pip:active{transform:scale(1.05)}.resource-track.clickable{cursor:default;z-index:1;position:relative}.resource-pip.filled{background:linear-gradient(135deg,#667eeaf2,#764ba2f2)!important;border-color:#667eeacc!important;box-shadow:0 6px 14px #667eea40!important}.resource-track.diamond .resource-pip{border-radius:3px;width:14px;height:14px;margin:2px;transform:rotate(45deg)}.resource-track.diamond .resource-pip.filled{background:linear-gradient(135deg,#f59e0bf2,#ed8936f2)!important;border-color:#f59e0bd9!important;box-shadow:0 6px 14px #f59e0b38!important}.thresholds-grid{border:1px solid #e2e8f0;border-radius:12px;grid-template-columns:repeat(3,1fr);gap:0;display:grid;overflow:hidden}.threshold-item{text-align:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-right:1px solid #e2e8f0;padding:1.25rem}.threshold-item:last-child{border-right:none}.threshold-item:first-child .threshold-value{color:#4299e1}.threshold-item:nth-child(2) .threshold-value{color:#ed8936}.threshold-item:nth-child(3) .threshold-value{color:#f56565}.threshold-value.severe{color:#f56565;font-size:1.2rem;font-weight:700}.threshold-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:flex}.threshold-value{margin-bottom:.5rem;font-size:2rem;font-weight:800}.threshold-desc{color:#718096;font-size:.85rem}.equipment-list{flex-direction:column;gap:1rem;display:flex}.equipment-item{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:3px solid #667eea;border-radius:10px;padding:1rem}.equipment-label{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.9rem;font-weight:700}.equipment-value{color:#4a5568;font-size:.95rem}.equipment-value .empty{color:#a0aec0;font-style:italic}.domain-cards-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.domain-cards-subsection{margin-bottom:2rem}.domain-cards-subsection:last-child{margin-bottom:0}.domain-cards-subsection h3{color:#2d3748;border-bottom:2px solid #667eea;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:700}.domain-cards-vault{border-top:2px solid #e2e8f0;margin-top:2.5rem;padding-top:2rem}.dark-mode .domain-cards-subsection h3{color:#e2e8f0}.dark-mode .domain-cards-vault{border-top-color:#4a5568}.domain-card-display{background:linear-gradient(135deg,#fff,#f7fafc);border-left:4px solid;-o-border-image:linear-gradient(#667eea 0%,#764ba2 100%) 1;border-image:linear-gradient(#667eea,#764ba2) 1;border-radius:12px;padding:1.5rem;transition:all .2s;position:relative;overflow:hidden;box-shadow:0 4px 12px #00000014}.domain-card-display:before{content:"";opacity:.8;background:linear-gradient(#667eea,#764ba2);width:4px;height:100%;position:absolute;top:0;left:0}.domain-card-display:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea33}.domain-card-header h4{color:#2d3748;margin:0 0 .5rem;font-family:Cinzel,serif;font-size:1.25rem;font-weight:700}.domain-card-meta{color:#718096;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.domain-card-body{margin-top:1rem}.domain-card-feature{color:#4a5568;margin-bottom:.75rem;line-height:1.6}.domain-card-recall{color:#667eea;font-size:.9rem;font-weight:600}.experiences-list{flex-direction:column;gap:.5rem;display:flex}.experience-display{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:3px solid #48bb78;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.experience-name{color:#2d3748;font-size:.95rem;font-weight:700}.experience-modifier{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:16px;padding:.35rem .75rem;font-size:.9rem;font-weight:700}.inventory-content{flex-direction:column;width:100%;display:flex}.inventory-tabs{border-bottom:2px solid #e2e8f0;gap:.5rem;margin-bottom:1.5rem;padding-bottom:0;display:flex}.inventory-tab-button{color:#718096;cursor:pointer;text-transform:none;letter-spacing:0;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:.5rem;margin-bottom:-2px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex;position:relative}.inventory-tab-icon{font-size:1.1rem;line-height:1}.inventory-tab-button:hover{color:#4a5568;background:#667eea0d}.inventory-tab-button.active{color:#667eea;background:0 0;border-bottom-color:#667eea}.dark-mode .inventory-tabs{border-bottom-color:#4a5568}.dark-mode .inventory-tab-button{color:#a0aec0}.dark-mode .inventory-tab-button:hover{color:#e2e8f0;background:#667eea1a}.dark-mode .inventory-tab-button.active{color:#90cdf4;border-bottom-color:#90cdf4}.inventory-items h3,.inventory-gold h3{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;font-size:1.1rem;font-weight:700}.inventory-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin:0;padding:0;list-style:none;display:grid}.inventory-list-two-column{-moz-column-count:2;column-count:2;-moz-column-gap:1rem;column-gap:1rem;width:100%;margin:0;padding:0;list-style:none}.inventory-items{width:100%}.inventory-item-card{-moz-column-break-inside:avoid;break-inside:avoid;background:linear-gradient(135deg,#fff,#f7fafc);border:2px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:.75rem;min-height:-moz-fit-content;min-height:fit-content;margin-bottom:1rem;padding:1rem;transition:all .2s;display:flex}.inventory-item-card.no-content{gap:0}.inventory-item-card.no-content .inventory-item-separator{display:none}.inventory-item-card:hover{border-color:#cbd5e0;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.inventory-item-card.equipped{background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-width:2px;border-color:#48bb78}.inventory-item-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.inventory-item-name{color:#2d3748;flex:1;font-size:1.1rem;font-weight:700;line-height:1.4}.inventory-item-card.equipped .inventory-item-name{color:#22543d}.inventory-item-type-badge{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;padding:.25rem .5rem;font-size:.75rem;font-weight:700;display:inline-block}.inventory-item-quantity{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;padding:.25rem .5rem;font-size:.875rem;font-weight:700;display:inline-block}.inventory-item-stats{margin-top:.5rem}.inventory-item-stats-detail{flex-direction:column;gap:.4rem;display:flex}.inventory-stats-two-column{grid-template-columns:repeat(2,1fr);gap:.4rem 1rem;display:grid}.inventory-stats-two-column .inventory-stat-row.full-width{grid-column:1/-1}.inventory-stat-row{gap:.5rem;font-size:.875rem;line-height:1.4;display:flex}.inventory-stat-row.feature{border-top:1px solid #e2e8f0;flex-direction:column;margin-top:.5rem;padding-top:.5rem}.inventory-stat-row.equipped-badge{border-top:1px solid #e2e8f0;margin-top:.5rem;padding-top:.5rem}.inventory-stat-label{color:#4a5568;min-width:100px;font-weight:600}.inventory-stat-value{color:#2d3748;flex:1}.inventory-stat-row.equipped-badge .inventory-stat-value{color:#22543d;font-weight:700}.inventory-item-description{color:#718096;margin-top:.5rem;font-size:.875rem;font-style:italic;line-height:1.5}.inventory-item-separator{background:linear-gradient(90deg,#0000,#e2e8f0 20%,#e2e8f0 80%,#0000);width:100%;height:1px;margin:.75rem 0}.inventory-item-actions-wrapper{flex-direction:column;margin-top:auto;display:flex}.inventory-item-actions{gap:.5rem;display:flex}.inventory-item-actions.no-separator{border-top:none;padding-top:0}.inventory-action-button{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:.4rem .75rem;font-size:.875rem;font-weight:600;transition:all .2s}.equip-button{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169)}.equip-button:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 2px 6px #48bb784d}.unequip-button{color:#fff;background:linear-gradient(135deg,#f56565,#e53e3e)}.unequip-button:hover{background:linear-gradient(135deg,#e53e3e,#c53030);transform:translateY(-1px);box-shadow:0 2px 6px #f565654d}.drink-button,.use-button{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 2px 4px #0000001a}.drink-button:before,.use-button:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.drink-button:hover:before,.use-button:hover:before{left:100%}.drink-button{color:#fff;background:linear-gradient(135deg,#4299e1,#3182ce)}.drink-button:hover{background:linear-gradient(135deg,#3182ce,#2c5282);transform:translateY(-2px);box-shadow:0 4px 12px #4299e166}.drink-button:active{transform:translateY(0);box-shadow:0 2px 4px #4299e14d}.drink-button:disabled{color:#718096;cursor:not-allowed;box-shadow:none;opacity:.6;background:#cbd5e0;transform:none}.use-button{color:#fff;background:linear-gradient(135deg,#9f7aea,#805ad5)}.use-button:hover{background:linear-gradient(135deg,#805ad5,#6b46c1);transform:translateY(-2px);box-shadow:0 4px 12px #9f7aea66}.use-button:active{transform:translateY(0);box-shadow:0 2px 4px #9f7aea4d}.use-button:disabled{color:#718096;cursor:not-allowed;box-shadow:none;opacity:.6;background:#cbd5e0;transform:none}.button-icon{align-items:center;font-size:1rem;line-height:1;display:inline-flex}.button-text{letter-spacing:.025em;font-weight:600}.inventory-item-notes{color:#718096;margin-top:.25rem;font-size:.875rem;font-style:italic;line-height:1.4}.inventory-empty{text-align:center;color:#a0aec0;background:linear-gradient(135deg,#f7fafc,#edf2f7);border:2px dashed #cbd5e0;border-radius:12px;padding:2rem;font-style:italic}.gold-header{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.gold-header h3{margin:0}.gold-section{margin-bottom:2rem}.gold-section .gold-header{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.gold-section .gold-header h2{margin:0}.gold-manager-inline{background:linear-gradient(135deg,#fffbf0,#fef3c7);border:2px solid #fbbf24;border-radius:12px;flex-wrap:wrap;align-items:center;gap:2rem;padding:1rem;display:flex}.gold-current-inline{flex:1;align-items:center;gap:1.5rem;display:flex}.gold-display-item-inline{flex-direction:column;align-items:center;gap:.25rem;display:flex}.gold-controls-inline{flex-shrink:0}.gold-current{background:linear-gradient(135deg,#fffbf0,#fef3c7);border:2px solid #fbbf24;border-radius:12px;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;display:flex}.gold-display-item{flex-direction:column;align-items:center;gap:.25rem;display:flex}.gold-display-label{color:#92400e;text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:600}.gold-display-value{color:#92400e;font-size:1.5rem;font-weight:700}.gold-controls-section{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:2px solid #e2e8f0;border-radius:12px;padding:1rem}.gold-input-group{align-items:center;gap:.5rem;display:flex}.gold-input{color:#2d3748;text-align:center;background:#fff;border:2px solid #cbd5e0;border-radius:8px;width:120px;padding:.5rem .75rem;font-size:1rem;transition:border-color .2s}.gold-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.gold-unit-select{color:#2d3748;cursor:pointer;background:#fff;border:2px solid #cbd5e0;border-radius:8px;padding:.5rem .75rem;font-size:1rem;transition:border-color .2s}.gold-unit-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.gold-action-button{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:1rem;font-weight:600;transition:all .2s}.gold-add-button{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169)}.gold-add-button:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 2px 8px #48bb784d}.gold-spend-button{color:#fff;background:linear-gradient(135deg,#f56565,#e53e3e)}.gold-spend-button:hover:not(:disabled){background:linear-gradient(135deg,#e53e3e,#c53030);transform:translateY(-1px);box-shadow:0 2px 8px #f565654d}.gold-action-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.class-features-content{flex-direction:column;gap:2rem;display:flex}.feature-group{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.feature-group h3{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #667eea;margin:0 0 1.25rem;padding-bottom:.75rem;font-family:Cinzel,serif;font-size:1.25rem;font-weight:700}.feature-group.multiclass-features{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-left:4px solid #667eea}.feature-item{border-bottom:1px solid #e2e8f0;margin-bottom:1.25rem;padding-bottom:1.25rem}.feature-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.feature-item-label{color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.9rem;font-weight:700}.feature-item-value{color:#4a5568;font-size:.95rem;line-height:1.6}.sheet-actions{border-top:3px solid;-o-border-image:linear-gradient(90deg,#667eea 0%,#764ba2 100%) 1;border-image:linear-gradient(90deg,#667eea,#764ba2) 1;justify-content:center;gap:1.5rem;margin-top:2.5rem;padding-top:2rem;display:flex}.sheet-actions button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #667eea4d}.sheet-actions button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.info-note{color:#718096;margin-left:.5rem;font-size:.9rem;font-style:italic}.step-content h3{color:#2d3748;margin-top:2rem;margin-bottom:1rem;font-size:1.4rem;font-weight:700}.dark-mode .background-questions h3,.dark-mode .party-connections h3{color:#e2e8f0}.expansion-selector{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;padding:15px}.expansion-selector h4{color:#2d3748;margin-top:0;margin-bottom:10px;font-size:1.1rem;font-weight:600}.expansion-checkboxes{flex-wrap:wrap;gap:15px;display:flex}.expansion-checkbox-label{cursor:pointer;color:#2d3748;align-items:center;gap:8px;font-size:.95rem;display:flex}.expansion-checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#667eea;width:18px;height:18px}.expansion-checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.expansion-checkbox-label.locked{opacity:.8;position:relative}.locked-badge{opacity:.7;margin-left:4px;font-size:14px}.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}.announcements-section,.announcement-card{padding:1.5rem}.announcement-header{flex-direction:column;align-items:flex-start;gap:1rem}.announcement-meta{flex-direction:row;justify-content:space-between;align-items:flex-start;width:100%}.announcement-card h3{font-size:1.25rem}.announcement-title-group{width:100%}.gold-manager-inline{flex-direction:column;align-items:stretch;gap:1rem}.gold-current-inline{justify-content:space-around}.gold-controls-inline,.gold-input-group{width:100%}.inventory-list-two-column{-moz-column-count:1;column-count:1}body{-webkit-overflow-scrolling:touch;overflow-x:hidden}.character-creation,.character-sheet{box-sizing:border-box;border-radius:16px;width:calc(100% - 1rem);max-width:100%;margin:.5rem;padding:1rem;overflow-x:hidden}.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{grid-template-columns:repeat(2,1fr);gap:.75rem}.combat-stats-grid,.thresholds-grid{grid-template-columns:1fr}.character-sheet{box-sizing:border-box;width:100%;overflow-x:hidden}.sheet-section{padding:1.25rem;overflow-x:hidden}.sheet-section h2{font-size:1.5rem}.trait-item{min-width:0;padding:1rem}.trait-value{font-size:1.75rem}.sheet-watermark{display:none}.thresholds-grid{border:none;grid-template-columns:repeat(2,1fr);gap:.75rem;overflow:visible}.threshold-item{border:1px solid #e2e8f0;border-right:none;border-radius:12px}.combat-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.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{padding:1rem;font-size:1.2rem}.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{-webkit-tap-highlight-color:#667eea4d;touch-action:manipulation;width:100%;max-width:100%;min-height:48px;padding:1.25rem 1.5rem;font-size:1rem}.step-content h2{margin-bottom:.5rem;font-size:1.5rem}.step-content>p{margin-bottom:1.5rem;font-size:1rem}.step-content-wrapper{min-height:auto;margin-bottom:1.5rem}input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{-webkit-appearance:none;border-radius:8px;font-size:16px}button,a,.clickable{min-width:44px;min-height:44px}.step-content,.character-creation{-webkit-overflow-scrolling:touch}.character-creation{padding-top:1rem;scroll-margin-top:0}.main-navigation{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;padding:.75rem 0;position:sticky;top:0}.dark-mode .main-navigation{background:#1a202cf2}.nav-container{flex-wrap:nowrap;gap:.5rem;padding:0 1rem}.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{gap:.5rem;margin-bottom:1rem}.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{margin-bottom:.5rem;font-size:.95rem}.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{justify-content:center;width:100%}.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{color:#e2e8f0;background:linear-gradient(135deg,#1a202c,#2d3748)}.dark-mode .character-creation,.dark-mode .character-sheet{background:linear-gradient(135deg,#1a202c,#2d3748);box-shadow:0 20px 60px #0009}.dark-mode .character-sheet:before{background:radial-gradient(1200px 700px at 20% 0,#4299e133,#0000 55%),radial-gradient(1000px 700px at 85% 0,#b794f433,#0000 55%),radial-gradient(900px 700px at 50% 100%,#48bb781a,#0000 60%)}.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{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;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 .thresholds-grid{border-color:#4a5568}.dark-mode .threshold-item{border-right-color:#4a5568}.dark-mode .resource-pip{background:#1a202c8c;border-color:#e2e8f038}.dark-mode .resource-pip.filled{box-shadow:0 8px 18px #00000059}.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{color:#cbd5e0;background:linear-gradient(135deg,#2d3748,#1a202c)}.dark-mode .inventory-item-card.no-content{gap:0}.dark-mode .inventory-item-card.no-content .inventory-item-separator{display:none}.dark-mode .inventory-item-card{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .inventory-item-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33}.dark-mode .inventory-item-card.equipped{background:linear-gradient(135deg,#1a3a2e,#22543d);border-color:#48bb78}.dark-mode .inventory-item-name{color:#e2e8f0}.dark-mode .inventory-item-card.equipped .inventory-item-name{color:#9ae6b4}.dark-mode .inventory-item-notes{color:#a0aec0}.dark-mode .inventory-empty{color:#718096;background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .gold-manager-inline,.dark-mode .gold-current{background:linear-gradient(135deg,#3d2e1f,#2d1f14);border-color:#d97706}.dark-mode .inventory-stat-row.feature,.dark-mode .inventory-stat-row.equipped-badge,.dark-mode .inventory-item-description{border-top-color:#4a5568}.dark-mode .inventory-item-description.no-separator,.dark-mode .inventory-item-notes.no-separator{border-top:none}.dark-mode .inventory-stat-label{color:#a0aec0}.dark-mode .inventory-stat-value{color:#e2e8f0}.dark-mode .inventory-item-description{color:#a0aec0}.dark-mode .inventory-item-actions.no-separator{border-top:none}.dark-mode .gold-display-label{color:#fde68a}.dark-mode .gold-display-value{color:#fbbf24}.dark-mode .inventory-items h3,.dark-mode .inventory-gold h3{color:#e2e8f0}.dark-mode .gold-controls-section{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .gold-input,.dark-mode .gold-unit-select{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.dark-mode .gold-input:focus,.dark-mode .gold-unit-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.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{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;background-clip:text}.dark-mode .step-number{color:#a0aec0}.dark-mode .list-header.invalid{background:linear-gradient(135deg,#fc81811a,#fc81810d);border-bottom-color:#fc8181}.dark-mode .validation-error,.dark-mode .validation-error-banner,.dark-mode .validation-error-inline{color:#fc8181}.dark-mode .validation-error-banner{background:linear-gradient(135deg,#fc818126,#fc818114);border-color:#fc8181}.dark-mode .invalid-input{background:linear-gradient(135deg,#1a202cf2,#fc81811a)!important;border-color:#fc8181!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{align-items:center;gap:1rem;display:flex}.theme-toggle{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;transition:all .3s;display:flex;box-shadow:0 4px 12px #667eea4d}.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{color:#e2e8f0;background:#4a5568}.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-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);border-color:#0000;box-shadow:0 2px 8px #0003}.dark-mode .trait-row:hover{border-color:#4299e14d;box-shadow:0 6px 16px #0000004d}.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{color:#cbd5e0;background:#2d3748;box-shadow:0 2px 6px #0003}.dark-mode .inventory-item:hover{box-shadow:0 4px 10px #0000004d}.dark-mode .inventory-item.highlight{color:#9ae6b4;background:linear-gradient(135deg,#2f855a,#276749)}.dark-mode .form-field label{color:#e2e8f0}.dark-mode .form-field input,.dark-mode .form-field textarea{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.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{flex-direction:column;align-items:flex-start;gap:1rem;display:flex}.character-avatar-preview-container{border:3px solid #667eea;border-radius:50%;flex-shrink:0;width:100px;height:100px;overflow:hidden;box-shadow:0 4px 12px #667eea33}.character-avatar-preview{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.character-avatar-placeholder{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:4px solid #667eea;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;font-size:2.5rem;font-weight:700;display:flex;position:relative;overflow:visible;box-shadow:0 4px 12px #667eea4d}.character-avatar-upload-label{color:#fff;text-align:center;cursor:pointer;white-space:nowrap;z-index:1;background:#0000004d;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;transition:all .2s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.character-avatar-upload-label:hover{background:#00000080;transform:translate(-50%,-50%)scale(1.05)}.character-avatar-subclass-icon .subclass-icon-display{font-size:3.5rem;line-height:1;display:block}.character-avatar-upload-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.character-avatar-upload-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.6rem 1.2rem;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{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:8px;padding:.6rem 1.2rem;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{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;width:100%;margin-top:.75rem;padding:.75rem}.character-avatar-restrictions .restriction-text{color:#4a5568;margin-bottom:.5rem;font-size:.85rem;line-height:1.6;display:block}.character-avatar-restrictions .restriction-text strong{color:#2d3748;font-weight:600}.avatar-error-message{color:#c33;word-wrap:break-word;background:#fee;border:1px solid #fcc;border-radius:6px;margin-top:.5rem;padding:.5rem .75rem;font-size:.8rem}.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{color:#fc8181;background:#e53e3e33;border-color:#e53e3e}.dark-mode .character-avatar-placeholder-edit .avatar-error-message{color:#fff;background:#e53e3ee6;border-color:#c53030}.dark-mode .character-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .character-avatar-upload-label{color:#fff;background:#0006}.dark-mode .character-avatar-upload-label:hover{background:#0009}.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{color:#e2e8f0;background:#2d3748;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-header{border-color:#4a5568}.dark-mode .experience-card-header h3{color:#e2e8f0}.dark-mode .experience-input{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.dark-mode .experience-input:focus{border-color:#667eea}.dark-mode .suggestions-summary{color:#cbd5e0;background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.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{color:#cbd5e0;background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .suggestion-tag:hover{color:#fff;background:linear-gradient(135deg,#4299e1,#667eea);box-shadow:0 4px 8px #4299e14d}.dark-mode .domain-section h3{color:#e2e8f0;-o-border-image:linear-gradient(90deg,#4299e1 0%,#667eea 100%) 1;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{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;background-clip:text}.dark-mode .trait-item{background:#1a202c;box-shadow:0 2px 4px #0003}.dark-mode .domain-card-display{background:#1a202c;-o-border-image:linear-gradient(#4299e1 0%,#667eea 100%) 1;border-image:linear-gradient(#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{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#90cdf4,#b794f4);-webkit-background-clip:text;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;color:#718096;padding:3rem;font-size:1.2rem}.error{color:#742a2a;background:linear-gradient(135deg,#fed7d7,#feb2b2);border-radius:12px;margin:1rem 0;padding:1.5rem;box-shadow:0 4px 6px #0000000d}.success{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border-radius:12px;margin:1rem 0;padding:1.5rem;box-shadow:0 4px 6px #0000000d}.tables-container{max-width:1400px;margin:0 auto;padding:2rem}.tables-header{margin-bottom:2rem}.tables-header h1{color:#2d3748;margin-bottom:.5rem;font-family:Cinzel,serif;font-size:2.5rem;font-weight:700}.tables-subtitle{color:#718096;margin:0;font-size:1.1rem}.tables-nav{border-bottom:2px solid #e2e8f0;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;display:flex}.table-nav-link{color:#4a5568;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s}.table-nav-link:hover{color:#667eea;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.table-nav-link.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000}.tables-content{margin-top:2rem}.back-to-top-button{color:#fff;cursor:pointer;opacity:.9;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .3s;display:flex;bottom:2rem;right:2rem;box-shadow:0 4px 12px #0000004d;z-index:10000!important;position:fixed!important}.back-to-top-button:hover{opacity:1;transform:translateY(-2px);box-shadow:0 6px 16px #0006}.back-to-top-button:active{transform:translateY(0)}.back-to-top-button svg{pointer-events:none;flex-shrink:0;width:20px;height:20px;display:block}.dark-mode .back-to-top-button{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #00000080}.dark-mode .back-to-top-button:hover{box-shadow:0 6px 16px #0009}@media (max-width:768px){.back-to-top-button{width:44px;height:44px;bottom:1.5rem;right:1.5rem!important}.character-creation .back-to-top-button{bottom:1.5rem;right:1.5rem!important}.back-to-top-button svg{width:18px;height:18px}}.tables-welcome{text-align:center;color:#718096;padding:4rem 2rem;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{background:#fff;border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:2rem;margin-bottom:2rem;padding:1.5rem;display:flex;box-shadow:0 2px 8px #0000000d}.control-group{flex-direction:column;gap:.5rem;display:flex}.control-group label{color:#4a5568;font-size:.9rem;font-weight:600}.dark-mode .control-group label{color:#cbd5e0}.button-group{gap:.5rem;display:flex}.type-button{cursor:pointer;color:#4a5568;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.type-button:hover{color:#667eea;border-color:#667eea}.type-button.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000}.dark-mode .type-button{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .type-button:hover{color:#667eea;border-color:#667eea}.dark-mode .type-button.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000}.rarity-select{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;font-size:1rem;font-weight:600}.dark-mode .rarity-select{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.generate-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f56565,#e53e3e);border:none;border-radius:8px;padding:.75rem 2rem;font-size:1.1rem;font-weight:700;transition:all .2s;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{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000001a}.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{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.result-header h3{color:#2d3748;margin:0;font-size:1.5rem}.dark-mode .result-header h3{color:#e2e8f0}.result-roll{color:#667eea;background:#e6f3ff;border-radius:6px;margin-bottom:.75rem;padding:.5rem;font-size:.9rem;font-weight:600;display:inline-block}.rarity-badge{text-transform:uppercase;border-radius:20px;padding:.4rem 1rem;font-size:.85rem;font-weight:700}.rarity-badge.rarity-common{color:#4a5568;background:#e2e8f0}.rarity-badge.rarity-uncommon{color:#22543d;background:#c6f6d5}.rarity-badge.rarity-rare{color:#2c5282;background:#bee3f8}.rarity-badge.rarity-legendary{color:#7c2d12;background:#feebc8}.dark-mode .rarity-badge.rarity-common{color:#e2e8f0;background:#e2e8f033}.dark-mode .rarity-badge.rarity-uncommon{color:#9ae6b4;background:#c6f6d533}.dark-mode .rarity-badge.rarity-rare{color:#90cdf4;background:#bee3f833}.dark-mode .rarity-badge.rarity-legendary{color:#fbd38d;background:#feebc833}.result-description{color:#4a5568;margin:.5rem 0}.dark-mode .result-description{color:#cbd5e0}.result-type{color:#718096;background:#f7fafc;border-radius:6px;margin-top:.5rem;padding:.3rem .8rem;font-size:.85rem;display:inline-block}.dark-mode .result-type{color:#cbd5e0;background:#2d374880}.gold-amount{text-align:center;color:#744210;background:linear-gradient(135deg,#f6e05e,#d69e2e);border-radius:8px;margin:1.5rem 0;padding:1rem;font-size:1.5rem;box-shadow:0 2px 8px #d69e2e4d}.dark-mode .gold-amount{color:#fef3c7;background:linear-gradient(135deg,#d69e2e,#b7791f)}.gold-drops{margin-top:1.5rem}.gold-drops h4{color:#2d3748;margin-bottom:1rem;font-size:1.2rem}.dark-mode .gold-drops h4{color:#e2e8f0}.loot-tables{margin-top:3rem}.loot-tables h2{color:#2d3748;margin-bottom:1.5rem;font-family:Cinzel,serif;font-size:2rem}.dark-mode .loot-tables h2{color:#e2e8f0}.loot-table-section{margin-bottom:2rem}.rarity-header{border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.3rem;font-weight:700}.dark-mode .rarity-header{color:#e2e8f0;border-bottom-color:#4a5568}.loot-table-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.loot-table-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.item-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.item-name{color:#2d3748;flex:1;font-weight:700}.item-roll{color:#667eea;background:#e6f3ff;border-radius:6px;padding:.25rem .5rem;font-size:.85rem;font-weight:600}.item-description{color:#718096;margin-bottom:.5rem;font-size:.9rem;line-height:1.5}.item-type{color:#a0aec0;font-size:.85rem}.shop-generator{max-width:1200px;margin:0 auto}.shop-type-select,.tier-select{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;min-width:150px;padding:.75rem 1rem;font-size:1rem;font-weight:600}.dark-mode .shop-type-select,.dark-mode .tier-select{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.clear-button{color:#fff;cursor:pointer;background:#718096;border:none;border-radius:8px;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.clear-button:hover{background:#4a5568;transform:translateY(-1px)}.dark-mode .clear-button{background:#4a5568}.dark-mode .clear-button:hover{background:#2d3748}.shop-info{background:#fff;border-radius:12px;gap:2rem;margin:2rem 0;padding:1.5rem;display:flex;box-shadow:0 2px 8px #0000000d}.dark-mode .shop-info{background:#2d3748}.shop-owner,.shop-staff,.shop-inventory-selection,.shop-pricing,.shop-encounter-event{flex:1}.shop-owner h3,.shop-staff h3,.shop-inventory-selection h3,.shop-pricing h3,.shop-encounter-event h3{color:#2d3748;margin:0 0 .5rem;font-size:1.1rem}.dark-mode .shop-owner h3,.dark-mode .shop-staff h3,.dark-mode .shop-inventory-selection h3,.dark-mode .shop-pricing h3,.dark-mode .shop-encounter-event h3{color:#e2e8f0}.shop-owner p,.shop-staff p,.shop-inventory-selection p,.shop-pricing p,.shop-encounter-event p{color:#4a5568;margin:0}.dark-mode .shop-owner p,.dark-mode .shop-staff p,.dark-mode .shop-inventory-selection p,.dark-mode .shop-pricing p,.dark-mode .shop-encounter-event p{color:#cbd5e0}.shop-encounter-event{border-left:3px solid #ed8936;margin-left:.5rem;padding-left:.75rem}.dark-mode .shop-encounter-event{border-left-color:#f6ad55}.shop-inventory{margin-top:2rem}.shop-inventory h2{color:#2d3748;margin-bottom:1.5rem;font-family:Cinzel,serif;font-size:2rem}.dark-mode .shop-inventory h2{color:#e2e8f0}.inventory-list{flex-direction:column;gap:0;display:flex}.inventory-item{cursor:help;background:#fff;border:1px solid #e2e8f0;border-left:4px solid #a0aec0;border-radius:8px;padding:1rem;transition:all .2s}.inventory-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.inventory-item.tier-1{border-left-color:#a0aec0}.inventory-item.tier-2{border-left-color:#48bb78}.inventory-item.tier-3{border-left-color:#4299e1}.inventory-item.tier-4{border-left-color:#ed8936}.dark-mode .inventory-item{background:#2d3748;border-color:#4a5568}.dark-mode .inventory-item.tier-1{border-left-color:#718096}.dark-mode .inventory-item.tier-2{border-left-color:#48bb78}.dark-mode .inventory-item.tier-3{border-left-color:#4299e1}.dark-mode .inventory-item.tier-4{border-left-color:#ed8936}.inventory-item .item-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.inventory-item .item-name{color:#2d3748;flex:1;font-weight:700}.dark-mode .inventory-item .item-name{color:#e2e8f0}.item-tier{color:#667eea;background:#e6f3ff;border-radius:6px;padding:.25rem .5rem;font-size:.85rem;font-weight:600}.dark-mode .item-tier{color:#90cdf4;background:#4299e133}.inventory-item .item-description{color:#718096;margin-bottom:.5rem;font-size:.9rem;line-height:1.5}.dark-mode .inventory-item .item-description{color:#cbd5e0}.item-stats{color:#4a5568;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;font-size:.85rem;display:flex}.dark-mode .item-stats{color:#a0aec0}.item-stats span{background:#f7fafc;border-radius:4px;padding:.2rem .5rem}.dark-mode .item-stats span{background:#2d374880}.item-feature{color:#4a5568;background:#f7fafc;border-radius:4px;margin-top:.5rem;padding:.5rem;font-size:.85rem}.dark-mode .item-feature{color:#cbd5e0;background:#2d374880}.item-feature strong{color:#667eea}.dark-mode .item-feature strong{color:#90cdf4}.inventory-group{margin-bottom:2rem}.inventory-group-header{color:#2d3748;border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.3rem;font-weight:700}.dark-mode .inventory-group-header{color:#e2e8f0;border-bottom-color:#4a5568}.inventory-group-items{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.beast-feast{max-width:1200px;margin:0 auto}.beast-feast h1{color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;font-size:2.5rem}.dark-mode .beast-feast h1{color:#e2e8f0}.beast-feast h2{color:#2d3748;margin-top:3rem;margin-bottom:1rem;font-family:Cinzel,serif;font-size:2rem}.dark-mode .beast-feast h2{color:#e2e8f0}.beast-feast h3{color:#2d3748;margin-top:2rem;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.dark-mode .beast-feast h3{color:#e2e8f0}.ingredient-generator-section{background:#fff;border-radius:12px;margin-bottom:4rem;padding:2rem;box-shadow:0 2px 8px #0000000d}.dark-mode .ingredient-generator-section{background:#2d3748}.ingredient-tables{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem;display:grid}.ingredient-table-section{margin-bottom:2rem}.ingredient-table-section h3{border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.3rem;font-weight:700}.dark-mode .ingredient-table-section h3{color:#e2e8f0;border-bottom-color:#4a5568}.ingredient-table-list{flex-direction:column;gap:.5rem;display:flex}.ingredient-table-item{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:1rem;padding:.75rem;display:flex}.dark-mode .ingredient-table-item{background:#2d374880;border-color:#4a5568}.ingredient-table-item .item-roll{text-align:center;color:#667eea;background:#e6f3ff;border-radius:6px;min-width:2.5rem;padding:.25rem .5rem;font-size:.9rem;font-weight:700}.dark-mode .ingredient-table-item .item-roll{color:#9f7aea;background:#667eea33}.ingredient-table-item .item-name{color:#2d3748;flex:1;font-weight:500}.dark-mode .ingredient-table-item .item-name{color:#e2e8f0}.table-description{color:#718096;margin-bottom:1rem;font-size:.9rem;font-style:italic}.dark-mode .table-description{color:#cbd5e0}.bloom-flavor-table{margin:2rem 0}.bloom-flavor-table table{border-collapse:collapse;background:#fff;border-radius:12px;width:100%;max-width:500px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.dark-mode .bloom-flavor-table table{background:#2d3748}.bloom-flavor-table thead{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.bloom-flavor-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:1rem;font-size:.9rem;font-weight:700}.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{color:#2d3748;padding:1rem;font-size:.95rem}.dark-mode .bloom-flavor-table td{color:#e2e8f0}.transformations{max-width:1200px;margin:0 auto}.transformations h1{color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;font-size:2.5rem}.dark-mode .transformations h1{color:#e2e8f0}.transformations-intro{margin-bottom:3rem}.transformations-info-box{background:#f7fafc;border-left:4px solid #667eea;border-radius:12px;margin-top:2rem;padding:2rem;box-shadow:0 2px 8px #0000000d}.dark-mode .transformations-info-box{background:#2d374880;border-left-color:#9f7aea}.transformations-info-box h3{color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;font-size:1.5rem}.dark-mode .transformations-info-box h3{color:#e2e8f0}.transformations-info-box ul{color:#4a5568;margin:1rem 0;padding-left:1.5rem;line-height:1.8}.dark-mode .transformations-info-box ul{color:#cbd5e0}.transformations-info-box ul li{margin-bottom:.75rem}.transformations-note{color:#4a5568;border-top:1px solid #e2e8f0;margin-top:1.5rem;padding-top:1.5rem;font-size:.95rem;line-height:1.6}.dark-mode .transformations-note{color:#cbd5e0;border-top-color:#4a5568}.transformations-grid{grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem;margin-bottom:3rem;display:grid}.transformation-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2rem;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #0000001a}.transformation-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.dark-mode .transformation-card{background:#2d3748;border-color:#4a5568}.transformation-header{border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:1rem}.dark-mode .transformation-header{border-bottom-color:#4a5568}.transformation-header h2{color:#2d3748;margin:0;font-family:Cinzel,serif;font-size:2rem}.dark-mode .transformation-header h2{color:#e2e8f0}.transformation-description{color:#4a5568;margin-bottom:1.5rem;font-size:1.1rem;font-style:italic;line-height:1.6}.dark-mode .transformation-description{color:#cbd5e0}.transformation-features{flex-direction:column;gap:1.5rem;display:flex}.transformation-feature{background:#f7fafc;border-left:3px solid #667eea;border-radius:8px;padding:1.5rem}.dark-mode .transformation-feature{background:#2d374880;border-left-color:#9f7aea}.feature-name{color:#2d3748;margin-bottom:.75rem;font-family:Cinzel,serif;font-size:1.25rem;font-weight:700}.dark-mode .feature-name{color:#e2e8f0}.feature-description{color:#4a5568;margin:0;font-size:.95rem;line-height:1.7}.transformations-source{text-align:center;border-top:2px solid #e2e8f0;margin-top:3rem;padding-top:2rem}.dark-mode .transformations-source{border-top-color:#4a5568}.source-text{color:#718096;margin:0;font-size:.9rem}.dark-mode .source-text{color:#a0aec0}@media (max-width:768px){.transformations-grid{grid-template-columns:1fr}.transformations h1{font-size:2rem}.transformation-header h2{font-size:1.5rem}.transformation-card,.transformations-info-box{padding:1.5rem}}.beastforms{max-width:1400px;margin:0 auto}.beastforms h1{color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;font-size:2.5rem}.dark-mode .beastforms h1{color:#e2e8f0}.beastforms-intro{margin-bottom:2rem}.beastforms-filters{flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:2rem;display:flex}.tier-filter-button{color:#4a5568;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.tier-filter-button:hover{color:#667eea;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.tier-filter-button.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 12px #667eea4d}.dark-mode .tier-filter-button{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .tier-filter-button:hover{color:#9f7aea;border-color:#9f7aea}.dark-mode .tier-filter-button.active{color:#fff;background:linear-gradient(135deg,#9f7aea,#764ba2);border-color:#0000}.beastforms-info-box{background:#f7fafc;border-left:4px solid #667eea;border-radius:12px;margin-top:2rem;padding:2rem;box-shadow:0 2px 8px #0000000d}.dark-mode .beastforms-info-box{background:#2d374880;border-left-color:#9f7aea}.beastforms-info-box h3{color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;font-size:1.5rem}.dark-mode .beastforms-info-box h3{color:#e2e8f0}.beastforms-info-box ul{color:#4a5568;margin:1rem 0;padding-left:1.5rem;line-height:1.8}.dark-mode .beastforms-info-box ul{color:#cbd5e0}.beastforms-info-box ul li{margin-bottom:.75rem}.beastforms-tiers{flex-direction:column;gap:3rem;margin-bottom:3rem;display:flex}.beastform-tier{margin-bottom:2rem}.beastform-tier h2{color:#2d3748;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:.5rem;font-family:Cinzel,serif;font-size:2rem}.dark-mode .beastform-tier h2{color:#e2e8f0;border-bottom-color:#4a5568}.beastforms-grid{grid-template-columns:repeat(auto-fit,minmax(600px,1fr));gap:2rem;display:grid}.beastform-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2rem;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #0000001a}.beastform-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.dark-mode .beastform-card{background:#2d3748;border-color:#4a5568}.beastform-header{border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:1rem}.dark-mode .beastform-header{border-bottom-color:#4a5568}.beastform-header h3{color:#2d3748;margin:0 0 .5rem;font-family:Cinzel,serif;font-size:1.75rem}.dark-mode .beastform-header h3{color:#e2e8f0}.beastform-examples{color:#718096;margin:0;font-size:.95rem;font-style:italic}.dark-mode .beastform-examples{color:#a0aec0}.beastform-stats{background:#f7fafc;border-radius:8px;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem;padding:1rem;display:grid}.dark-mode .beastform-stats{background:#2d374880}.beastform-stat{flex-direction:column;gap:.25rem;display:flex}.beastform-stat-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.dark-mode .beastform-stat-label{color:#a0aec0}.beastform-stat-value{color:#2d3748;font-size:1rem;font-weight:600}.dark-mode .beastform-stat-value{color:#e2e8f0}.beastform-features{flex-direction:column;gap:1rem;display:flex}.beastform-feature{background:#f7fafc;border-left:3px solid #667eea;border-radius:8px;padding:1rem}.dark-mode .beastform-feature{background:#2d374880;border-left-color:#9f7aea}.beastform-feature-name{color:#2d3748;margin-bottom:.5rem;font-family:Cinzel,serif;font-size:1.1rem;font-weight:700}.dark-mode .beastform-feature-name{color:#e2e8f0}.beastform-feature-description{color:#4a5568;margin:0;font-size:.95rem;line-height:1.7}.dark-mode .beastform-feature-description{color:#cbd5e0}.beastforms-source{text-align:center;border-top:2px solid #e2e8f0;margin-top:3rem;padding-top:2rem}.dark-mode .beastforms-source{border-top-color:#4a5568}@media (max-width:768px){.beastforms-grid{grid-template-columns:1fr}.beastforms h1{font-size:2rem}.beastform-tier h2{font-size:1.5rem}.beastform-card,.beastforms-info-box{padding:1.5rem}.beastform-stats{grid-template-columns:1fr}}.equipment-tables-section{margin-top:4rem}.equipment-table-section{margin-bottom:3rem}.equipment-table-section table{border-collapse:collapse;background:#fff;border-radius:12px;width:100%;overflow:hidden;box-shadow:0 2px 8px #0000000d}.dark-mode .equipment-table-section table{background:#2d3748}.equipment-table-section thead{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.equipment-table-section th{text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:1rem;font-size:.9rem;font-weight:700}.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{color:#2d3748;padding:1rem;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{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.table-stats{color:#718096;margin-bottom:1rem;font-size:.9rem}.dark-mode .table-stats{color:#cbd5e0}.adversary-table-container{overflow-x:auto}.adversary-data-table{border-collapse:collapse;background:#fff;border-radius:12px;width:100%;overflow:hidden;box-shadow:0 2px 8px #0000000d}.adversary-data-table thead{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.adversary-data-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:1rem;font-size:.9rem;font-weight:700}.adversary-data-table th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.adversary-data-table th.sortable:hover{background:#ffffff1a}.adversary-data-table td{vertical-align:top;border-bottom:1px solid #e2e8f0;padding:1rem}.adversary-data-table tbody tr:hover{background:#f7fafc}.adversary-name-cell{min-width:200px}.adversary-description{color:#718096;margin-top:.5rem;font-size:.85rem}.attacks-list,.features-list{flex-direction:column;gap:.5rem;display:flex}.attack-item,.feature-item{color:#4a5568;font-size:.85rem}.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{grid-template-columns:400px 1fr;align-items:stretch;gap:2rem;margin-top:2rem;display:grid}.environments-sidebar{background:#fff;border-radius:12px;flex-direction:column;height:100%;max-height:calc(100vh - 200px);padding:1.5rem;display:flex;overflow-y:auto;box-shadow:0 2px 8px #0000000d}.environments-list{flex-direction:column;flex:1;gap:.75rem;padding-right:.5rem;display:flex;overflow-y:auto}.environment-list-item{cursor:pointer;background:#f7fafc;border:2px solid #0000;border-radius:8px;padding:1rem;transition:all .2s}.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{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.environment-list-header strong{color:#2d3748;font-size:1rem}.environment-list-meta{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;display:flex}.type-badge{color:#2c5282;text-transform:uppercase;letter-spacing:.5px;background:#e6f3ff;border-radius:12px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.difficulty-badge{color:#744210;background:#fef5e7;border-radius:12px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.dark-mode .difficulty-badge{color:#f6ad55;background:#f6ad5533}.environment-list-description{color:#718096;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;line-height:1.4;display:-webkit-box;overflow:hidden}.environment-details{background:#fff;border-radius:12px;flex-direction:column;height:100%;max-height:calc(100vh - 200px);padding:2rem;display:flex;overflow-y:auto;box-shadow:0 2px 8px #0000000d}.environment-detail-content{flex-direction:column;gap:2rem;display:flex}.environment-detail-header{border-bottom:2px solid #e2e8f0;flex-direction:column;gap:1rem;padding-bottom:1.5rem;display:flex}.environment-detail-header h2{color:#2d3748;margin:0;font-family:Cinzel,serif;font-size:2rem}.environment-detail-badges{flex-wrap:wrap;gap:.75rem;display:flex}.environment-detail-section{flex-direction:column;gap:.75rem;display:flex}.environment-detail-section h3{color:#2d3748;margin:0;font-family:Cinzel,serif;font-size:1.3rem;font-weight:700}.environment-detail-section p{color:#4a5568;margin:0;line-height:1.6}.impulses-text{color:#718096;font-style:italic}.dark-mode .impulses-text{color:#cbd5e0}.difficulty-text{color:#2d3748;font-size:1.1rem;font-weight:600}.dark-mode .difficulty-text{color:#e2e8f0}.adversaries-list{margin:0;padding-left:1.5rem;list-style:outside}.adversaries-list li{color:#4a5568;margin:.5rem 0;line-height:1.5}.dark-mode .adversaries-list li{color:#cbd5e0}.no-selection{text-align:center;color:#718096;padding:4rem 2rem;font-size:1.1rem}.no-results{text-align:center;color:#718096;padding:2rem;font-size:.95rem}.feature-questions{background:#fef5e7;border-left:3px solid #f6ad55;border-radius:8px;margin-top:.75rem;padding:.75rem}.feature-questions em{color:#744210;margin-bottom:.5rem;font-weight:600;display:block}.feature-questions ul{margin:0;padding-left:1.5rem;list-style:outside}.feature-questions li{color:#744210;margin:.25rem 0;line-height:1.5}.dark-mode .environments-sidebar,.dark-mode .environment-details{color:#e2e8f0;background:#2d3748}.dark-mode .environment-list-item{color:#e2e8f0;background:#4a5568}.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{color:#e2e8f0;background:#4a5568;border-color:#5a6578}.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{border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:2rem}.detail-section h4{color:#2d3748;margin-bottom:1rem;font-family:Cinzel,serif;font-size:1.2rem;font-weight:700}.dark-mode .detail-section{border-top-color:#4a5568}.class-items-list{margin:0;padding:0;list-style:none}.class-items-list li{color:#4a5568;cursor:default;-webkit-user-select:text;-moz-user-select:text;user-select:text;background:#f7fafc;border-radius:8px;margin-bottom:.5rem;padding:.75rem}.class-item-choice{margin-top:1rem;margin-bottom:1rem}.choice-label{color:#2d3748;margin-bottom:.5rem;font-size:.9rem;font-weight:600}.choice-options{flex-direction:column;gap:.5rem;display:flex}.choice-button{cursor:pointer;text-align:left;color:#4a5568;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:all .2s;display:flex}.choice-button:hover{background:#edf2f7;border-color:#cbd5e0}.choice-button.selected{color:#2d3748;background:#e6fffa;border-color:#38b2ac}.choice-check{color:#38b2ac;margin-left:.5rem;font-weight:700}.feature-text{color:#4a5568;white-space:pre-wrap;background:#f7fafc;border-radius:8px;padding:1rem;line-height:1.6}.subclasses-list{flex-direction:column;gap:1.5rem;display:flex}.subclass-item{background:#f7fafc;border-left:4px solid #667eea;border-radius:12px;padding:1.5rem}.subclass-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.subclass-header strong{color:#2d3748;font-size:1.1rem}.dark-mode .subclass-header strong{color:#e2e8f0}.spellcast-trait{color:#234e52;background:#e6fffa;border-radius:6px;padding:.3rem .8rem;font-size:.85rem;font-weight:600}.subclass-description{color:#718096;margin-bottom:1rem;font-style:italic}.dark-mode .subclass-description{color:#cbd5e0}.subclass-feature{color:#4a5568;background:#fff;border-radius:8px;margin-top:.75rem;padding:.75rem;line-height:1.6}.subclass-feature strong{color:#2d3748;margin-bottom:.5rem;display:block}.dark-mode .tables-header h1{color:#fff}.dark-mode .tables-subtitle{color:#cbd5e0}.dark-mode .table-nav-link{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .table-nav-link:hover{color:#667eea;border-color:#667eea}.dark-mode .table-nav-link.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.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{color:#e2e8f0;background:#2d3748}.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{color:#e2e8f0;background:#2d3748}.dark-mode .class-item-choice .choice-label{color:#e2e8f0}.dark-mode .choice-button{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .choice-button:hover{background:#374151;border-color:#6b7280}.dark-mode .choice-button.selected{color:#e2e8f0;background:#1a4d4a;border-color:#38b2ac}.dark-mode .feature-text,.dark-mode .subclass-item{color:#cbd5e0;background:#374151}.dark-mode .subclass-feature{color:#e2e8f0;background:#4a5568}.adversary-motives{color:#a0aec0;margin-top:.5rem;font-size:.85rem;font-style:italic}.thresholds-cell{color:#4a5568;font-size:.9rem}.standard-attack-cell{flex-direction:column;gap:.25rem;font-size:.9rem;display:flex}.standard-attack-cell strong{color:#2d3748;font-size:.95rem}.dark-mode .standard-attack-cell{color:#cbd5e0}.feature-header{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.feature-type-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.feature-type-badge.feature-type-action{color:#742a2a;background:#fed7d7}.feature-type-badge.feature-type-reaction{color:#7c2d12;background:#feebc8}.feature-type-badge.feature-type-passive{color:#22543d;background:#c6f6d5}.feature-type-badge.feature-type-fear-feature{color:#553c9a;background:#e9d8fd}.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{color:#fed7d7;background:#742a2a}.dark-mode .feature-type-badge.feature-type-reaction{color:#feebc8;background:#7c2d12}.dark-mode .feature-type-badge.feature-type-passive{color:#c6f6d5;background:#22543d}.dark-mode .feature-type-badge.feature-type-fear-feature{color:#e9d8fd;background:#553c9a}.dark-mode .feature-description{color:#cbd5e0}.expandable-row{transition:background-color .2s}.expandable-row:hover{background:#f0f4ff!important}.dark-mode .expandable-row:hover{background:#2d3748!important}.expand-indicator{color:#667eea;justify-content:center;align-items:center;min-width:24px;font-size:.75rem;display:inline-flex}.dark-mode .expand-indicator{color:#90cdf4}.feature-sub-row{background:#f7fafc}.feature-sub-row td{border-bottom:1px solid #e2e8f0;padding:0!important}.features-expanded{background:#f7fafc;border-left:4px solid #667eea;padding:1.5rem}.features-expanded-title{color:#2d3748;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;font-size:1rem;font-weight:700}.features-expanded .experiences-list{flex-flow:row;gap:.5rem;margin-bottom:1.5rem;display:flex;overflow-x:auto}.experience-badge{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;align-items:center;padding:.5rem 1rem;font-size:.9rem;font-weight:600;display:inline-flex;box-shadow:0 2px 4px #667eea4d}.dark-mode .experience-badge{background:linear-gradient(135deg,#805ad5,#553c9a);box-shadow:0 2px 4px #805ad566}.features-expanded .features-list{flex-direction:column;gap:1rem;display:flex}.features-expanded .feature-item{background:#fff;border-left:3px solid #667eea;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000000d}.features-expanded .feature-item:last-child{margin-bottom:0}.features-expanded .feature-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.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{flex-direction:column;gap:1.5rem;margin-top:1rem;display:flex}.colossus-segment{background:#fff;border-left:4px solid #ed8936;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.segment-name{color:#2d3748;border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.1rem;font-weight:700}.segment-details{color:#4a5568;flex-direction:column;gap:.75rem;font-size:.9rem;display:flex}.segment-details>div{line-height:1.6}.segment-attack{background:#f7fafc;border-radius:6px;margin-top:.5rem;padding:.75rem}.segment-features{border-top:1px solid #e2e8f0;margin-top:1rem;padding-top:1rem}.segment-feature{background:#f7fafc;border-radius:6px;margin-top:.5rem;padding:.75rem;font-size:.85rem;line-height:1.5}.adversary-size{color:#718096;margin-top:.5rem;font-size:.85rem;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{color:#4a5568;max-width:500px;line-height:1.6}.dark-mode .description-cell{color:#cbd5e0}.auth-container{justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem;display:flex}.auth-card{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:24px;width:100%;max-width:500px;padding:3rem;box-shadow:0 20px 60px #0000004d}.auth-card h1{-webkit-text-fill-color:transparent;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2.5rem}.auth-subtitle{color:#718096;text-align:center;margin-bottom:2rem}.auth-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:#2d3748;font-size:.95rem;font-weight:600}.multiclass-selection{flex-direction:column;gap:1rem;display:flex}.multiclass-dropdowns-row{flex-flow:wrap;gap:1rem;display:flex}.multiclass-dropdowns-row .multiclass-form-group{flex:1;min-width:200px}.multiclass-form-group{flex-direction:column;gap:.5rem;display:flex}.multiclass-label{color:#2d3748;margin-bottom:.25rem;font-size:.95rem;font-weight:600}.multiclass-select{color:#2d3748;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff 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") right 1rem center/12px no-repeat;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 2.5rem .75rem 1rem;font-family:inherit;font-size:.95rem;transition:all .2s}.multiclass-select:hover{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.multiclass-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea33}.multiclass-select:disabled{cursor:not-allowed;opacity:.6;background-color:#f7fafc}.multiclass-select option{padding:.5rem}.dark-mode .multiclass-label{color:#e2e8f0}.dark-mode .multiclass-select{color:#e2e8f0;background:#2d3748 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") right 1rem center/12px no-repeat;border-color:#4a5568}.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{opacity:.6;background-color:#1a202c}.form-group input,.form-group textarea{border:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input.disabled-input{cursor:not-allowed;background:#f7fafc}.form-group small{color:#718096;font-size:.85rem}.form-actions{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.remember-me-checkbox{cursor:pointer;color:#4a5568;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.remember-me-checkbox input[type=checkbox]{cursor:pointer;accent-color:#667eea;flex-shrink:0;width:18px;height:18px}.remember-me-checkbox span{font-weight:500}.remember-me-checkbox:hover{color:#667eea}.forgot-password-link{color:#667eea;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.auth-button{cursor:pointer;border:none;border-radius:8px;padding:.875rem 2rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.auth-button.primary{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);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{color:#2d3748;background:#e2e8f0}.auth-button.secondary:hover:not(:disabled){background:#cbd5e0}.auth-button.danger{color:#fff;background:#f56565}.auth-button.danger:hover:not(:disabled){background:#e53e3e}.auth-button.google{color:#2d3748;background:#fff;border:2px solid #e2e8f0;justify-content:center;align-items:center;gap:.5rem;width:100%;display:flex}.auth-button.google:hover{background:#f7fafc;border-color:#cbd5e0}.auth-divider{text-align:center;color:#718096;align-items:center;margin:2rem 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";border-bottom:1px solid #e2e8f0;flex:1}.auth-divider span{padding:0 1rem}.auth-footer{text-align:center;color:#718096;margin-top:2rem}.auth-footer a{color:#667eea;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-error{color:#742a2a;background:linear-gradient(135deg,#fed7d7,#feb2b2);border:2px solid #e53e3e;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.auth-success{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border:2px solid #48bb78;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.nav-logout{color:#e53e3e;cursor:pointer;background:0 0;border:2px solid #e53e3e;border-radius:8px;padding:.5rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.nav-logout:hover{color:#fff;background:#e53e3e}.account-container{max-width:1000px;margin:2rem auto;padding:2rem}.account-header{margin-bottom:2rem}.account-header h1{-webkit-text-fill-color:transparent;letter-spacing:-.5px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.account-header p{color:#718096;font-size:1.1rem}.account-content{flex-direction:column;gap:2rem;display:flex}.account-section{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:2rem;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #0000001a}.account-section:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.profile-image-and-name-section{align-items:flex-start;gap:2rem;margin-bottom:1.5rem;display:flex}.name-email-fields-group{flex-direction:column;flex:1;gap:1.5rem;min-width:0;display:flex}.form-group-narrow{max-width:400px}.avatar-upload-section{flex-direction:column;align-items:flex-start;gap:1rem;display:flex}.avatar-preview-container{border:3px solid #667eea;border-radius:50%;flex-shrink:0;width:120px;height:120px;overflow:hidden;box-shadow:0 4px 12px #667eea33}.avatar-preview{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.avatar-placeholder{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;font-weight:700;display:flex}.avatar-upload-controls{flex-direction:column;align-items:flex-start;gap:.75rem;width:100%;display:flex}.avatar-upload-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.6rem 1.2rem;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{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:8px;padding:.6rem 1.2rem;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;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.5rem;font-weight:600;display:flex}.account-form{flex-direction:column;gap:1.5rem;display:flex}.checkbox-group{flex-direction:column;gap:.5rem;display:flex}.checkbox-group label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.checkbox-group input[type=checkbox]{cursor:pointer;width:auto}.account-section-profile{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:4px solid #667eea}.account-section-subscription{background:linear-gradient(135deg,#f0fff4,#e6fffa);border-left:4px solid #48bb78}.account-section-danger{background:linear-gradient(135deg,#fff5f5,#fed7d7);border-left:4px solid #f56565}.profile-container{max-width:1200px;margin:2rem auto;padding:2rem}.profile-header{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;align-items:flex-start;gap:2rem;margin-bottom:3rem;padding:2rem;display:flex;box-shadow:0 4px 12px #0000001a}.profile-avatar-section{flex-shrink:0;position:relative}.profile-avatar{-o-object-fit:cover;object-fit:cover;border:4px solid #667eea;border-radius:50%;width:140px;height:140px;box-shadow:0 4px 12px #667eea33}.profile-avatar-placeholder{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:4px solid #667eea;border-radius:50%;justify-content:center;align-items:center;width:140px;height:140px;font-size:3rem;font-weight:700;display:flex;box-shadow:0 4px 12px #667eea33}.profile-edit-btn{color:#667eea;background:#fff;border:2px solid #667eea;border-radius:20px;padding:.4rem .8rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;position:absolute;bottom:0;right:0;box-shadow:0 2px 8px #0000001a}.profile-edit-btn:hover{color:#fff;background:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.profile-title-section{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.profile-info h1{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;margin:0;font-size:2.5rem}.profile-settings-link{color:#718096;border-radius:8px;align-items:center;gap:.3rem;padding:.4rem .8rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:inline-flex}.profile-settings-link:hover{color:#667eea;background:#f7fafc}.profile-bio{color:#4a5568;margin:1rem 0;font-size:1.1rem;line-height:1.6}.profile-meta{color:#718096;font-size:.9rem}.profile-stats{border-top:1px solid #e2e8f0;flex-wrap:wrap;gap:2rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.profile-stat{flex-direction:column;gap:.25rem;display:flex}.stat-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem}.profile-content{background:linear-gradient(135deg,#fff,#f7fafc);border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000001a}.profile-content-header{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.profile-content-header h2{color:#2d3748;align-items:center;gap:.75rem;margin:0;font-size:1.8rem;display:flex}.content-icon{font-size:1.5rem}.profile-characters{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.profile-character-card{color:inherit;background:#fff;border:2px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:1rem;height:100%;padding:1.5rem;text-decoration:none;transition:all .2s;display:flex}.profile-character-card-avatar{border:3px solid #667eea;border-radius:50%;flex-shrink:0;width:100px;height:100px;margin:0 auto;overflow:hidden;box-shadow:0 2px 8px #667eea33}.profile-character-card-avatar-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}.profile-character-card-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.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{justify-content:space-between;align-items:flex-start;gap:1rem;min-width:0;display:flex}.character-card-header h3{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.profile-character-card h3{color:#2d3748;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin:0;font-size:1.3rem;font-weight:600;overflow:hidden}.character-level{color:#fff;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;flex-shrink:0;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.character-card-info{grid-template-columns:1fr 1fr;gap:.75rem;min-width:0;font-size:.9rem;display:grid}.character-info-item{flex-direction:column;gap:.25rem;display:flex}.info-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;font-size:.8rem}.info-value{color:#2d3748;font-weight:500}.character-card-footer{border-top:1px solid #e2e8f0;margin-top:auto;padding-top:1rem}.character-date{color:#718096;font-size:.85rem}.character-tags{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.tag{color:#4a5568;background:#edf2f7;border-radius:12px;padding:.25rem .75rem;font-size:.85rem;font-weight:500}.profile-loading{text-align:center;color:#718096;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.loading-spinner{border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}.profile-error{text-align:center;color:#e53e3e;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.error-icon{margin-bottom:1rem;font-size:4rem}.profile-error h2{color:#e53e3e;margin:0}.profile-error-banner{color:#c33;background:#fee;border:1px solid #fcc;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;display:flex}.error-close{color:#c33;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.5rem;display:flex}.error-close:hover{background:#cc33331a}.loading-container{color:#718096;justify-content:center;align-items:center;min-height:400px;display:flex}.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{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .form-group input:focus,.dark-mode .form-group textarea:focus{border-color:#667eea}.dark-mode .form-group input.disabled-input{color:#a0aec0;background:#2d3748}.dark-mode .form-group small{color:#a0aec0}.dark-mode .forgot-password-link{color:#90cdf4}.dark-mode .auth-button.google{color:#e2e8f0;background:#2d3748;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:hover{box-shadow:0 6px 20px #0006}.dark-mode .account-section-profile{background:linear-gradient(135deg,#1e2a4a,#2d3748);border-left-color:#667eea}.dark-mode .account-section-subscription{background:linear-gradient(135deg,#1a3a2a,#2d3748);border-left-color:#48bb78}.dark-mode .account-section-danger{background:linear-gradient(135deg,#3a1a1a,#2d3748);border-left-color:#f56565}.dark-mode .account-header p{color:#a0aec0}.dark-mode .account-section h2{color:#e2e8f0}.dark-mode .account-section-description{color:#a0aec0}.dark-mode .profile-privacy-notice{background:linear-gradient(135deg,#1e3a5f,#2a4a6f);border-color:#3a5f8f}.dark-mode .privacy-notice-content strong{color:#e2e8f0}.dark-mode .privacy-notice-content p{color:#cbd5e0}.dark-mode .subscription-info-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem;display:grid}.subscription-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;align-items:center;gap:1rem;padding:1.5rem;transition:all .2s;display:flex}.subscription-card:hover{border-color:#48bb78;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.subscription-card-icon{font-size:2.5rem;line-height:1}.subscription-card-content{flex:1}.subscription-card-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-size:.85rem;font-weight:600}.subscription-card-value{color:#2d3748;font-size:1.25rem;font-weight:700}.subscription-actions{flex-wrap:wrap;gap:1rem;display:flex}.subscription-actions button{flex:1;min-width:200px}.danger-zone-warning{background:#fff5f5;border:2px solid #feb2b2;border-radius:12px;gap:1rem;margin-bottom:1.5rem;padding:1.5rem;display:flex}.warning-icon{font-size:2rem;line-height:1}.warning-content{flex:1}.warning-content strong{color:#c53030;margin-bottom:.5rem;font-size:1.1rem;display:block}.warning-content p{color:#742a2a;margin:.5rem 0}.warning-content ul{color:#742a2a;margin:.5rem 0;padding-left:1.5rem}.warning-content li{margin:.25rem 0}.delete-modal{max-width:500px}.delete-modal h2{color:#c53030;margin-bottom:1rem}.delete-modal-warning{background:#fff5f5;border:2px solid #feb2b2;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.delete-modal-warning p{color:#742a2a;margin:.5rem 0}.delete-modal-warning strong{color:#c53030}.delete-modal-warning ul{color:#742a2a;margin:.5rem 0 0;padding-left:1.5rem}.delete-modal-warning li{margin:.25rem 0}.modal-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.modal-actions button{min-width:120px}.dark-mode .subscription-card{background:#2d3748;border-color:#4a5568}.dark-mode .subscription-card:hover{border-color:#48bb78;box-shadow:0 4px 12px #0000004d}.dark-mode .subscription-card-label{color:#a0aec0}.dark-mode .subscription-card-value{color:#e2e8f0}.dark-mode .danger-zone-warning{background:#3a1a1a;border-color:#c53030}.dark-mode .warning-content strong{color:#fc8181}.dark-mode .warning-content p,.dark-mode .warning-content li{color:#feb2b2}.dark-mode .delete-modal-warning{background:#3a1a1a;border-color:#c53030}.dark-mode .delete-modal-warning p,.dark-mode .delete-modal-warning li{color:#feb2b2}.dark-mode .delete-modal-warning strong,.dark-mode .delete-modal h2{color:#fc8181}.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{border-top:1px solid #e2e8f0;margin-top:1.5rem;padding-top:1.5rem}.share-link-container{flex-direction:column;gap:.5rem;display:flex}.share-link-container label{color:#718096;font-size:.9rem;font-weight:500}.share-link-input-group{align-items:stretch;gap:.5rem;display:flex}.share-link-input{color:#2d3748;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;padding:.5rem .75rem;font-family:monospace;font-size:.9rem}.share-link-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.share-link-remove-btn{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:8px;padding:.5rem .75rem;font-size:1rem;transition:background .2s}.share-link-remove-btn:hover{background:#c53030}.share-link-copy-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s,background .2s}.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:.3s ease-in-out successPulse}.generate-share-link-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.75rem 1.5rem;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{flex-direction:column;display:flex;position:relative}.copy-character-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;justify-content:center;align-self:flex-start;align-items:center;gap:.5rem;width:100%;margin-top:.75rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;transition:transform .2s,box-shadow .2s,background .2s;display:flex}.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:.3s ease-in-out successPulse}@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{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.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;color:#718096;padding:4rem 2rem}.empty-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.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{color:#ff6b6b;background:#3a1f1f;border-color:#5a2f2f}.dark-mode .error-close:hover{background:#ff6b6b1a}.dark-mode .profile-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2)}.dark-mode .profile-edit-btn{color:#667eea;background:#2d3748;border-color:#667eea}.dark-mode .profile-edit-btn:hover{color:#fff;background:#667eea}.dark-mode .profile-settings-link:hover{color:#667eea;background:#2d3748}.dark-mode .profile-stats{border-top-color:#4a5568}.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{color:#f7fafc;pointer-events:none;z-index:10000;word-wrap:break-word;white-space:normal;overflow-wrap:break-word;background:#1a202c;border-radius:6px;min-width:150px;max-width:300px;padding:.5rem .75rem;font-size:.875rem;line-height:1.4;position:fixed;box-shadow:0 4px 12px #0000004d}.tooltip:before{content:"";border:6px solid #0000;width:0;height:0;position:absolute}.tooltip-top:before{border-top-color:#1a202c;bottom:-12px;left:50%;transform:translate(-50%)}.tooltip-bottom:before{border-bottom-color:#1a202c;top:-12px;left:50%;transform:translate(-50%)}.tooltip-left:before{border-left-color:#1a202c;top:50%;right:-12px;transform:translateY(-50%)}.tooltip-right:before{border-right-color:#1a202c;top:50%;left:-12px;transform:translateY(-50%)}.dark-mode .tooltip{color:#e2e8f0;background:#2d3748;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{color:#718096;align-items:center;gap:.25rem;margin-left:.5rem;font-size:.875rem;display:inline-flex}.help-icon{cursor:help;font-size:.875rem}.help-content{font-style:italic}.help-icon-inline{cursor:help;opacity:.7;vertical-align:middle;color:#667eea;background:#667eea1a;border-radius:50%;justify-content:center;align-items:center;width:1.2em;height:1.2em;margin-left:.25rem;font-size:.875rem;font-weight:600;line-height:1;transition:opacity .2s;display:inline-flex}.help-icon-inline:hover{opacity:1;background:#667eea33}body.dark-mode .help-icon-inline{color:#818cf8;background:#667eea26}body.dark-mode .help-icon-inline:hover{background:#667eea40}.dark-mode .help-text{color:#a0aec0}.dark-mode .help-icon-inline{opacity:.8}.dark-mode .help-icon-inline:hover{opacity:1}.account-menu{display:inline-block;position:relative}.account-menu-button{color:#4a5568;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.account-menu-avatar{-o-object-fit:cover;object-fit:cover;border-radius:50%;flex-shrink:0;width:24px;height:24px}.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{z-index:1000;background:#fff;border:1px solid #667eea1a;border-radius:8px;min-width:200px;margin-top:.5rem;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 12px #00000026}.account-menu-item{color:#4a5568;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .2s;display:block}.account-menu-item:hover{color:#667eea;background:#667eea1a}.account-menu-item.active{color:#667eea;background:#667eea26}.account-menu-logout{color:#e53e3e}.account-menu-logout:hover{color:#c53030;background:#e53e3e1a}.account-menu-divider{background:#e2e8f0;height:1px;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{color:#90cdf4;background:#4299e126}.dark-mode .account-menu-item.active{color:#90cdf4;background:#4299e133}.dark-mode .account-menu-divider{background:#4a5568}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:.75rem;max-width:400px;display:flex;position:fixed;top:80px;right:2rem}.toast{pointer-events:auto;background:#fff;border-left:4px solid;border-radius:8px;min-width:300px;max-width:400px;padding:1rem;animation:.3s ease-out slideInRight;box-shadow:0 4px 12px #00000026}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{background:linear-gradient(135deg,#f0fff4,#fff);border-left-color:#48bb78}.toast-error{background:linear-gradient(135deg,#fff5f5,#fff);border-left-color:#e53e3e}.toast-warning{background:linear-gradient(135deg,#fffaf0,#fff);border-left-color:#ed8936}.toast-info{background:linear-gradient(135deg,#ebf8ff,#fff);border-left-color:#4299e1}.toast-content{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.toast-message{color:#2d3748;flex:1;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{color:#718096;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.5rem;line-height:1;transition:all .2s;display:flex}.toast-close:hover{color:#2d3748;background:#0000001a}.dark-mode .toast{background:linear-gradient(135deg,#2d3748,#1a202c);border-color:#4a5568}.dark-mode .toast-success{background:linear-gradient(135deg,#1a202c,#2d3748);border-left-color:#48bb78}.dark-mode .toast-error{background:linear-gradient(135deg,#1a202c,#2d3748);border-left-color:#e53e3e}.dark-mode .toast-warning{background:linear-gradient(135deg,#1a202c,#2d3748);border-left-color:#ed8936}.dark-mode .toast-info{background:linear-gradient(135deg,#1a202c,#2d3748);border-left-color:#4299e1}.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{color:#e2e8f0;background:#ffffff1a}.admin-dashboard{max-width:1400px;margin:2rem auto;padding:2rem}.admin-header{border-bottom:2px solid #667eea33;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.admin-header h1{color:#fff;text-shadow:0 2px 10px #0003;font-size:2.5rem}.admin-tabs{gap:.5rem;display:flex}.admin-tabs button{color:#fff;cursor:pointer;background:#ffffff1a;border:2px solid #fff3;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.admin-tabs button:hover{background:#fff3;border-color:#ffffff4d}.admin-tabs button.active{color:#667eea;background:#fff;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{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.admin-card{text-align:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.admin-card h3{color:#4a5568;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.9rem;font-weight:600}.admin-card-value{color:#667eea;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.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{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem;display:grid}.admin-stat-box{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.admin-stat-box h4{color:#2d3748;margin-bottom:1rem;font-size:1.1rem}.stat-values{flex-direction:column;gap:.5rem;display:flex}.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{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.admin-resource-section{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.admin-resource-section h3{color:#2d3748;margin-bottom:1rem;font-size:1.2rem}.resource-gauge{margin-bottom:1.5rem}.gauge-label{color:#4a5568;margin-bottom:.5rem;font-size:.9rem;font-weight:600}.gauge-value{margin-bottom:.5rem;font-size:2rem;font-weight:700}.gauge-bar{background:#e2e8f0;border-radius:10px;width:100%;height:20px;margin-bottom:.5rem;overflow:hidden}.gauge-fill{border-radius:10px;height:100%;transition:width .3s}.gauge-max{color:#718096;font-size:.8rem}.resource-details{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.resource-details div{color:#4a5568;font-size:.95rem}.resource-item-with-details{margin-bottom:1.5rem}.resource-item-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;display:flex}.resource-item-title{flex-direction:column;flex:1;gap:.25rem;display:flex}.resource-label{color:#4a5568;font-size:.9rem;font-weight:600}.resource-detail{color:#718096;font-size:.85rem}.resource-item-value{white-space:nowrap;text-align:right;min-width:50px;font-size:1rem;font-weight:600}.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{margin-top:1rem;overflow-x:auto}.admin-table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;overflow:hidden;box-shadow:0 2px 8px #0000001a}.admin-table thead{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.admin-table th{text-align:left;padding:1rem;font-size:.9rem;font-weight:600}.admin-table td{border-bottom:1px solid #e2e8f0;padding:.75rem 1rem;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{color:#e2e8f0;border-bottom-color:#4a5568}.dark-mode .admin-table tbody tr:hover{background:#4a5568}.admin-filters{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.admin-filters input,.admin-filters select{border:1px solid #e2e8f0;border-radius:4px;padding:.5rem;font-size:.9rem}.admin-filters input{flex:1;min-width:200px}.dark-mode .admin-filters input,.dark-mode .admin-filters select{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.admin-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.admin-modal{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:80vh;padding:2rem;overflow:auto;box-shadow:0 4px 20px #0000004d}.dark-mode .admin-modal{color:#e2e8f0;background:#2d3748}.admin-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.dark-mode .admin-modal-header{border-bottom-color:#4a5568}.admin-modal-close{cursor:pointer;color:#4a5568;background:0 0;border:none;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:1.5rem;display:flex}.dark-mode .admin-modal-close{color:#a0aec0}.admin-modal-close:hover{color:#2d3748}.dark-mode .admin-modal-close:hover{color:#e2e8f0}.admin-action-button{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:.25rem .5rem;font-size:.85rem;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{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.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{background:#e6f3ff;border-radius:4px;align-items:center;gap:.5rem;margin-left:auto;padding:.5rem;display:flex}.dark-mode .admin-owner-filter-indicator{color:#e2e8f0;background:#2c5282}.banned-words-add,.banned-words-bulk{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.banned-words-add h3,.banned-words-bulk h3{color:#2d3748;margin-bottom:1rem;font-size:1.2rem}.banned-word-form{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.banned-word-form input,.banned-word-form select{border:1px solid #e2e8f0;border-radius:8px;flex:1;min-width:150px;padding:.75rem;font-size:1rem}.banned-word-form button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.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{resize:vertical;border:1px solid #e2e8f0;border-radius:8px;width:100%;margin-bottom:1rem;padding:.75rem;font-family:inherit;font-size:1rem}.bulk-import-controls{align-items:flex-end;gap:1rem;display:flex}.bulk-import-controls input,.bulk-import-controls select{border:1px solid #e2e8f0;border-radius:8px;flex:1;min-width:150px;padding:.75rem;font-size:1rem}.bulk-import-controls button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.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{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;overflow:hidden}.banned-words-table thead{color:#fff;background:#667eea}.banned-words-table th{text-align:left;padding:1rem;font-weight:600}.banned-words-table td{color:#4a5568;border-bottom:1px solid #e2e8f0;padding:1rem}.banned-words-table tbody tr:hover{background:#f7fafc}.delete-btn{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:all .2s}.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{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.dark-mode .banned-words-table{background:#1a202c}.dark-mode .banned-words-table thead{background:#434190}.dark-mode .banned-words-table td{color:#a0aec0;border-color:#4a5568}.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{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.dark-mode .banned-words-add input[type=checkbox]{accent-color:#667eea}.dark-mode .banned-words-add label{color:#e2e8f0}.dark-mode .badge-button{color:#e2e8f0!important;background:#2d3748!important;border-color:#4a5568!important}.dark-mode .badge-button:hover{background:#4a5568!important;border-color:#667eea!important}.dark-mode .badge-button-selected{color:#9f7aea!important;background:#2d3748!important;border-color:#667eea!important}.dark-mode .badge-button-selected:hover{background:#3d4a5c!important}.level-up-actions{align-items:center;gap:.5rem;display:flex}.level-up-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.level-up-button:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 4px 8px #48bb784d}.history-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.history-button:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.export-pdf-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e53e3e,#c53030);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.export-pdf-button:hover{background:linear-gradient(135deg,#c53030,#9b2c2c);transform:translateY(-1px);box-shadow:0 4px 8px #e53e3e4d}.actions-menu-container{display:inline-block;position:relative}.actions-menu-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4a5568,#2d3748);border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.actions-menu-button:hover{background:linear-gradient(135deg,#2d3748,#1a202c);transform:translateY(-1px);box-shadow:0 4px 8px #4a55684d}.actions-menu-arrow{font-size:.7rem;transition:transform .2s}.actions-menu-dropdown{z-index:1000;background:#fff;border:1px solid #e2e8f0;border-radius:8px;min-width:180px;animation:.2s dropdownFadeIn;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 4px 12px #00000026}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.actions-menu-item{color:#2d3748;text-align:left;cursor:pointer;background:#fff;border:none;width:100%;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:background-color .2s;display:block}.actions-menu-item:hover{background:#f7fafc}.actions-menu-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.actions-menu-item:last-child{border-bottom-right-radius:8px;border-bottom-left-radius:8px}@media (prefers-color-scheme:dark){.actions-menu-dropdown{background:#2d3748;border-color:#4a5568}.actions-menu-item{color:#e2e8f0;background:#2d3748}.actions-menu-item:hover{background:#374151}}.companion-toggle-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f6ad55,#ed8936);border:none;border-radius:8px;margin-right:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.companion-toggle-button:hover{background:linear-gradient(135deg,#ed8936,#dd6b20);transform:translateY(-1px);box-shadow:0 4px 8px #f6ad554d}.companion-toggle-button.active{background:linear-gradient(135deg,#dd6b20,#c05621);box-shadow:inset 0 2px 4px #f6ad5566}.companion-sheet{padding:2rem}.companion-header-section{align-items:flex-start;gap:1.5rem;margin-bottom:2rem;display:flex}.companion-header-text h1{color:var(--text-color);margin:0 0 .5rem;font-size:2rem}.companion-type{color:var(--text-secondary);font-size:.9rem;font-style:italic}.companion-experiences-section{margin-bottom:2rem}.companion-experiences-list{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.companion-experience-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.companion-experience-name{color:var(--text-color);font-weight:600}.companion-experience-modifier{color:var(--accent-color);font-size:1.1rem;font-weight:700}.companion-attack-section{margin-bottom:2rem}.companion-attack-info{margin-top:1rem}.companion-attack-description{background:var(--bg-secondary);color:var(--text-color);border-radius:8px;margin-bottom:1rem;padding:.75rem}.companion-attack-stats{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;display:grid}.companion-attack-stat{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;gap:.25rem;padding:.75rem;display:flex}.companion-attack-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.companion-attack-value{color:var(--text-color);font-size:1.1rem;font-weight:700}.companion-training-section{margin-bottom:2rem}.companion-training-list{grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem;display:grid}.companion-training-empty{text-align:center;color:var(--text-secondary);margin-top:1rem;padding:1rem;font-style:italic}.companion-training-item{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;padding:1rem;transition:all .2s}.companion-training-item.taken{border-color:var(--accent-color);background:#667eea0d}.companion-training-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.companion-training-badge{background:var(--accent-color);color:#fff;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.companion-training-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.companion-rules-section{margin-top:2rem}.companion-rules-content{background:var(--bg-secondary);color:var(--text-color);border-radius:8px;margin-top:1rem;padding:1rem;line-height:1.6}.companion-rules-content p{margin:0}.companion-rules-content p+p{margin-top:1rem}.dark-mode .companion-experience-item,.dark-mode .companion-attack-stat,.dark-mode .companion-training-item{background:#ffffff0d;border-color:#ffffff1a}.dark-mode .companion-training-item.taken{border-color:var(--accent-color);background:#667eea26}.dark-mode .companion-rules-content{background:#ffffff0d}.companion-creation-step{max-width:900px;margin:0 auto}.companion-creation-step .step-header{text-align:center;margin-bottom:2.5rem}.companion-creation-step .step-header h2{color:var(--text-color);margin-bottom:.75rem;font-family:Cinzel,serif;font-size:2rem}.companion-creation-step .step-description{color:var(--text-secondary);max-width:700px;margin:0 auto;font-size:1rem;line-height:1.6}.companion-creation-form{flex-direction:column;gap:2rem;display:flex}.companion-creation-step .form-section{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000d}.companion-creation-step .form-label{color:var(--text-color);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1rem;font-weight:600;display:flex}.companion-creation-step .required{color:var(--error-color);font-weight:700}.companion-creation-step .form-input,.companion-creation-step .form-textarea{border:2px solid var(--border-color);background:var(--bg-color);width:100%;color:var(--text-color);border-radius:8px;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.companion-creation-step .form-input:focus,.companion-creation-step .form-textarea:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.companion-creation-step .form-textarea{resize:vertical;min-height:80px}.experiences-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:1rem;display:grid}.experience-card{background:var(--bg-color);border:2px solid var(--border-color);border-radius:10px;padding:1.25rem;transition:all .2s}.experience-card:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #667eea1a}.experience-card-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.experience-card-title{align-items:center;gap:.75rem;display:flex}.experience-number{color:var(--text-color);font-size:.95rem;font-weight:600}.experience-modifier{background:linear-gradient(135deg,var(--accent-color)0%,#764ba2 100%);color:#fff;border-radius:6px;padding:.25rem .75rem;font-size:.875rem;font-weight:700}.suggest-button-small{background:linear-gradient(135deg,var(--accent-color)0%,#764ba2 100%);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.4rem .85rem;font-size:.8rem;font-weight:600;transition:all .2s}.suggest-button-small:hover{transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.suggestions-details{margin-top:.75rem}.suggestions-summary{cursor:pointer;color:var(--text-secondary);padding:.5rem 0;font-size:.875rem;font-weight:600;transition:color .2s}.suggestions-summary:hover{color:var(--accent-color)}.suggestions-grid{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;padding:.75rem;display:flex}.suggestion-chip{background:var(--bg-color);border:1px solid var(--border-color);cursor:pointer;color:var(--text-color);border-radius:6px;padding:.35rem .75rem;font-size:.85rem;font-weight:500;transition:all .2s}.suggestion-chip:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-1px)}.attack-section{border-color:var(--accent-color);background:linear-gradient(135deg,#667eea0d,#764ba20d)}.attack-section .section-title{color:var(--text-color);margin-bottom:.5rem;font-family:Cinzel,serif;font-size:1.25rem;font-weight:700}.attack-section .section-description{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.9rem;line-height:1.5}.attack-form-grid{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}.attack-description-field{grid-column:1}.damage-type-field{grid-column:2}.radio-group{flex-direction:column;gap:.75rem;display:flex}.radio-option{cursor:pointer;background:var(--bg-color);border:2px solid var(--border-color);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;transition:all .2s;display:flex}.radio-option:hover{border-color:var(--accent-color);background:#667eea0d}.radio-option input[type=radio]{cursor:pointer;width:20px;height:20px;accent-color:var(--accent-color)}.radio-option input[type=radio]:checked+.radio-label{color:var(--accent-color);font-weight:600}.radio-label{color:var(--text-color);font-size:1rem;transition:all .2s}.dark-mode .companion-creation-step .form-section{background:#ffffff14;border-color:#fff3;box-shadow:0 2px 8px #0000004d}.dark-mode .companion-creation-step .form-label{color:#e2e8f0}.dark-mode .companion-creation-step .form-input,.dark-mode .companion-creation-step .form-textarea{color:#e2e8f0;background:#ffffff1a;border-color:#fff3}.dark-mode .companion-creation-step .form-input:focus,.dark-mode .companion-creation-step .form-textarea:focus{border-color:var(--accent-color);background:#ffffff1f;box-shadow:0 0 0 3px #667eea4d}.dark-mode .experience-card{background:#ffffff0f;border-color:#fff3}.dark-mode .experience-card:hover{border-color:var(--accent-color);background:#ffffff1a;box-shadow:0 4px 12px #667eea33}.dark-mode .experience-number{color:#e2e8f0}.dark-mode .suggestions-grid{background:#ffffff0f;border-color:#fff3}.dark-mode .suggestions-summary{color:#cbd5e0}.dark-mode .suggestions-summary:hover{color:var(--accent-color)}.dark-mode .suggestion-chip{color:#e2e8f0;background:#ffffff14;border-color:#ffffff40}.dark-mode .suggestion-chip:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.dark-mode .attack-section{border-color:var(--accent-color);background:linear-gradient(135deg,#667eea26,#764ba226)}.dark-mode .attack-section .section-title{color:#e2e8f0}.dark-mode .attack-section .section-description{color:#cbd5e0}.dark-mode .radio-option{background:#ffffff0f;border-color:#fff3}.dark-mode .radio-option:hover{border-color:var(--accent-color);background:#667eea26}.dark-mode .radio-label{color:#e2e8f0}.dark-mode .step-description{color:#cbd5e0}.hope-pips-container{align-items:center;gap:.5rem;display:flex}.hope-separator{background:var(--border-color);width:8px;height:1px;margin:0 .25rem}.companion-hope-slot{opacity:.8}.companion-hope-slot .resource-pip{background:linear-gradient(135deg,#f6ad5533,#ed893633);border-color:#f6ad55}.companion-hope-slot .resource-pip.filled{background:linear-gradient(135deg,#f6ad55,#ed8936);border-color:#ed8936}.companion-hope-slot .resource-pip:hover{border-color:#ed8936;box-shadow:0 0 8px #f6ad5566}.dark-mode .companion-hope-slot .resource-pip{border-color:#f6ad55}.dark-mode .companion-hope-slot .resource-pip.filled{background:linear-gradient(135deg,#f6ad55,#ed8936);border-color:#ed8936}.companion-training-selection{max-width:900px;margin:0 auto}.training-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.5rem;display:grid}.training-option{background:var(--bg-secondary);border:2px solid var(--border-color);cursor:pointer;border-radius:10px;padding:1.25rem;transition:all .2s}.training-option:hover{border-color:var(--accent-color);background:#667eea0d;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.training-option.selected{border-color:var(--accent-color);background:#667eea1a;box-shadow:0 0 0 3px #667eea33}.training-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.training-header h3{color:var(--text-color);margin:0;font-family:Cinzel,serif;font-size:1.1rem;font-weight:700}.selected-badge{background:var(--accent-color);color:#fff;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.training-description{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.5}.training-details-panel{background:var(--bg-secondary);border:2px solid var(--accent-color);border-radius:10px;margin-top:2rem;padding:1.5rem}.training-details-panel h3{color:var(--text-color);margin-top:0;margin-bottom:.5rem;font-family:Cinzel,serif;font-size:1.25rem;font-weight:700}.training-details-panel p{color:var(--text-secondary);margin-bottom:1rem}.vicious-choice-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.choice-button{background:var(--bg-color);border:2px solid var(--border-color);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:.5rem;padding:1rem;transition:all .2s;display:flex}.choice-button:hover{border-color:var(--accent-color);background:#667eea0d}.choice-button.selected{border-color:var(--accent-color);background:#667eea1a;box-shadow:0 0 0 3px #667eea33}.choice-button strong{color:var(--text-color);font-size:1rem}.choice-button span{color:var(--text-secondary);font-size:.9rem}.experience-selection-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.experience-choice-button{background:var(--bg-color);border:2px solid var(--border-color);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:.25rem;padding:1rem;transition:all .2s;display:flex}.experience-choice-button:hover{border-color:var(--accent-color);background:#667eea0d}.experience-choice-button.selected{border-color:var(--accent-color);background:#667eea1a;box-shadow:0 0 0 3px #667eea33}.experience-choice-button strong{color:var(--text-color);font-size:1rem}.experience-choice-button span{color:var(--text-secondary);font-size:.85rem}.info-message{background:var(--bg-secondary);border:2px solid var(--border-color);text-align:center;color:var(--text-secondary);border-radius:10px;padding:1.5rem}.dark-mode .training-option{background:#ffffff0d;border-color:#ffffff1a}.dark-mode .training-option:hover{border-color:var(--accent-color);background:#667eea26}.dark-mode .training-option.selected{border-color:var(--accent-color);background:#667eea33}.dark-mode .training-details-panel{border-color:var(--accent-color);background:#ffffff0d}.dark-mode .choice-button,.dark-mode .experience-choice-button{background:#ffffff08;border-color:#ffffff1a}.dark-mode .choice-button:hover,.dark-mode .experience-choice-button:hover{border-color:var(--accent-color);background:#667eea26}.dark-mode .choice-button.selected,.dark-mode .experience-choice-button.selected{border-color:var(--accent-color);background:#667eea33}.level-up-info{grid-template-columns:1fr 1fr;gap:2rem;margin:2rem 0;display:grid}.info-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem}.info-section h3{color:#667eea;margin-bottom:1rem;font-family:Cinzel,serif}.stat-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem;display:grid}.stat-item{background:#f7fafc;border-radius:8px;justify-content:space-between;padding:.75rem;display:flex}.stat-label{color:#718096;font-weight:600}.stat-value{color:#2d3748;font-size:1.1rem;font-weight:700}.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{padding-left:0;list-style:none}.automatic-changes li,.choices-needed li{padding:.5rem 0 .5rem 1.5rem;position:relative}.automatic-changes li:before,.choices-needed li:before{content:"✓";color:#48bb78;font-weight:700;position:absolute;left:0}.tier-achievement-benefits{flex-direction:column;gap:1.5rem;margin:2rem 0;display:flex}.benefit-item{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem}.benefit-item h3{color:#667eea;margin-bottom:.75rem;font-family:Cinzel,serif}.marked-traits-list{background:#fef5e7;border-left:4px solid #f6ad55;border-radius:8px;margin-top:1rem;padding:1rem}.marked-traits-list ul{margin-top:.5rem;padding-left:0;list-style:none}.marked-traits-list li{color:#744210;padding:.25rem 0;font-weight:600}.location-selection{background:#f7fafc;border-radius:8px;gap:1rem;margin:1.5rem 0;padding:1rem;display:flex}.location-selection label{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;flex:1;align-items:center;gap:.5rem;padding:.75rem 1rem;transition:all .2s;display:flex}.location-selection label:hover{background:#f0f4ff;border-color:#667eea}.location-selection input[type=radio]:checked+span{color:#667eea;font-weight:600}.exchange-warning{background:#fef5e7;border-left:4px solid #f6ad55;border-radius:8px;margin:1.5rem 0;padding:1rem}.exchange-warning p{color:#744210;margin-bottom:1rem;font-weight:600}.loadout-cards{margin-top:1rem}.loadout-cards h4{color:#4a5568;margin-bottom:.75rem}.exchange-card-button{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;width:100%;margin-bottom:.5rem;padding:1rem;transition:all .2s;display:flex}.exchange-card-button:hover{background:#f0f4ff;border-color:#667eea}.exchange-card-button.selected{background:#eef2ff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.current-loadout{background:#f0f4ff;border-radius:8px;margin:1.5rem 0;padding:1rem}.current-loadout h4{color:#4a5568;margin-bottom:.75rem}.loadout-list{flex-direction:column;gap:.5rem;display:flex}.loadout-card-item{background:#fff;border:1px solid #cbd5e0;border-radius:6px;justify-content:space-between;padding:.75rem;display:flex}.advancements-selection{margin:2rem 0}.selected-count{text-align:center;color:#4a5568;background:#f7fafc;border-radius:8px;margin-bottom:1.5rem;padding:1rem;font-weight:600}.advancements-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.advancement-option.multiclass-full-width{grid-column:1/-1}.advancement-option{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:all .2s}.advancement-option:hover{border-color:#cbd5e0}.advancement-option.selected{background:#f0f4ff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.advancement-option.special{background:#faf5ff;border-color:#9f7aea}.advancement-checkbox{cursor:pointer;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.advancement-checkbox input[type=checkbox]{cursor:pointer;width:20px;height:20px}.advancement-name{color:#2d3748;font-size:1.05rem;font-weight:600}.advancement-details{border-top:1px solid #e2e8f0;margin-top:1rem;padding-top:1rem}.trait-selection{margin-top:1rem}.traits-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.75rem;display:grid}.trait-button{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem;font-weight:600;transition:all .2s;position:relative}.trait-button:hover:not(:disabled){background:#f0f4ff;border-color:#667eea}.trait-button.selected{background:#eef2ff;border-color:#667eea;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{color:#fff;background:#f6ad55;border-radius:4px;padding:.25rem .5rem;font-size:.7rem;font-weight:700;position:absolute;top:.25rem;right:.25rem}.review-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.review-section h3{color:#667eea;margin-bottom:1rem;font-family:Cinzel,serif}.review-item{background:#f7fafc;border-radius:8px;margin-top:.75rem;padding:1rem}.exchange-note{color:#f6ad55;margin-top:.5rem;font-size:.9rem;font-weight:600}.complete-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;padding:1rem 2rem;font-size:1.1rem;font-weight:700;transition:all .2s}.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{color:#22543d;background:#c6f6d5;border-radius:4px;margin-left:.5rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.in-vault-badge{color:#2c5282;background:#bee3f8;border-radius:4px;margin-left:.5rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.owned-badge{color:#742a2a;background:#fed7d7;border-radius:4px;margin-left:.5rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.domain-card.owned{opacity:.6;cursor:not-allowed;position:relative}.domain-card.owned:after{content:"";pointer-events:none;background:#0000001a;border-radius:16px;position:absolute;top:0;right:0;bottom:0;left:0}.dark-mode .in-vault-badge{color:#bee3f8;background:#2c5282}.dark-mode .owned-badge{color:#fed7d7;background:#742a2a}.info-box{background:#eef2ff;border-left:4px solid #667eea;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.error-text{color:#e53e3e;margin-top:.5rem;font-size:.9rem;font-weight:600}.step-actions{border-top:2px solid #e2e8f0;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.step-actions .previous-button,.step-actions .next-button{color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:12px;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s}.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{cursor:not-allowed;box-shadow:none;opacity:.6;background:#cbd5e0}.step-actions .previous-button:disabled:hover,.step-actions .next-button:disabled:hover{box-shadow:none;transform:none}.dark-mode .step-indicator{background:0 0}.dark-mode .step-number{color:#a0aec0;background:#2d3748;border-color:#4a5568}.dark-mode .step-number.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea66}.dark-mode .step-number.completed{color:#fff;background:#48bb78;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{color:#718096;background:#4a5568}.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{color:#e2e8f0;background:#1a202c;border:1px solid #4a5568}.dark-mode .review-item p{color:#e2e8f0}.dark-mode .review-item strong{color:#f7fafc}.dark-mode .review-item code{color:#fbb6ce;background:#2d3748;border:1px solid #4a5568;border-radius:4px;padding:.2rem .4rem;font-size:.9em}.dark-mode .review-item>div,.dark-mode .review-item>div p{color:#e2e8f0}.dark-mode .review-item>div strong{color:#f7fafc}.dark-mode .exchange-note{color:#f6ad55;background:#f6ad551a;border-left:3px solid #f6ad55;border-radius:4px;padding:.5rem}.dark-mode .error-text{color:#fc8181;background:#fc81811a;border-left:3px solid #fc8181;border-radius:4px;padding:.5rem}.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{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.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{color:#e2e8f0;background:#2d3748;border-color:#4a5568}.dark-mode .exchange-card-button{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.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{background:linear-gradient(135deg,#3d4a5c,#2d3748);border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.dark-mode .advancement-name{color:#e2e8f0}.info-box{background:#f0f4ff;border-left:4px solid #667eea;border-radius:8px;margin:1rem 0;padding:1rem 1.5rem}.info-box p{color:#2d3748;margin:0;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{color:#718096;font-size:.75rem;font-weight:500}.dark-mode .advancement-limit{color:#a0aec0}.dark-mode .tier-limits-info{color:#e2e8f0!important;background:#2d3748!important;border-color:#4a5568!important}.dark-mode .tier-limits-info h4,.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{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.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{opacity:.5;background:#1a202c}.dark-mode .selected-count{color:#a0aec0;background:#2d3748}.dark-mode .search-input{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.dark-mode .search-input:focus{background:#2d3748;border-color:#667eea}.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{border:2px solid #e2e8f0;border-radius:8px;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .2s}.domain-card-selection .search-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.domain-card-selection .domain-card{z-index:1;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative}.domain-card-selection .domain-card *{pointer-events:none}.domain-card-selection .domain-card{pointer-events:auto}.dark-mode .domain-card-selection .search-input{color:#e2e8f0;background:#1a202c;border-color:#4a5568}.dark-mode .domain-card-selection .search-input:focus{background:#2d3748;border-color:#667eea}.dark-mode .no-cards{color:#a0aec0}.modal-overlay{z-index:1000;background:#0f172ad9;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.level-up-history-modal{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:800px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-content{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:720px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000059}.modal-header{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{margin:0;font-family:Cinzel,serif;font-size:1.5rem}.modal-close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:2rem;line-height:1;transition:all .2s;display:flex}.modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body{background:#f7fafc;flex:1;padding:2rem;overflow-y:auto}.modal-footer{background:#f7fafc;border-top:1px solid #e2e8f0;justify-content:flex-end;gap:.75rem;padding:1rem 2rem 1.5rem;display:flex}.section-header-with-actions{justify-content:space-between;align-items:center;gap:1rem;display:flex}.manage-button{color:#4c51bf;cursor:pointer;background:#edf2ff;border:1px solid #cbd5f5;border-radius:999px;padding:.4rem .9rem;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s,transform 50ms}.manage-button:hover{background:#e2e8ff;border-color:#667eea;transform:translateY(-1px)}.inventory-list-editable{flex-direction:column;gap:.75rem;margin:.5rem 0 0;padding:0;list-style:none;display:flex}.inventory-edit-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem;font-size:.9rem;transition:all .2s;display:flex;box-shadow:0 1px 3px #00000014}.inventory-edit-item:hover{border-color:var(--accent-color);transform:translateY(-1px);box-shadow:0 2px 6px #0000001f}.inventory-edit-item .remove-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e53e3e,#c53030);border:none;border-radius:6px;min-width:2.5rem;padding:.5rem .75rem;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #e53e3e4d}.inventory-edit-item .remove-button:hover{background:linear-gradient(135deg,#c53030,#a02626);transform:translateY(-1px);box-shadow:0 3px 6px #e53e3e66}.inventory-edit-item .remove-button:active{transform:translateY(0)}.modal-content .next-button,.modal-content .previous-button{border-radius:8px;justify-content:center;align-items:center;gap:.5rem;min-height:44px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 6px #0000001a}.modal-content .next-button{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border:none;box-shadow:0 2px 8px #48bb784d}.modal-content .next-button:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 4px 12px #48bb7866}.modal-content .previous-button{color:#fff;background:linear-gradient(135deg,#718096,#4a5568);border:none;box-shadow:0 2px 8px #7180964d}.modal-content .previous-button:hover:not(:disabled){background:linear-gradient(135deg,#4a5568,#2d3748);transform:translateY(-1px);box-shadow:0 4px 12px #71809666}.equipment-browser-item .next-button{color:#fff;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 2px 6px #667eea4d}.equipment-browser-item .next-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);transform:translateY(-1px);box-shadow:0 4px 10px #667eea66}.equipment-browser-item .next-button:active{transform:translateY(0)}.inventory-edit-item .next-button,.inventory-edit-item .previous-button{border-radius:6px;min-width:80px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #0000001a}.inventory-edit-item .next-button{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border:none;box-shadow:0 2px 6px #48bb784d}.inventory-edit-item .next-button:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 3px 8px #48bb7866}.inventory-edit-item .previous-button{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 2px 6px #667eea4d}.inventory-edit-item .previous-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);transform:translateY(-1px);box-shadow:0 3px 8px #667eea66}.modal-footer .next-button,.modal-footer .previous-button{border-radius:8px;min-width:140px;padding:.875rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.modal-footer .next-button{color:#fff;background:linear-gradient(135deg,#48bb78,#38a169);border:none;box-shadow:0 3px 10px #48bb784d}.modal-footer .next-button:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-2px);box-shadow:0 4px 14px #48bb7866}.modal-footer .previous-button{color:#fff;background:linear-gradient(135deg,#718096,#4a5568);border:none;box-shadow:0 3px 10px #7180964d}.modal-footer .previous-button:hover:not(:disabled){background:linear-gradient(135deg,#4a5568,#2d3748);transform:translateY(-2px);box-shadow:0 4px 14px #71809666}.dark-mode .modal-content .next-button{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 2px 8px #48bb7866}.dark-mode .modal-content .previous-button{background:linear-gradient(135deg,#718096,#4a5568);box-shadow:0 2px 8px #71809666}.dark-mode .equipment-browser-item .next-button{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 6px #667eea66}.dark-mode .inventory-edit-item .next-button{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 2px 6px #48bb7866}.dark-mode .inventory-edit-item .previous-button{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 6px #667eea66}@media (max-width:768px){.traits-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.thresholds-grid{border:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;overflow:visible}.threshold-item{border:1px solid #e2e8f0;border-right:none;border-radius:12px}.combat-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.equipment-browser{margin:.5rem auto;padding:1rem}.equipment-browser h1{margin-bottom:1rem;font-size:2rem}.equipment-tabs{justify-content:space-between;gap:.5rem;margin:1.5rem 0}.tab-button{flex:1;justify-content:center;min-width:0;padding:.75rem}.tab-label{display:none}.tab-icon{font-size:1.5rem}.equipment-table-container{box-shadow:none;background:0 0;border-radius:0;padding:0}.equipment-table{width:100%;display:block}.equipment-table thead{display:none}.equipment-table tbody{flex-direction:column;gap:1rem;display:flex}.equipment-table tbody tr{background:#fffffff2;border:1px solid #e2e8f0;border-bottom:none;border-radius:12px;flex-direction:column;padding:1rem;display:flex;box-shadow:0 2px 8px #0000001a}.equipment-table tbody tr:hover{box-shadow:0 4px 12px #00000026}.equipment-table td{border-bottom:1px solid #f1f5f9;align-items:flex-start;gap:.75rem;width:100%;padding:.75rem 0;display:flex}.equipment-table td:last-child{border-bottom:none}.equipment-table td[data-label]:not([data-label=""]):before{content:attr(data-label)":";color:#667eea;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:110px;font-size:.85rem;font-weight:700}.equipment-name-cell{flex-direction:column;align-items:flex-start;gap:.5rem}.equipment-name-cell:before{display:none}.equipment-name{font-size:1.1rem;font-weight:700}.stat-cell{text-align:left}.feature-cell{max-width:100%}.description-cell{line-height:1.6}.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:95vh;margin:0}.modal-header{padding:1rem 1.25rem}.modal-header h2{font-size:1.25rem}.modal-close{width:2rem;height:2rem;font-size:1.5rem}.modal-body{max-height:calc(95vh - 140px);padding:1.25rem}.modal-footer{flex-direction:column;gap:.75rem;padding:1rem 1.25rem}.modal-footer .next-button,.modal-footer .previous-button{width:100%;min-height:48px;padding:1rem;font-size:1rem}.inventory-list-editable{gap:.5rem}.inventory-edit-item{flex-direction:column;align-items:stretch;gap:1rem;padding:1rem}.inventory-edit-item>div:first-child{width:100%}.inventory-edit-item>div:last-child{flex-direction:column;gap:.5rem;width:100%;display:flex}.inventory-edit-item .next-button,.inventory-edit-item .previous-button,.inventory-edit-item .remove-button{width:100%;min-height:44px;padding:.75rem}.modal-body>div:first-child{flex-wrap:wrap;gap:.25rem;margin-bottom:1rem}.modal-body>div:first-child button{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:calc(50% - .25rem);padding:.75rem .5rem;font-size:.9rem;overflow:hidden}.loadout-management-grid{grid-template-columns:1fr;gap:1rem}.loadout-column h3{margin-bottom:.75rem;font-size:.95rem}.loadout-card-pill{min-height:48px;padding:.75rem 1rem}.section-header-with-actions{flex-direction:column;align-items:stretch;gap:.75rem}.manage-button{justify-content:center;width:100%;min-height:44px;padding:.75rem}.inventory-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;border-bottom:2px solid #e2e8f0;flex-wrap:nowrap;gap:0;margin:0 -1rem 1.5rem;padding:0 1rem;overflow-x:auto}.inventory-tabs::-webkit-scrollbar{display:none}.inventory-tab-button{white-space:nowrap;flex:none;min-width:auto;padding:.75rem 1rem;font-size:.85rem}.inventory-tab-icon{font-size:1rem}@media (max-width:400px){.inventory-tab-button span:not(.inventory-tab-icon){display:none}.inventory-tab-button{padding:.75rem 1.25rem}.inventory-tab-icon{font-size:1.25rem}}.effects-section{margin-bottom:1.5rem}.effect-item{flex-direction:column;align-items:stretch;gap:.5rem;padding:1rem}.effect-remove-button{align-self:flex-end;min-width:44px;min-height:44px;padding:.5rem}.sheet-actions{flex-direction:column;gap:.75rem}.sheet-actions button{width:100%;min-height:48px;padding:1rem}.search-input{width:100%;min-height:44px;padding:.75rem;font-size:16px}.custom-item-form{flex-direction:column;gap:1rem;display:flex}.custom-item-form>div{width:100%}.custom-item-form input,.custom-item-form select,.custom-item-form textarea{width:100%;min-height:44px;padding:.75rem;font-size:16px}.custom-item-form textarea{min-height:100px}.expansion-selector{padding:1rem}.expansion-selector>div{flex-direction:column;gap:.75rem}.expansion-checkbox-label{width:100%;min-height:44px;padding:.75rem}.modal-body>div>div:first-child{flex-wrap:wrap;gap:.25rem}.modal-body>div>div:first-child button{flex:1;min-width:calc(50% - .25rem);padding:.75rem .5rem;font-size:.85rem}.modal-body>div>div:nth-child(2){flex-wrap:wrap;gap:.25rem;margin-bottom:1rem}.modal-body>div>div:nth-child(2) button{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:calc(50% - .25rem);padding:.75rem .5rem;font-size:.8rem;overflow:hidden}.modal-body>div>div[style*=flex]:has(.search-input){flex-direction:column;gap:.75rem}.modal-body input.search-input,.modal-body select{width:100%;min-height:44px;font-size:16px}.inventory-edit-item div[style*="display: flex"]{flex-direction:column!important;gap:.5rem!important}.gold-manager{flex-direction:column;gap:1rem}.gold-display{text-align:center;width:100%}.gold-controls-inline{width:100%}.gold-input-group{flex-direction:column;gap:.75rem;width:100%}.gold-input-group input,.gold-input-group select{width:100%;min-height:44px;padding:.75rem;font-size:16px}.gold-action-button{width:100%;min-height:44px;padding:.75rem;font-size:1rem}.gold-input-group>*{width:100%}.gold-input-group button{margin-top:.5rem}.combat-stat{padding:.75rem}.combat-stat-label{font-size:.85rem}.combat-stat-value{font-size:1.5rem}.threshold-item{padding:.75rem}.domain-cards-section{padding:1rem}.domain-cards-grid{gap:.75rem}.sheet-header{padding:1rem}.sheet-header-main{gap:1rem}.character-avatar-display{align-self:center}.sheet-header-info{flex-direction:column;align-items:flex-start;gap:.75rem;width:100%}.level-up-actions{flex-direction:column;gap:.5rem;width:100%}.level-up-actions button{width:100%;min-height:44px;padding:.75rem}.companion-toggle-button,.level-up-button,.history-button,.export-pdf-button,.actions-menu-button{min-height:44px;padding:.75rem 1rem}.actions-menu-dropdown{width:100%;min-width:unset;left:0;right:0}.inventory-item-card{padding:.75rem}.inventory-action-button{width:100%;min-height:44px;padding:.75rem}.inventory-item-actions{flex-direction:column;gap:.5rem}.inventory-item-actions-wrapper{margin-top:1rem}.sheet-actions{flex-direction:column;gap:.75rem;padding:1rem}.sheet-actions button{width:100%;min-height:48px;padding:1rem;font-size:1rem}.help-icon{min-width:20px;min-height:20px}.modal-body>div[style*="display: flex"]:has(button){-webkit-overflow-scrolling:touch;scrollbar-width:thin;overflow-x:auto}.modal-body>div[style*="display: flex"]:has(button) button{flex-shrink:0}.loot-generator{padding:1rem}.generated-result{margin:1.5rem 0}.result-card{border-radius:12px;padding:1rem}.result-card h3{margin-bottom:1rem;font-size:1.25rem}.loot-table-item{margin-bottom:.75rem;padding:.75rem}.shop-generator{padding:1rem}.shop-generator h1{margin-bottom:.5rem;font-size:1.75rem}.generator-subtitle{margin-bottom:1.5rem;font-size:.9rem}.generator-controls{flex-direction:column;gap:1rem;padding:1rem}.control-group{width:100%}.control-group label{margin-bottom:.5rem;font-size:.9rem;display:block}.shop-type-select,.tier-select,.rarity-select{width:100%;min-height:44px;padding:.75rem;font-size:16px}.generate-button,.clear-button{width:100%;min-height:48px;padding:1rem;font-size:1rem}.shop-info{flex-direction:column;gap:1rem;padding:1rem}.shop-owner,.shop-staff,.shop-inventory-selection,.shop-pricing,.shop-encounter-event{flex:none;width:100%}.shop-encounter-event{border-left-width:4px;margin-left:0;padding:1rem}.shop-inventory h2{font-size:1.5rem}.inventory-group{margin-bottom:1.5rem}.inventory-group-header{padding:.75rem;font-size:1.1rem}.inventory-group-items{gap:.75rem;padding:.5rem}.inventory-item{padding:.75rem}.inventory-item .item-header{flex-direction:column;align-items:flex-start;gap:.5rem}.inventory-item .item-name{font-size:1rem}.inventory-item .item-tier{font-size:.75rem}.inventory-item .item-stats{flex-direction:column;gap:.25rem}.tables-container{padding:1rem}.tables-header h1{font-size:1.75rem}.tables-subtitle{font-size:.95rem}.tables-nav{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex;overflow-x:visible}.table-nav-link{text-align:center;white-space:nowrap;text-overflow:ellipsis;flex:calc(33.333% - .5rem);justify-content:center;align-items:center;min-width:0;min-height:44px;padding:.6rem .75rem;font-size:.8rem;display:flex;overflow:hidden}.home-header{padding:1.5rem 1rem}.home-header h1{font-size:1.75rem}.home-dashboard{gap:1rem;padding:1rem}.profile-image-and-name-section{text-align:center;flex-direction:column;align-items:center;gap:1rem}.character-card{padding:1rem}.character-card h3{font-size:1.1rem}.primary-button,.secondary-button,.next-button,.previous-button{touch-action:manipulation;min-height:44px}.browser-filters{flex-direction:column;gap:1rem}.filter-group{width:100%}.filter-group label{margin-bottom:.5rem;font-size:.9rem;display:block}.filter-group select{width:100%;padding:.75rem}.search-box{width:100%}.search-input{width:100%;padding:.75rem}.browser-stats{margin:1rem 0;font-size:.9rem}.dark-mode .equipment-table tbody tr{background:#2d3748f2;border-color:#4a5568}.dark-mode .equipment-table td{border-bottom-color:#4a5568}.dark-mode .equipment-table td:before{color:#90cdf4}}.loadout-instructions{color:#4a5568;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:4px solid #667eea;border-radius:8px;margin-bottom:1.5rem;padding:1rem;font-size:.95rem;line-height:1.6}.loadout-management-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:1rem;display:grid}.loadout-column{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:all .3s;box-shadow:0 2px 8px #00000014}.loadout-column-active{background:linear-gradient(135deg,#fff,#f0f4ff);border-color:#667eea}.loadout-column-vault{background:linear-gradient(135deg,#fff,#f7fafc);border-color:#cbd5e0}.loadout-column-header{border-bottom:2px solid #e2e8f0;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.loadout-column-active .loadout-column-header{border-bottom-color:#667eea}.loadout-icon{font-size:1.5rem;line-height:1}.loadout-column h3{color:#2d3748;align-items:center;gap:.5rem;margin:0;font-size:1.1rem;font-weight:700;display:flex}.loadout-count{color:#667eea;background:#eef2ff;border-radius:6px;padding:.25rem .5rem;font-size:.9rem;font-weight:600}.loadout-column-vault .loadout-count{color:#718096;background:#edf2f7}.loadout-card-list{flex-direction:column;gap:.75rem;min-height:200px;max-height:500px;padding-right:.5rem;display:flex;overflow-y:auto}.loadout-card-list::-webkit-scrollbar{width:6px}.loadout-card-list::-webkit-scrollbar-track{background:0 0;border-radius:3px}.loadout-card-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.loadout-card-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.loadout-card-pill{cursor:pointer;text-align:left;border:2px solid;border-radius:10px;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1rem;font-size:.9rem;transition:all .2s;display:flex;position:relative;overflow:hidden}.loadout-card-pill:before{content:"";opacity:0;background:linear-gradient(135deg,#667eea0d,#667eea1a);transition:opacity .2s;position:absolute;top:0;right:0;bottom:0;left:0}.loadout-card-pill:hover:before{opacity:1}.loadout-card-content{z-index:1;flex-direction:column;flex:1;gap:.25rem;display:flex;position:relative}.loadout-card-active{color:#2c5282;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-color:#667eea;box-shadow:0 2px 6px #667eea26}.loadout-card-active:hover{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-color:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea40}.loadout-card-vault{color:#2d3748;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-color:#cbd5e0;box-shadow:0 1px 3px #0000000d}.loadout-card-vault:hover{background:linear-gradient(135deg,#edf2f7,#e2e8f0);border-color:#a0aec0;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.loadout-card-pill .card-name{font-size:.95rem;font-weight:600}.loadout-card-pill .card-meta{opacity:.75;font-size:.8rem;font-weight:500}.loadout-card-arrow{opacity:.6;z-index:1;font-size:1.2rem;transition:all .2s;position:relative}.loadout-card-pill:hover .loadout-card-arrow{opacity:1;transform:scale(1.2)}.loadout-card-active .loadout-card-arrow{color:#667eea}.loadout-card-vault .loadout-card-arrow{color:#718096}.loadout-empty{text-align:center;color:#a0aec0;padding:2rem 1rem;font-size:.9rem;font-style:italic}.dark-mode .modal-content{color:#e2e8f0;background:#1a202c}.dark-mode .modal-body{background:#111827}.dark-mode .modal-footer{background:#111827;border-top-color:#4b5563}.dark-mode .loadout-instructions{color:#cbd5e0;background:linear-gradient(135deg,#1f2937,#111827);border-left-color:#667eea}.dark-mode .loadout-column{background:#1f2937;border-color:#374151}.dark-mode .loadout-column-active{background:linear-gradient(135deg,#1f2937,#1e1b4b);border-color:#667eea}.dark-mode .loadout-column-vault{background:linear-gradient(135deg,#1f2937,#111827);border-color:#4b5563}.dark-mode .loadout-column-header{border-bottom-color:#374151}.dark-mode .loadout-column-active .loadout-column-header{border-bottom-color:#667eea}.dark-mode .loadout-column h3{color:#e2e8f0}.dark-mode .loadout-count{color:#a5b4fc;background:#312e81}.dark-mode .loadout-column-vault .loadout-count{color:#9ca3af;background:#374151}.dark-mode .loadout-card-list::-webkit-scrollbar-thumb{background:#4b5563}.dark-mode .loadout-card-list::-webkit-scrollbar-thumb:hover{background:#6b7280}.dark-mode .loadout-card-active{color:#c7d2fe;background:linear-gradient(135deg,#312e81,#1e1b4b);border-color:#667eea}.dark-mode .loadout-card-active:hover{background:linear-gradient(135deg,#4338ca,#312e81);border-color:#818cf8}.dark-mode .loadout-card-vault{color:#d1d5db;background:linear-gradient(135deg,#1f2937,#111827);border-color:#4b5563}.dark-mode .loadout-card-vault:hover{background:linear-gradient(135deg,#374151,#1f2937);border-color:#6b7280}.dark-mode .loadout-card-active .loadout-card-arrow{color:#a5b4fc}.dark-mode .loadout-card-vault .loadout-card-arrow{color:#9ca3af}.dark-mode .loadout-empty{color:#6b7280}.dark-mode .manage-button{color:#c3dafe;background:#1f2937;border-color:#4b5563}.dark-mode .manage-button:hover{background:#111827;border-color:#667eea}.dark-mode .inventory-edit-item{color:#e2e8f0;background:#1f2937;border-color:#4b5563;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{color:#fff;background:linear-gradient(135deg,#c53030,#a02626);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{color:#c3dafe;background:#1f2937;border-color:#4b5563}.dark-mode .loadout-card-pill.vault{color:#e2e8f0;background:#111827;border-color:#4b5563}.no-history{text-align:center;color:#718096;padding:3rem;font-style:italic}.history-list{flex-direction:column;gap:2rem;display:flex}.history-entry{background:#f7fafc;border-left:4px solid #667eea;border-radius:12px;padding:1.5rem}.history-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.history-header h3{color:#667eea;margin:0;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;margin-bottom:.5rem;font-size:1rem;font-weight:600}.history-section ul{margin:.5rem 0;padding:0;list-style:none}.history-section li{color:#4a5568;padding:.25rem 0}.history-section p{color:#4a5568;margin:.5rem 0}.exchange-note{color:#f6ad55;font-size:.9rem;font-style:italic}.dark-mode .level-up-history-modal{color:#e2e8f0;background:#1a202c}.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{align-items:center;gap:1rem;display:flex}.revert-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f56565,#e53e3e);border:none;border-radius:6px;padding:.4rem .8rem;font-size:.85rem;font-weight:600;transition:all .2s}.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{background:#fff5f5;border:2px solid #feb2b2;border-radius:8px;margin-top:1rem;padding:1rem}.revert-confirmation p{color:#742a2a;margin:0 0 1rem;font-weight:500}.revert-confirmation-actions{gap:.75rem;display:flex}.confirm-revert-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f56565,#e53e3e);border:none;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:all .2s}.confirm-revert-button:hover:not(:disabled){background:linear-gradient(135deg,#e53e3e,#c53030)}.confirm-revert-button:disabled{opacity:.5;cursor:not-allowed}.cancel-revert-button{color:#2d3748;cursor:pointer;background:#e2e8f0;border:none;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:all .2s}.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{color:#e2e8f0;background:#4a5568}.dark-mode .cancel-revert-button:hover:not(:disabled){background:#2d3748}.login-link{border-radius:8px;padding:.75rem 1.5rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-block;color:#fff!important;background:linear-gradient(135deg,#667eea,#764ba2)!important}.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{box-shadow:0 4px 12px #667eea99;color:#fff!important}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}#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}.join-campaign-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background:var(--bg-primary, #0a0a0a)}.join-card{max-width:500px;width:100%;padding:3rem 2rem;background:var(--card-bg, #1a1a1a);border:1px solid var(--border-color, #333);border-radius:12px;text-align:center}.join-card h2{margin:0 0 1rem;color:var(--text-primary, #fff)}.join-card h3{margin:1rem 0;color:#4a90e2;font-size:1.5rem}.join-card p{margin:.5rem 0;color:var(--text-secondary, #aaa)}.join-card.success{border-color:#4caf5080}.join-card.error{border-color:#f4433680}.redirect-message{margin-top:2rem;font-style:italic;color:var(--text-secondary, #888)}.loading-spinner{width:50px;height:50px;border:4px solid var(--border-color, #333);border-top-color:#4a90e2;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary{margin-top:1.5rem;padding:.75rem 2rem;background:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#357abd}
