@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{justify-content:center;margin:0;padding:80px 0 0;background:linear-gradient(135deg,#2a1a5e,#0d1b2a);position:relative;min-height:90vh;overflow-x:hidden;display:flex;align-items:flex-start}#root{width:100%;max-width:100vw;display:flex;flex-direction:column;min-height:100vh}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100vh;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:20px 20px;opacity:.7;animation:twinkle 5s ease-in-out infinite}@keyframes twinkle{0%{opacity:.7}50%{opacity:.9}to{opacity:.7}}h2{font-family:Cinzel,serif;color:#fff;text-align:left;margin-top:1rem;text-shadow:0 0 5px rgba(255,255,255,.5)}.app{margin:0 auto;padding:2rem;position:relative;z-index:1;width:90%;max-width:1200px}.app-content{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;overflow-x:hidden}.app-settings{display:flex;justify-content:flex-start;padding:.5rem 0}.settings-row{display:flex;align-items:center;gap:1rem;width:100%}.session-hamburger-menu{position:relative}.session-hamburger-button{background:linear-gradient(135deg,#2a1a5ecc,#0d1b2ae6);border:2px solid rgba(204,204,204,.3);border-radius:6px;color:#fff;padding:.5rem .75rem;font-size:1.2rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #0000004d}.session-hamburger-button:hover{background:linear-gradient(135deg,#3e2e72e6,#212f3ef2);border-color:#cccccc80;transform:translateY(-1px);box-shadow:0 4px 15px #0006}.session-dropdown-menu{position:absolute;top:100%;left:0;min-width:180px;background:linear-gradient(135deg,#2a1a5ef2,#0d1b2af2);border:2px solid rgba(204,204,204,.3);border-radius:8px;box-shadow:0 8px 25px #0006;z-index:1000;margin-top:.25rem}.session-dropdown-item{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;color:#fff;text-align:left;cursor:pointer;transition:all .3s ease;font-size:.9rem;border-bottom:1px solid rgba(204,204,204,.1)}.session-dropdown-item:last-child{border-bottom:none;border-radius:0 0 6px 6px}.session-dropdown-item:first-child{border-radius:6px 6px 0 0}.session-dropdown-item:hover{background:#ffffff1a;transform:translate(2px)}.session-dropdown-item:disabled{opacity:.5;cursor:not-allowed;background:none;transform:none}.settings-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#fff;cursor:pointer}.settings-label input[type=checkbox]{width:1rem;height:1rem;accent-color:#D147A3}.combatant-form,.combat-controls,.combat-history{margin:0}.combatant-form .note{color:#ccc;font-style:italic;margin:5px 0;font-size:.9em}.content-container{max-width:100%;padding:10px;background:linear-gradient(135deg,#2a1a5ecc,#0d1b2ae6);border:2px solid rgba(204,204,204,.3);border-radius:10px;position:relative;box-shadow:0 4px 20px #0000004d,inset 0 2px 5px #ffffff1a}.content-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px;opacity:.2;z-index:-1;border-radius:10px}.form-title,.controls-title,.table-title,.history-title{font-size:1.2em;margin-bottom:5px;color:#fff;text-shadow:0 0 5px rgba(255,255,255,.5)}.combatant-form{display:flex;flex-direction:column;gap:5px}.form-grid{display:grid;grid-template-columns:repeat(5,minmax(100px,1fr));gap:5px;margin-bottom:5px;align-items:center}.form-group{display:flex;flex-direction:column;gap:2px}.form-group label{font-size:.9em;color:#ddd;font-weight:500;margin-bottom:2px}.form-group input,.form-group select{padding:4px;border:1px solid rgba(204,204,204,.5);border-radius:3px;font-size:.9em;background:#ffffffe6;color:#333;width:100%;box-sizing:border-box}.short-input,.med-input{width:100%}.submit-button{padding:5px 10px;background:#d147a3;color:#fff;border:1px solid rgba(204,204,204,.5);border-radius:3px;font-size:.9em;cursor:pointer;transition:background .2s,box-shadow .2s;align-self:flex-end}.submit-button:hover{background:#b5368e;box-shadow:0 0 10px #d147a3b3}.submit-button:disabled{background:#666;cursor:not-allowed}.combat-active-controls{display:flex;flex-direction:column;gap:1rem}.turn-section{margin-top:1rem}.turn-title{font-size:1.25rem;margin-bottom:.75rem;color:#fff;text-shadow:0 0 5px rgba(255,255,255,.5)}.action-form{display:flex;flex-direction:column;gap:1rem}.action-buttons{display:flex;gap:1rem;margin-top:1rem}.action-buttons .submit-button{flex:1}.submit-button.end-combat-small{background:linear-gradient(135deg,#dc3545,#c82333);border-color:#dc3545}.submit-button.end-combat-small:hover{background:linear-gradient(135deg,#c82333,#bd2130);box-shadow:0 0 15px #dc354580}@media (max-width: 768px){.action-buttons{flex-direction:column;gap:.75rem}}.action-button{padding:8px 16px;background:#d147a3;color:#fff;border:1px solid rgba(204,204,204,.5);border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s,box-shadow .2s}.action-button:hover{background:#b5368e;box-shadow:0 0 10px #d147a3b3}.action-button:disabled{background:#666;cursor:not-allowed}.combatant-table{width:100%;border-collapse:collapse;background:linear-gradient(135deg,#2a1a5e33,#0d1b2a4d);border:1px solid rgba(204,204,204,.3)}.combatant-table th,.combatant-table td{border:1px solid rgba(204,204,204,.3);padding:8px;text-align:left;font-size:.9rem;color:#ddd;background:#ffffff1a;transition:background .2s}.combatant-table th{background:#e9ecef33;font-weight:600;color:#fff;text-shadow:0 0 2px rgba(255,255,255,.5)}.combatant-table tr.active{background-color:#d4edda4d}.combatant-table tr.defeated{background-color:#f8d7da4d;text-decoration:line-through}.combatant-table tr:hover:not(.active):not(.defeated){background:#f1f3f533}.combatant-table td.empty-state{text-align:center;color:#ccc;font-style:italic;padding:16px;background:transparent}.history-column{flex:1;min-width:200px;max-width:30%;padding-right:1rem}.main-column{flex:2;min-width:400px}.layout-container{display:flex;gap:1rem;justify-content:center;align-items:flex-start}@media (max-width: 800px){.layout-container{flex-direction:column}.history-column{order:2;max-width:100%;padding-right:0;margin-bottom:1rem}.main-column{order:1;min-width:100%}}.history-list{list-style:none;padding:0;margin:0;background:#ffffffe6;border:1px solid rgba(204,204,204,.5);border-radius:4px}.history-item{display:flex;flex-direction:column;padding:8px;border-bottom:1px solid rgba(204,204,204,.5)}.history-item:last-child{border-bottom:none}.history-timestamp{font-size:.85rem;color:#ccc;margin-bottom:.25rem}.history-description{font-size:.9rem;color:#333}.empty-state{text-align:center;color:#ccc;font-style:italic;padding:16px;margin:0}button{padding:8px 16px;margin:0 5px;background:#d147a3;color:#fff;border:1px solid rgba(204,204,204,.5);border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s,box-shadow .2s}button:hover{background:#b5368e;box-shadow:0 0 10px #d147a3b3}button:disabled{background:#666;cursor:not-allowed}.site-header{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#2a1a5ef2,#0d1b2af2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid rgba(204,204,204,.3);box-shadow:0 4px 20px #0000004d;z-index:1000;padding:1rem 0}.header-content{width:100%;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;margin-left:0;gap:2rem}.header-nav{display:flex;gap:1rem;margin-left:2rem}.header-nav-button{background:transparent;border:none;color:#fffc;padding:.5rem 1rem;cursor:pointer;transition:all .3s ease;font-family:Cinzel,serif;font-size:1rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap}.header-nav-button:hover{color:#fff;text-shadow:0 0 8px rgba(255,255,255,.6)}.header-nav-button.active{color:#ff69b4;text-shadow:0 0 10px rgba(255,105,180,.8)}.header-nav-button.changelog-button{color:#ffa500cc}.header-nav-button.changelog-button:hover{color:orange;text-shadow:0 0 8px rgba(255,165,0,.6)}.logo-section{display:flex;align-items:center;gap:1rem}.tss-logo{width:80px;height:80px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all .4s ease}.logo-image{width:100%;height:100%;object-fit:contain;transition:all .4s ease;filter:drop-shadow(0 4px 15px rgba(139,92,246,.3))}.tss-logo:hover .logo-image{transform:translateY(-2px) scale(1.05);filter:drop-shadow(0 8px 25px rgba(139,92,246,.5))}@media (max-width: 768px){.header-content{padding:0 .5rem;flex-wrap:wrap}.header-left{gap:1rem;flex-wrap:wrap;width:100%;justify-content:space-between}.header-nav{margin-left:0;gap:.5rem;order:3;width:100%;justify-content:center;padding-top:.5rem}.header-nav-button{padding:.25rem .75rem;font-size:.9rem;flex:0 0 auto;min-width:0}.tss-logo{width:60px;height:60px}.logo-section{gap:.75rem}.app-name{font-size:1.4rem}}.app-name{font-family:Cinzel,serif;font-size:1.8rem;font-weight:700;color:#ff69b4;margin:0;text-shadow:0 0 10px rgba(255,105,180,.8),0 0 15px rgba(199,21,133,.6)}.header-right{display:flex;align-items:center;margin-right:40px}.auth-nav{display:flex;gap:1rem}.auth-button{padding:.5rem 1.5rem;border:2px solid transparent;border-radius:5px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem}.login-button{background:transparent;color:#fff;border-color:#ffffff4d}.login-button:hover{background:#ffffff1a;border-color:#fff;box-shadow:0 0 10px #ffffff4d}.signup-button{background:linear-gradient(135deg,#d147a3,#b5368e);color:#fff;border-color:#d147a3}.signup-button:hover{background:linear-gradient(135deg,#b5368e,#9a2e78);box-shadow:0 0 10px #d147a3b3}.logout-button{background:#ffffff1a;color:#fff;border-color:#ffffff4d}.logout-button:hover{background:#fff3;border-color:#fff;box-shadow:0 0 10px #ffffff4d}.user-welcome{color:#fff;margin-right:1rem;font-weight:500}.user-section{display:flex;align-items:center;gap:.75rem}.clickable-user-section{cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .3s ease;border:1px solid transparent;position:relative}.clickable-user-section:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.clickable-user-section .user-welcome{margin-right:0}.user-menu-indicator{font-size:.8rem;opacity:.7;transition:all .3s ease;margin-left:.5rem}.clickable-user-section:hover .user-menu-indicator{opacity:1}.user-dropdown-menu{position:absolute;top:100%;right:0;min-width:180px;background:linear-gradient(135deg,#2a1a5ef2,#0d1b2af2);border:2px solid rgba(204,204,204,.3);border-radius:8px;box-shadow:0 8px 25px #0006;z-index:1000;margin-top:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-dropdown-item{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;color:#fff;text-align:left;cursor:pointer;transition:all .3s ease;font-size:.9rem;border-bottom:1px solid rgba(204,204,204,.1)}.user-dropdown-item:last-child{border-bottom:none;border-radius:0 0 6px 6px}.user-dropdown-item:first-child{border-radius:6px 6px 0 0}.user-dropdown-item:hover{background:#ffffff1a;transform:translate(2px)}.user-avatar{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 2px 8px #0003,inset 0 1px 2px #fff3;border:2px solid rgba(255,255,255,.2);transition:all .3s ease;cursor:pointer}.user-avatar:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d,inset 0 1px 2px #ffffff4d;border-color:#fff6}.user-avatar{position:relative}.user-avatar:after{content:"⚙️";position:absolute;bottom:-2px;right:-2px;font-size:.6rem;opacity:0;transition:opacity .3s ease;background:#000000b3;border-radius:50%;width:1rem;height:1rem;display:flex;align-items:center;justify-content:center}.user-avatar:hover:after{opacity:1}@media (max-width: 768px){.user-avatar{width:2rem;height:2rem;font-size:.85rem}.user-welcome,.user-menu-indicator{display:none}.user-section{gap:.5rem}.clickable-user-section{padding:.25rem .5rem}.clickable-user-section:hover{background:#ffffff26}.user-dropdown-menu{right:-.5rem;min-width:160px}.user-dropdown-item{padding:.65rem .85rem;font-size:.85rem}}.avatar-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:10000;padding:2rem 1rem;box-sizing:border-box}.avatar-selector-modal{background:linear-gradient(135deg,#2a1a5ef2,#0d1b2af2);border:2px solid rgba(204,204,204,.3);border-radius:15px;width:100%;max-width:600px;max-height:calc(100vh - 4rem);box-shadow:0 20px 50px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;display:flex;flex-direction:column;margin:auto}.avatar-selector-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(204,204,204,.2);flex-shrink:0}.avatar-selector-header h3{color:#fff;margin:0;font-family:Cinzel,serif;font-size:1.5rem}.close-button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s ease}.close-button:hover{background:#ffffff1a;transform:rotate(90deg)}.avatar-selector-content{padding:1.5rem;flex:1;overflow-y:auto;min-height:0}.avatar-categories{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.category-button{background:#ffffff1a;border:1px solid rgba(204,204,204,.3);color:#fff;padding:.5rem 1rem;border-radius:20px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.category-button:hover{background:#fff3;border-color:#cccccc80}.category-button.active{background:linear-gradient(135deg,#d147a3,#b5368e);border-color:#d147a3;box-shadow:0 0 10px #d147a380}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.75rem;margin-bottom:1.5rem}.avatar-option{width:60px;height:60px;background:#ffffff1a;border:2px solid rgba(204,204,204,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;cursor:pointer;transition:all .3s ease}.avatar-option:hover{background:#fff3;border-color:#cccccc80;transform:scale(1.05)}.avatar-option.selected{background:linear-gradient(135deg,#d147a3,#b5368e);border-color:#d147a3;box-shadow:0 0 15px #d147a3b3;transform:scale(1.1)}.avatar-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff0d;border-radius:10px;border:1px solid rgba(204,204,204,.2)}.preview-label{color:#fff;font-weight:500}.avatar-preview-display{width:50px;height:50px;background:#ffffff1a;border:2px solid rgba(204,204,204,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.avatar-selector-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid rgba(204,204,204,.2);flex-shrink:0}.cancel-button,.save-button{padding:.75rem 1.5rem;border:2px solid transparent;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem}.cancel-button{background:#ffffff1a;color:#fff;border-color:#ffffff4d}.cancel-button:hover{background:#fff3;border-color:#ffffff80}.save-button{background:linear-gradient(135deg,#d147a3,#b5368e);color:#fff;border-color:#d147a3}.save-button:hover:not(:disabled){background:linear-gradient(135deg,#b5368e,#9a2e78);box-shadow:0 0 15px #d147a3b3}.save-button:disabled{opacity:.5;cursor:not-allowed;background:#ffffff1a;border-color:#ffffff4d}@media (max-width: 768px){.avatar-selector-overlay{padding:1rem .5rem}.avatar-selector-modal{width:100%;max-height:calc(100vh - 2rem);border-radius:10px}.avatar-selector-header,.avatar-selector-content,.avatar-selector-footer{padding:1rem}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem}.avatar-option{width:50px;height:50px;font-size:1.4rem}.avatar-categories{gap:.25rem}.category-button{padding:.4rem .8rem;font-size:.8rem}.avatar-selector-header h3{font-size:1.2rem}}@media (max-height: 600px){.avatar-selector-overlay{padding:.5rem;align-items:flex-start;justify-content:center;overflow-y:auto}.avatar-selector-modal{max-height:none;min-height:500px;margin-top:.5rem;margin-bottom:.5rem}}.auth-loading{color:#ccc;font-style:italic}.app{margin-top:0}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:2000}.auth-modal{background:linear-gradient(135deg,#2a1a5ef2,#0d1b2af2);border:2px solid rgba(204,204,204,.3);border-radius:10px;box-shadow:0 4px 20px #0000004d;width:90%;max-width:400px;max-height:90vh;overflow-y:auto}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid rgba(204,204,204,.3)}.auth-modal-header h2{font-family:Cinzel,serif;color:#ff69b4;margin:0;text-shadow:0 0 10px rgba(255,105,180,.8)}.auth-modal-close{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:0;margin:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.auth-modal-close:hover{background:#ffffff1a;box-shadow:none}.auth-modal-content{padding:1.5rem}.auth-form-group{margin-bottom:1rem}.auth-form-group label{display:block;margin-bottom:.5rem;color:#fff;font-weight:600}.auth-form-group input{width:100%;padding:.75rem;border:2px solid rgba(204,204,204,.3);border-radius:5px;background:#ffffffe6;color:#333;font-size:1rem;box-sizing:border-box;transition:border-color .2s}.auth-form-group input:focus{outline:none;border-color:#ff69b4;box-shadow:0 0 5px #ff69b480}.auth-submit-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#d147a3,#b5368e);color:#fff;border:none;border-radius:5px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.auth-submit-button:hover:not(:disabled){background:linear-gradient(135deg,#b5368e,#9a2e78);box-shadow:0 0 10px #d147a3b3}.auth-submit-button:disabled{background:#666;cursor:not-allowed;box-shadow:none}.auth-switch{text-align:center;color:#ccc;margin:0}.auth-link{background:none;border:none;color:#ff69b4;cursor:pointer;text-decoration:underline;padding:0;margin:0;font-size:inherit}.auth-link:hover{color:#b5368e;background:none;box-shadow:none}.auth-error{background:#f8d7dae6;color:#721c24;padding:.75rem;border-radius:5px;margin-bottom:1rem;border:1px solid rgba(245,198,203,.8)}.auth-confirm-message{color:#ccc;text-align:center;margin-bottom:1rem;line-height:1.5}.landing-page{min-height:80vh;display:flex;align-items:center;justify-content:center;position:relative}.landing-page:before{content:"";position:fixed;top:0;left:0;width:100%;height:100vh;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:20px 20px;opacity:.7;animation:twinkle 5s ease-in-out infinite;z-index:1}.landing-content{position:relative;z-index:2;max-width:1400px;width:100%;text-align:center}.landing-hero{background:linear-gradient(135deg,#2a1a5eb3,#0d1b2ab3);border:2px solid rgba(204,204,204,.3);border-radius:15px;padding:2rem;box-shadow:0 8px 32px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.landing-title{font-family:Cinzel,serif;font-size:2.8rem;font-weight:700;color:#ff69b4;margin:0 0 .5rem;text-shadow:0 0 20px rgba(255,105,180,.8),0 0 30px rgba(199,21,133,.6)}.landing-subtitle{font-family:Cinzel,serif;font-size:1.4rem;font-weight:400;color:#fff;margin:0 0 1.5rem;text-shadow:0 0 10px rgba(255,255,255,.5);text-align:center}.landing-description{margin-bottom:2rem}.landing-description p{font-size:1.2rem;color:#e0e0e0;line-height:1.6;max-width:600px;margin:0 auto}.landing-features{margin-bottom:2rem}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:1rem;background-image:url(/assets/blue-purple-pebble-background-CcA_OD2X.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;border-radius:15px;padding:2rem;position:relative;overflow:hidden}.feature-grid:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#2a1a5eb3;z-index:1;border-radius:15px}.feature-item{background:#ffffff1a;border:1px solid rgba(204,204,204,.3);border-radius:10px;padding:1rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);position:relative;z-index:2}.feature-item h3{font-size:1.1rem;color:#ff69b4;margin:0 0 .5rem;text-shadow:0 0 5px rgba(255,105,180,.6)}.feature-item p{color:#e0e0e0;line-height:1.4;margin:0;font-size:.9rem}.landing-cta{margin-top:1.5rem}.landing-cta h3{font-size:1.3rem;color:#fff;margin:0 0 1rem;text-shadow:0 0 10px rgba(255,255,255,.5)}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cta-button{padding:1rem 2rem;border:2px solid transparent;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:160px}.cta-button.primary{background:linear-gradient(135deg,#d147a3,#b5368e);color:#fff;border-color:#d147a3}.cta-button.primary:hover{background:linear-gradient(135deg,#b5368e,#9a2e78);box-shadow:0 0 20px #d147a3b3;transform:translateY(-2px)}.cta-button.secondary{background:transparent;color:#fff;border-color:#ffffff80}.cta-button.secondary:hover{background:#ffffff1a;border-color:#fff;box-shadow:0 0 15px #ffffff4d;transform:translateY(-2px)}.landing-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.landing-footer p{color:#ccc;font-size:.9rem;margin:0;opacity:.8}@media (max-width: 1024px){.feature-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.5rem}}@media (max-width: 768px){.landing-title{font-size:2.2rem}.landing-subtitle{font-size:1.2rem}.landing-description p{font-size:1rem}.feature-grid{grid-template-columns:1fr;gap:1rem;padding:1rem}.cta-buttons{flex-direction:column;align-items:center}.landing-hero{padding:1.5rem 1rem}.landing-page{padding:1rem}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:50vh;color:#fff;font-size:1.2rem}.footer-link{background:none;border:none;color:#4db6ac;cursor:pointer;text-decoration:underline;font-size:inherit;font-family:inherit;padding:0;margin:0;transition:color .3s ease}.footer-link:hover{color:#80cbc4}.changelog-button{margin-right:1rem}.changelog-button:hover{background:#4db6ac33;border-color:#80cbc4;color:#80cbc4}.sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.changelog-sidebar{position:fixed;top:0;right:-400px;width:400px;height:100vh;background:linear-gradient(135deg,#2a1a5e,#0d1b2a);border-left:1px solid rgba(77,182,172,.3);z-index:999;transition:right .3s ease-in-out;box-shadow:-5px 0 15px #0000004d;overflow:hidden;display:flex;flex-direction:column}.changelog-sidebar.open{right:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#4db6ac1a;border-bottom:1px solid rgba(77,182,172,.3);flex-shrink:0}.sidebar-header h2{color:#4db6ac;margin:0;font-size:1.5rem;font-weight:600}.sidebar-close{background:none;border:none;color:#4db6ac;font-size:1.5rem;cursor:pointer;padding:.25rem;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease}.sidebar-close:hover{background:#4db6ac33}.sidebar-content{padding:1.5rem;overflow-y:auto;flex:1}.changelog-intro{color:#b0bec5;font-size:.9rem;margin-bottom:1.5rem;line-height:1.6}.changelog-entry{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.changelog-entry:last-child{border-bottom:none;margin-bottom:0}.changelog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.changelog-header h3{color:#4db6ac;font-size:1.2rem;margin:0;font-weight:600}.changelog-date{color:#78909c;font-size:.75rem;background:#ffffff1a;padding:.2rem .5rem;border-radius:10px}.changelog-changes{display:flex;flex-direction:column;gap:.5rem}.changelog-change{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#ffffff0d;border-radius:6px;border-left:3px solid;transition:background-color .3s ease}.changelog-change:hover{background:#ffffff14}.change-type-badge{color:#fff;font-size:.7rem;font-weight:600;padding:.2rem .4rem;border-radius:8px;white-space:nowrap;align-self:flex-start;margin-bottom:.25rem}.change-description{color:#e0e0e0;line-height:1.4;font-size:.85rem}.changelog-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.changelog-footer p{color:#4db6ac;font-size:.9rem;margin:0;font-weight:500}@media (max-width: 768px){.changelog-sidebar{width:100vw;right:-100vw}.sidebar-header,.sidebar-content{padding:1rem}.changelog-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.heroes-container{padding:2rem;max-width:1600px;margin:0 auto;width:95%}.heroes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid rgba(209,71,163,.3)}.heroes-header h1{font-family:Cinzel,serif;color:#fff;margin:0;font-size:2.5rem;text-shadow:0 0 10px rgba(255,255,255,.5);background:linear-gradient(45deg,#d147a3,#fff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.heroes-create-button{padding:12px 24px;background:linear-gradient(45deg,#d147a3,#b5368e);color:#fff;border:1px solid rgba(209,71,163,.5);border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #d147a34d}.heroes-create-button:hover{background:linear-gradient(45deg,#b5368e,#9a2f7a);transform:translateY(-2px);box-shadow:0 6px 20px #d147a380}.heroes-create-button.primary{padding:16px 32px;font-size:1.1rem;border-radius:12px}.heroes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:2rem}.hero-card{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:16px;padding:0;transition:all .4s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;overflow:hidden}.hero-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#d147a3,#4caf50,#2196f3);opacity:0;transition:opacity .3s ease}.hero-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px #0006;border-color:#d147a366}.hero-card:hover:before{opacity:1}.hero-card-header{background:linear-gradient(135deg,#d147a333,#ffffff0d);padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.hero-card-header h3{color:#fff;margin:0;font-size:1.1rem;font-weight:700;text-shadow:0 0 5px rgba(255,255,255,.3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero-card-actions{display:flex;gap:6px}.hero-action-button{padding:6px;border:none;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .2s ease;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.hero-action-button.edit{background:linear-gradient(45deg,#2a1a5eb3,#0d1b2acc);color:#d147a3;border:1px solid rgba(209,71,163,.3)}.hero-action-button.edit:hover{transform:scale(1.1);box-shadow:0 4px 12px #d147a34d;background:linear-gradient(45deg,#2a1a5ecc,#0d1b2ae6);color:#fff}.hero-action-button.delete{background:linear-gradient(45deg,#2a1a5eb3,#0d1b2acc);color:#b5368e;border:1px solid rgba(181,54,142,.3)}.hero-action-button.delete:hover{transform:scale(1.1);box-shadow:0 4px 12px #b5368e4d;background:linear-gradient(45deg,#2a1a5ecc,#0d1b2ae6);color:#fff}.hero-card-content{padding:.75rem 1rem}.hero-main-info{margin-bottom:.75rem}.hero-name-level{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.hero-class{color:#d147a3;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.hero-level{color:#fff;font-size:.8rem;font-weight:700;background:#d147a333;padding:2px 6px;border-radius:4px;border:1px solid rgba(209,71,163,.3)}.hero-player-name{color:#ccc;font-size:.8rem;font-style:italic}.hero-info-grid{margin-bottom:12px}.hero-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:4px 0}.hero-info-row:last-of-type{border-bottom:none;margin-bottom:12px}.hero-label{font-weight:700;color:#d147a3;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.hero-value{color:#fff;font-size:.9rem;font-weight:500}.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:.75rem 0;padding:8px;background:#ffffff08;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.hero-stat{text-align:center;padding:6px;background:linear-gradient(135deg,#d147a31a,#ffffff05);border-radius:4px;border:1px solid rgba(209,71,163,.2)}.stat-label{display:block;font-size:.65rem;color:#d147a3;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}.stat-value{display:block;font-size:1.1rem;color:#fff;font-weight:700;text-shadow:0 0 5px rgba(255,255,255,.3)}.hero-note{margin-top:.75rem;padding:6px;background:#ffffff08;border-radius:4px;border-left:2px solid #D147A3}.hero-note-text{color:#ccc;font-size:.75rem;font-style:italic;margin:0;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.hero-card-footer{padding:.5rem 1rem;background:#0003;border-top:1px solid rgba(255,255,255,.05)}.hero-card-footer small{color:#999;font-size:.65rem}.heroes-empty{text-align:center;padding:6rem 2rem;color:#ccc}.heroes-empty-content{max-width:500px;margin:0 auto}.heroes-empty h2{color:#fff;margin-bottom:1rem;font-family:Cinzel,serif;font-size:2rem;text-shadow:0 0 10px rgba(255,255,255,.3)}.heroes-empty p{font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.heroes-loading{text-align:center;padding:4rem 2rem;color:#fff;font-size:1.2rem}.heroes-error{text-align:center;padding:2rem;color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:12px;margin-bottom:2rem}.heroes-error p{margin:0 0 1rem;font-size:1.1rem}.retry-button{padding:8px 16px;background:linear-gradient(45deg,#ff6b6b,#ff5252);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:all .2s ease}.retry-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b6b66}.hero-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.hero-form-modal{background:linear-gradient(135deg,#2a1a5e,#1a1430);border:2px solid rgba(209,71,163,.3);border-radius:16px;padding:0;width:100%;max-width:600px;max-height:90vh;overflow:hidden;position:relative;box-shadow:0 20px 60px #00000080}.hero-form-modal.compact{max-width:450px;max-height:75vh}.hero-form-modal.compact .hero-form-header{padding:1.25rem 1.5rem}.hero-form-modal.compact .hero-form-title{font-size:1.4rem}.hero-form-modal.compact .hero-form-content{padding:1.5rem;max-height:calc(75vh - 120px)}.hero-form-modal.compact .hero-form-content form{gap:1rem}.hero-form-modal.compact .hero-form-field{gap:.5rem}.hero-form-modal.compact .hero-form-field label{font-size:.9rem}.hero-form-modal.compact .hero-form-field input,.hero-form-modal.compact .hero-form-field textarea,.hero-form-modal.compact .hero-form-field select{padding:8px 12px;font-size:.9rem}.hero-form-modal.compact .hero-form-field textarea{min-height:60px}.hero-form-modal.compact .hero-form-row{gap:1rem}.hero-form-modal.compact .hero-form-actions{margin-top:1.5rem;padding-top:1.5rem;gap:.75rem}.hero-form-modal.compact .hero-form-button{padding:10px 20px;font-size:.9rem;min-width:100px}.heroes-grid.compact{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.hero-card.compact{border-radius:12px}.hero-card.compact .hero-card-header{padding:.5rem .75rem}.hero-card.compact .hero-card-header h3{font-size:1rem}.hero-card.compact .hero-action-button{width:26px;height:26px;font-size:.9rem}.hero-card.compact .hero-card-content{padding:.5rem .75rem}.hero-card.compact .hero-main-info{margin-bottom:.5rem}.hero-card.compact .hero-class{font-size:.8rem}.hero-card.compact .hero-level{font-size:.75rem;padding:1px 4px}.hero-card.compact .hero-player-name{font-size:.75rem}.hero-card.compact .hero-info-row{margin-bottom:6px;padding:2px 0}.hero-card.compact .hero-label{font-size:.75rem}.hero-card.compact .hero-value{font-size:.8rem}.hero-card.compact .hero-stats{gap:6px;margin:.5rem 0}.hero-card.compact .hero-stat-value{font-size:1rem}.hero-card.compact .hero-stat-label{font-size:.65rem}.hero-card.compact .hero-note{margin-top:.5rem;padding:4px}.hero-card.compact .hero-note-text{font-size:.7rem;-webkit-line-clamp:1;line-clamp:1}.hero-card.compact .hero-card-footer{padding:.4rem .75rem}.hero-card.compact .hero-card-footer small{font-size:.6rem}.hero-form-title{color:#fff;margin:0;font-family:Cinzel,serif;font-size:1.8rem;text-shadow:0 0 10px rgba(255,255,255,.5);background:linear-gradient(45deg,#d147a3,#fff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-form-close{background:none;border:none;color:#ccc;font-size:1.8rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:50%}.hero-form-close:hover{color:#fff;background:#ffffff1a;transform:scale(1.1)}.hero-form-content{padding:2rem;max-height:calc(90vh - 180px);overflow-y:auto}.hero-form-content form{display:flex;flex-direction:column;gap:1.5rem}.hero-form-field{display:flex;flex-direction:column;gap:.75rem}.hero-form-field label{color:#fff;font-weight:700;font-size:1rem;text-shadow:0 0 3px rgba(255,255,255,.3);display:flex;align-items:center;gap:.5rem}.hero-form-field label:before{content:"•";color:#d147a3;font-size:1.2rem;font-weight:700}.hero-form-field input,.hero-form-field textarea,.hero-form-field select{padding:12px 16px;border:2px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:#fff;font-size:1rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-form-field input::placeholder,.hero-form-field textarea::placeholder{color:#ffffff80;font-style:italic}.hero-form-field input:focus,.hero-form-field textarea:focus,.hero-form-field select:focus{outline:none;border-color:#d147a3;box-shadow:0 0 15px #d147a366;background:#ffffff1a;transform:translateY(-1px)}.hero-form-field input:hover,.hero-form-field textarea:hover,.hero-form-field select:hover{border-color:#fff6}.hero-form-field textarea{min-height:100px;resize:vertical;font-family:inherit;line-height:1.5}.hero-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.hero-form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:2px solid rgba(255,255,255,.1)}.hero-form-button{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:120px;display:flex;align-items:center;justify-content:center;gap:.5rem}.hero-form-button.cancel{background:transparent;color:#ccc;border:2px solid rgba(255,255,255,.3)}.hero-form-button.cancel:hover{background:#ffffff1a;color:#fff;border-color:#ffffff80;transform:translateY(-1px)}.hero-form-button.save{background:linear-gradient(45deg,#d147a3,#b5368e);color:#fff;border:2px solid rgba(209,71,163,.5);box-shadow:0 4px 15px #d147a34d}.hero-form-button.save:hover:not(:disabled){background:linear-gradient(45deg,#b5368e,#9a2f7a);transform:translateY(-2px);box-shadow:0 6px 20px #d147a380}.hero-form-button:disabled{background:#666;cursor:not-allowed;opacity:.6;transform:none!important;box-shadow:none!important}.error-message{color:#ff6b6b;font-size:.85rem;margin-top:.25rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.error-message:before{content:"⚠️";font-size:.9rem}.hero-form-field input.error,.hero-form-field textarea.error,.hero-form-field select.error{border-color:#ff6b6b;background:#ff6b6b1a;box-shadow:0 0 10px #ff6b6b4d}@media (max-width: 768px){.heroes-container{padding:1rem}.heroes-header{flex-direction:column;gap:1.5rem;align-items:stretch;text-align:center}.heroes-header h1{font-size:2rem}.heroes-grid{grid-template-columns:1fr;gap:1.5rem}.hero-card-header{flex-direction:column;gap:1rem;align-items:stretch}.hero-card-actions{justify-content:center}.hero-stats{grid-template-columns:1fr;gap:12px}.hero-form-row{grid-template-columns:1fr;gap:1rem}.hero-form-modal{margin:.5rem;width:calc(100% - 1rem);max-height:95vh}.hero-form-header,.hero-form-content{padding:1.5rem}.hero-form-title{font-size:1.4rem}.hero-form-actions{flex-direction:column;gap:.75rem}.hero-form-button{width:100%}.heroes-empty{padding:3rem 1rem}.heroes-empty h2{font-size:1.5rem}}.main-navigation{background:#0000004d;padding:1rem 0;border-bottom:1px solid rgba(209,71,163,.3);position:relative;z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;gap:1rem;align-items:center}.nav-button{padding:.75rem 1.5rem;border:2px solid transparent;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem;background:#ffffff1a;color:#fff;border-color:#fff3}.nav-button:hover{background:#d147a333;border-color:#d147a3;box-shadow:0 0 10px #d147a34d;transform:translateY(-1px)}.nav-button.active{background:linear-gradient(135deg,#d147a3,#b5368e);border-color:#d147a3;box-shadow:0 0 15px #d147a380}.nav-button.active:hover{background:linear-gradient(135deg,#b5368e,#9a2e78);box-shadow:0 0 20px #d147a3b3}.changelog-button{margin-left:auto}@media (max-width: 768px){.nav-container{padding:0 1rem;flex-wrap:wrap;gap:.5rem}.nav-button{padding:.6rem 1rem;font-size:.9rem}.changelog-button{margin-left:0}}.add-mode-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(209,71,163,.2)}.mode-button{flex:1;padding:.75rem 1rem;border:2px solid transparent;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem;background:#ffffff1a;color:#fff;border-color:#fff3}.mode-button:hover:not(:disabled){background:#d147a333;border-color:#d147a3;box-shadow:0 0 10px #d147a34d}.mode-button.active{background:linear-gradient(135deg,#d147a3,#b5368e);border-color:#d147a3;box-shadow:0 0 15px #d147a380}.mode-button:disabled{opacity:.5;cursor:not-allowed;background:#ffffff0d}.form-group-wide{grid-column:1 / -1}.hero-select{width:100%;padding:.75rem;border:2px solid rgba(209,71,163,.3);border-radius:5px;background:#0003;color:#fff;font-size:.9rem}.hero-select:focus{outline:none;border-color:#d147a3;box-shadow:0 0 10px #d147a34d}.hero-select option{background:#1a1a1a;color:#fff;padding:.5rem}.remove-combatant-button{background:transparent;border:1px solid rgba(255,193,7,.5);color:#ffc107;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.remove-combatant-button:hover{background:#ffc1071a;border-color:#ffc107;box-shadow:0 0 5px #ffc1074d}.remove-combatant-button:active{background:#ffc10733;transform:translateY(1px)}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.confirm-dialog{background:linear-gradient(135deg,#1a1a1a,#2a2a2a);border:2px solid rgba(209,71,163,.5);border-radius:12px;box-shadow:0 20px 40px #00000080,0 0 30px #d147a34d;max-width:400px;width:100%;overflow:hidden;animation:confirmDialogAppear .2s ease-out}@keyframes confirmDialogAppear{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-dialog-header{padding:1.5rem 1.5rem 0}.confirm-dialog-title{margin:0;color:#fff;font-size:1.2rem;font-weight:600}.confirm-dialog-body{padding:1rem 1.5rem}.confirm-dialog-message{margin:0;color:#ffffffe6;line-height:1.5}.confirm-dialog-footer{padding:0 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.confirm-dialog-button{padding:.75rem 1.5rem;border:2px solid transparent;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem;min-width:80px}.confirm-dialog-button.cancel{background:#ffffff1a;color:#fff;border-color:#fff3}.confirm-dialog-button.cancel:hover{background:#fff3;border-color:#fff6}.confirm-dialog-button.confirm{background:linear-gradient(135deg,#d147a3,#b5368e);color:#fff;border-color:#d147a3}.confirm-dialog-button.confirm:hover{background:linear-gradient(135deg,#b5368e,#9a2e78);box-shadow:0 0 15px #d147a380}.confirm-dialog-button.confirm.destructive{background:linear-gradient(135deg,#dc3545,#c82333);border-color:#dc3545}.confirm-dialog-button.confirm.destructive:hover{background:linear-gradient(135deg,#c82333,#bd2130);box-shadow:0 0 15px #dc354580}@media (max-width: 768px){.confirm-dialog{margin:1rem;max-width:none}.confirm-dialog-footer{flex-direction:column-reverse}.confirm-dialog-button{width:100%}}.combat-session-controls{background:#ffffff0d;border:1px solid rgba(209,71,163,.2);border-radius:8px;padding:1rem;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.session-actions{display:flex;gap:.75rem}.session-button{padding:.75rem 1.25rem;border:2px solid transparent;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.session-button.save{background:linear-gradient(135deg,#28a745,#218838);color:#fff;border-color:#28a745}.session-button.save:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1e7e34);box-shadow:0 0 15px #28a74580}.session-button.new{background:#ffffff1a;color:#fff;border-color:#fff3}.session-button.new:hover:not(:disabled){background:#d147a333;border-color:#d147a3;box-shadow:0 0 10px #d147a34d}.session-button.load{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff;border-color:#17a2b8}.session-button.load:hover:not(:disabled){background:linear-gradient(135deg,#138496,#117a8b);box-shadow:0 0 15px #17a2b880}.session-button.history{background:linear-gradient(135deg,#6f42c1,#5a32a3);color:#fff;border-color:#6f42c1}.session-button.history:hover:not(:disabled){background:linear-gradient(135deg,#5a32a3,#4e2d91);box-shadow:0 0 15px #6f42c180}.session-button:disabled{opacity:.5;cursor:not-allowed}.session-status{display:flex;align-items:center;gap:.5rem}.session-indicator{background:linear-gradient(135deg,#28a745,#218838);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.session-indicator:before{content:"🟢";font-size:.7rem}@media (max-width: 768px){.combat-session-controls{flex-direction:column;align-items:stretch;gap:1rem}.session-actions{justify-content:space-between}.session-button{flex:1;padding:.6rem 1rem;font-size:.85rem}.session-status{justify-content:center}}.combat-sessions-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.combat-sessions-content{background:linear-gradient(135deg,#1a1a1a,#2a2a2a);border:2px solid rgba(209,71,163,.5);border-radius:12px;box-shadow:0 20px 40px #00000080,0 0 30px #d147a34d;max-width:800px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.sessions-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(209,71,163,.3)}.sessions-header h2{margin:0;color:#fff;font-size:1.5rem;font-weight:600}.close-button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .3s ease}.close-button:hover{background:#ffffff1a;border-color:#fff}.sessions-container{flex:1;overflow-y:auto;padding:1.5rem}.sessions-section{margin-bottom:2rem}.sessions-section h3{color:#fff;margin:0 0 1rem;font-size:1.2rem;font-weight:600}.sessions-list{display:flex;flex-direction:column;gap:1rem}.session-card{background:#ffffff0d;border:1px solid rgba(209,71,163,.2);border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.session-card:hover{background:#ffffff14;border-color:#d147a366}.session-card.active{border-color:#28a74580}.session-card.completed{border-color:#6c757d80}.session-info h4{color:#fff;margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.session-details{display:flex;gap:1rem;color:#ffffffb3;font-size:.9rem}.session-actions{display:flex;gap:.5rem}.session-action-button{padding:.5rem 1rem;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s ease;display:flex;align-items:center;gap:.25rem}.session-action-button.resume{background:linear-gradient(135deg,#28a745,#218838);color:#fff;border-color:#28a745}.session-action-button.resume:hover{background:linear-gradient(135deg,#218838,#1e7e34)}.session-action-button.view{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff;border-color:#17a2b8}.session-action-button.view:hover{background:linear-gradient(135deg,#138496,#117a8b)}.session-action-button.delete{background:transparent;border-color:#dc354580;color:#dc3545}.session-action-button.delete:hover{background:#dc35451a;border-color:#dc3545}.sessions-empty{text-align:center;padding:3rem 1rem;color:#ffffffb3}.sessions-empty h3{color:#fff;margin-bottom:1rem}.sessions-error{background:#dc35451a;border:1px solid rgba(220,53,69,.3);border-radius:6px;padding:1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.sessions-error p{color:#dc3545;margin:0}.retry-button{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:1px solid #dc3545;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.retry-button:hover{background:linear-gradient(135deg,#c82333,#bd2130)}@media (max-width: 768px){.session-card{flex-direction:column;align-items:stretch;gap:1rem}.session-details{flex-direction:column;gap:.5rem}.session-actions{justify-content:space-between}.session-action-button{flex:1}}.combatant-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.expand-toggle-button{background:#ffffff1a;border:2px solid rgba(209,71,163,.3);color:#fff;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:40px}.expand-toggle-button:hover{background:#d147a333;border-color:#d147a3;box-shadow:0 0 10px #d147a34d}.expand-toggle-button.expanded{background:linear-gradient(135deg,#d147a3,#b5368e);border-color:#d147a3}.expand-toggle-button.collapsed{animation:pulseGlow 2s infinite}@keyframes pulseGlow{0%,to{box-shadow:0 0 5px #d147a34d}50%{box-shadow:0 0 15px #d147a399}}.form-collapsed-state{padding:.75rem 1rem;text-align:center;background:#ffffff05;border:1px dashed rgba(209,71,163,.3);border-radius:6px;margin-top:.5rem}.collapsed-message{color:#ffffffb3;font-size:.85rem;margin:0;line-height:1.3}.collapsed-message strong{color:#d147a3;font-weight:600}@media (max-width: 768px){.combatant-form-header{gap:1rem}.expand-toggle-button{padding:.4rem .6rem;font-size:.9rem;min-width:36px}.form-collapsed-state{padding:.5rem .75rem;margin-top:.25rem}.collapsed-message{font-size:.8rem}}.empty-history{text-align:center;padding:2rem 1rem;background:#ffffff05;border-radius:8px;margin:1rem 0}.empty-hint{color:#ffffff80;font-size:.9rem;margin-top:.5rem;font-style:italic}.history-entries{margin:1rem 0}.history-entry{background:#ffffff08;border:1px solid rgba(209,71,163,.2);border-radius:6px;padding:.75rem;margin-bottom:.75rem;transition:all .3s ease}.history-entry:hover{background:#ffffff0d;border-color:#d147a366;transform:translateY(-1px)}.history-timestamp{display:block;font-size:.8rem;color:#d147a3cc;margin-bottom:.25rem;font-weight:500}.history-description{color:#ffffffe6;line-height:1.4;font-size:.9rem}
