:root{font-family:Inter,ui-sans-serif,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#e9edef;background-color:#0b141a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{height:100%;width:100%;margin:0;padding:0;overflow:hidden}body{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}button{border-radius:10px;border:1px solid #0e171c;padding:.55rem .9rem;font-size:.95rem;font-weight:600;background:#0f1b21;color:#d9e3ea;cursor:pointer}button:hover{border-color:#1c2a31;background:#122129}button:focus-visible{outline:2px solid #00a884;outline-offset:2px}:root{--bg: #0b141a;--panel: #111b21;--panel-2: #1f2c33;--accent: #00a884;--text: #e9edef;--muted: #8696a0}:root html,:root body,:root #root{height:100%}:is(:root html,:root body,:root #root) #root{margin:0;padding:0}:is(:root html,:root body,:root #root) .app{display:grid;grid-template-rows:64px 1fr;height:100vh;background:linear-gradient(180deg,#0b141a,#111b21);color:var(--text)}:is(:root html,:root body,:root #root) .topbar{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 16px;background:var(--panel-2);border-bottom:1px solid #0e171c;-webkit-backdrop-filter:saturate(1.1) blur(6px);backdrop-filter:saturate(1.1) blur(6px);z-index:20;min-height:72px;height:72px}@media (max-width: 700px){:is(:root html,:root body,:root #root) .topbar{flex-wrap:wrap;flex-direction:column;align-items:flex-start;gap:8px;padding:8px 6px;min-height:56px;height:auto}:is(:root html,:root body,:root #root) .topbar .title{font-size:1.1rem;margin-bottom:2px}:is(:root html,:root body,:root #root) .topbar .user-name-section{width:100%;display:flex;align-items:center;gap:6px;margin-bottom:4px}:is(:root html,:root body,:root #root) .topbar .user-label{font-size:12px;margin-right:4px}:is(:root html,:root body,:root #root) .topbar .user-input{width:120px;font-size:12px;padding:6px 7px}:is(:root html,:root body,:root #root) .topbar .actions{width:100%;display:flex;gap:6px;justify-content:flex-start;flex-wrap:wrap}:is(:root html,:root body,:root #root) .topbar .actions button,:is(:root html,:root body,:root #root) .topbar .logout-btn,:is(:root html,:root body,:root #root) .topbar .change-pwd-btn{padding:7px 12px;font-size:13px;min-width:0}}:root .topbar .title{font-weight:700;letter-spacing:.2px}:root .topbar .actions{display:flex;gap:8px;align-items:center}:root .icon-button{display:none;width:36px;height:36px;border-radius:8px;background:var(--panel);border:1px solid #0e171c;align-items:center;justify-content:center}:root .layout{display:grid;grid-template-columns:360px 1fr;height:100%;overflow:hidden;min-height:0}:root .sidebar{border-right:1px solid #0e171c;background:var(--panel);overflow:auto}:root .sidebar .section{padding:12px 16px;color:var(--muted);font-size:12px}:root .sidebar .chat-item{padding:12px 16px;border-bottom:1px solid #172229;cursor:pointer;transition:background .16s ease}:root .sidebar .chat-item:hover{background:#152129}:root .sidebar .chat-item.active{background:#23323b}:root .chat-window{background:var(--bg);display:flex;flex-direction:column;min-width:0;min-height:0}:root .messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px;display:flex;flex-direction:column;gap:10px}:root .messages input,:root .messages textarea{pointer-events:auto}:root .bubble{max-width:min(72ch,85%);width:fit-content;padding:10px 12px;border-radius:12px;font-size:14px;line-height:1.4;background:#202c33;box-shadow:0 1px 1px #0003}:root .bubble.me{align-self:flex-end;background:#005c4b}:root .bubble.other{align-self:flex-start;background:#1e2a31}:root .meta{display:flex;gap:8px;opacity:.7;font-size:11px;margin-top:6px}:root .meta.me{justify-content:flex-end}:root .meta.other{justify-content:flex-start}:root .media{margin-top:8px;border-radius:10px;overflow:hidden;max-width:320px}:root .media img,:root .media video,:root .media audio{width:100%;height:auto;display:block;background:#000}:root .empty-state{height:100%;display:grid;place-items:center;color:var(--muted)}:root .overlay{position:fixed;inset:0;background:#0006;z-index:15;display:none}@media (max-width: 900px){:root .icon-button{display:inline-flex}:root .layout{grid-template-columns:1fr}:root .sidebar{position:fixed;top:64px;left:0;bottom:0;width:88vw;max-width:420px;transform:translate(-100%);transition:transform .22s ease;z-index:20;box-shadow:0 8px 24px #0006}:root .sidebar.open{transform:translate(0)}:root .overlay.open{display:block}:root .app{grid-template-rows:56px 1fr;min-height:100vh}:root .topbar{padding:0 8px;gap:6px;font-size:15px}:root .layout{min-height:0;height:100%;overflow:hidden}:root .sidebar{width:92vw;max-width:100vw;min-width:0;left:0;top:56px;border-radius:0;box-shadow:none;z-index:1001}:root .chat-window{min-width:0;min-height:0;padding:0}:root .messages{padding:24px 4px 4px;font-size:13px;gap:8px}:root .bubble{font-size:13px;padding:8px 10px;border-radius:10px;margin-bottom:8px;word-break:break-word}:root .meta{font-size:11px;flex-direction:column;gap:2px}}@media (max-width: 600px){:root .app{grid-template-rows:48px 1fr}:root .topbar{padding:0 4px;gap:4px;font-size:14px}:root .sidebar{top:48px}:root .messages{padding:20px 2px 2px;font-size:12px;gap:6px}:root .bubble{font-size:12px;padding:6px 8px;border-radius:8px;margin-bottom:6px}:root .meta{font-size:10px;gap:1px}}@media (max-width: 900px){:root .media-viewer{max-width:100vw;max-height:80vh;padding:0}:root .media-viewer img,:root .media-viewer video,:root .media-viewer audio{max-width:100vw;max-height:80vh}:root .media-viewer-close{top:8px;right:8px;width:32px;height:32px;font-size:16px}:root .media-viewer-nav{bottom:8px;gap:10px}:root .media-viewer-nav button{width:32px;height:32px;font-size:18px}:root .media-viewer-nav .counter{font-size:12px}}.media-viewer-overlay{position:fixed;inset:0;z-index:50;background:#000000d9;display:grid;place-items:center}.media-viewer{max-width:92vw;max-height:88vh}.media-viewer img,.media-viewer video,.media-viewer audio{max-width:92vw;max-height:88vh}.media-viewer-close{position:fixed;top:12px;right:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;width:36px;height:36px;border-radius:999px}.media-viewer-nav{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:16px;align-items:center;color:#cfd8dc}.media-viewer-nav button{width:40px;height:40px;border-radius:10px;background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.2);font-size:22px}.media-viewer-nav .counter{font-size:14px;opacity:.85}.login-container{height:100vh;width:100%;background:linear-gradient(135deg,#d6f5e6,#bfe8d5);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;font-family:Inter,sans-serif}.circle{position:absolute;border-radius:50%;opacity:.2;filter:blur(80px)}.circle1{width:250px;height:250px;background:#9fd5b6;top:-80px;left:-80px}.circle2{width:350px;height:350px;background:#a8e0c0;bottom:-120px;right:-120px}.circle3{width:200px;height:200px;background:#7fcf9c;top:20%;left:70%}.circle4{width:180px;height:180px;background:#b3e6cf;bottom:25%;left:15%}.login-card{background:#fff;border-radius:20px;box-shadow:0 12px 40px #00000026;display:flex;overflow:hidden;width:850px;max-width:95%;min-height:450px;z-index:1}.login-left{flex:1;background:linear-gradient(135deg,#ccefe0,#b3e6cf);padding:40px;display:flex;flex-direction:column;justify-content:center;color:#1d3b2a}.login-left h1{font-size:2rem;margin-bottom:15px}.login-left p{font-size:1rem;line-height:1.6;opacity:.9}.login-right{flex:1;padding:40px;display:flex;flex-direction:column;justify-content:center}.login-right h2{font-size:1.5rem;margin-bottom:20px;color:#1d3b2a}.login-right input{width:100%;padding:12px 15px;margin-bottom:15px;border-radius:10px;border:1px solid #d3d3d3;font-size:1rem;outline:none}.login-right input:focus{border-color:#5cbf8a;box-shadow:0 0 5px #5cbf8a4d}.password-wrapper{position:relative;width:100%}.password-wrapper input{padding-right:40px;line-height:1.4}.eye-icon{position:absolute;right:12px;top:0;bottom:0;margin:auto;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center}.login-right button{width:100%;padding:12px;background:#5cbf8a;color:#fff;border:none;border-radius:10px;font-size:1rem;cursor:pointer;font-weight:600;margin-top:5px;transition:background .3s}.login-right button:disabled{opacity:.6;cursor:not-allowed}.login-right button:hover:not(:disabled){background:#4da876}.error{color:red;font-size:.9rem;margin-bottom:10px}.login-footer{position:absolute;bottom:15px;text-align:center;font-size:.85rem;color:#1d3b2a;width:100%}.login-footer a{color:#2d8055;text-decoration:none}.login-footer a:hover{text-decoration:underline}@media (max-width: 768px){.login-card{flex-direction:column;width:95%;min-height:auto}.login-left{padding:24px;text-align:center}.login-left h1{font-size:1.6rem}.login-left p{font-size:.95rem}.login-right{padding:24px}.login-right h2{font-size:1.3rem}.login-right input{font-size:.95rem;padding:10px 12px}.login-right button{padding:10px;font-size:.95rem}.circle{filter:blur(50px)}.circle1,.circle2,.circle3,.circle4{width:150px;height:150px}}@media (max-width: 480px){.login-left h1{font-size:1.3rem}.login-left p{font-size:.85rem}.login-right h2{font-size:1.1rem}.login-footer{font-size:.75rem;padding:0 10px}}
