*{box-sizing:border-box}body{margin:0;font-family:system-ui,sans-serif;background:#36393f;color:#dcddde}body[data-theme=light]{background:#f2f3f5;color:#2e3338}body[data-theme=light] .irc-client{background:#fff}body[data-theme=light] .irc-header{background:#f2f3f5;border-color:#e3e5e8}body[data-theme=light] .irc-sidebar,body[data-theme=light] .irc-nicklist{background:#f2f3f5}body[data-theme=light] .irc-channel-header{background:#fff;border-color:#e3e5e8}body[data-theme=light] .irc-topic{background:#f2f3f5;color:#2e3338}body[data-theme=light] .irc-messages{background:#fff}body[data-theme=light] .irc-input-form{background:#f2f3f5}body[data-theme=light] .irc-input-form input{background:#fff;color:#2e3338;border-color:#e3e5e8}body[data-theme=light] .channel-list li:hover,body[data-theme=light] .channel-list li.active{background:#e3e5e8}body[data-theme=light] .irc-search input{background:#fff;color:#2e3338;border-color:#e3e5e8}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid #40444b;border-top-color:#7289da;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#36393f}.login-box{background:#202225;padding:2rem;border-radius:8px;width:100%;max-width:360px}.login-box h1{margin:0 0 1.5rem;font-size:1.5rem}.login-box input{display:block;width:100%;padding:.75rem;margin-bottom:.75rem;border:none;border-radius:4px;background:#40444b;color:#fff;font-size:1rem}.login-box button{width:100%;padding:.75rem;margin-top:.5rem;border:none;border-radius:4px;background:#5865f2;color:#fff;font-size:1rem;cursor:pointer}.login-box button:hover:not(:disabled){background:#4752c4}.login-box button:disabled{opacity:.6;cursor:not-allowed}.login-toggle{margin-top:1rem;background:transparent!important;color:#00b0f4;text-decoration:underline}.login-error{color:#ed4245;font-size:.9rem;margin:.5rem 0 0}.admin-settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-settings-modal{background:#36393f;border-radius:8px;width:90%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0006}.admin-settings-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #40444b}.admin-settings-header h2{margin:0;font-size:1.25rem;color:#fff}.admin-settings-close{background:none;border:none;color:#b9bbbe;font-size:1.5rem;cursor:pointer;padding:0 .25rem;line-height:1}.admin-settings-close:hover{color:#fff}.admin-settings-loading{padding:2rem;color:#72767d;text-align:center}.admin-settings-form{padding:1.25rem}.admin-settings-form label{display:block;margin-bottom:1rem;color:#b9bbbe;font-size:.9rem}.admin-settings-form label:not(.admin-settings-checkbox) input,.admin-settings-form label:not(.admin-settings-checkbox) select{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;background:#202225;border:1px solid #40444b;border-radius:4px;color:#fff}.admin-settings-checkbox{display:flex;align-items:center;gap:.5rem}.admin-settings-checkbox input{width:auto}.admin-settings-error{color:#f04747;margin-bottom:1rem;font-size:.9rem}.admin-settings-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.25rem;padding-top:1rem;border-top:1px solid #40444b}.admin-settings-actions button{padding:.5rem 1rem;border-radius:4px;border:none;cursor:pointer;font-size:.9rem}.admin-settings-actions button[type=button]{background:#40444b;color:#fff}.admin-settings-actions button[type=submit]{background:#5865f2;color:#fff}.admin-settings-actions button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.admin-users-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-users-modal{background:#36393f;border-radius:8px;width:90%;max-width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.admin-users-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #40444b}.admin-users-header h2{margin:0;font-size:1.25rem}.admin-users-close{background:none;border:none;color:#b9bbbe;font-size:1.5rem;cursor:pointer}.admin-users-error{color:#f04747;padding:.5rem 1rem;font-size:.9rem}.admin-users-loading{padding:2rem;text-align:center;color:#72767d}.admin-users-list{overflow-y:auto;padding:.5rem}.admin-users-row{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px}.admin-users-row:hover{background:#40444b}.admin-users-name{flex:1;font-weight:500}.admin-users-badges{display:flex;gap:.25rem}.admin-users-badges .badge{font-size:.7rem;padding:.15rem .4rem;border-radius:3px}.admin-users-badges .badge.admin{background:#5865f2;color:#fff}.admin-users-badges .badge.pending{background:#faa61a;color:#000}.admin-users-actions{display:flex;gap:.25rem}.admin-users-actions button{padding:.25rem .5rem;font-size:.8rem;border:none;border-radius:4px;background:#5865f2;color:#fff;cursor:pointer}.admin-users-actions button.danger{background:#f04747}.change-pw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.change-pw-modal{background:#36393f;border-radius:8px;padding:1.5rem;width:90%;max-width:360px}.change-pw-modal h2{margin:0 0 1rem;font-size:1.25rem}.change-pw-modal input{display:block;width:100%;padding:.5rem;margin-bottom:.5rem;background:#202225;border:1px solid #40444b;border-radius:4px;color:#fff}.change-pw-error{color:#f04747;font-size:.9rem;margin-bottom:.5rem}.change-pw-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.change-pw-actions button{padding:.5rem 1rem;border-radius:4px;border:none;cursor:pointer}.change-pw-actions button[type=button]{background:#40444b;color:#fff}.change-pw-actions button[type=submit]{background:#5865f2;color:#fff}.nick-change-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.nick-change-modal{background:#36393f;border-radius:8px;padding:1.5rem;width:90%;max-width:320px}.nick-change-modal h2{margin:0 0 1rem;font-size:1.25rem}.nick-change-modal input{display:block;width:100%;padding:.5rem;margin-bottom:1rem;background:#202225;border:1px solid #40444b;border-radius:4px;color:#fff}.nick-change-actions{display:flex;gap:.5rem;justify-content:flex-end}.nick-change-actions button{padding:.5rem 1rem;border-radius:4px;border:none;cursor:pointer}.nick-change-actions button[type=button]{background:#40444b;color:#fff}.nick-change-actions button[type=submit]{background:#5865f2;color:#fff}.irc-client{display:flex;flex-direction:column;height:100vh;background:#36393f}.irc-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#202225;border-bottom:1px solid #40444b}.irc-header span:first-child{font-weight:600}.irc-status{color:#72767d}.irc-status.connected{color:#43b581}.irc-header-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.irc-settings-btn{padding:.35rem .6rem;background:#40444b;border:none;border-radius:4px;color:#b9bbbe;cursor:pointer;font-size:1.1rem}.irc-settings-btn:hover{background:#5865f2;color:#fff}.irc-header button:last-child{padding:.4rem .8rem;background:#5865f2;border:none;border-radius:4px;color:#fff;cursor:pointer}.irc-body{display:flex;flex:1;overflow:hidden}.irc-sidebar{width:220px;background:#2f3136;padding:.5rem;overflow-y:auto}.irc-sidebar input{width:100%;padding:.5rem;margin-bottom:.5rem;border:none;border-radius:4px;background:#40444b;color:#fff}.irc-sidebar button{width:100%;padding:.4rem;background:#5865f2;border:none;border-radius:4px;color:#fff;cursor:pointer}.channel-list{list-style:none;margin:.5rem 0;padding:0}.channel-list li{display:flex;align-items:center;justify-content:space-between;padding:.4rem .5rem;cursor:pointer;border-radius:4px}.channel-list li:hover,.channel-list li.active{background:#40444b}.channel-name{flex:1}.channel-part-btn{padding:0 .3rem;font-size:1rem;line-height:1;background:transparent;border:none;color:#72767d;cursor:pointer;border-radius:2px}.channel-part-btn:hover{background:#f04747;color:#fff}.irc-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.irc-channel-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#36393f;border-bottom:1px solid #40444b}.irc-channel-title{font-weight:600;color:#dcddde}.irc-part-btn{padding:.25rem .5rem;font-size:.8rem;background:transparent;border:1px solid #40444b;border-radius:4px;color:#b9bbbe;cursor:pointer}.irc-part-btn:hover{background:#40444b;color:#fff}.irc-messages{flex:1;overflow-y:auto;padding:1rem}.irc-msg{display:flex;gap:.5rem;margin-bottom:.4rem;line-height:1.4}.irc-msg-time{flex-shrink:0;color:#72767d;font-size:.75rem;min-width:2.5rem}.irc-msg-nick{flex-shrink:0;font-weight:600;margin-right:.25rem}.irc-msg-text{word-break:break-word}.irc-msg-text a{color:#00b0f4;text-decoration:none}.irc-msg-text a:hover{text-decoration:underline}.irc-input-form{display:flex;gap:.5rem;padding:.75rem;background:#40444b}.irc-input-form input{flex:1;padding:.6rem 1rem;border:none;border-radius:4px;background:#202225;color:#fff}.irc-input-form button{padding:.6rem 1rem;background:#5865f2;border:none;border-radius:4px;color:#fff;cursor:pointer}.irc-empty{padding:2rem;color:#72767d}.irc-nicklist{width:180px;background:#2f3136;padding:.5rem;overflow-y:auto}.irc-nicklist-title{font-size:.75rem;color:#72767d;text-transform:uppercase;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid #40444b}.irc-nicklist ul{list-style:none;margin:0;padding:0}.irc-nicklist li{padding:.25rem 0;font-size:.9rem;cursor:pointer}.irc-nicklist li:hover{text-decoration:underline}.unread-badge{background:#f04747;color:#fff;font-size:.7rem;padding:.1rem .4rem;border-radius:10px;margin-left:.25rem}.irc-msg-action{font-style:italic}.irc-msg-action .irc-msg-action-text{margin-left:.25rem}.irc-topic{padding:.4rem 1rem;background:#2f3136;font-size:.9rem;color:#b9bbbe;border-bottom:1px solid #40444b}.irc-notices{padding:.25rem 1rem;background:#202225;font-size:.8rem;color:#72767d;max-height:80px;overflow-y:auto}.irc-notice{margin:.15rem 0}.irc-notice-nick{color:#faa61a;margin-right:.25rem}.irc-search{padding:.25rem 1rem}.irc-search input{width:100%;padding:.35rem .5rem;background:#202225;border:1px solid #40444b;border-radius:4px;color:#fff;font-size:.9rem}.irc-icon-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;padding:.25rem}
