*{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:light;--bg: #f7f7f8;--bg-alt: #f1f2f4;--surface: #ffffff;--card: #ffffff;--input-bg: #ffffff;--text: #101114;--text-muted: #686d76;--primary: #101114;--primary-hover: #2a2d33;--accent: #4f46e5;--border: #dedfe3;--border-strong: #c8cad0;--success: #15803d;--success-bg: #ecfdf3;--danger: #b42318;--danger-bg: #fff1f0;--warning: #a15c07;--warning-bg: #fff7ed;--shadow: 0 14px 35px rgba(16, 17, 20, .08);--shadow-soft: 0 8px 20px rgba(16, 17, 20, .06);--radius: 8px;--scrollbar: #c8cad0;--scrollbar-hover: #a9adb6}html,body,#root{width:100%;min-height:100%}body{background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}img{max-width:100%}a{color:inherit}::selection{background:#101114;color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}.loading-screen{min-height:100vh;display:grid;place-items:center;background:var(--bg)}.auth-container{min-height:100vh;display:grid;place-items:center;padding:32px 16px;background:linear-gradient(180deg,#ffffffb8,#f7f7f8f5),var(--bg)}.auth-box{width:min(100%,420px);color:var(--text);background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}.auth-box h2{margin:0 0 26px;color:var(--text);font-size:1.55rem;font-weight:750;letter-spacing:0;text-align:center}.auth-form{display:flex;flex-direction:column;gap:18px}.form-group label{color:var(--text);font-size:.9rem;font-weight:650}.form-group input,.form-group textarea{width:100%;padding:12px 13px;border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text);outline:none;font-size:.98rem;transition:border-color .18s ease,box-shadow .18s ease}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.button-submit,.btn-primary,.btn-cta{background:var(--primary);color:#fff;border:1px solid var(--primary)}.button-submit{min-height:46px;padding:12px 18px;border-radius:var(--radius);font-size:1rem;font-weight:700;cursor:pointer;transition:background .18s ease,transform .18s ease,opacity .18s ease}.button-submit:hover:not(:disabled),.btn-primary:hover,.btn-cta:hover{background:var(--primary-hover);transform:translateY(-1px)}.button-submit:disabled{opacity:.62;cursor:not-allowed}.button-link{width:fit-content;height:auto;padding:0;align-self:center;border:none;background:transparent;color:var(--primary);cursor:pointer;font:inherit;font-weight:700}.button-link:hover:not(:disabled),.link:hover{text-decoration:underline}.error-message,.success-message{padding:12px 14px;border-radius:var(--radius);font-size:.92rem;line-height:1.4}.otp-summary{color:var(--text-muted);font-size:.94rem;line-height:1.45;text-align:center}.otp-summary strong{color:var(--text)}.auth-link{margin:16px 0 0;color:var(--text-muted);font-size:.94rem;text-align:center}.link{color:var(--primary);font-weight:700;text-decoration:none}.auth-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text)}.navbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 40px;background:#ffffffe6;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.navbar-brand{color:var(--text);font-size:1.35rem;font-weight:800}.navbar-menu{display:flex;align-items:center;gap:12px}.navbar-menu a{color:var(--text-muted);font-size:.94rem;font-weight:650;text-decoration:none}.navbar-menu a:hover{color:var(--text)}.btn-primary,.btn-secondary,.btn-cta{min-height:40px;padding:9px 16px;border-radius:var(--radius);cursor:pointer;font-size:.94rem;font-weight:700;transition:background .18s ease,border-color .18s ease,transform .18s ease}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);transform:translateY(-1px)}.hero-section{flex:1;display:flex;align-items:center;padding:56px 40px}.hero-content{width:min(100%,1180px);margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.8fr);gap:56px;align-items:center}.hero-text h1{margin:0 0 18px;color:var(--text);font-size:clamp(2.2rem,5vw,4.4rem);line-height:1.02;letter-spacing:0;font-weight:850}.hero-subtitle{max-width:560px;margin:0 0 34px;color:var(--text-muted);font-size:1.15rem;line-height:1.6}.features-list{display:grid;gap:16px;margin-bottom:28px}.feature-item{display:flex;gap:14px;align-items:flex-start}.feature-icon{width:34px;height:34px;flex:0 0 auto;color:var(--primary)}.feature-item strong{display:block;margin-bottom:3px;color:var(--text);font-size:1rem}.feature-item p{margin:0;color:var(--text-muted);line-height:1.5}.btn-cta{min-height:46px;padding-inline:22px}.hero-image{display:flex;align-items:center;justify-content:center}.hero-image img{width:min(100%,440px);height:auto;object-fit:contain}@media(max-width:820px){.navbar{padding:14px 18px;align-items:flex-start;flex-direction:column}.navbar-menu{width:100%;flex-wrap:wrap}.hero-section{padding:34px 18px}.hero-content{grid-template-columns:1fr;gap:32px}.hero-image{order:-1}}@media(max-width:520px){.auth-container{align-items:start;padding:18px 12px}.auth-box{padding:24px 18px}.auth-box h2{font-size:1.35rem}.btn-primary,.btn-secondary,.btn-cta,.button-submit{width:100%}}.rooms-page{min-height:100vh;padding:24px;background:var(--bg)}.rooms-header{position:sticky;top:16px;z-index:15;width:min(100%,1180px);margin:0 auto 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px;background:#fffffff0;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.rooms-header-left,.new-div{display:flex;align-items:center;gap:12px}.new-div{flex:1;justify-content:flex-end}.Chat-Rooms{color:var(--text);font-size:1.35rem;font-weight:850}.home-button{width:40px;height:40px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:1.1rem;font-weight:800}.home-button:hover{border-color:var(--primary)}.rooms-search{width:min(100%,420px)}.search-input{width:100%;min-height:42px;padding:10px 13px;border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text);outline:none}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #10111414}.button-create-room,.button-primary,.button-secondary,.button-pending,.button-rejected{min-height:42px;padding:10px 16px;border-radius:var(--radius);font-size:.94rem;font-weight:750;cursor:pointer}.button-create-room,.button-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.button-create-room:hover,.button-primary:hover{background:var(--primary-hover)}.button-pending{background:var(--warning-bg);color:var(--warning);border:1px solid #fed7aa;cursor:not-allowed}.button-rejected{background:var(--danger-bg);color:var(--danger);border:1px solid #ffcdc7;cursor:not-allowed}.rooms-grid{width:min(100%,1180px);margin:0 auto 40px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.room-card{min-width:0;display:flex;flex-direction:column;gap:14px;padding:20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.room-card:hover{border-color:var(--border-strong)}.room-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.room-card-header h3{min-width:0;color:var(--text);font-size:1.08rem;font-weight:850;overflow-wrap:anywhere}.room-card-badges,.room-members-preview{display:flex;flex-wrap:wrap;gap:7px;align-items:center}.room-members,.pending-requests-badge,.member-badge,.room-owner{width:fit-content;padding:5px 9px;border-radius:999px;font-size:.78rem;font-weight:750}.room-members,.member-badge,.room-owner{background:var(--bg-alt);color:var(--text);border:1px solid var(--border)}.pending-requests-badge{background:var(--danger-bg);color:var(--danger);border:1px solid #ffcdc7}.room-description{min-height:44px;color:var(--text-muted);font-size:.93rem;line-height:1.5}.room-info{display:grid;gap:8px;padding-block:12px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);color:var(--text-muted)}.room-user{color:var(--text)}.room-created{font-size:.82rem}.members-label{color:var(--text-muted);font-size:.82rem;font-weight:750}.open-chat,.side-btn,.button-pending,.button-rejected{width:100%;margin-top:auto}.success-message,.error-message{position:fixed;top:88px;right:24px;z-index:100;max-width:min(420px,calc(100vw - 32px));padding:12px 14px;border-radius:var(--radius);box-shadow:var(--shadow)}.success-message{background:var(--success-bg);color:var(--success);border:1px solid #b7efca}.error-message{background:var(--danger-bg);color:var(--danger);border:1px solid #ffcdc7}.empty-state,.loading-container{width:min(100%,1180px);margin:0 auto;display:grid;place-items:center;gap:16px;min-height:320px;padding:40px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted)}@media(max-width:980px){.rooms-header{align-items:stretch;flex-direction:column}.new-div,.rooms-search{width:100%}.rooms-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:620px){.rooms-page{padding:14px}.rooms-header{top:8px}.new-div{flex-direction:column}.button-create-room{width:100%}.rooms-grid{grid-template-columns:1fr}}.request-toggle-btn{position:absolute;top:88px;left:24px;z-index:30;display:flex;align-items:center;gap:8px;min-height:40px;padding:9px 14px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-weight:750;box-shadow:var(--shadow-soft)}.request-toggle-btn:hover{border-color:var(--primary)}.badge{min-width:20px;height:20px;display:grid;place-items:center;padding:0 6px;background:var(--danger);color:#fff;border-radius:999px;font-size:.72rem;font-weight:800}.requests-panel{position:absolute;top:136px;left:24px;z-index:40;width:min(440px,calc(100vw - 48px));padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.requests-panel h3{margin:0 0 14px;padding-bottom:12px;color:var(--text);border-bottom:1px solid var(--border);font-size:1rem;font-weight:850}.no-requests{padding:18px;color:var(--text-muted);text-align:center}.requests-list{max-height:360px;overflow-y:auto;display:grid;gap:10px}.request-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.request-info{min-width:0}.request-info h4{margin:0 0 4px;color:var(--text);font-size:.94rem;font-weight:800}.request-email,.request-time{margin:0;color:var(--text-muted);font-size:.8rem;overflow-wrap:anywhere}.request-actions{display:flex;gap:8px;flex-shrink:0}.btn-approve,.btn-reject{min-height:34px;padding:7px 10px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;font-size:.8rem;font-weight:800}.btn-approve{background:var(--success);color:#fff}.btn-reject{background:var(--danger-bg);color:var(--danger);border-color:#ffcdc7}@media(max-width:560px){.request-toggle-btn,.requests-panel{left:12px;right:12px;width:calc(100vw - 24px)}.request-card{align-items:stretch;flex-direction:column}.request-actions{width:100%}.btn-approve,.btn-reject{flex:1}}.chat-room-page{height:100vh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.chat-header{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-soft);flex-shrink:0}.chat-header-left{min-width:0;display:flex;align-items:center;gap:14px}.button-back,.button-leave,.button-send,.button-primary{min-height:40px;padding:9px 15px;border-radius:var(--radius);cursor:pointer;font-weight:750;transition:background .18s ease,border-color .18s ease}.button-back,.button-leave{background:var(--surface);color:var(--text);border:1px solid var(--border)}.button-back:hover{border-color:var(--primary)}.button-leave{color:var(--danger);border-color:#f2b8b5}.button-leave:hover{background:var(--danger-bg)}.chat-info{min-width:0}.chat-info h2{margin:0;color:var(--text);font-size:1.15rem;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-members-count{display:block;margin-top:3px;color:var(--text-muted);font-size:.84rem}.chat-container{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 280px}.messages-area{min-width:0;display:flex;flex-direction:column;background:var(--bg)}.notification{padding:10px 16px;background:#eef2ff;color:#3730a3;border-bottom:1px solid #dbe3ff;text-align:center;font-size:.9rem}.messages-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:24px}.message{display:flex}.own-message{justify-content:flex-end}.message-content{max-width:min(680px,72%);padding:11px 13px;border-radius:14px;box-shadow:var(--shadow-soft)}.own-message .message-content{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.other-message .message-content{background:var(--surface);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.message-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:5px;font-size:.78rem}.message-header strong{font-weight:800}.message-header small{opacity:.7}.message-text{margin:0;font-size:.98rem;line-height:1.5;overflow-wrap:anywhere}.empty-messages,.loading-container,.error-container{flex:1;display:grid;place-items:center;padding:32px;color:var(--text-muted);text-align:center}.members-sidebar{min-width:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column}.members-sidebar h3{margin:0;padding:17px 18px;color:var(--text);border-bottom:1px solid var(--border);font-size:.98rem;font-weight:850}.members-list{min-height:0;overflow-y:auto;padding:10px}.member-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius)}.member-item:hover{background:var(--bg-alt)}.member-avatar{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:var(--primary);color:#fff;font-size:.9rem;font-weight:800;flex:0 0 auto}.member-info{min-width:0}.member-name{display:block;color:var(--text);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.owner-badge{display:inline-block;margin-top:3px;padding:2px 6px;border-radius:999px;background:var(--bg-alt);color:var(--text-muted);font-size:.72rem;font-weight:750}.chat-footer{padding:14px 24px;background:var(--surface);border-top:1px solid var(--border)}.message-form{display:flex;gap:10px;width:100%}.message-form input{flex:1;min-width:0;min-height:44px;padding:10px 13px;border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text);outline:none}.message-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #10111414}.button-send,.button-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.button-send:hover:not(:disabled),.button-primary:hover{background:var(--primary-hover)}.button-send:disabled{opacity:.55;cursor:not-allowed}.error-message{padding:10px 12px;background:var(--danger-bg);color:var(--danger);border:1px solid #ffcdc7;border-radius:var(--radius);font-size:.9rem}.spinner{width:38px;height:38px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:999px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:760px){.chat-header{align-items:flex-start;flex-direction:column;padding:12px 14px}.chat-header-left,.button-leave{width:100%}.chat-container{grid-template-columns:1fr}.members-sidebar{display:none}.messages-list{padding:14px}.message-content{max-width:86%}.chat-footer{padding:10px}}@media(max-width:460px){.message-form{flex-direction:column}.button-send{width:100%}}.create-room-page{min-height:100vh;display:grid;place-items:center;padding:72px 16px 32px;background:var(--bg);position:relative}.back-button{position:absolute;top:22px;left:22px;min-height:40px;padding:9px 15px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-weight:750}.back-button:hover{border-color:var(--primary)}.create-room-container{width:min(100%,520px);padding:32px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);color:var(--text)}.create-room-container h2{margin:0 0 26px;color:var(--text);font-size:1.55rem;font-weight:850;text-align:center}.create-room-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--text);font-size:.9rem;font-weight:750}.form-group input[type=text],.form-group input[type=number],.form-group textarea{width:100%;padding:12px 13px;border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text);outline:none;font-size:.98rem}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #10111414}.form-group textarea{min-height:110px;resize:vertical}.form-group small{color:var(--text-muted);font-size:.84rem}.form-actions{display:flex;gap:12px;margin-top:6px}.button-primary,.button-secondary{flex:1;min-height:44px;padding:10px 16px;border-radius:var(--radius);cursor:pointer;font-size:.96rem;font-weight:750}.button-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.button-primary:hover:not(:disabled){background:var(--primary-hover)}.button-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.button-secondary:hover:not(:disabled){border-color:var(--primary)}.button-primary:disabled,.button-secondary:disabled{opacity:.58;cursor:not-allowed}.error-message{padding:12px 14px;background:var(--danger-bg);color:var(--danger);border:1px solid #ffcdc7;border-radius:var(--radius);font-size:.92rem}@media(max-width:520px){.create-room-page{align-items:start;padding:78px 12px 20px}.back-button{left:12px;right:12px;width:calc(100% - 24px)}.create-room-container{padding:24px 18px}.form-actions{flex-direction:column}}.home-shell{min-height:100vh;background:var(--bg)}.home-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 40px;background:#ffffffeb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.home-header h2{margin-top:4px;color:var(--text);font-size:1.55rem;font-weight:800}.tagline{display:block;color:var(--text-muted);font-size:.78rem;font-weight:750;letter-spacing:.08em;text-transform:uppercase}.header-buttons,.dashboard-actions{display:flex;align-items:center;gap:12px}.button-primary,.button-secondary,.action-btn{min-height:42px;padding:10px 18px;border-radius:var(--radius);cursor:pointer;font-size:.95rem;font-weight:750;transition:background .18s ease,border-color .18s ease,transform .18s ease}.button-primary,.action-btn.primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.button-primary:hover,.action-btn.primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.button-secondary,.action-btn.secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.button-secondary:hover,.action-btn.secondary:hover{border-color:var(--primary);transform:translateY(-1px)}.logout{color:var(--danger);border-color:#f2b8b5}.dashboard-content{width:min(100%,1180px);margin:0 auto;padding:56px 32px}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,420px);gap:54px;align-items:center;margin-bottom:38px}.dashboard-text h1{margin:0 0 18px;color:var(--text);font-size:clamp(2rem,5vw,3.8rem);line-height:1.04;font-weight:850;letter-spacing:0}.dashboard-intro{max-width:660px;margin:0 0 28px;color:var(--text-muted);font-size:1.08rem;line-height:1.65}.dashboard-features{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:26px}.feature-block{min-width:0;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.feature-block h3{margin:0 0 7px;color:var(--text);font-size:.98rem;font-weight:800}.feature-block p{margin:0;color:var(--text-muted);font-size:.9rem;line-height:1.45}.dashboard-image{display:flex;justify-content:center}.dashboard-image img{width:min(100%,390px);height:auto;object-fit:contain}.user-info-section{width:100%}.user-card{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-soft)}.user-card h2{margin:0 0 18px;color:var(--text);font-size:1.2rem;font-weight:800}.user-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.detail-item{min-width:0;padding:15px;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius)}.label{display:block;margin-bottom:5px;color:var(--text-muted);font-size:.8rem;font-weight:750;text-transform:uppercase;letter-spacing:.04em}.value{display:block;color:var(--text);font-weight:750;overflow-wrap:anywhere}.loading-container{min-height:60vh;display:grid;place-items:center;color:var(--text-muted)}@media(max-width:920px){.home-header{padding:16px 22px}.dashboard-content{padding:36px 18px}.dashboard-hero{grid-template-columns:1fr;gap:30px}.dashboard-image{order:-1}.dashboard-features{grid-template-columns:1fr}}@media(max-width:560px){.home-header{align-items:flex-start;flex-direction:column}.header-buttons,.dashboard-actions{width:100%;flex-direction:column}.button-primary,.button-secondary,.action-btn{width:100%}.user-details{grid-template-columns:1fr}}
