:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--border-color:#475569;--accent-primary:#3b82f6;--accent-secondary:#06b6d4;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}[data-theme=light]{--bg-primary:#f9fafb;--bg-secondary:#f3f4f6;--bg-tertiary:#e5e7eb;--text-primary:#1f2937;--text-secondary:#4b5563;--text-muted:#6b7280;--border-color:#d1d5db;--accent-primary:#2563eb;--accent-secondary:#0891b2;--success:#059669;--warning:#d97706;--error:#dc2626;--shadow-sm:0 1px 2px 0 #00000014;--shadow-md:0 4px 6px -1px #0000001f;--shadow-lg:0 10px 15px -3px #00000026}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#0f172a;color:#f1f5f9;padding:0}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#1e293b;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#475569;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--text-muted)}.cursor-pointer{cursor:pointer}.transition-all{transition:all .3s ease}@media (max-width:359px){html{font-size:14px}}@media (min-width:360px) and (max-width:480px){html{font-size:14px}}@media (min-width:481px) and (max-width:768px){html{font-size:15px}}@media (min-width:769px) and (max-width:1024px){html{font-size:16px}}@media (min-width:1025px){html{font-size:16px}}*,:after,:before{box-sizing:border-box}#root,body,html{height:100%}body,html{margin:0;padding:0}canvas,img,picture,svg,video{display:block;max-width:100%}button,input,select,textarea{font:inherit}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;white-space:nowrap;width:1px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;display:flex;justify-content:center;margin:auto;max-width:1200px;min-height:100vh;padding:clamp(.5rem,2vw,2rem);position:relative;width:100%}.login-box{animation:fadeIn 1.2s ease-in-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:clamp(12px,2vw,24px);box-shadow:var(--shadow-lg);max-width:clamp(280px,90vw,450px);padding:clamp(1rem,3vw,2.5rem);text-align:center;transition:background-color .3s ease,box-shadow .3s ease;width:100%}.site-title{color:var(--accent-primary);font-size:clamp(1.4rem,4vw,2.5rem);margin-bottom:.5rem}.city-info,.site-title{transition:color .3s ease}.city-info{color:var(--text-muted);font-size:clamp(.75rem,2vw,1rem);margin-bottom:1rem}.subtitle{color:var(--text-secondary);font-size:clamp(.8rem,1.8vw,1rem);font-style:italic;margin-bottom:1.25rem;transition:color .3s ease}.tab-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;display:flex;margin-bottom:1.5rem;overflow:hidden}.tab-button{background:#0000;border:none;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:clamp(.85rem,1.8vw,1rem);font-weight:500;padding:clamp(10px,2vw,14px);transition:background-color .3s ease,color .3s ease}.tab-button.active{background:var(--accent-primary);color:#fff}.tab-button:hover:not(.active){background:var(--bg-secondary);color:var(--text-primary)}form{display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.4rem)}input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;box-sizing:border-box;color:var(--text-primary);font-size:clamp(.8rem,1.8vw,.95rem);padding:clamp(10px,2.5vw,14px);transition:box-shadow .25s,background .25s,border-color .25s;width:100%}input::placeholder{color:var(--text-muted)}input:focus-visible{background:var(--bg-secondary);border-color:var(--accent-primary);box-shadow:0 0 10px var(--accent-primary);outline:none}button[type=submit]{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:clamp(.9rem,2vw,1.1rem);font-weight:600;padding:clamp(11px,2.5vw,14px);transform-origin:center;transition:transform .2s,box-shadow .3s,opacity .2s;width:100%}button[type=submit]:hover:not(:disabled){box-shadow:0 0 15px #3b82f680;transform:scale(1.02)}button[type=submit]:active:not(:disabled){transform:scale(.98)}button[type=submit]:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#ef44441a;border-left:3px solid var(--error);border-radius:8px;color:var(--error);font-size:clamp(.75rem,1.8vw,.9rem);margin-top:1rem;padding:clamp(.5rem,1vw,.75rem);text-align:left;transition:background-color .3s ease,color .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:359px){.login-box{border-radius:12px;max-width:95vw;padding:1rem}.site-title{font-size:1.2rem}form{gap:.9rem}button[type=submit],input{padding:10px}}@media (min-width:360px) and (max-width:480px){.login-box{max-width:95vw;padding:1.2rem}form{gap:1rem}}@media (min-width:481px) and (max-width:768px){.login-box{max-width:85vw}}@media (min-width:769px) and (max-width:1024px){.login-box{max-width:450px}}@media (min-width:1025px){.login-box{max-width:500px}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:linear-gradient(#0206178c,#0206178c);inset:0;z-index:9999}.modal-card{animation:modalFade .18s ease-out;background:#fff;background:var(--card-bg,#fff);border-radius:12px;box-shadow:0 14px 40px #02061773;color:#000;color:var(--app-foreground,#000);max-width:820px;min-width:320px;padding:18px;position:relative}.startup-modal .modal-header{align-items:center;border-bottom:1px solid #0b1e3d0f;display:flex;justify-content:space-between;padding-bottom:8px}.modal-title{color:#0b1e3d;color:var(--app-accent,#0b1e3d);font-size:1.1rem;font-weight:700}.modal-close{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:18px;padding:6px}.modal-close:hover{background:#0000000f}.modal-body{color:#0b1e3d;color:var(--app-foreground,#0b1e3d);font-size:.98rem;line-height:1.45;max-height:56vh;overflow:auto;padding:14px 6px}.modal-footer{border-top:1px solid #0b1e3d0a;display:flex;gap:10px;justify-content:flex-end;padding-top:12px}.btn{border-radius:8px;font-weight:600;padding:.55rem .9rem}.btn-primary{background:linear-gradient(90deg,var(--accent-primary),#0000000f);color:var(--text-primary)}.btn-primary:hover{opacity:.95}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary)}@keyframes modalFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.upload-btn{background:var(--accent-primary);border:none;border-radius:8px;color:var(--text-primary);font-size:1rem;font-weight:600;padding:.6rem 0;width:140px}.upload-btn:hover{background:#0000000f}.dashboard-container{background:var(--bg-primary);color:var(--text-primary);display:flex;font-family:Inter,sans-serif;height:100vh;overflow:hidden;transition:background-color .3s ease,color .3s ease;width:100vw}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);color:var(--text-secondary);display:flex;flex-direction:column;justify-content:space-between;padding:clamp(1rem,2vw,1.5rem);transition:transform .3s ease-in-out,background-color .3s ease;width:clamp(200px,20vw,260px);z-index:100}.sidebar.closed{height:100%;left:0;position:absolute;top:0;transform:translateX(-100%)}.sidebar .logo{color:var(--accent-primary);font-size:clamp(1.2rem,2vw,1.6rem);font-weight:700;margin-bottom:2rem;text-align:center;transition:color .3s ease}.sidebar nav{display:flex;flex-direction:column;gap:1rem}.sidebar button{align-items:center;background:#0000;border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:clamp(.85rem,1.5vw,1rem);gap:.75rem;overflow:hidden;padding:clamp(.5rem,1vw,.8rem) clamp(.75rem,1.5vw,1rem);text-overflow:ellipsis;transition:background .3s,color .3s;white-space:nowrap}.sidebar button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-footer{margin-top:2rem;text-align:center}.main-content{background:var(--bg-primary);display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:clamp(.75rem,1.5vw,2rem);transition:background-color .3s ease}.topbar{align-items:center;display:flex;flex-wrap:wrap;gap:clamp(.5rem,1vw,1rem);justify-content:space-between;margin-bottom:clamp(1rem,2vw,1.5rem);position:relative}.topbar h1{color:var(--text-primary);font-size:clamp(1.1rem,2.5vw,2rem);font-weight:700;margin-bottom:.3rem;transition:color .3s ease}.topbar .highlight{color:var(--accent-primary)}.topbar .city{color:var(--text-muted);font-size:clamp(.75rem,1.5vw,1rem);transition:color .3s ease}.hamburger{background:#0000;border:none;box-shadow:none;color:var(--text-primary);cursor:pointer;display:none;font-weight:400;padding:.3rem;transition:transform .3s,color .3s ease;z-index:150}.hamburger:hover{color:var(--accent-primary)}.hamburger.active{transform:rotate(90deg)}@media (max-width:1024px){.hamburger{display:block;left:clamp(.75rem,1.5vw,1rem);position:fixed;top:clamp(.75rem,1.5vw,1rem);z-index:9999}}.widgets{grid-gap:clamp(.6rem,1.5vw,1.5rem);display:grid;gap:clamp(.6rem,1.5vw,1.5rem);grid-template-columns:repeat(auto-fit,minmax(clamp(150px,40vw,200px),1fr));margin-top:1rem;width:100%}.widget{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:clamp(.8rem,1.5vw,1.5rem);transition:transform .2s,background .3s,box-shadow .3s}.widget:hover{background:var(--bg-tertiary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.widget h3{color:var(--text-primary);font-size:clamp(.9rem,2vw,1.2rem);font-weight:600}.widget h3,.widget p{margin:0;transition:color .3s ease}.widget p{color:var(--text-secondary);font-size:clamp(.7rem,1.2vw,.9rem);line-height:1.3}.widget.disabled{cursor:not-allowed;opacity:.6}@media (max-width:359px){.sidebar{padding:.75rem;width:160px}.sidebar .logo{font-size:1rem;margin-bottom:1.5rem}.sidebar button{font-size:.75rem;padding:.4rem .5rem}.topbar h1{font-size:.95rem}.topbar{padding-left:clamp(3rem,18vw,4rem)}.topbar .city{font-size:.7rem}.widgets{grid-template-columns:1fr}}@media (min-width:360px) and (max-width:480px){.sidebar{padding:1rem .75rem;width:180px}.sidebar .logo{font-size:1.1rem;margin-bottom:1.5rem}.sidebar button{font-size:.85rem;padding:.5rem .75rem}.topbar h1{font-size:1rem}.topbar{padding-left:clamp(3rem,15vw,4rem)}.topbar .city{font-size:.75rem}.widgets{grid-template-columns:1fr}.widget{padding:1rem}.widget h3{font-size:.95rem}.widget p{font-size:.8rem}}@media (min-width:481px) and (max-width:768px){.sidebar{width:200px}.topbar h1{font-size:1.3rem}.widgets{grid-template-columns:repeat(2,1fr)}}@media (min-width:769px) and (max-width:1024px){.widgets{grid-template-columns:repeat(2,1fr)}.hamburger{display:none!important}.sidebar{display:flex}.sidebar.closed{position:relative;transform:translateX(0)}}@media (min-width:1025px){.hamburger{display:none!important}.sidebar{display:flex}.sidebar.closed{position:relative;transform:translateX(0)}.widgets{grid-template-columns:repeat(3,1fr)}}:root{--chat-title-color:#000;--chat-bg:#fff;--chat-text:#000;--bot-bubble-bg:#fff;--bot-text:#111827;--user-bubble-bg:#2563eb;--user-text:#000;--chat-input-bg:#fff;--chat-input-text:#000;--chat-input-placeholder:#9ca3af}.chatbot-container{background:var(--app-gradient);border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;font-family:Segoe UI,Helvetica Neue,sans-serif;height:100%;overflow:hidden}.chat-header{background:var(--app-gradient);border-bottom:2px solid #ffffff14;padding:12px 16px}.chat-header,.chat-header button,.chat-header select{color:#000;color:var(--chat-title-color)}.header-top{align-items:center;display:flex;gap:12px;justify-content:space-between}.header-left{width:36px}.header-center{flex:1 1;text-align:center}.header-center .chat-title{align-items:center;display:inline-flex;font-size:20px;font-weight:600;gap:8px;margin:0}.header-right{align-items:center;display:flex;gap:8px}.chat-title{font-size:20px;font-weight:600}.chat-subtitle{font-size:13px;margin-top:6px;opacity:.9}.chat-input::placeholder{opacity:.9}.chat-messages .message-bubble.bot{color:#111827;color:var(--bot-text)}.chat-messages{background:#fff;background:var(--chat-bg);color:#000;color:var(--chat-text);display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:20px 20px 120px}.message-row{display:flex;gap:8px}.message-row.user{justify-content:flex-end}.message-row.bot{justify-content:flex-start}.message-bubble{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid #ffffff08;border-radius:18px;box-shadow:none;line-height:1.4;max-width:70%;padding:12px 16px}.message-bubble.user{background:#2563eb;background:var(--user-bubble-bg);color:#000;color:var(--user-text)}.message-bubble.bot{background:#fff;background:var(--bot-bubble-bg);border:1px solid #ffffff0a;color:#111827;color:var(--bot-text)}.typing-indicator{display:flex;gap:6px;padding:8px}.typing-indicator span{animation:blink 1.4s infinite both;background:var(--app-primary);border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}.chat-input-area{border-top:1px solid #00000014;bottom:0;box-shadow:0 -6px 20px #0000000f;left:0;padding:12px 16px;position:fixed;width:100%;z-index:50}.chat-input-area,.input-controls{background:#fff;background:var(--chat-input-bg)}.input-controls{align-items:center;border-radius:28px;box-shadow:0 2px 10px #0000000f;display:flex;gap:8px;margin:0 auto;max-width:980px;padding:6px;width:calc(100% - 32px)}.chat-input{min-width:0}.chat-input::placeholder{color:#9ca3af;color:var(--chat-input-placeholder)}.voice-btn{align-items:center;display:inline-flex;justify-content:center}.send-btn,.voice-btn{height:40px;width:40px}@media (max-width:600px){.input-controls{border-radius:20px;gap:6px;padding:6px;width:calc(100% - 20px)}.send-btn,.voice-btn{height:36px;width:36px}.chat-input{font-size:13px;padding:8px 10px}.chat-input-area{padding:10px}}.chat-input{border:none;flex:1 1;font-size:14px;outline:none;padding:10px 12px}.chat-input,.voice-btn{background:#0000;color:#000;color:var(--chat-input-text)}.voice-btn{border:none;border-radius:50%;cursor:pointer;height:38px;width:38px}.voice-btn.active{animation:pulse 1s infinite;background:var(--app-primary);color:#fff}@keyframes pulse{0%{box-shadow:0 0 0 3px #667eea4d}to{box-shadow:0 0 0 8px #667eea00}}.send-btn{background:#0000;border:none;border-radius:50%;color:#000;color:var(--chat-input-text);cursor:pointer;height:38px;width:38px}.send-btn:disabled{cursor:not-allowed;opacity:.4}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:var(--app-primary);border-radius:3px}@media (max-width:600px){.message-bubble{max-width:85%}.chat-title{font-size:18px}}.btn-danger{background:var(--danger);border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 12px}.retry-btn{background:#0000;border:1px solid var(--danger);border-radius:6px;color:var(--danger);cursor:pointer;font-size:12px;margin-left:8px;padding:4px 8px}.retry-btn:hover{background:#e74c3c0f}.chat-input::placeholder{color:var(--placeholder)}.profile-container{align-items:center;background:var(--bg-primary);box-sizing:border-box;color:var(--text-primary);display:flex;flex-direction:column;justify-content:flex-start;margin:0;min-height:100vh;overflow-x:hidden;padding:0;width:100vw}.muted-text{color:var(--muted-text)}.small-text{font-size:.85rem}.profile-topbar{align-items:center;background:#0000;box-sizing:border-box;display:flex;justify-content:space-between;max-width:100%;padding:1.2rem 2rem .5rem;position:relative;width:100vw;z-index:2}.back-btn{background:var(--accent-primary);box-shadow:0 2px 8px #0000000f;font-weight:600;padding:.5rem 1.1rem;transition:background .2s,color .2s}.back-btn:focus,.back-btn:hover{background:var(--hover-bg);color:var(--hover-text);outline:none}.profile-app-title{color:var(--accent-primary);font-size:1.5rem;font-weight:700;letter-spacing:1px;text-shadow:0 2px 8px #00000014}.profile-card{align-items:center;background:var(--bg-secondary);border-radius:20px;box-shadow:0 8px 25px #00000059;display:flex;flex-direction:column;margin:2.5rem auto 0;max-width:480px;padding:2rem 1.5rem;text-align:center;width:100%}@media (max-width:600px){.profile-card{max-width:98vw;padding:1rem .5rem}}.profile-header{align-items:center;display:flex;flex-direction:column;gap:.6rem;justify-content:flex-start;margin-bottom:1rem;margin-top:0;width:100%}.profile-pic{align-self:center;background:var(--bg-primary);border:3px solid var(--accent-primary);border-radius:50%;box-shadow:0 2px 12px #00000014;height:120px;margin-bottom:.5rem;margin-top:0;object-fit:cover;position:relative;top:0;width:120px}.username{font-size:1.3rem;font-weight:700}.user-id{font-size:.9rem}.user-city,.user-id{color:var(--muted-text)}.user-city{font-size:.95rem;margin-bottom:.5rem}.profile-mood{margin:1.5rem 0 1rem;text-align:left;width:100%}.profile-mood h3{color:var(--accent-primary);font-size:1.1rem;margin-bottom:.5rem}.mood-bar{align-items:center;display:flex;margin-bottom:.4rem}.mood-bar span{font-size:.98rem;width:70px}.bar{background:var(--bg-primary);flex:1 1;height:12px;margin-left:10px;overflow:hidden}.bar,.fill{border-radius:8px}.fill{background:linear-gradient(90deg,var(--accent-primary),var(--mood-mid));height:100%;transition:width .4s}.profile-actions{display:flex;flex-direction:column;gap:.7rem;margin:1.2rem 0 1.5rem;width:100%}.profile-actions button{background:var(--accent-primary);border:none;border-radius:8px;box-shadow:0 2px 8px #0000000f;color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:600;padding:.7rem 0;transition:background .2s,color .2s,box-shadow .2s;width:100%}.profile-actions button:focus,.profile-actions button:hover{background:var(--hover-bg);color:var(--hover-text);outline:none}.edit-section{display:flex;flex-direction:column;gap:.7rem;margin-top:1.2rem;text-align:left;width:100%}.edit-section label{color:var(--text-secondary);font-size:.97rem;margin-bottom:.1rem}.edit-section input,.edit-section textarea{background:var(--input-bg);border:1px solid var(--accent-primary);border-radius:7px;color:var(--input-text);font-size:1rem;margin-bottom:.2rem;padding:.5rem .7rem;transition:border .2s;width:100%}.edit-section input:focus,.edit-section textarea:focus{border:1.5px solid var(--hover-bg);outline:none}.edit-btn,.save-btn{background:var(--hover-bg);border:none;border-radius:8px;color:var(--hover-text);cursor:pointer;font-size:1rem;font-weight:600;margin-top:.7rem;padding:.6rem 0;transition:background .2s,color .2s;width:100%}.edit-btn:focus,.edit-btn:hover,.save-btn:focus,.save-btn:hover{background:var(--accent-primary);color:var(--text-primary);outline:none}.profile-details{font-size:1rem;margin-top:1.2rem;text-align:left;width:100%}.profile-details p{margin:.3rem 0}.upload-btn{background:var(--bg-secondary);border-radius:6px;color:var(--accent-primary);cursor:pointer;display:inline-block;font-size:.95rem;margin-top:.5rem;padding:.3rem .8rem;transition:background .2s,color .2s}.upload-btn input[type=file]{display:none}.upload-btn:focus,.upload-btn:hover{background:var(--accent-primary);color:var(--text-primary);outline:none}.profile-divider{background:linear-gradient(90deg,var(--accent-primary) 0,var(--mood-mid) 100%);border-radius:2px;height:1.5px;margin:1.2rem 0 1rem;width:100%}@media (max-width:600px){.profile-card{max-width:98vw;padding:1rem .5rem}.profile-pic{height:80px;width:80px}}@media (min-width:601px) and (max-width:900px){.profile-card{max-width:600px}.profile-pic{height:110px;width:110px}}@media (min-width:901px){.profile-card{max-width:700px}.profile-pic{height:140px;width:140px}}.mood-tracker-container{align-items:center;background:#fff;box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-y:auto;padding:1.2rem;width:100vw}.mood-tracker-title{color:#1e293b;font-size:1.6rem;font-weight:700;margin-bottom:.4rem;text-align:center}.mood-tracker-subtitle{color:#475569;font-size:.9rem;margin-bottom:1.2rem;max-width:90%;text-align:center}.emoji-row{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:1.5rem}.emoji-btn{background:none;border:none;cursor:pointer;font-size:2rem;transition:transform .2s ease}.emoji-btn:active{transform:scale(1.15)}.emoji-btn.selected{border-bottom:2px solid #3b82f6;transform:scale(1.1)}.chart-container{background:#f8fafc;border-radius:12px;box-shadow:0 2px 6px #00000014;height:260px;margin-bottom:1rem;max-width:100%;padding:.6rem;width:100%}.summary-section{align-items:center;display:flex;flex-direction:column;gap:.8rem;margin-top:10vh;width:100%}.summary-card{background:#f1f5f9;border-radius:10px;box-shadow:0 2px 5px #0000000d;padding:.9rem 1rem;text-align:center;width:100%}.summary-card h3{color:#000;font-size:.95rem;font-weight:600;margin-bottom:.3rem}.summary-card p{color:#000;font-size:1.1rem;font-weight:600}@media (max-width:400px){.mood-tracker-title{font-size:1.4rem}.emoji-btn{font-size:1.8rem}.chart-container{height:220px}.summary-card h3{font-size:.85rem}.summary-card p{font-size:1rem}}.page{align-items:center;background:linear-gradient(135deg,#f9fafb,#eef2ff);display:flex;flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:2rem}.page h1{color:#374151;font-size:2rem;font-weight:600;margin-bottom:1.5rem}.notesWrapper{background:#fff;border-radius:1rem;box-shadow:0 4px 12px #00000014;margin-bottom:2rem;max-width:800px;overflow-y:auto;padding:1.5rem;width:100%}.btn{border:none;border-radius:.75rem;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease-in-out}.btn:hover{transform:translateY(-2px)}.backBtn{background-color:#4f46e5;box-shadow:0 3px 6px #4f46e54d;color:#fff}.backBtn:hover{background-color:#4338ca;box-shadow:0 4px 10px #4f46e566}.community-page{background-color:#fff;background-color:var(--app-background,#fff);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;height:100vh}.community-sidebar{background:var(--app-gradient);border-right:1px solid var(--divider);display:flex;flex-direction:column;overflow:hidden;width:300px}@media (max-width:768px){.community-sidebar{bottom:0;box-shadow:4px 0 20px #0003;left:0;position:fixed;top:0;transform:translateX(-110%);transition:transform .25s ease;width:260px;z-index:200}.community-sidebar.open{transform:translateX(0)}.community-page{padding-top:48px}.community-topbar{align-items:center;background:var(--app-background);border-bottom:1px solid #0000000f;display:flex;gap:12px;height:48px;left:0;padding:8px 12px;position:fixed;right:0;top:0;z-index:100}.close-sidebar:focus,.community-topbar .hamburger:focus,.create-btn:focus{border-radius:6px;outline:3px solid #667eea2e}.community-topbar .hamburger{background:#0000;border:none;cursor:pointer;font-size:20px}.community-topbar .topbar-title{color:var(--text-primary);font-weight:700}.sidebar-header{padding:12px}.groups-list{padding:8px}}.sidebar-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--app-gradient,linear-gradient(135deg,#667eea 0,#764ba2 100%));border-bottom:1px solid #fff3;display:flex;justify-content:space-between;padding:16px}.sidebar-header h2{color:#fff;color:var(--app-foreground,#fff);font-size:24px;font-weight:700;margin:0}.create-btn{align-items:center;background:#ffffff1f;border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;transition:all .3s ease;width:36px}.create-btn:hover{background:#ffffff2e;transform:scale(1.1)}.close-sidebar{align-items:center;background:#ffffff14;border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;height:32px;justify-content:center;transition:transform .15s ease,background .15s ease;width:32px}.close-sidebar:hover{background:#ffffff24;transform:scale(1.05)}.join-btn{background:#0000;border:1px solid var(--divider);border-radius:20px;color:var(--text-primary);cursor:pointer;font-weight:600;padding:8px 16px}.join-btn:hover{background:var(--hover-bg);color:var(--hover-text)}.no-selection{background:var(--app-gradient-soft);color:var(--text-secondary)}.groups-list{flex:1 1;overflow-y:auto;padding:8px 0}.group-item{align-items:center;background:#fff;background:var(--chat-paper-bg,#fff);border-left:4px solid #0000;border-radius:8px;box-shadow:0 1px 3px #0000001a;cursor:pointer;display:flex;justify-content:space-between;margin:4px 8px;padding:12px 16px;transition:all .2s ease}.group-item:hover{background:#0000001f;background:var(--group-hover-bg,#0000001f);transform:translateY(-2px);transition:background .16s ease,transform .12s ease}.group-item:hover .group-info h4,.group-item:hover .group-info p{color:#fff;color:var(--group-hover-text,#fff)}.group-item.active{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--group-active-bg,var(--app-gradient,linear-gradient(135deg,#667eea 0,#764ba2 100%)));border-left-color:#fff;border-left-color:var(--app-foreground,#fff)}.group-item.active .group-info h4,.group-item.active .group-info p{color:#fff;color:var(--group-hover-text,#fff)}.group-info{flex:1 1;min-width:0}.group-info h4{color:var(--text-primary);font-size:14px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-info p{color:var(--text-secondary);font-size:12px;margin:4px 0 0;opacity:.85}.community-sidebar .group-item.active .group-info h4,.community-sidebar .group-item.active .group-info p{color:#fff;color:var(--app-foreground,#fff)}.group-menu{background:none;border:none;color:#666;color:var(--app-foreground,#666);cursor:pointer;font-size:18px;margin-left:8px;padding:4px}.group-menu:hover{color:#e74c3c;color:var(--danger,#e74c3c)}.community-main{background:var(--bg-primary);display:flex;flex:1 1;flex-direction:column;position:relative}.no-selection{align-items:center;background:linear-gradient(135deg,#667eea0d,#764ba20d);color:#999;display:flex;flex:1 1;font-size:18px;justify-content:center}.chat-header-comm{align-items:center;background:var(--app-gradient-soft);border-bottom:1px solid var(--divider);box-shadow:0 2px 4px #0000000a;display:flex;justify-content:space-between;padding:16px}.chat-header-comm .hamburger.small{background:#0000;border:none;cursor:pointer;font-size:16px}.header-info h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.header-info p{color:var(--text-secondary);font-size:13px;margin:4px 0 0}.leave-btn{background:var(--danger);color:var(--text-primary)}.leave-btn:hover{background:#e74c3ce6}.header-actions{display:flex;gap:8px}.leave-btn{background:#e74c3c;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;transition:all .3s ease}.leave-btn:hover{background:#c0392b;transform:scale(1.05)}.messages-container{background:var(--chat-bg);display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto;padding:16px}.message-item{align-items:flex-end;animation:slideIn .3s ease;display:flex;gap:8px;margin-bottom:8px}.message-item.own{justify-content:flex-end}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.msg-bubble{word-wrap:break-word;background:var(--msg-bubble-other-bg);border-radius:12px;box-shadow:0 1px 2px #0000000f;color:var(--text-primary);max-width:70%;padding:10px 14px}.message-item.own .msg-bubble{background:var(--msg-bubble-own-bg);border-radius:12px 0 12px 12px;color:var(--text-primary)}.message-item:not(.own) .msg-bubble{background:var(--msg-bubble-other-bg);border-radius:0 12px 12px 12px;color:var(--text-primary)}.msg-sender{color:var(--text-secondary);font-size:11px;font-weight:600;margin-bottom:4px;opacity:.85}.message-item.own .msg-sender{color:#ffffffe6}.message-item:not(.own) .msg-sender{color:var(--accent-primary)}.msg-text{color:var(--text-primary);font-size:14px;line-height:1.4}.edited{font-size:10px;font-style:italic;margin-left:4px;opacity:.7}.msg-timestamp,.muted-text{color:var(--text-secondary)}.msg-timestamp{font-size:11px;margin-left:6px}.back-btn{color:var(--text-primary)}.msg-delete{background:none;border:none;color:#e74c3c;cursor:pointer;font-size:20px;margin-left:4px;opacity:0;padding:0 4px;transition:all .2s ease}.message-item.own:hover .msg-delete{opacity:1}.msg-delete:hover{transform:scale(1.2)}.msg-input-area{background:var(--chat-input-bg);border-top:1px solid var(--divider);padding:12px 16px}.nickname-display{color:var(--text-secondary);font-size:12px;margin-bottom:8px}.nickname-display strong{color:var(--accent-primary)}.msg-input-area form{align-items:center;display:flex;gap:8px;position:relative}.msg-input{border:1px solid var(--divider);border-radius:12px;flex:1 1;font-family:inherit;font-size:14px;height:44px;outline:none;padding:10px 12px;resize:none;transition:box-shadow .2s ease,border-color .2s ease}.msg-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 4px #0000000a}.msg-send{background:var(--app-gradient)}.modal-content,.msg-send{color:var(--text-primary)}.modal-content{background:var(--bg-primary)}.modal-content h3{color:var(--text-primary)}.modal-content input,.modal-content textarea{border:1px solid var(--divider)}.modal-content input:focus,.modal-content textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #0000000a}.modal-buttons button[type=submit]{background:var(--app-gradient);color:var(--text-primary)}.modal-buttons button[type=submit]:hover{box-shadow:0 4px 12px #00000014}.modal-buttons button[type=button]{background:var(--bg-secondary);color:var(--text-primary)}.modal-buttons button[type=button]:hover{background:#0000000a}.msg-send{border-radius:10px;height:40px;min-width:40px;padding:0 12px}.msg-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea14}.msg-send{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:56px;justify-content:center;margin-left:8px;padding:0;transition:transform .12s ease;width:56px}.msg-send:hover:not(:disabled){transform:scale(1.03)}.msg-input-area .input-controls{align-items:center;background:#fff;background:var(--chat-paper-bg,#fff);border-radius:24px;box-shadow:0 2px 4px #0000000f;display:flex;gap:8px;padding:8px}.msg-input-area .chat-input{background:#0000;border:1px solid #0000000f;border-radius:20px;flex:1 1;font-size:14px;min-width:0;padding:10px 12px}.msg-input-area .send-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.msg-input-area .send-btn:disabled,.msg-send:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:400px;padding:24px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{color:#333;font-size:20px;margin:0 0 16px}.modal-content input,.modal-content textarea{border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:14px;margin-bottom:12px;outline:none;padding:10px 12px;resize:vertical;width:100%}.modal-content input:focus,.modal-content textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-buttons{display:flex;gap:8px;justify-content:flex-end}.modal-buttons button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.modal-buttons button[type=submit]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-buttons button[type=submit]:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.modal-buttons button[type=button]{background:#f0f0f0;color:#333}.modal-buttons button[type=button]:hover{background:#e0e0e0}.violation-modal{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.violation-content{animation:slideUp .3s ease;background:var(--bg-primary);border-radius:12px;box-shadow:0 10px 40px #0006;color:var(--text-primary);max-width:500px;padding:32px;text-align:center}.groups-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:var(--bg-secondary)}.groups-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:var(--divider)}.violation-content h2{color:#fff;font-size:24px;margin:0 0 16px}.violation-content p{color:#ddd;font-size:14px;line-height:1.6;margin:0 0 24px}.violation-content button{background:linear-gradient(135deg,#444,#111);border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 32px;transition:all .3s ease}.violation-content button:hover{box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.groups-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:6px}.groups-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:#f1f1f1}.groups-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:#bbb;border-radius:3px}.groups-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover{background:#888}@media (max-width:1024px){.community-sidebar{width:250px}.msg-bubble{max-width:85%}}@media (max-width:768px){.community-page{flex-direction:column}.community-sidebar{border-bottom:1px solid #e0e0e0;border-right:none;height:200px;width:100%}.groups-list{max-height:150px}.community-main{flex:1 1}.msg-bubble{max-width:90%}}.settings-container{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;padding:clamp(1rem,2vw,2rem);transition:background-color .3s ease,color .3s ease}.settings-header{flex-wrap:wrap;gap:clamp(1rem,2vw,2rem);margin-bottom:clamp(1.5rem,3vw,2.5rem)}.back-btn,.settings-header{align-items:center;display:flex}.back-btn{background:#0000;border:none;border-radius:8px;color:var(--accent-primary);cursor:pointer;font-size:1rem;gap:.5rem;padding:clamp(.5rem,1vw,.75rem) clamp(.75rem,1.5vw,1rem);transition:background .3s,color .3s}.back-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.settings-header h1{color:var(--text-primary);font-size:clamp(1.5rem,3vw,2.5rem);margin:0;transition:color .3s ease}.settings-content{display:flex;flex-direction:column;gap:clamp(1.5rem,2.5vw,2.5rem);margin:0 auto;max-width:900px}.settings-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-sm);padding:clamp(1rem,2vw,2rem);transition:background-color .3s ease,box-shadow .3s ease}.section-header{align-items:center;color:var(--accent-primary);display:flex;gap:clamp(.75rem,1.5vw,1rem);margin-bottom:clamp(1rem,1.5vw,1.5rem)}.section-header h2{color:var(--text-primary);font-size:clamp(1.1rem,2vw,1.5rem);margin:0;transition:color .3s ease}.theme-grid{grid-gap:clamp(1rem,2vw,1.5rem);display:grid;gap:clamp(1rem,2vw,1.5rem);grid-template-columns:repeat(auto-fit,minmax(clamp(120px,25vw,180px),1fr))}.theme-option{align-items:center;background:#0000;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:clamp(.75rem,1vw,1rem);overflow:hidden;padding:clamp(1rem,1.5vw,1.5rem);position:relative;transition:all .3s ease}.theme-option:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.theme-option.active,.theme-option:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.theme-option.active{box-shadow:0 0 15px #3b82f64d}.theme-preview{align-items:center;border-radius:10px;box-shadow:var(--shadow-md);color:#fff;display:flex;height:clamp(60px,12vw,100px);justify-content:center;transition:transform .3s ease;width:clamp(60px,12vw,100px)}.theme-option:hover .theme-preview{transform:scale(1.05)}.theme-option p{color:var(--text-primary);font-size:clamp(.85rem,1.5vw,1rem);font-weight:500;margin:0;text-align:center}.checkmark{background:var(--accent-primary);border-radius:50%;box-shadow:var(--shadow-md);color:#fff;font-size:1rem;font-weight:700;height:28px;justify-content:center;position:absolute;right:8px;top:8px;width:28px}.checkmark,.setting-item{align-items:center;display:flex}.setting-item{border-radius:8px;gap:1rem;margin-bottom:.75rem;padding:clamp(.75rem,1.5vw,1rem);transition:background .3s ease}.setting-item:last-child{margin-bottom:0}.setting-item:hover{background:var(--bg-tertiary)}.setting-item label{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:clamp(.85rem,1.5vw,1rem);gap:.75rem;width:100%}.setting-item input[type=checkbox]{accent-color:var(--accent-primary);cursor:pointer;height:clamp(18px,4vw,24px);width:clamp(18px,4vw,24px)}.about-text{color:var(--text-secondary);font-size:clamp(.85rem,1.5vw,1rem);line-height:1.6;margin:clamp(.75rem,1vw,1rem) 0;transition:color .3s ease}.about-text strong{color:var(--text-primary)}@media (max-width:359px){.settings-container{padding:.75rem}.settings-header{align-items:flex-start;flex-direction:column}.theme-grid{grid-template-columns:1fr}.settings-section{padding:1rem}}@media (min-width:360px) and (max-width:480px){.settings-container{padding:1rem}.settings-header{gap:.75rem}.theme-grid{grid-template-columns:repeat(2,1fr)}.settings-section{padding:1.2rem}}@media (min-width:481px) and (max-width:768px){.theme-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:769px) and (max-width:1024px){.theme-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1025px){.theme-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.games-page{margin:24px auto;max-width:980px;padding:12px}.games-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.games-tabs button{background:var(--bg-primary);border:1px solid var(--divider);border-radius:8px;color:var(--text-primary);cursor:pointer;margin-left:8px;padding:8px 12px;transition:all .16s ease}.games-tabs button:hover{background:var(--hover-bg);color:var(--hover-text);transform:translateY(-2px)}.games-tabs button.active{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 8px 20px #00000014;color:var(--text-primary);transform:translateY(-2px)}.games-content{display:flex;flex-wrap:wrap;gap:16px}.game-card{background:var(--bg-secondary);border-radius:12px;box-shadow:0 6px 18px #0000000f;color:var(--text-primary);flex:1 1;min-width:280px;padding:16px}.game-top{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:72px}.ttt-board{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);height:240px;margin:12px 0;width:240px}.ttt-cell{align-items:center;background:var(--bg-primary);border:1px solid var(--divider);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:28px;height:72px;justify-content:center;transition:transform .14s ease,background .14s ease,box-shadow .14s ease;width:72px}.ttt-cell:hover{box-shadow:0 6px 12px #0000000f;transform:translateY(-3px)}.ttt-cell:focus{outline:2px solid var(--divider)}.ttt-cell.filled{background:var(--hover-bg);color:var(--hover-text)}.rps-message,.ttt-message{background:var(--bg-primary);border-radius:8px;color:var(--text-primary);margin-bottom:8px;min-height:28px;padding:8px}.rps-controls{display:flex;gap:8px}.rps-btn{background:var(--accent-primary);border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;padding:10px 14px;transition:transform .14s ease,opacity .14s ease}.rps-btn:hover{opacity:.95;transform:translateY(-2px)}.rps-result{color:var(--text-primary)}.game-actions,.rps-result{margin-top:8px}.game-banner{animation:bannerIn .45s ease-out;background:linear-gradient(90deg,var(--accent-primary),var(--mood-mid));border-radius:10px;box-shadow:0 6px 18px #0000001f;color:var(--text-primary);font-weight:700;margin-bottom:8px;padding:10px 14px;position:relative;text-align:center}@keyframes bannerIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.game-card .btn{background:var(--accent-primary);border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;font-weight:700;padding:8px 12px;transition:transform .14s ease,opacity .14s ease,box-shadow .14s ease}.game-card .btn:hover{opacity:.95;transform:translateY(-2px)}.game-card .btn:focus{box-shadow:0 8px 20px #00000014;outline:2px solid var(--divider)}.ttt-board{animation:boardIn .22s ease-out}@keyframes boardIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.ca6037e0.css.map*/