@import"https://fonts.googleapis.com/css2?family=Pirata+One&display=swap";@import"https://fonts.googleapis.com/css2?family=Faustina:ital,wght@0,300..800;1,300..800&display=swap";@import"https://fonts.googleapis.com/css2?family=Metamorphous&display=swap";:root{--blk: #030303;--accent: #21a6ff;--accent-b: color-mix(in srgb, var(--accent) 50%, black 50%);--wht: #fff;--dark-grey: #131313;--light-grey: #929292;--danger: #d12d2d;--font-accent: "Metamorphous", system-ui;--font-body: "Faustina", system-ui}body{background-color:var(--blk);color:var(--wht);margin:0;overflow-x:hidden;font-size:14px}.content-zone{height:auto;margin-top:10vh;min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 50%,color-mix(in srgb,var(--accent) 15%,transparent) 0%,transparent 50%),radial-gradient(circle at 80% 20%,color-mix(in srgb,var(--accent) 15%,transparent) 0%,transparent 50%)}.content-container{width:100%;display:flex;align-items:center;justify-content:center}.content-container:before{content:"";position:fixed;inset:0;pointer-events:none}.content-header{width:60%;display:flex;flex-direction:column;align-items:center;justify-content:center;height:20vh}.content-header a{color:var(--accent)}.content-header-title{font-family:var(--font-accent);font-size:38px;font-weight:500;color:var(--wht);margin:0}.content-header-subtitle{font-family:var(--font-body);font-size:14px;color:var(--light-grey);margin:0}.content-body{min-height:70vh;width:60%;display:flex;flex-direction:column;align-items:center;gap:25px}.bar-options{width:auto;display:flex;flex-direction:row;align-items:center;padding:20px}.bar-options ul{list-style:none;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:50px;padding:10px;margin:0;width:100%}.bar-options ul li{font-family:var(--font-body);color:var(--wht);text-decoration:none;font-weight:500;padding:.5rem 0;transition:color .3s ease;position:relative;cursor:pointer}.bar-options ul li:hover{color:var(--accent)}.bar-options ul li:after{content:"";position:absolute;bottom:-5px;left:50%;width:0;height:2px;background:var(--accent);transition:all .3s ease;transform:translate(-50%)}.bar-options ul li:hover:after{width:100%}.bar-options ul li.active a:after{content:"";position:absolute;bottom:-5px;left:0;right:0;height:2px;background:var(--accent)}.input-field{width:100%;padding:.75rem 1rem;background:#ffffff0d;border:1px solid var(--dark-grey);border-radius:6px;color:var(--wht);font-size:14px;font-family:var(--font-body);transition:all .3s ease}.input-field:focus{outline:none;border-color:var(--accent);background:#ffffff14;box-shadow:0 0 0 2px #d41d1d33}.input-field:disabled{opacity:.6;cursor:not-allowed;background:#ffffff05}.input-field::placeholder{color:#fefefe80}@media(prefers-color-scheme:light){.input-field{background:#00000005;border:1px solid rgba(0,0,0,.1);color:#213547}.input-field:focus{border-color:var(--accent);background:#0000000d;box-shadow:0 0 0 2px #d41d1d33}.input-field:disabled{background:#00000003}.input-field::placeholder{color:#21354780}}.button-a{font-size:14px;align-items:center;justify-content:center;background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body);display:flex;flex-direction:row;gap:.5rem}.button-a:hover{transform:translateY(-1px)}.button-a-round{font-size:14px;align-items:center;justify-content:center;background:var(--accent);color:#fff;border:none;padding:1rem;border-radius:50px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body);display:flex;flex-direction:row;gap:.5rem}.button-a-round:hover{transform:translateY(-1px)}.button-b{font-size:14px;align-items:center;justify-content:center;background:var(--dark-grey);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body);display:flex;flex-direction:row;gap:.5rem}.button-b:hover{transform:translateY(-1px)}.button-danger{font-size:14px;align-items:center;justify-content:center;background:var(--danger);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body);display:flex;flex-direction:row;gap:.5rem}.button-discord{font-size:14px;align-items:center;justify-content:center;background:#5865f2;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body);display:flex;flex-direction:row;gap:.5rem}.footer{font-family:var(--font-accent);font-size:12px;height:10vh;background-color:var(--blk);display:flex;align-items:center;justify-content:center;color:var(--wht)}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;margin-top:80px;padding:2rem 0}.container{max-width:1280px;margin:0 auto;padding:0 2rem;text-align:center}.container h1{color:#ffffffde;font-size:3rem;margin-bottom:1rem;background:linear-gradient(135deg,#646cff,#535bf2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.container p{color:#fff9;font-size:1.2rem;line-height:1.6;max-width:600px;margin:0 auto}@media(prefers-color-scheme:light){.container h1{color:#213547;-webkit-text-fill-color:transparent}.container p{color:#213547cc}}@media(max-width:768px){.main-content{margin-top:70px;padding:1rem 0}.container{padding:0 1rem}.container h1{font-size:2rem}.container p{font-size:1rem}}.navbar{position:fixed;top:0;left:0;right:0;background:var(--blk);z-index:1000;border-bottom:1px solid color-mix(in srgb,var(--accent) 25%,transparent)}.navbar-container{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:10vh}.brand-link{font-family:var(--font-accent);font-size:1.5rem;font-weight:500;color:var(--wht);text-decoration:none;transition:color .3s ease}.brand-link img{height:60px}.brand-link:hover{color:var(--accent)}.navbar-menu{display:flex;align-items:center;gap:2rem}.nav-links{display:flex;gap:2rem}.nav-link{font-family:var(--font-accent);color:var(--wht);text-decoration:none;font-weight:500;padding:.5rem 0;transition:color .3s ease;position:relative}.nav-link:hover{color:var(--accent)}.nav-link:after{content:"";position:absolute;bottom:-5px;left:50%;width:0;height:2px;background:var(--accent);transition:all .3s ease;transform:translate(-50%)}.nav-link:hover:after{width:100%}.auth-section{display:flex;align-items:center}.login-button{background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body)}.login-button:hover{transform:translateY(-1px)}.user-dropdown{position:relative}.user-button{display:flex;align-items:center;gap:.5rem;background:none;border:0px solid var(--dark-gre);padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .3s ease;color:var(--wht);font-family:var(--font-body)}.user-button:hover{border-color:var(--accent)}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-b));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;position:relative;overflow:hidden;border:2px solid var(--accent)}.user-avatar.has-image{background:none}.user-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.user-avatar-initials{font-weight:600;font-size:.875rem}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.dropdown-arrow{font-size:.75rem;transition:transform .2s ease}.user-dropdown:hover .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;right:0;min-width:200px;background:#242424f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:8px;box-shadow:0 8px 25px #0000004d;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease;z-index:1000;margin-top:.5rem}.user-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:var(--wht);font-size:.875rem;font-weight:500;transition:all .2s ease;font-family:var(--font-body)}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}.dropdown-item:hover:not(:disabled){color:var(--accent)}.logout-item:hover:not(:disabled){color:var(--danger)}.dropdown-item:disabled{opacity:.6;cursor:not-allowed}.dropdown-divider{height:1px;background:#ffffff1a;margin:.25rem 0}.mobile-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:8px}.mobile-toggle span{width:25px;height:3px;background:var(--wht);border-radius:3px;transition:all .3s ease}.mobile-toggle:hover span{background:var(--accent)}.mobile-toggle.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.mobile-toggle.active span:nth-child(2){opacity:0}.mobile-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media(max-width:768px){.navbar-container{padding:1rem}.mobile-toggle{display:flex}.navbar-menu{position:fixed;top:0;left:-100%;width:100%;height:100vh;background:var(--blk);flex-direction:column;justify-content:center;align-items:center;gap:3rem;transition:left .3s ease}.navbar-menu.active{left:0}.nav-links{flex-direction:column;gap:2rem}.nav-link{font-size:1.5rem;padding:1rem}.dropdown-menu{position:fixed;top:auto;right:1rem;left:1rem;margin-top:1rem}}@media(prefers-color-scheme:light){.navbar{background:#fff;border-bottom:1px solid rgba(212,29,29,.2)}.brand-link,.nav-link,.user-button{color:#213547}.mobile-toggle span{background:#213547}.dropdown-menu{background:#fffffff2}.dropdown-item{color:#213547}.dropdown-divider{background:#0000001a}}.info-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:600px;margin:0 auto}.avatar-section{display:flex;flex-direction:column;align-items:center;gap:1rem;border-radius:16px}.avatar-circle{position:relative;width:150px;height:150px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--accent),var(--accent-b));border:3px solid var(--accent);display:flex;align-items:center;justify-content:center}.avatar-circle.has-image{background:none}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-initials{font-size:3rem;font-weight:600;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}.avatar-loading{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;border-radius:50%}.avatar-actions{display:flex;flex-direction:row;gap:.5rem;width:auto;margin-top:1rem}.avatar-input{display:none}.profile-form{align-items:center;padding:2rem;border-radius:16px;display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.75rem}.form-group label{font-size:.875rem;font-weight:500;color:#fffc;margin-bottom:.5rem}.form-actions{margin-top:2rem}.button-group{display:flex;gap:.75rem}.account-info{background:var(--dark-grey);padding:2rem;border-radius:12px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0}.info-item .label{font-weight:500;color:var(--text-secondary, #8b949e)}.info-item .value{color:var(--text-primary, #fff)}.debug-section{background:var(--warning-bg, #2d1b00);border:1px solid var(--warning-border, #f85149);padding:2rem;border-radius:12px;text-align:center}.debug-section p{margin-bottom:1rem;color:var(--warning-text, #f85149)}.message{padding:.75rem;border-radius:8px;margin-bottom:1rem;font-weight:500}.message.success{background:var(--success-bg, #1b2d1b);color:var(--success-text, #3fb950);border:1px solid var(--success-border, #3fb950)}.spinner{width:20px;height:20px;border:2px solid #333;border-top:2px solid var(--accent-color, #58a6ff);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.info-container{gap:1rem}.avatar-section,.profile-form,.account-info,.debug-section{padding:1.5rem}.avatar-circle{width:100px;height:100px}.avatar-initials{font-size:2rem}.button-group{flex-direction:column}}.toast{position:fixed;bottom:20px;right:20px;background:var(--success-bg, #1b2d1b);color:var(--success-text, #3fb950);border:1px solid var(--success-border, #3fb950);border-radius:12px;padding:1rem 1.5rem;box-shadow:0 4px 12px #0000004d;z-index:1000;transform:translate(100%);opacity:0;transition:all .3s ease-in-out;max-width:350px;min-width:280px}.toast-show{transform:translate(0);opacity:1}.toast-content{display:flex;align-items:center;gap:.75rem}.toast-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--success-text, #3fb950);color:var(--success-bg, #1b2d1b);border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}.toast-message{font-weight:500;font-size:.9rem}.chars-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:800px;margin:0 auto}.chars-content{display:flex;flex-direction:column;align-items:center;text-align:center}.empty-state,.loading-state{display:flex;flex-direction:column;align-items:center;padding:2rem;color:var(--text-secondary, #8b949e)}.empty-state{max-width:400px;margin:0 auto}.empty-state p{margin:0 0 2rem;color:var(--light-grey);font-size:14px}.characters-grid{width:100%;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.character-card{display:flex;align-items:center;justify-content:space-between;background:var(--dark-grey);border:1px solid var(--border-color, #333);border-radius:12px;padding:20px;transition:all .2s ease}.character-card:hover{border-color:var(--accent);transform:translateY(-2px)}.character-info{text-align:left}.character-info h3{font-family:var(--font-accent);font-weight:500;margin:0;color:var(--wht);font-size:18px}.character-subclass{margin:0;color:var(--accent);font-weight:500;font-size:1rem}.character-actions{display:flex;gap:.5rem}.edit-btn,.delete-btn,.close-btn{background:none;border:1px solid var(--dark-grey);border-radius:6px;padding:.5rem;color:var(--wht);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.edit-btn:hover{background:var(--accent);color:var(--wht)}.delete-btn:hover,.close-btn:hover{background:var(--danger);color:var(--wht)}.add-character-section{display:flex;justify-content:center;padding:2rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.character-form-modal{background:var(--surface-color, #1a1a1a);border:1px solid var(--border-color, #333);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color, #333)}.form-header h3{margin:0;color:var(--text-primary, #fff);font-size:1.3rem}.character-form{display:flex;flex-direction:column;align-items:center;padding:1.5rem}.form-error{background:#da36331a;border:1px solid #da3633;color:#da3633;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary, #fff);font-weight:500}.form-group input,.form-group select{width:100%;padding:.75rem;background:var(--dark-grey);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #fff);font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent)}.form-group input::placeholder{color:var(--text-secondary, #8b949e)}.form-group select{cursor:pointer}.form-group select option{background:var(--input-bg, #0d1117);color:var(--text-primary, #fff);padding:.5rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.cancel-btn,.submit-btn{padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s ease;border:1px solid}.cancel-btn{background:none;color:var(--text-secondary, #8b949e);border-color:var(--border-color, #333)}.cancel-btn:hover:not(:disabled){background:var(--border-color, #333);color:var(--text-primary, #fff)}.submit-btn{background:var(--accent);color:var(--wht);border:0px}.cancel-btn:disabled,.submit-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.chars-container{gap:1rem}.characters-grid{grid-template-columns:1fr}.character-form-modal{margin:0;max-height:100vh;border-radius:0}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.options-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:700px;margin:0 auto}.options-section{border-radius:12px;padding:2rem}.options-section h3{margin:0;color:var(--accent);font-family:var(--font-accent);font-size:22px;padding-bottom:.5rem}.option-item{display:flex;justify-content:space-between;align-items:center;padding:15px 0}.option-item:last-child{border-bottom:none}.option-info h4{margin:0;color:var(--wht);font-size:14px;font-weight:500}.option-info p{margin:0;color:var(--text-secondary, #8b949e);font-size:14px;line-height:1.4}.danger-zone{border-radius:12px;padding:2rem}.danger-zone h3{font-family:var(--font-accent);margin:0;color:var(--danger);font-size:1.3rem;padding-bottom:.5rem}.danger-content{display:flex;flex-direction:column;gap:1rem}.danger-item{display:flex;justify-content:space-between;align-items:center;padding:15px 0}.danger-info h4{margin:0;color:var(--wht);font-size:14px;font-weight:500}.danger-info p{margin:0;color:var(--text-secondary, #8b949e);font-size:14px;line-height:1.4;max-width:400px}.button-danger:disabled{opacity:.6;cursor:not-allowed;transform:none}.message{padding:.75rem;border-radius:8px;font-weight:500}.message.error{background:var(--error-bg, #2d1b1b);color:var(--error-text, #f85149);border:1px solid var(--error-border, #f85149)}@media(max-width:768px){.options-container{gap:1rem}.options-header,.options-section,.danger-zone{padding:1.5rem}.options-header h2{font-size:1.5rem}.option-item{flex-direction:column;align-items:flex-start;gap:1rem}.danger-item{gap:1.5rem}.button-danger{width:100%;justify-self:stretch}}.profile-content{width:100%;margin-top:1rem}.spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}@media(max-width:768px){.profile-content{margin-top:.5rem}}.login-card{width:100%;max-width:400px;border-radius:16px;padding:2.5rem;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-family:var(--font-accent);font-size:2rem;font-weight:600;color:var(--wht);margin:0 0 .5rem;background:linear-gradient(135deg,var(--wht),rgba(255,255,255,.8));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:#ffffffb3;font-size:1rem;margin:0;font-weight:400}.login-form{display:flex;flex-direction:column;align-items:center;width:100%;gap:1.5rem}.form-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:90%}.form-label{font-size:.875rem;font-weight:500;color:var(--wht);margin:0}.form-help{font-size:.75rem;color:#ffffff80;margin:0}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:.875rem}.error-icon{font-size:1rem}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{margin-top:2rem;text-align:center}.toggle-text{color:#ffffffb3;font-size:.875rem;margin:0;display:flex;align-items:center;justify-content:center;gap:.5rem}.toggle-btn{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:.875rem;transition:all .3s ease;text-decoration:none;font-family:var(--font-body)}.toggle-btn:hover:not(:disabled){color:#b91c1c;text-decoration:underline}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.back-home{margin-top:1.5rem;text-align:center}.back-btn{background:none;border:none;color:#ffffff80;font-size:.875rem;cursor:pointer;transition:all .3s ease;padding:.5rem;font-family:var(--font-body)}.back-btn:hover:not(:disabled){color:#fffc}.back-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.login-container{padding:1rem}.login-card{padding:2rem}.login-title{font-size:1.75rem}}@media(max-width:480px){.login-card{padding:1.5rem}.login-title{font-size:1.5rem}.toggle-text{flex-direction:column;gap:.25rem}}@media(prefers-color-scheme:light){.login-container{background:#f8fafc}.login-card{background:#fffffff2;border:1px solid rgba(212,29,29,.1)}.login-title{color:#1a202c;background:linear-gradient(135deg,#1a202c,#1a202ccc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:#1a202cb3}.form-label{color:#1a202c}.toggle-text{color:#1a202cb3}.back-btn{color:#1a202c80}.back-btn:hover:not(:disabled){color:#1a202ccc}}.comment-item{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background-color .2s ease}.comment-item:hover{background:#ffffff05}.comment-item:last-child{border-bottom:none}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.comment-author{display:flex;align-items:center;gap:.5rem;flex:1}.comment-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-b));display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--accent);flex-shrink:0}.comment-avatar.has-image{background:none}.comment-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.comment-avatar .avatar-initials{color:#fff;font-weight:600;font-size:.8rem}.comment-info{display:flex;flex-direction:row;gap:.8rem}.author-name{font-family:var(--font-accent);color:var(--wht);font-size:.9rem;font-weight:500;margin:0}.comment-date{color:var(--light-grey);font-size:.75rem;font-family:var(--font-body)}.delete-comment-btn{background:none;border:1px solid rgba(218,54,51,.2);border-radius:4px;padding:.4rem;color:#ff6b6bb3;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;flex-shrink:0}.delete-comment-btn:hover{background:#da36331a;border-color:#da363380;color:#ff6b6b}.comment-content{margin:.25rem 0 .5rem 2.25rem}.comment-content p{font-family:var(--font-body);color:var(--wht);margin:0;line-height:1.3;font-size:.85rem;word-wrap:break-word}.comment-actions{display:flex;align-items:center;margin-left:2.25rem}.comment-like-btn{display:flex;align-items:center;gap:.4rem;background:none;border:none;color:var(--light-grey);cursor:pointer;transition:all .2s ease;font-family:var(--font-body);font-size:.8rem;padding:.4rem .6rem;border-radius:4px}.comment-like-btn:hover:not(:disabled){background:#ffffff0d;color:var(--wht)}.comment-like-btn:disabled{opacity:.5;cursor:not-allowed}.comment-like-btn svg{font-size:.9rem}.comment-like-btn.liked{color:#ff3040}.comment-like-btn.liked:hover{color:#ff3040;background:#ff30401a}.comment-like-btn span{font-size:.8rem;font-weight:500}.comment-error{background:#da36331a;border:1px solid rgba(218,54,51,.3);color:#ff6b6b;padding:.5rem;border-radius:4px;margin-top:.5rem;margin-left:2.75rem;font-size:.8rem}@media(max-width:768px){.comment-item{padding:.75rem 1rem}.comment-author{gap:.5rem}.comment-avatar{width:28px;height:28px}.comment-avatar .avatar-initials{font-size:.75rem}.author-name{font-size:.85rem}.comment-date{font-size:.7rem}.comment-content{margin:.5rem 0 .5rem 2.25rem}.comment-content p{font-size:.85rem}.comment-actions{margin-left:2.25rem}.comment-like-btn{font-size:.75rem;padding:.3rem .5rem;gap:.3rem}.comment-like-btn svg{font-size:.8rem}.comment-like-btn span{font-size:.75rem}.delete-comment-btn{min-width:24px;height:24px;padding:.3rem}.comment-error{margin-left:2.25rem;padding:.4rem;font-size:.75rem}}.comment-item:first-child{padding-top:1rem}.comment-item:last-child{padding-bottom:1rem}.comment-like-btn:focus,.delete-comment-btn:focus{outline:2px solid var(--accent);outline-offset:2px}.comment-item{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.media-post{background:var(--dark-grey);border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;transition:all .3s ease;contain:layout style;isolation:isolate;width:100%;align-self:flex-start}.media-post:hover{border-color:#21a6ff4d;transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.post-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.author-info{display:flex;align-items:center;gap:.75rem}.author-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-b));display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--accent);position:relative}.author-avatar.has-image{background:none}.author-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.author-avatar .avatar-initials{color:#fff;font-weight:600;font-size:1rem}.author-details h4{font-family:var(--font-accent);color:var(--wht);margin:0;font-size:1rem;font-weight:500}.post-date{color:var(--light-grey);font-size:.8rem;font-family:var(--font-body)}.delete-post-btn{background:none;border:1px solid rgba(218,54,51,.3);border-radius:6px;padding:.5rem;color:#ff6b6b;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.delete-post-btn:hover{background:#da36331a;border-color:#da3633;color:#da3633}.post-image{position:relative;width:100%;max-height:600px;overflow:hidden;transition:transform .2s ease}.post-image:hover{transform:scale(1.02)}.post-image:after{content:"";position:absolute;inset:0;background:#0000;transition:background .2s ease;pointer-events:none}.post-image:hover:after{background:#0000001a}.post-image img{width:100%;height:auto;max-height:600px;object-fit:cover;display:block}.post-description{padding:20px 0}.post-description p{padding:0 1.5rem;font-family:var(--font-body);color:var(--wht);margin:0;line-height:1.5;font-size:14px}.post-actions{display:flex;align-items:center;gap:.5rem;padding:10px 1rem;border-bottom:1px solid rgba(255,255,255,.05)}.action-btn{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--light-grey);cursor:pointer;transition:all .2s ease;font-family:var(--font-body);font-size:.9rem;padding:.5rem;border-radius:6px}.action-btn:hover:not(:disabled){background:#ffffff0d;color:var(--wht)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn svg{font-size:1.2rem}.like-btn.liked,.like-btn.liked:hover{color:#ff3040}.comment-btn{color:var(--accent)}.comment-btn:hover{color:var(--accent);background:#21a6ff1a}.download-btn{color:var(--light-grey)}.download-btn:hover{color:#10b981;background:#10b9811a}.post-error{background:#da36331a;border-top:1px solid #da3633;color:#ff6b6b;padding:.75rem 1.5rem;font-size:.9rem}.comments-section{border-top:1px solid rgba(255,255,255,.05);will-change:contents;contain:layout}.comment-form{padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.comment-input-group{display:flex;flex-direction:row;align-items:center;gap:.75rem}.comment-input-group textarea{flex:1;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--wht);font-size:.9rem;font-family:var(--font-body);resize:none;min-height:40px;max-height:120px;transition:all .3s ease}.comment-input-group textarea:focus{outline:none;border-color:var(--accent);background:#ffffff14}.comment-input-group textarea::placeholder{color:var(--light-grey)}.comment-submit-btn{background:var(--accent);border:none;border-radius:8px;padding:.75rem;color:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px}.comment-submit-btn:hover:not(:disabled){background:var(--accent-b);transform:translateY(-1px)}.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.comment-form small{display:block;color:var(--light-grey);font-size:.8rem;text-align:right}.login-prompt{padding:1rem 1.5rem;text-align:center;color:var(--light-grey);font-style:italic;border-bottom:1px solid rgba(255,255,255,.05)}.comments-list{max-height:300px;overflow-y:auto;scroll-behavior:smooth;contain:layout style}.loading-comments,.no-comments{padding:2rem 1.5rem;text-align:center;color:var(--light-grey);font-style:italic}@media(max-width:768px){.media-post{margin:0 -.5rem;border-radius:8px}.post-header,.post-description,.post-actions,.comment-form,.login-prompt{padding-left:1rem;padding-right:1rem}.author-avatar{width:36px;height:36px}.author-avatar .avatar-initials,.author-details h4{font-size:.9rem}.post-date{font-size:.75rem}.action-btn{font-size:.85rem;gap:.4rem}.action-btn svg{font-size:1.1rem}.post-actions{gap:1rem}.comment-input-group{gap:.5rem}.comment-input-group textarea{font-size:.85rem}.comment-submit-btn{min-width:36px;height:36px;padding:.6rem}}.comments-list::-webkit-scrollbar{width:6px}.comments-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.comments-list::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.comments-list::-webkit-scrollbar-thumb:hover{background:var(--accent-b)}.image-modal-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:9999;padding:0}.image-modal{position:relative;width:90vw;max-width:1000px;height:600px;background:var(--dark-grey);border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px #00000080}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:#000000b3;border:1px solid var(--dark-grey);border-radius:50%;width:40px;height:40px;color:var(--wht);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:10001;font-size:1rem}.modal-close-btn:hover{background:var(--accent);border-color:var(--accent);color:var(--wht);transform:scale(1.1)}.image-modal-content{display:flex;flex-direction:row;height:100%;width:100%}.modal-image-section{flex:1;display:flex;align-items:center;justify-content:center;background:var(--blk);overflow:hidden;position:relative;min-width:300px}.modal-image-section img{width:100%;height:auto;object-fit:cover;display:block}.modal-comments-section{flex:0 0 400px;display:flex;flex-direction:column;border-left:1px solid rgba(255,255,255,.1);background:var(--dark-grey);overflow:hidden}.modal-post-header{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05)}.modal-post-header .author-info{display:flex;align-items:center;gap:.5rem}.modal-post-description{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05)}.modal-post-description p{color:var(--wht);margin:0;line-height:1.5;font-size:.9rem;font-family:var(--font-body)}.modal-comments-list{flex:1;overflow-y:auto;padding:.5rem 1rem;min-height:0}.modal-comments-list::-webkit-scrollbar{width:6px}.modal-comments-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.modal-comments-list::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.modal-comments-list::-webkit-scrollbar-thumb:hover{background:var(--accent-b)}.modal-comment-form{border-top:1px solid rgba(255,255,255,.1);background:var(--dark-grey)}.modal-post-actions{display:flex;padding:.5rem 1rem;border-bottom:1px solid rgba(255,255,255,.05)}.modal-comment-form .comment-form{padding:.75rem 1rem}.modal-comment-form .login-prompt{padding:.75rem 1rem;text-align:center;color:var(--light-grey);font-style:italic}.modal-error{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#da3633e6;color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;z-index:10002}@media(max-width:1024px)and (min-width:769px){.image-modal{max-width:900px;height:550px}.modal-comments-section{flex:0 0 350px}}@media(max-width:768px){.image-modal{width:95vw;max-width:none;height:80vh}.image-modal-content{flex-direction:column}.modal-image-section{flex:0 0 auto;max-height:300px;min-height:250px;min-width:unset}.modal-comments-section{flex:1;border-left:none;border-top:1px solid rgba(255,255,255,.1);min-height:200px}.modal-close-btn{top:.75rem;right:.75rem;width:36px;height:36px;font-size:.9rem}}@media(max-width:480px){.image-modal{width:98vw;height:75vh}.modal-image-section{max-height:250px;min-height:200px}.modal-comments-section{min-height:180px}.modal-post-header,.modal-post-description,.modal-post-actions,.modal-comment-form .comment-form,.modal-comment-form .login-prompt{padding-left:1rem;padding-right:1rem}.modal-comments-list{padding:.5rem 1rem}}.post-image-container{position:relative;width:100%}.post-image{position:relative;width:100%;overflow:hidden;border-radius:8px}.post-image img{width:100%;height:auto;display:block}.image-tag{position:absolute;transform:translate(-50%,-50%);z-index:10;cursor:pointer}.tag-dot{width:12px;height:12px;background:var(--accent);border:2px solid white;border-radius:50%;box-shadow:0 2px 8px #0000004d;transition:all .3s ease}.tag-label{position:absolute;left:50%;top:-35px;transform:translate(-50%);background:#000c;color:#fff;padding:.3rem .6rem;border-radius:4px;font-size:.75rem;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s ease}.tag-label:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(0,0,0,.8)}.image-tag:hover .tag-dot{transform:scale(1.2);background:var(--accent-hover)}.image-tag:hover .tag-label{opacity:1}.tag-btn{color:var(--accent)!important}.tag-btn.active{background:#21a6ff1a!important}.post-tags{margin-top:1rem;padding:1rem;background:#21a6ff0d;border:1px solid var(--dark-grey);border-radius:8px}.post-tags h4{color:var(--light-grey);font-size:.9rem;font-weight:500;margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.post-tags .tag-item{background:#21a6ff1a;color:var(--accent);padding:.4rem .75rem;border-radius:16px;font-size:.8rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.post-tags .tag-item svg{font-size:.7rem}.tag-source{color:var(--light-grey)!important;font-weight:400!important;font-size:.7rem!important}@media(max-width:768px){.tag-label{font-size:.7rem;padding:.25rem .5rem;top:-30px}.tag-dot{width:10px;height:10px}.post-tags{padding:.75rem}.post-tags h4{font-size:.85rem}}.modal-tags-overlay{position:absolute;left:50%;transform:translate(-50%);bottom:0;z-index:20;color:#fff;border-radius:12px;box-shadow:0 4px 24px #0000002e;display:flex;flex-direction:column;align-items:center;min-width:400px;max-width:90%}.modal-tags-overlay h4{color:#fff;font-size:.95rem;font-weight:500;margin:0 0 .5rem;text-align:center}.modal-tags-overlay .tags-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.modal-tags-overlay .tag-item{background:#21a6ff1a;color:var(--accent);padding:.4rem .75rem;border-radius:16px;font-size:.8rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.modal-tags-overlay .tag-item svg{font-size:.8rem}.modal-tags-overlay .tag-source{color:#e0e0e0!important;font-weight:400!important;font-size:.7rem!important}.modal-image-container{position:relative}.upload-button{display:flex;align-items:center;gap:.5rem;background:var(--accent);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:var(--font-body);font-size:1rem;margin-top:1rem}.upload-button:hover{background:var(--accent-b);transform:translateY(-2px)}.loading-state{display:flex;justify-content:center;align-items:center;padding:4rem 2rem;color:var(--light-grey);font-family:var(--font-body)}.error-message{background:#da36331a;border:1px solid #da3633;color:#ff6b6b;padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;text-align:center;grid-column:1 / -1}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:4rem 2rem;color:var(--light-grey);grid-column:1 / -1}.empty-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.6;color:var(--accent)}.empty-state h3{font-family:var(--font-accent);color:var(--wht);margin:0 0 .5rem;font-size:1.5rem}.empty-state p{margin:0 0 2rem;color:var(--light-grey);font-size:1rem}.media-feed{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;max-width:800px;margin:0 auto;padding:0 1rem;grid-auto-rows:max-content;align-items:start}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.upload-modal{background:var(--blk);border:1px solid var(--dark-grey);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--dark-grey)}.modal-header h3{font-family:var(--font-accent);color:var(--wht);margin:0;font-size:1.3rem}.close-btn{background:none;border:1px solid var(--dark-grey);border-radius:6px;padding:.5rem;color:var(--light-grey);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.close-btn:hover:not(:disabled){background:var(--dark-grey);color:var(--wht)}.close-btn:disabled{opacity:.5;cursor:not-allowed}.modal-content{padding:1.5rem}.form-error{background:#da36331a;border:1px solid #da3633;color:#ff6b6b;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.upload-section{margin-bottom:1.5rem}.file-input{display:none}.file-label{display:block;cursor:pointer;border:2px dashed var(--dark-grey);border-radius:8px;transition:all .3s ease}.file-label:hover{border-color:var(--accent);background:#21a6ff0d}.upload-placeholder{display:flex;flex-direction:column;align-items:center;padding:3rem 2rem;color:var(--light-grey);text-align:center}.upload-placeholder svg{font-size:3rem;margin-bottom:1rem;color:var(--accent)}.upload-placeholder span{font-size:1.1rem;font-weight:500;margin-bottom:.5rem;color:var(--wht)}.upload-placeholder small{font-size:.9rem;color:var(--light-grey)}.image-preview{position:relative;border-radius:8px;overflow:hidden}.image-preview img{width:100%;height:300px;object-fit:cover;display:block}.change-overlay{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;color:#fff}.image-preview:hover .change-overlay{opacity:1}.change-overlay svg{font-size:2rem;margin-bottom:.5rem}.description-section{margin-bottom:1.5rem}.description-section label{display:block;margin-bottom:.5rem;color:var(--wht);font-weight:500;font-family:var(--font-body)}.description-section textarea{width:100%;padding:.75rem;background:#ffffff0d;border:1px solid var(--dark-grey);border-radius:6px;color:var(--wht);font-size:14px;font-family:var(--font-body);resize:vertical;min-height:80px;transition:all .3s ease;box-sizing:border-box}.description-section textarea:focus{outline:none;border-color:var(--accent);background:#ffffff14}.description-section textarea::placeholder{color:var(--light-grey)}.description-section small{display:block;margin-top:.5rem;color:var(--light-grey);font-size:.8rem;text-align:right}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-actions .button-a,.modal-actions .button-b{padding:.75rem 1.5rem;font-size:1rem}.modal-actions .button-a:disabled,.modal-actions .button-b:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.media-feed{grid-template-columns:1fr;max-width:500px;padding:0 .5rem}.upload-modal{margin:0;max-height:100vh;border-radius:0}.modal-actions{flex-direction:column}.modal-actions .button-a,.modal-actions .button-b{width:100%}.image-preview img{height:250px}.upload-placeholder{padding:2rem 1rem}.upload-placeholder svg{font-size:2.5rem}}.tagging-section{display:flex;flex-direction:column;gap:1rem;align-items:center;margin-bottom:1.5rem;border:1px solid var(--dark-grey);border-radius:8px;padding:1rem}.section-header{display:flex;width:100%;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-header label{color:var(--light-grey);font-weight:500;display:flex;align-items:center;gap:.5rem}.add-tag-btn{background:var(--accent);color:#fff;border:none;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background .3s ease}.add-tag-btn:hover{background:var(--accent-hover)}.add-tag-btn:disabled{opacity:.5;cursor:not-allowed}.current-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.tag-item{background:#21a6ff1a;border:1px solid var(--accent);border-radius:16px;padding:.4rem .75rem;display:flex;align-items:center;gap:.5rem;font-size:.85rem}.tag-name{color:var(--accent);font-weight:500}.tag-name small{color:var(--light-grey);font-weight:400}.remove-tag-btn{background:none;border:none;color:var(--light-grey);cursor:pointer;padding:.2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;width:20px;height:20px;transition:all .3s ease}.remove-tag-btn:hover{background:#da36331a;color:#ff6b6b}.character-search{border-top:1px solid var(--dark-grey);padding-top:.75rem;width:100%;display:flex;align-items:center;flex-direction:column}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%;margin-bottom:.75rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--light-grey);font-size:.9rem}.search-input{width:100%;padding:.75rem .75rem .75rem 2.5rem;border:1px solid var(--dark-grey);border-radius:6px;background:var(--background);color:var(--text);font-size:.9rem}.search-input:focus{outline:none;border-color:var(--accent)}.search-results{margin-bottom:.75rem}.results-header{color:var(--light-grey);font-size:.8rem;font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.character-result{width:100%;background:none;border:1px solid var(--dark-grey);padding:.75rem;border-radius:6px;cursor:pointer;transition:all .3s ease;text-align:left;margin-bottom:.5rem}.character-result:hover{border-color:var(--accent);background:#21a6ff0d}.character-result:last-child{margin-bottom:0}.character-name{display:block;color:var(--text);font-weight:500;margin-bottom:.25rem}.character-info{color:var(--light-grey);font-size:.8rem}.custom-tag-option{border-top:1px solid var(--dark-grey);padding-top:.75rem}.add-custom-tag{width:100%;background:#21a6ff1a;border:1px dashed var(--accent);color:var(--accent);padding:.75rem;border-radius:6px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:.5rem;justify-content:center;transition:all .3s ease}.add-custom-tag:hover{background:#21a6ff26;border-style:solid}@media(max-width:1024px)and (min-width:769px){.media-feed{max-width:700px;gap:.75rem;padding:0 .75rem}}
