:root{--color-bg:#0f0c29;--color-bg-mid:#302b63;--color-bg-end:#24243e;--color-surface:#ffffff0f;--color-surface-hover:#ffffff1a;--color-border:#ffffff1f;--color-text:#ffffffeb;--color-text-muted:#ffffff8c;--color-accent:#a78bfa;--color-accent-2:#f472b6;--color-accent-3:#34d399;--color-cta:#7c3aed;--color-cta-hover:#6d28d9;--radius:16px;--radius-sm:10px;--shadow:0 8px 32px #0006}.gradient-text{background:linear-gradient(90deg, var(--color-accent), var(--color-accent-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn-primary{background:linear-gradient(135deg, var(--color-cta), #9333ea);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:.85rem 2rem;font-size:1rem;font-weight:700;transition:opacity .2s,transform .15s;box-shadow:0 4px 20px #7c3aed66}.btn-primary:hover{opacity:.9;transform:translateY(-2px)}.btn-ghost{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:.85rem 2rem;font-size:1rem;font-weight:600;transition:background .2s,transform .15s}.btn-ghost:hover{background:var(--color-surface-hover);transform:translateY(-2px)}.section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);font-size:.8rem;font-weight:700}.section-title{letter-spacing:-.03em;text-align:center;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;line-height:1.2}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);transition:background .2s,transform .2s}.card:hover{background:var(--color-surface-hover);transform:translateY(-4px)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{min-width:320px;min-height:100vh;color:var(--color-text);background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-mid) 50%, var(--color-bg-end) 100%);background-attachment:fixed}#root{min-height:100vh}.welcome{flex-direction:column;min-height:100vh;display:flex}.welcome-nav{border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#0f0c2980;align-items:center;padding:1.25rem 2rem;display:flex;position:sticky;top:0}.welcome-nav-logo{letter-spacing:-.02em;font-size:1.3rem;font-weight:700}.welcome-hero{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:6rem 2rem 5rem;display:flex}.welcome-hero-badge{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-accent);letter-spacing:.02em;border-radius:999px;align-items:center;gap:.4rem;padding:.35rem 1rem;font-size:.82rem;font-weight:500;display:inline-flex}.welcome-hero-title{letter-spacing:-.03em;max-width:820px;font-size:clamp(2.6rem,6vw,4.2rem);font-weight:800;line-height:1.1}.welcome-hero-sub{color:var(--color-text-muted);max-width:560px;font-size:clamp(1rem,2.5vw,1.25rem);line-height:1.65}.welcome-problem{text-align:center;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:#00000040;padding:3rem 2rem}.welcome-problem p{color:var(--color-text-muted);max-width:680px;margin:0 auto;font-size:clamp(1.1rem,2.5vw,1.4rem);line-height:1.7}.welcome-problem p em{color:var(--color-accent-2);font-style:normal;font-weight:600}.welcome-features{flex-direction:column;align-items:center;gap:3rem;padding:5rem 2rem;display:flex}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;width:100%;max-width:1100px;display:grid}.feature-card{flex-direction:column;gap:1rem;padding:2rem;display:flex}.feature-icon{font-size:2.2rem;line-height:1}.feature-card h3{letter-spacing:-.01em;font-size:1.15rem;font-weight:700}.feature-card p{color:var(--color-text-muted);font-size:.95rem;line-height:1.65}.welcome-cta-banner{text-align:center;background:#7c3aed14;border-top:1px solid #7c3aed33;flex-direction:column;align-items:center;gap:1.5rem;padding:5rem 2rem;display:flex}.welcome-cta-banner h2{letter-spacing:-.03em;max-width:640px;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1.2}.welcome-cta-banner p{color:var(--color-text-muted);max-width:480px;font-size:1.05rem}.welcome-footer{text-align:center;border-top:1px solid var(--color-border);color:var(--color-text-muted);padding:2rem;font-size:.85rem}.nav-menu-wrapper{position:relative}.nav-menu-trigger{letter-spacing:.1em;padding:.5rem .85rem;font-size:1.4rem;line-height:1}.nav-menu-dropdown{background:var(--color-bg-mid);border:1px solid var(--color-border);border-radius:var(--radius-sm);min-width:160px;box-shadow:var(--shadow);z-index:100;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.nav-menu-item{width:100%;color:var(--color-text);text-align:left;cursor:pointer;background:0 0;border:none;padding:.75rem 1rem;font-size:.95rem;font-weight:500;transition:background .15s;display:block}.nav-menu-item:hover{background:var(--color-surface-hover)}.group-info-card{padding:1.5rem}.group-info-card .section-label{margin-bottom:1rem;display:block}.group-info-content{flex-direction:column;gap:1rem;display:flex}.info-item{justify-content:space-between;align-items:center;display:flex}.info-label{color:var(--color-text-muted);font-size:.9rem;font-weight:600}.info-value{color:var(--color-accent);font-size:1.1rem;font-weight:700}.info-members{flex-direction:column;gap:.5rem;display:flex}.members-list{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.member-name{color:var(--color-text);background:var(--color-surface);border-radius:var(--radius-sm);padding:.35rem .6rem;font-size:.95rem}.invite-toggle-btn{align-self:flex-start;padding:.4rem .9rem;font-size:.85rem}.invite-panel{padding:1.5rem}.invite-panel.card:hover{transform:none}.invite-panel .section-label{margin-bottom:1rem;display:block}.invite-form{flex-direction:column;gap:1rem;display:flex}.invite-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.75rem;font-size:1rem;transition:border-color .2s}.invite-input:focus{border-color:var(--color-accent);outline:none}.invite-input:disabled{opacity:.5;cursor:not-allowed}.invite-success{border:1px solid var(--color-accent-3);color:var(--color-accent-3);border-radius:var(--radius-sm);text-align:center;background:#34d3991a;padding:.75rem;font-size:.9rem}.invite-error{color:#ef4444;border-radius:var(--radius-sm);text-align:center;background:#ef44441a;border:1px solid #ef4444;padding:.75rem;font-size:.9rem}.chat-box{flex-direction:column;flex:1;padding:1.5rem;display:flex}.chat-box.card:hover{transform:none}.chat-box .section-label{margin-bottom:1rem;display:block}.chat-messages{border:1px solid var(--color-border);border-radius:var(--radius-sm);flex-direction:column;flex:1;gap:.5rem;min-height:400px;margin-bottom:1rem;padding:1rem;display:flex;overflow-y:auto}.chat-empty{color:var(--color-text-muted);text-align:center;padding:2rem 1rem}.message-wrapper{flex-direction:column;gap:.2rem;max-width:70%;display:flex}.message-other{align-self:flex-start}.message-own{align-self:flex-end}.message-sender{color:var(--color-accent);padding-left:.4rem;font-size:.8rem;font-weight:700}.message-bubble{border-radius:var(--radius-sm);flex-direction:column;gap:.25rem;padding:.75rem;display:flex}.message-other .message-bubble{background:var(--color-surface);border:1px solid var(--color-border)}.message-own .message-bubble{background:#a78bfa26;border:1px solid #a78bfa4d}.message-text{color:var(--color-text);word-wrap:break-word}.message-time{color:var(--color-text-muted);text-align:right;font-size:.75rem}.chat-input-row{gap:.75rem;display:flex}.chat-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);flex:1;padding:.75rem;font-size:1rem;transition:border-color .2s}.chat-input:focus{border-color:var(--color-accent);outline:none}.chat-input:disabled{opacity:.5;cursor:not-allowed}.update-dialog-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.update-dialog{width:90%;max-width:400px;padding:2rem}.update-dialog:hover{transform:none}.update-dialog .section-label{margin-bottom:1.5rem;display:block}.form-group input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);box-sizing:border-box;padding:.75rem;font-size:1rem;transition:border-color .2s}.form-actions{gap:1rem;display:flex}.form-actions button{flex:1}.edit-error{color:#ef4444;border-radius:var(--radius-sm);text-align:center;background:#ef44441a;border:1px solid #ef4444;margin-bottom:1.5rem;padding:.75rem;font-size:.9rem}.home-container{flex-direction:column;min-height:100vh;display:flex}.home-nav{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.home-logo{margin:0;font-size:1.5rem;font-weight:800}.home-body{flex:1;gap:2rem;padding:2rem;display:flex}.home-left{flex-direction:column;gap:1.5rem;width:360px;display:flex}.home-right{flex-direction:column;flex:1;display:flex}.loading{color:var(--color-text-muted);text-align:center;padding:2rem}@media (width<=768px){.home-body{flex-direction:column;gap:1rem}.home-left{width:100%}.home-nav{flex-direction:column;align-items:flex-start;gap:1rem}}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-content{text-align:center;max-width:400px}.login-content h1{margin-bottom:.5rem}.login-subtitle{color:var(--color-text-muted);margin-bottom:2rem;font-size:1.1rem}.login-button{width:100%;margin-top:2rem}.register-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.register-content{text-align:center;width:100%;max-width:400px}.register-content h1{margin-bottom:.5rem}.register-subtitle{color:var(--color-text-muted);margin-bottom:2rem;font-size:1.1rem}.register-form{flex-direction:column;gap:1.5rem;margin-top:2rem;display:flex}.form-group{text-align:left;flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:600}.form-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.75rem 1rem;font-size:1rem;transition:background .2s,border-color .2s}.form-input:focus{background:var(--color-surface-hover);border-color:var(--color-accent);outline:none}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-error{border-radius:var(--radius-sm);color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef44444d;padding:.75rem 1rem;font-size:.9rem}.register-button{width:100%;margin-top:.5rem}.register-button:disabled{opacity:.7;cursor:not-allowed}.invites-container{flex-direction:column;min-height:100vh;display:flex}.invites-nav{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.invites-logo{margin:0;font-size:1.5rem;font-weight:800}.invites-content{flex:1;width:100%;max-width:800px;margin:0 auto;padding:2rem}.invites-header{margin-bottom:2rem}.invites-error{color:#ef4444;border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef444433;margin-bottom:1.5rem;padding:1rem}.invites-loading{color:var(--color-text-muted);text-align:center;padding:2rem}.invites-section{margin-bottom:2rem}.invites-list{flex-direction:column;gap:1rem;display:flex}.invite-card{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.invite-header{justify-content:space-between;align-items:center;display:flex}.invite-group-name{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:600}.invite-meta{color:var(--color-text-muted);margin:0;font-size:.9rem}.invites-create{margin-top:2rem}.create-group-form{padding:2rem}.create-group-form h3{margin-top:0}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--color-text);margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.form-group input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;color:var(--color-text);padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input:focus{border-color:var(--color-primary);outline:none}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-actions{justify-content:flex-end;gap:1rem;display:flex}.create-group-empty{text-align:center;border:2px dashed var(--color-border);border-radius:var(--radius-sm);flex-direction:column;align-items:center;gap:1rem;padding:2rem;display:flex}.create-group-empty p{color:var(--color-text-muted);margin:0}
