: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}.chat-container,.chat-fullscreen,.chatbot-container,.community-container,.modal-content,.modal-overlay{background-image:none!important}.chat-container,.chat-fullscreen,.chatbot-container,.community-container{background:var(--bg-primary)!important;background:var(--chat-bg,var(--bg-primary))!important}.login-container{align-items:center;background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;justify-content:center;margin:auto;max-width:100%;min-height:100vh;padding:clamp(.5rem,2vw,2rem);position:relative;width:100%}.login-container:before{background:linear-gradient(135deg,#0b2740d9,#112b46bf 50%,#00ff661a);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:0}.login-box{animation:fadeIn 1.2s ease-in-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b2740e6;border:1px solid #00ff664d;border-radius:clamp(12px,2vw,24px);box-shadow:0 20px 60px #0006,0 0 40px #00ff661a;max-width:clamp(280px,90vw,450px);padding:clamp(1rem,3vw,2.5rem);position:relative;text-align:center;transition:background-color .3s ease,box-shadow .3s ease;width:100%;z-index:1}.site-title{color:#0f6;font-size:clamp(1.4rem,4vw,2.5rem);margin-bottom:.5rem;text-shadow:0 0 20px #00ff6680}.city-info,.site-title{transition:color .3s ease}.city-info{color:#ffffffe6;font-size:clamp(.75rem,2vw,1rem);margin-bottom:1rem}.subtitle{color:#fffc;font-size:clamp(.8rem,1.8vw,1rem);font-style:italic;margin-bottom:1.25rem;transition:color .3s ease}.tab-container{background:#ffffff1a;border:1px solid #0f63;border-radius:10px;display:flex;margin-bottom:1.5rem;overflow:hidden}.tab-button{background:#0000;border:none;color:#ffffffb3;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:linear-gradient(135deg,#0f6,#00d07a);color:#0b2740}.tab-button:hover:not(.active){background:#ffffff26;color:#fff}form{display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.4rem)}input{background:#fffffff2;border:1px solid #00ff664d;border-radius:10px;box-sizing:border-box;color:#0b2740;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:#0b274099}input:focus-visible{background:#fff;border-color:#0f6;box-shadow:0 0 15px #00ff6680;outline:none}button[type=submit]{background:linear-gradient(135deg,#0f6,#00d07a);border:none;border-radius:10px;box-shadow:0 4px 15px #00ff664d;color:#0b2740;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 6px 20px #00ff6680;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:#ff6b6b1a;border-left:3px solid #ff6b6b;border-radius:8px;color:#ff6b6b;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}@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{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:1px solid var(--border-color);border-radius:12px;box-shadow:0 14px 40px #02061773;color:#000;color:var(--text-primary,#000);max-width:820px;min-width:320px;padding:18px;position:relative}.startup-modal .modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding-bottom:8px}.modal-title{color:var(--text-primary);font-size:1.2rem;font-weight:700}.modal-close{background:#0000;border:1px solid var(--border-color);border-radius:6px;font-size:16px;padding:6px 10px}.modal-close:hover{background:var(--bg-tertiary)}.modal-body{color:var(--text-primary);font-size:.95rem;line-height:1.5;max-height:56vh;overflow:auto;padding:14px 6px}.modal-body h1,.modal-body h2,.modal-body h3{color:var(--text-primary);margin-top:1rem}.modal-body p{color:var(--text-secondary);margin-bottom:.75rem}.modal-body ol,.modal-body ul{color:var(--text-secondary);padding-left:1.5rem}.modal-body li{margin-bottom:.5rem}.modal-body a{color:var(--accent-primary)}.modal-footer{border-top:1px solid var(--border-color);display:flex;gap:10px;justify-content:flex-end;padding-top:12px}.btn{border-radius:8px;font-size:.9rem;padding:.6rem 1rem;transition:all .2s ease}.btn-primary{background:var(--accent-primary)}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary:hover{background:var(--hover-bg)}@keyframes modalFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.upload-btn{background:var(--accent-primary);border:none;color:var(--bg-primary);font-size:1rem;font-weight:600;padding:.6rem 0;transition:all .2s ease;width:140px}.upload-btn:hover{opacity:.9;transform:translateY(-1px)}.dashboard-container{background:var(--bg-primary);color:var(--text-primary);display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100vh;overflow:hidden;position:relative;transition:background-color .3s ease,color .3s ease;width:100vw}.dashboard-container:before{background:radial-gradient(circle at 10% 15%,#00ff660d 0,#0000 40%),radial-gradient(circle at 90% 85%,#3b82f60d 0,#0000 40%),radial-gradient(circle at 50% 50%,#00d27a05 0,#0000 60%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.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,2.5vw,1.8rem);position:relative;transition:transform .3s ease-in-out,background-color .3s ease;width:clamp(200px,20vw,280px);z-index:101}.sidebar.closed{height:100vh;left:0;position:fixed;top:0;transform:translateX(-100%);z-index:101}@media (min-width:1025px){.sidebar.closed{position:relative;transform:translateX(0)}}.sidebar-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:100}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar .logo{color:var(--accent-primary);font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:700;margin-bottom:2rem;text-align:center;text-shadow:0 0 20px #00ff664d;transition:color .3s ease}.sidebar nav{display:flex;flex-direction:column;gap:.5rem}.sidebar button{align-items:center;background:#0000;border:none;border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:clamp(.85rem,1.8vw,1rem);gap:.85rem;overflow:hidden;padding:clamp(.6rem,1.5vw,.9rem) clamp(.8rem,1.8vw,1.2rem);text-overflow:ellipsis;transition:all .25s ease;white-space:nowrap}.sidebar button:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translateX(4px)}.sidebar button:active{transform:translateX(2px)}.sidebar-footer{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1rem;text-align:center}.sidebar-footer button{justify-content:center;width:100%}.main-content{background:var(--bg-primary);flex:1 1;flex-direction:column;overflow-y:auto;padding:clamp(1rem,2.5vw,2.5rem);transition:background-color .3s ease;z-index:1}.main-content,.topbar{display:flex;position:relative}.topbar{align-items:center;flex-wrap:wrap;gap:clamp(.75rem,2vw,1.5rem);justify-content:space-between;margin-bottom:clamp(1.5rem,3vw,2.5rem)}.topbar h1{color:var(--text-primary);font-size:clamp(1.3rem,3.5vw,2.5rem);font-weight:700;margin-bottom:.4rem;transition:color .3s ease}.topbar .highlight{color:var(--accent-primary)}.topbar .city{color:var(--text-muted);font-size:clamp(.8rem,1.8vw,1rem);transition:color .3s ease}.hamburger{background:#0000;border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;display:none;font-weight:400;padding:.5rem;transition:all .3s ease;z-index:150}.hamburger:hover{background:var(--bg-secondary);color:var(--accent-primary)}.hamburger.active{transform:rotate(90deg)}@media (max-width:1024px){.hamburger{align-items:center;display:flex;justify-content:center;left:clamp(.75rem,1.5vw,1.2rem);position:fixed;top:clamp(.75rem,1.5vw,1.2rem);z-index:102}}.widgets{grid-gap:clamp(1rem,2.5vw,1.8rem);display:grid;gap:clamp(1rem,2.5vw,1.8rem);grid-template-columns:repeat(auto-fit,minmax(clamp(160px,35vw,240px),1fr));margin-top:1rem;width:100%}.widget{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 15px #00000014;cursor:pointer;display:flex;flex-direction:column;gap:.6rem;overflow:hidden;padding:clamp(1rem,2.5vw,1.8rem);position:relative;transition:all .3s ease}.widget:before{background:linear-gradient(135deg,var(--accent-primary) 0,#0000 100%);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease;z-index:0}.widget>*{position:relative;z-index:1}.widget:hover{border-color:var(--accent-primary);box-shadow:0 12px 35px #00000026,0 0 20px #0f63;transform:translateY(-6px)}.widget:hover:before{opacity:.05}.widget h3{color:var(--text-primary);font-size:clamp(.95rem,2.2vw,1.25rem);font-weight:600}.widget h3,.widget p{margin:0;transition:color .3s ease}.widget p{color:var(--text-secondary);font-size:clamp(.75rem,1.5vw,.9rem);line-height:1.4}.widget svg{color:var(--accent-primary);transition:transform .3s ease}.widget:hover svg{transform:scale(1.1)}.widget.disabled{cursor:not-allowed;opacity:.5}.widget.disabled:hover{border-color:var(--border-color);box-shadow:0 4px 15px #00000014;transform:none}.widget.disabled:before{display:none}@media (max-width:359px){.sidebar{max-width:280px;padding:1rem;width:85%}.sidebar .logo{font-size:1.3rem;margin-bottom:1.5rem}.sidebar button{font-size:.9rem;gap:.7rem;padding:.7rem .8rem}.topbar{padding-left:3.5rem}.topbar h1{font-size:1.2rem}.topbar .city{font-size:.8rem}.widgets{gap:.8rem;grid-template-columns:1fr}.widget{padding:1.2rem}.widget h3{font-size:1rem}.widget p{font-size:.8rem}}@media (min-width:360px) and (max-width:480px){.sidebar{padding:1rem .75rem;width:200px}.sidebar .logo{font-size:1.2rem;margin-bottom:1.5rem}.sidebar button{font-size:.85rem;padding:.6rem .8rem}.topbar{padding-left:3.5rem}.topbar h1{font-size:1.2rem}.topbar .city{font-size:.8rem}.widgets{grid-template-columns:1fr}.widget{padding:1.2rem}.widget h3{font-size:1rem}.widget p{font-size:.8rem}}@media (min-width:481px) and (max-width:768px){.sidebar{width:220px}.topbar h1{font-size:1.4rem}.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)}}.lang-select{background:var(--chat-surface);border:1px solid var(--chat-border);border-radius:8px;color:var(--chat-text);cursor:pointer;font-size:.85rem;outline:none;padding:6px 10px}.lang-select:focus{border-color:var(--chat-accent)}.lang-select option{background:var(--chat-surface);color:var(--chat-text)}.chat-input-area .chat-input{height:auto;max-height:100px;min-height:24px}.chat-input{field-sizing:content}.chat-fullscreen{background:var(--chat-bg);bottom:0;display:flex;flex-direction:column;height:100vh;height:100dvh;height:100svh;left:0;overflow:hidden;position:fixed;right:0;top:0;width:100%}.chat-back-btn{align-items:center;background:var(--chat-surface);border:1px solid var(--chat-border);border-radius:10px;color:var(--chat-text);cursor:pointer;display:flex;height:40px;justify-content:center;left:12px;position:fixed;top:12px;transition:all .25s ease;width:40px;z-index:100}.chat-back-btn:hover{background:var(--chat-accent);border-color:var(--chat-accent);color:var(--bg-primary)}@media (min-width:601px){.chat-back-btn{display:none}}.send-btn{align-items:center;background:var(--chat-accent);border:none;border-radius:50%;color:var(--bg-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:44px;justify-content:center;transition:all .25s ease;width:44px}.send-btn:hover:not(:disabled){transform:scale(1.08)}.send-btn:disabled{cursor:not-allowed;opacity:.4}.voice-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:var(--chat-text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:44px;justify-content:center;transition:all .25s ease;width:44px}.voice-btn:hover{background:var(--chat-border);color:var(--chat-text)}.voice-btn.active{animation:pulse 1s infinite;background:#ef4444;color:#fff}.voice-btn:disabled{cursor:not-allowed;opacity:.5}.input-controls{align-items:center;display:flex;flex:1 1;gap:10px}.message-row.user{justify-content:flex-end}.message-row.bot{justify-content:flex-start}.typing{animation:typingPulse 1.5s infinite;background:var(--msg-received-bg);border-radius:16px;color:var(--chat-text-secondary);display:inline-block;font-size:.85rem;padding:10px 16px}@keyframes typingPulse{0%,to{opacity:.5}50%{opacity:1}}@media (max-width:600px){.chat-fullscreen{height:100vh;height:100dvh}.chat-header{padding:10px 12px 10px 60px}.lang-select{font-size:.8rem;padding:4px 8px}.chat-input-area{gap:8px;padding:8px 10px}.chat-action-btn,.send-btn,.voice-btn{height:40px;width:40px}.message-text{font-size:.9rem}}.whatsapp-chat-bg{background-color:#e4ddd5!important;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%23cbc7bd' fill-opacity='.4' fill-rule='evenodd'/%3E%3C/svg%3E")!important}.whatsapp-chat-bg.dark{background-color:#0b1418!important;background-image:none!important}.whatsapp-chat-bg.blue{background-color:#d2dbdf!important;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%23b8c4cc' fill-opacity='.4' fill-rule='evenodd'/%3E%3C/svg%3E")!important}.whatsapp-chat-bg.teal{background-color:#d5e8e8!important;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%23c0d4d4' fill-opacity='.4' fill-rule='evenodd'/%3E%3C/svg%3E")!important}:root,[data-theme=light]{--chat-bg:#e4ddd5;--chat-surface:#f0f0f0;--chat-text:#000;--chat-text-secondary:#555;--chat-border:#00000014;--chat-accent:#00a86b;--msg-sent-bg:#dcf8c6;--msg-sent-text:#000;--msg-sent-radius:7.5px 7.5px 0 7.5px;--msg-received-bg:#fff;--msg-received-text:#000;--msg-received-radius:7.5px 7.5px 7.5px 0;--chat-input-bg:#f0f0f0;--chat-input-text:#000;--chat-input-placeholder:#888;--chat-input-border:#0000000d;--typing-dot:#00a86b}[data-theme=dark]{--chat-bg:#0b1418;--chat-surface:#1f2a30;--chat-text:#e9edef;--chat-text-secondary:#8696a0;--chat-border:#ffffff0d;--chat-accent:#00d07a;--msg-sent-bg:#005c4b;--msg-sent-text:#e9edef;--msg-sent-radius:7.5px 7.5px 0 7.5px;--msg-received-bg:#1f2a30;--msg-received-text:#e9edef;--msg-received-radius:7.5px 7.5px 7.5px 0;--chat-input-bg:#1f2a30;--chat-input-text:#e9edef;--chat-input-placeholder:#8696a0;--chat-input-border:#ffffff0d;--typing-dot:#00d07a}[data-theme=brand]{--chat-bg:#0b2740;--chat-surface:#112b46;--chat-text:#fff;--chat-text-secondary:#9fb8d0;--chat-border:#ffffff1a;--chat-accent:#0f6;--msg-sent-bg:#0f6;--msg-sent-text:#0b2740;--msg-sent-radius:7.5px 7.5px 0 7.5px;--msg-received-bg:#112b46;--msg-received-text:#fff;--msg-received-radius:7.5px 7.5px 7.5px 0;--chat-input-bg:#112b46;--chat-input-text:#fff;--chat-input-placeholder:#7a9bbf;--chat-input-border:#ffffff1a;--typing-dot:#0f6}.chat-container{background:#e4ddd5;background:var(--chat-bg);display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;width:100%}.chat-container:before{background-image:radial-gradient(#00000014 1px,#0000 0);background-image:radial-gradient(var(--chat-border) 1px,#0000 1px);background-size:20px 20px;bottom:0;content:"";left:0;opacity:.5;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.chat-header{align-items:center;background:#f0f0f0;background:var(--chat-surface);border-bottom:1px solid #00000014;border-bottom:1px solid var(--chat-border);color:#000;color:var(--chat-text);display:flex;flex-shrink:0;gap:12px;padding:12px 16px;position:relative;z-index:10}.chat-header-info{flex:1 1}.chat-header-title{align-items:center;color:#000;color:var(--chat-text);display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0}.chat-header-subtitle{color:#555;color:var(--chat-text-secondary);font-size:.8rem;margin:0}.chat-header-actions{display:flex;gap:8px}.chat-header-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#555;color:var(--chat-text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.chat-header-btn:hover{background:#00000014;background:var(--chat-border);color:#000;color:var(--chat-text)}.chat-messages{background:#e4ddd5;background:var(--chat-bg);display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:16px;position:relative;z-index:1}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#0000}.chat-messages::-webkit-scrollbar-thumb{background:#00000014;background:var(--chat-border);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#555;background:var(--chat-text-secondary)}.message-row{animation:msgSlideIn .2s ease;display:flex;gap:8px;margin-bottom:4px;max-width:85%}.message-row.sent{align-self:flex-end;flex-direction:row-reverse}.message-row.received{align-self:flex-start}.message-bubble{box-shadow:0 1px .5px #0000001a;max-width:100%;min-width:60px;padding:8px 12px 6px;position:relative}.message-bubble.sent{background:#dcf8c6;background:var(--msg-sent-bg);border-radius:7.5px 7.5px 0 7.5px;border-radius:var(--msg-sent-radius);color:#000!important;color:var(--msg-sent-text)!important}.message-bubble.received{background:#fff;background:var(--msg-received-bg);border-radius:7.5px 7.5px 7.5px 0;border-radius:var(--msg-received-radius);color:#000!important;color:var(--msg-received-text)!important}.message-text{word-wrap:break-word;color:inherit;font-size:.95rem;line-height:1.4;margin:0;white-space:pre-wrap}.message-sender{color:#00a86b;color:var(--chat-accent);font-size:.75rem;font-weight:600;margin-bottom:2px}.message-row.sent .message-sender{display:none}.message-meta{align-items:center;display:flex;font-size:.7rem;gap:4px;justify-content:flex-end;margin-top:2px;opacity:.7}.message-row.sent .message-meta{color:#000;color:var(--msg-sent-text)}.message-row.received .message-meta{color:#000;color:var(--msg-received-text)}.message-status{font-size:.8rem}.typing-indicator{align-items:center;align-self:flex-start;background:#fff;background:var(--msg-received-bg);border-radius:7.5px 7.5px 7.5px 0;border-radius:var(--msg-received-radius);display:flex;gap:4px;max-width:80px;padding:12px 16px}.typing-dot{animation:typingBounce 1.4s ease-in-out infinite;background:#00a86b;background:var(--typing-dot);border-radius:50%;height:8px;width:8px}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.chat-scroll-container{display:flex;flex:1 1;flex-direction:column;overflow:hidden;position:relative}.chat-scroll-btn{align-items:center;background:#f0f0f0;background:var(--chat-surface);border:none;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#000;color:var(--chat-text);cursor:pointer;display:flex;height:36px;justify-content:center;opacity:.9;position:absolute;right:16px;transition:all .2s ease;width:36px;z-index:5}.chat-scroll-btn:hover{box-shadow:0 4px 12px #0003;opacity:1;transform:scale(1.1)}.chat-scroll-btn.scroll-down{bottom:80px}.chat-scroll-btn.scroll-up{top:8px}.chat-scroll-btn svg{height:20px;width:20px}.chat-scroll-btn.hidden{display:none}.chat-input-area{align-items:flex-end;background:#f0f0f0;background:var(--chat-surface);border-top:1px solid #00000014;border-top:1px solid var(--chat-border);display:flex;flex-shrink:0;gap:10px;padding:10px 12px;position:relative;z-index:10}.chat-input-wrapper{align-items:flex-end;background:#f0f0f0;background:var(--chat-input-bg);border:1px solid #0000000d;border:1px solid var(--chat-input-border);border-radius:24px;display:flex;flex:1 1;min-height:44px;padding:4px 12px}.chat-input{background:#0000;border:none;color:#000;color:var(--chat-input-text);flex:1 1;font-size:.95rem;line-height:1.4;max-height:120px;outline:none;padding:8px 0;resize:none}.chat-input::placeholder{color:#888;color:var(--chat-input-placeholder)}.chat-input::-webkit-input-placeholder{color:#888;color:var(--chat-input-placeholder)}.chat-action-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#555;color:var(--chat-text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .2s ease;width:44px}.chat-action-btn:hover{background:#00000014;background:var(--chat-border);color:#000;color:var(--chat-text)}.chat-action-btn.send{background:#00a86b;background:var(--chat-accent);color:var(--bg-primary)}.chat-action-btn.send:hover{box-shadow:0 4px 12px #00ff664d;transform:scale(1.05)}.chat-action-btn:disabled{cursor:not-allowed;opacity:.5}.date-separator{align-items:center;display:flex;justify-content:center;margin:16px 0;position:relative}.date-separator span{background:#f0f0f0;background:var(--chat-surface);border:1px solid #00000014;border:1px solid var(--chat-border);border-radius:8px;font-size:.75rem;padding:4px 12px;z-index:1}.chat-empty,.date-separator span{color:#555;color:var(--chat-text-secondary)}.chat-empty{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px;text-align:center}.chat-empty svg{color:#555;color:var(--chat-text-secondary);margin-bottom:16px;opacity:.3}.chat-empty h3{color:#000;color:var(--chat-text);font-size:1.2rem;margin:0 0 8px}.chat-empty p{color:#555;color:var(--chat-text-secondary);font-size:.9rem;margin:0}.join-prompt{background:#e4ddd5;background:var(--chat-bg);color:#555;padding:40px}.join-prompt svg{color:#555;margin-bottom:16px;opacity:.3}.join-prompt h3{color:#000;font-size:1.2rem;margin:0 0 8px}.join-prompt p{color:#555;color:var(--chat-text-secondary);font-size:.95rem;margin:0 0 20px}.join-prompt .join-btn{align-items:center;background:#00a86b;background:var(--chat-accent);border:none;border-radius:24px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.join-prompt .join-btn:hover{box-shadow:0 4px 15px #0003;transform:scale(1.05)}.join-prompt .join-btn.large{font-size:1.1rem;padding:14px 28px}@media (max-width:600px){.chat-header{padding:10px 12px}.chat-messages{gap:2px;padding:12px}.message-row{max-width:90%}.message-bubble{padding:6px 10px}.message-text{font-size:.9rem}.chat-input-area{gap:8px;padding:8px 10px}.chat-input-wrapper{min-height:40px;padding:2px 10px}.chat-action-btn{height:40px;width:40px}}.chat-action-btn.recording{animation:pulse 1s infinite;background:#ef4444;color:#fff}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.back-btn{background:var(--bg-secondary);border-radius:8px;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 14px;position:relative;transition:all .2s ease;z-index:10}.back-btn:hover{transform:translateX(-2px)}.back-btn:active{transform:translateX(0)}.back-btn-text{display:inline}@media (max-width:480px){.back-btn-text{display:none}.back-btn{height:36px;justify-content:center;padding:8px;width:36px}}.back-btn.primary{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.back-btn.primary:hover{transform:scale(1.02)}.back-btn.ghost{background:#0000;border-color:#0000}.back-btn.ghost:hover{background:var(--bg-tertiary);transform:none}.back-btn.floating{box-shadow:0 2px 8px #0003;left:12px;position:fixed;top:12px;z-index:100}.back-btn.header{left:12px;position:absolute;top:50%;transform:translateY(-50%)}.back-btn.header:hover{transform:translateY(-50%) translateX(-2px)}.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;position:relative;width:100vw}.profile-container:before{background:radial-gradient(circle at 20% 30%,#00ff660a 0,#0000 50%),radial-gradient(circle at 80% 70%,#3b82f60a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.muted-text{color:var(--text-muted)}.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:clamp(1rem,3vw,1.5rem) clamp(1.5rem,4vw,2.5rem);position:relative;width:100vw;z-index:2}.back-btn:hover{box-shadow:0 4px 15px #00ff664d;transform:translateY(-2px)}.profile-app-title{color:var(--accent-primary);font-size:clamp(1.3rem,3.5vw,1.8rem);font-weight:700;letter-spacing:1px;text-shadow:0 2px 15px #00ff664d}.profile-back-btn{font-size:.85rem;padding:.5rem .8rem}.profile-card{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:24px;box-shadow:0 10px 40px #00000040;display:flex;flex-direction:column;margin:clamp(1rem,3vw,2rem) auto;max-width:500px;padding:clamp(1.5rem,4vw,2.5rem);position:relative;text-align:center;transition:all .3s ease;width:100%;z-index:1}.profile-card:hover{box-shadow:0 15px 50px #0000004d}.profile-header{align-items:center;display:flex;flex-direction:column;gap:clamp(.5rem,1.5vw,.8rem);justify-content:flex-start;margin-bottom:1.5rem;width:100%}.profile-pic{align-self:center;background:var(--bg-primary);border:4px solid var(--accent-primary);border-radius:50%;box-shadow:0 4px 20px #0003,0 0 30px #0f63;height:clamp(100px,25vw,140px);margin-bottom:.5rem;object-fit:cover;transition:all .3s ease;width:clamp(100px,25vw,140px)}.profile-pic:hover{box-shadow:0 6px 25px #0000004d,0 0 40px #00ff664d;transform:scale(1.05)}.username{color:var(--text-primary);font-size:clamp(1.3rem,3.5vw,1.8rem);font-weight:700;margin:0}.user-id{color:var(--text-muted);font-size:clamp(.8rem,2vw,.95rem);margin:0}.user-city{color:var(--text-secondary);font-size:clamp(.85rem,2vw,1rem);margin:0}.upload-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--accent-primary);cursor:pointer;display:inline-block;font-size:clamp(.8rem,2vw,.9rem);margin-top:.5rem;padding:.4rem 1rem;transition:all .25s ease}.upload-btn input[type=file]{display:none}.upload-btn:hover{background:var(--accent-primary);box-shadow:0 4px 15px #00ff664d;color:var(--bg-primary);transform:translateY(-2px)}.profile-mood{margin:1.5rem 0;text-align:left;width:100%}.profile-mood h3{color:var(--accent-primary);font-size:clamp(1rem,2.5vw,1.2rem);font-weight:600;margin-bottom:1rem}.mood-bar{align-items:center;display:flex;margin-bottom:.8rem}.mood-bar span{color:var(--text-secondary);font-size:clamp(.85rem,2vw,.95rem);text-transform:capitalize;width:80px}.bar{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;flex:1 1;height:14px;margin-left:12px;overflow:hidden}.fill{background:linear-gradient(90deg,var(--accent-primary),var(--mood-mid));border-radius:10px;box-shadow:0 0 10px var(--accent-primary);height:100%;transition:width .5s ease}.profile-actions{display:flex;flex-direction:column;gap:.8rem;margin:1.5rem 0 2rem;width:100%}.profile-actions button{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:10px;box-shadow:0 3px 12px #00ff6640;color:var(--bg-primary);cursor:pointer;font-size:.9rem;font-weight:600;padding:.6rem 0;transition:all .25s ease;width:100%}.profile-actions button:hover{box-shadow:0 6px 20px #0f66;transform:translateY(-3px)}.profile-actions button:active{transform:translateY(-1px)}.edit-section{gap:.9rem;margin-top:1.5rem;text-align:left;width:100%}.edit-field,.edit-section{display:flex;flex-direction:column}.edit-field{gap:.3rem}.edit-field label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.edit-field input,.edit-field textarea{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.9rem;padding:.6rem .9rem;transition:all .25s ease;width:100%}.edit-field input:focus,.edit-field textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00ff6626;outline:none}.edit-field input::placeholder,.edit-field textarea::placeholder{color:var(--text-muted)}.edit-actions{display:flex;gap:.75rem;margin-top:.5rem}.edit-actions button{border-radius:8px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;padding:.6rem 0;transition:all .25s ease}.save-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;box-shadow:0 3px 12px #00ff6640;color:var(--bg-primary)}.save-btn:hover{box-shadow:0 5px 18px #00ff6659;transform:translateY(-2px)}.cancel-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary)}.cancel-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.edit-profile-btn{background:var(--bg-tertiary);border:1px solid var(--accent-primary);border-radius:10px;color:var(--accent-primary);cursor:pointer;font-size:.85rem;font-weight:600;margin-top:1rem;padding:.55rem 1.5rem;transition:all .25s ease}.edit-profile-btn:hover{background:var(--accent-primary);box-shadow:0 4px 15px #00ff664d;color:var(--bg-primary);transform:translateY(-2px)}.profile-divider{background:linear-gradient(90deg,var(--accent-primary),var(--mood-mid));border-radius:2px;height:2px;margin:1.5rem 0 1.2rem;width:100%}@media (max-width:359px){.profile-card{margin:.75rem auto;max-width:98vw;padding:1rem .75rem}.profile-pic{height:90px;width:90px}.profile-actions{gap:.5rem}.profile-actions button{font-size:.85rem;padding:.55rem 0}.mood-bar span{font-size:.8rem;width:60px}.edit-actions{flex-direction:column}.edit-profile-btn{font-size:.8rem;padding:.5rem 1.2rem}}@media (min-width:360px) and (max-width:480px){.profile-card{max-width:95vw;padding:1.2rem 1rem}.profile-pic{height:100px;width:100px}}@media (min-width:481px) and (max-width:768px){.profile-card{max-width:550px;padding:1.8rem 1.5rem}.profile-pic{height:120px;width:120px}}@media (min-width:769px) and (max-width:1024px){.profile-card{max-width:600px;padding:2rem}.profile-pic{height:130px;width:130px}}@media (min-width:1025px){.profile-card{max-width:650px;padding:2.5rem}.profile-pic{height:140px;width:140px}}.mood-tracker-container{background:#0000;border:none;border-radius:0;box-shadow:none;max-width:100%;min-height:calc(100vh - 150px);min-height:auto;padding:0}.emoji-row{gap:clamp(.8rem,2vw,1.2rem);padding:1.5rem}.emoji-btn{font-size:clamp(2rem,6vw,2.8rem);height:clamp(55px,14vw,75px);width:clamp(55px,14vw,75px)}.emoji-btn.selected{box-shadow:0 0 25px var(--accent-primary);transform:scale(1.15)}.emoji-btn:hover{box-shadow:0 4px 15px #0003;transform:scale(1.12)}.chart-container{box-shadow:0 4px 15px #0000001a;height:clamp(240px,45vw,320px);padding:clamp(1rem,2.5vw,1.5rem)}.summary-section{flex-direction:row;flex-wrap:wrap;gap:clamp(1rem,3vw,2rem);justify-content:center;margin-top:1rem}.summary-card{flex:1 1;max-width:200px;min-width:140px;padding:clamp(1rem,2.5vw,1.5rem)}.summary-card:hover{box-shadow:0 8px 25px #00000026}.summary-card h3{align-items:center;display:flex;font-size:clamp(.85rem,2vw,1rem);gap:.4rem;justify-content:center;margin-bottom:.5rem}.summary-card p{font-size:clamp(1.1rem,3vw,1.4rem)}.mood-tracker-container p{font-size:clamp(.9rem,2vw,1rem);padding:2rem}@media (max-width:359px){.mood-tracker-title{font-size:1.3rem}.emoji-row{gap:.6rem;padding:1rem}.emoji-btn{font-size:1.7rem;height:48px;width:48px}.chart-container{height:200px}.summary-card{min-width:120px}.summary-card h3{font-size:.8rem}.summary-card p{font-size:1rem}}@media (min-width:360px) and (max-width:480px){.emoji-row{gap:.7rem;padding:1.2rem}.emoji-btn{font-size:1.9rem;height:52px;width:52px}.chart-container{height:220px}.summary-section{align-items:center;flex-direction:column}.summary-card{max-width:280px}}@media (min-width:481px) and (max-width:768px){.emoji-btn{font-size:2.1rem;height:58px;width:58px}.chart-container{height:260px}.summary-section{gap:1.2rem}.summary-card{max-width:220px}}@media (min-width:769px) and (max-width:1024px){.emoji-btn{font-size:2.4rem;height:65px;width:65px}.chart-container{height:280px}.summary-card{max-width:240px}}@media (min-width:1025px){.emoji-btn{font-size:2.6rem;height:70px;width:70px}.chart-container{height:300px}.summary-section{gap:2rem}.summary-card{max-width:260px}}.mood-tracker-page{background:var(--bg-primary);box-sizing:border-box;color:var(--text-primary);min-height:100vh;overflow-y:auto;padding:60px clamp(1rem,3vw,2rem) clamp(1rem,3vw,2rem);position:relative;width:100%}@media (min-width:769px){.mood-tracker-page{padding-top:clamp(1rem,3vw,2rem)}}.mood-tracker-page:before{background:radial-gradient(circle at 20% 30%,#00ff660d 0,#0000 50%),radial-gradient(circle at 80% 70%,#3b82f60d 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.mood-header{align-items:center;display:flex;gap:1rem;margin-bottom:clamp(1.5rem,4vw,2.5rem);position:relative;z-index:1}.mood-header-content{flex:1 1}.mood-header h1{align-items:center;color:var(--text-primary);display:flex;font-size:clamp(1.4rem,3.5vw,2rem);font-weight:700;gap:.5rem;margin:0 0 .25rem}.mood-header .subtitle{color:var(--text-secondary);font-size:clamp(.8rem,1.8vw,1rem);margin:0}.mood-tracker-container{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 10px 40px #0003;box-sizing:border-box;display:flex;flex-direction:column;margin:0 auto;max-width:800px;overflow-y:auto;padding:clamp(1.2rem,3vw,2rem);position:relative;width:100%;z-index:1}.mood-tracker-title{color:var(--text-primary);font-size:clamp(1.4rem,3.5vw,2rem);font-weight:700;margin-bottom:.4rem;text-align:center}.mood-tracker-subtitle{color:var(--text-secondary);font-size:clamp(.85rem,1.8vw,1rem);margin-bottom:1.5rem;max-width:90%;text-align:center}.emoji-row{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:16px;flex-wrap:wrap;gap:clamp(.6rem,1.5vw,1rem);margin-bottom:2rem;padding:.8rem}.emoji-btn,.emoji-row{display:flex;justify-content:center}.emoji-btn{align-items:center;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:50%;cursor:pointer;font-size:clamp(1.6rem,4.5vw,2.2rem);height:clamp(48px,11vw,64px);transition:all .25s ease;width:clamp(48px,11vw,64px)}.emoji-btn:active{transform:scale(1.15)}.emoji-btn.selected{background:var(--bg-secondary);box-shadow:0 0 20px var(--accent-primary)}.emoji-btn.selected,.emoji-btn:hover{border-color:var(--accent-primary);transform:scale(1.1)}.emoji-btn:hover{box-shadow:0 4px 15px #00000026}.chart-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 15px #00000014;height:clamp(200px,35vw,280px);margin-bottom:1.5rem;max-width:100%;padding:clamp(.6rem,1.5vw,1rem);width:100%}.summary-section{align-items:center;display:flex;flex-direction:column;gap:clamp(.8rem,2vw,1.2rem);margin-top:auto;padding-top:1rem;width:100%}.summary-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 15px #00000014;max-width:280px;padding:clamp(.8rem,2vw,1.2rem);text-align:center;transition:transform .25s ease,box-shadow .25s ease;width:100%}.summary-card:hover{box-shadow:0 8px 25px #0000001f;transform:translateY(-4px)}.summary-card h3{color:var(--text-primary);font-size:clamp(.85rem,1.8vw,1rem);font-weight:600;margin-bottom:.4rem}.summary-card p{color:var(--accent-primary);font-size:clamp(1rem,2.2vw,1.2rem);font-weight:700;margin:0}.mood-tracker-container p{color:var(--text-secondary);font-size:clamp(.85rem,1.8vw,1rem);padding:1.5rem;text-align:center}.error-text{color:var(--error)!important}@media (max-width:359px){.mood-header{gap:.75rem;padding-top:50px}.mood-header h1{font-size:1.2rem}.emoji-btn{font-size:1.4rem;height:42px;width:42px}.chart-container{height:180px}}@media (min-width:360px) and (max-width:480px){.emoji-btn{font-size:1.6rem;height:46px;width:46px}.chart-container{height:200px}}@media (min-width:481px) and (max-width:768px){.summary-section{flex-direction:row;flex-wrap:wrap;justify-content:center}.summary-card{max-width:240px}}@media (min-width:769px) and (max-width:1024px){.summary-section{flex-direction:row;justify-content:center}.summary-card{max-width:260px}}@media (min-width:1025px){.summary-section{flex-direction:row;justify-content:center}.summary-card{max-width:300px}}.page{background:var(--bg-primary);color:var(--text-primary);flex-direction:column;font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:clamp(1rem,3vw,2rem)}.page,.therapist-notes-header{align-items:center;display:flex;position:relative}.therapist-notes-header{gap:1.5rem;margin-bottom:1.5rem;max-width:800px;width:100%;z-index:1}.tn-back-btn{font-size:.85rem;padding:.5rem .8rem}.therapist-notes-header h1{color:var(--text-primary);font-size:clamp(1.3rem,3.5vw,1.8rem);font-weight:700;margin:0}.page:before{background:radial-gradient(circle at 20% 30%,#00ff660a 0,#0000 40%),radial-gradient(circle at 80% 70%,#3b82f60a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.page>*{position:relative;z-index:1}.page h1{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;margin-bottom:1.5rem;text-shadow:0 2px 10px #0000001a}.notesWrapper,.page h1{color:var(--text-primary)}.notesWrapper{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 20px #0000001a;height:100%;margin-bottom:2rem;max-width:800px;min-height:400px;overflow-y:auto;padding:clamp(1rem,3vw,1.8rem);width:100%}.notesWrapper::-webkit-scrollbar{width:6px}.notesWrapper::-webkit-scrollbar-track{background:var(--bg-tertiary)}.notesWrapper::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:3px}.btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:10px;box-shadow:0 4px 15px #00ff664d;color:var(--bg-primary);padding:clamp(.6rem,1.5vw,.85rem) clamp(1rem,3vw,1.5rem)}.btn:hover{box-shadow:0 6px 20px #0f66;transform:translateY(-3px)}.btn:active{transform:translateY(-1px)}.backBtn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));box-shadow:0 4px 15px #00ff664d;color:var(--bg-primary)}.backBtn:hover{box-shadow:0 6px 20px #0f66;transform:translateY(-3px)}.page input,.page textarea{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:clamp(.9rem,2vw,1rem);padding:.75rem 1rem;transition:all .25s ease;width:100%}.page input:focus,.page textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00ff6626;outline:none}@media (max-width:600px){.notesWrapper,.page{padding:1rem}}.ai-guide-container{background:var(--bg-primary);box-sizing:border-box;color:var(--text-primary);min-height:100vh;overflow-x:hidden;padding:clamp(1rem,3vw,2rem);position:relative;width:100%}.ai-guide-container:before{background:radial-gradient(circle at 20% 30%,#00ff660a 0,#0000 40%),radial-gradient(circle at 80% 70%,#3b82f60a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.ai-guide-header{align-items:center;display:flex;gap:clamp(1rem,3vw,2rem);margin-bottom:clamp(1.5rem,4vw,2.5rem);padding-top:60px;position:relative;z-index:1}@media (min-width:769px){.ai-guide-header{padding-top:0}}.aiguide-back-btn{font-size:.85rem;padding:.5rem .8rem}.ai-guide-header h1{align-items:center;color:var(--text-primary);display:flex;font-size:clamp(1.3rem,3.5vw,2rem);font-weight:700;gap:.75rem;margin:0}.ai-guide-header h1 svg{color:var(--accent-primary)}.ai-guide-content{display:flex;flex-direction:column;gap:clamp(1.5rem,4vw,2rem);margin:0 auto;max-width:700px;position:relative;z-index:1}.guide-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);background:var(--card-bg,var(--bg-secondary));border:1px solid var(--border-color);border-radius:24px;box-shadow:0 8px 40px #00000026;padding:clamp(1.5rem,4vw,3rem);text-align:center}.guide-icon{align-items:center;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:20px;box-shadow:0 8px 30px #00ff664d;color:var(--bg-primary);display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.guide-card h2{color:var(--text-primary);font-size:clamp(1.2rem,3vw,1.6rem);margin:0 0 1.5rem}.guide-message{color:var(--text-secondary);font-size:clamp(.95rem,2.2vw,1.1rem);line-height:1.7;margin:0 0 2rem}.loading-state{padding:2rem}.loading-state p{color:var(--text-secondary);margin:0}.category-options{margin-bottom:2rem}.options-label{color:var(--text-muted);font-size:clamp(.85rem,1.8vw,.95rem);margin-bottom:1rem}.options-grid{display:flex;flex-direction:column;gap:.75rem}.category-btn{align-items:center;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:16px;color:var(--text-primary);cursor:pointer;display:flex;font-size:clamp(1rem,2.2vw,1.1rem);font-weight:600;gap:1rem;padding:1rem 1.5rem;text-align:left;transition:all .25s ease;width:100%}.category-btn:hover{background:#00ff661a;border-color:var(--accent-primary);transform:translateX(4px)}.category-btn svg{color:var(--accent-primary);flex-shrink:0}.category-btn span{flex:1 1}.category-btn svg:last-child{opacity:.5}.guide-actions{align-items:center;display:flex;gap:1rem;justify-content:center}.last-action{color:var(--text-muted);font-size:.85rem;margin-top:1.5rem}.btn{justify-content:center;padding:clamp(.7rem,2vw,.9rem) clamp(1.2rem,3vw,1.8rem)}.btn-icon{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);height:44px;padding:0;width:44px}.btn-icon:hover:not(:disabled){background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.tips-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:clamp(1.5rem,4vw,2rem)}.tips-section h3{color:var(--text-primary);font-size:clamp(1rem,2.2vw,1.2rem);margin:0 0 1.5rem}.tips-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.tip-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;text-align:center;transition:all .25s ease}.tip-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.tip-card svg{color:var(--accent-primary);margin-bottom:.75rem}.tip-card p{color:var(--text-secondary);font-size:clamp(.85rem,1.8vw,.9rem);line-height:1.4;margin:0}.routine-modal{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;background:var(--overlay-bg,#000c);bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.routine-content{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--bg-secondary);background:var(--card-bg,var(--bg-secondary));border:1px solid var(--border-color);border-radius:24px;box-shadow:0 20px 60px #0006;margin:auto;max-height:90vh;max-width:500px;overflow-y:auto;padding:clamp(1.2rem,3vw,2.5rem);position:relative;width:100%}.close-btn{align-items:center;background:var(--bg-tertiary);border:none;border-radius:10px;color:var(--text-primary);cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .25s ease;width:40px}.close-btn:hover{background:var(--error);color:#fff}.routine-header{margin-bottom:2rem;text-align:center}.routine-header h2{color:var(--text-primary);font-size:clamp(1.3rem,3vw,1.6rem);margin:0 0 .5rem}.routine-duration{color:var(--accent-primary);font-weight:600}.routine-progress{margin-bottom:2rem}.routine-progress span{color:var(--text-muted);display:block;font-size:.85rem;margin-bottom:.5rem}.progress-bar{background:var(--bg-tertiary);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:4px;height:100%;transition:width .3s ease}.current-step{background:var(--bg-tertiary);border-radius:16px;margin-bottom:2rem;padding:2rem;text-align:center}.current-step p{color:var(--text-primary);font-size:clamp(1.1rem,2.5vw,1.3rem);line-height:1.6;margin:0}.timer-display{margin-bottom:2rem;text-align:center}.timer-value{font-feature-settings:"tnum";color:var(--accent-primary);font-size:3rem;font-variant-numeric:tabular-nums;font-weight:700}.routine-controls{display:flex;gap:1rem;justify-content:center}.routine-controls .btn{flex:1 1;max-width:200px}@media (max-width:600px){.ai-guide-container{padding:.75rem}.ai-guide-header{align-items:center;flex-direction:row;gap:.75rem}.guide-card{padding:1.5rem 1rem}.guide-icon{height:60px;width:60px}.guide-icon svg{height:28px;width:28px}.options-grid{gap:.5rem}.category-btn{font-size:.95rem;padding:.85rem 1rem}.guide-actions{flex-direction:column;gap:.75rem}.guide-actions .btn-secondary{justify-content:center;width:100%}.tips-grid{grid-template-columns:1fr}.timer-value{font-size:2.5rem}.routine-controls{flex-direction:column;gap:.75rem}.routine-controls .btn{justify-content:center;max-width:100%;width:100%}.current-step{padding:1.5rem 1rem}.current-step p{font-size:1rem}}.community-page{background-color:var(--chat-bg);color:var(--chat-text);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;height:100dvh;overflow:hidden;width:100%}.community-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;position:relative;transition:transform .3s ease;width:300px;z-index:1}.sidebar-header{align-items:center;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:clamp(12px,2vw,20px)}.sidebar-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:clamp(1rem,2.2vw,1.2rem);font-weight:700;gap:.5rem;margin:0}.sidebar-actions{display:flex;gap:8px}.close-sidebar,.create-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .25s ease;width:36px}.create-btn{background:var(--accent-primary);color:var(--bg-primary)}.create-btn:hover{box-shadow:0 4px 15px #0f66;transform:scale(1.1)}.close-sidebar{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.close-sidebar:hover{background:var(--error);border-color:var(--error);color:#fff}.groups-list{flex:1 1;overflow-y:auto;padding:10px}.groups-list::-webkit-scrollbar{width:6px}.groups-list::-webkit-scrollbar-track{background:var(--bg-secondary)}.groups-list::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:3px}.empty-groups{color:var(--text-muted);padding:2rem 1rem;text-align:center}.empty-groups svg{margin-bottom:.75rem;opacity:.5}.empty-groups p{font-weight:600;margin:0 0 .25rem}.empty-groups span{font-size:.85rem}.group-item{background:var(--bg-tertiary);border:1px solid #0000;border-radius:12px;cursor:pointer;margin-bottom:6px;padding:14px 16px;transition:all .2s ease}.group-item:hover{background:var(--hover-bg);border-color:var(--border-color);transform:translateX(4px)}.group-item.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-color:var(--accent-primary)}.group-info h4{align-items:center;color:var(--text-primary);display:flex;font-size:15px;font-weight:600;gap:6px;margin:0 0 4px}.group-item.active .group-info h4,.group-item.active .group-info p{color:var(--bg-primary)}.group-info p{color:var(--text-muted);font-size:12px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.community-main{background:var(--chat-bg);overflow:hidden;position:relative;z-index:1}.community-main,.no-selection{display:flex;flex:1 1;flex-direction:column}.no-selection{align-items:center;justify-content:center;padding:2rem;text-align:center}.no-selection,.no-selection svg{color:var(--chat-text-secondary)}.no-selection svg{margin-bottom:1rem;opacity:.3}.no-selection h3{color:var(--chat-text);font-size:clamp(1.2rem,3vw,1.5rem);margin:0 0 .5rem}.no-selection p{font-size:clamp(.9rem,2vw,1rem);margin:0}.join-prompt{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.join-prompt,.join-prompt svg{color:var(--chat-text-secondary)}.join-prompt svg{margin-bottom:1rem;opacity:.5}.join-prompt h3{color:var(--chat-text);margin:0 0 .5rem}.join-prompt p{margin:0 0 1.5rem;max-width:300px}.chat-header-comm{align-items:center;background:var(--chat-surface);border-bottom:1px solid var(--chat-border);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:clamp(12px,2vw,20px)}.chat-info h3{align-items:center;color:var(--chat-text);display:flex;font-size:clamp(1rem,2.5vw,1.2rem);gap:6px;margin:0 0 4px}.chat-info p{color:var(--chat-text-secondary);font-size:13px;margin:0}.header-actions{display:flex;gap:10px}.join-btn,.leave-btn{align-items:center;border:none;border-radius:20px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:all .25s ease}.join-btn{background:var(--chat-accent);color:#fff}.join-btn:hover{box-shadow:0 4px 15px #0003;transform:scale(1.05)}.join-btn.large{font-size:16px;padding:14px 28px}.leave-btn{background:#0000;border:1px solid var(--chat-border);color:var(--chat-text-secondary)}.leave-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.messages-container{background:var(--chat-bg);display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:16px}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:#0000}.messages-container::-webkit-scrollbar-thumb{background:var(--chat-border);border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--chat-text-secondary)}.empty-messages{align-items:center;color:var(--chat-text-secondary);display:flex;flex:1 1;flex-direction:column;justify-content:center;text-align:center}.empty-messages svg{color:var(--chat-text-secondary);margin-bottom:.5rem;opacity:.3}.empty-messages p{color:var(--chat-text);font-weight:600;margin:0 0 .25rem}.empty-messages span{color:var(--chat-text-secondary);font-size:.85rem}.message-item{align-items:flex-end;animation:msgSlideIn .2s ease;display:flex;gap:8px;margin-bottom:4px;max-width:85%}.message-item.own{align-self:flex-end;flex-direction:row-reverse}.message-item:not(.own){align-self:flex-start}@keyframes msgSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.msg-bubble{word-wrap:break-word;max-width:100%;min-width:60px;overflow-wrap:break-word;padding:8px 12px 6px}.message-item.own .msg-bubble{background:var(--msg-sent-bg);border-radius:var(--msg-sent-radius);color:var(--msg-sent-text)!important}.message-item:not(.own) .msg-bubble{background:var(--msg-received-bg);border-radius:var(--msg-received-radius);box-shadow:0 1px .5px #0000001a;color:var(--msg-received-text)!important}.msg-sender{color:var(--chat-accent);font-size:.75rem;font-weight:600;margin-bottom:2px}.message-item.own .msg-sender{display:none}.msg-text{font-size:.95rem;line-height:1.4;margin:0;white-space:pre-wrap}.msg-meta{display:flex;font-size:.7rem;gap:4px;justify-content:flex-end;margin-top:2px;opacity:.7}.edited{font-style:italic}.msg-input-area{align-items:flex-end;background:var(--chat-surface);border-top:1px solid var(--chat-border);display:flex;flex-shrink:0;gap:10px;padding:10px 12px}.nickname-display{color:var(--chat-text-secondary);font-size:.75rem;margin-bottom:8px}.nickname-display strong{color:var(--chat-accent)}.msg-input-area form{gap:10px}.msg-input-area form,.msg-input-wrapper{align-items:flex-end;display:flex;flex:1 1}.msg-input-wrapper{background:var(--chat-input-bg);border:1px solid var(--chat-input-border);border-radius:24px;min-height:44px;padding:4px 12px}.msg-input{background:#0000;border:none;border-radius:0;color:var(--chat-input-text);flex:1 1;font-family:inherit;font-size:.95rem;line-height:1.4;max-height:100px;min-height:24px;outline:none;padding:8px 0;resize:none}.msg-input:focus{border:none;box-shadow:none}.msg-input::placeholder{color:var(--chat-input-placeholder)}.msg-send{align-items:center;background:var(--chat-accent);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:44px;justify-content:center;padding:0;transition:all .25s ease;width:44px}.msg-send:hover:not(:disabled){transform:scale(1.05)}.msg-send:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;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:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:420px;padding:clamp(1.5rem,4vw,2rem);width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.modal-header h3{color:var(--text-primary);font-size:20px;margin:0}.modal-close{align-items:center;background:var(--bg-tertiary);border:none;border-radius:10px;color:var(--text-primary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .25s ease;width:36px}.modal-close:hover{background:var(--error);color:#fff}.modal-content input,.modal-content textarea{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:14px;margin-bottom:14px;outline:none;padding:12px 14px;resize:vertical;transition:all .25s ease;width:100%}.modal-content input:focus,.modal-content textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00ff6626}.checkbox-label{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px;margin-bottom:1rem}.checkbox-label input{accent-color:var(--accent-primary);height:18px;margin:0;width:18px}.modal-buttons{display:flex;gap:12px;justify-content:flex-end;margin-top:1rem}.modal-buttons button{border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 22px;transition:all .25s ease}.modal-buttons button:first-child{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.modal-buttons button:first-child:hover{background:var(--hover-bg)}.modal-buttons .btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary)}.modal-buttons .btn-primary:hover{box-shadow:0 6px 20px #0f66;transform:translateY(-2px)}.violation-modal{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000b3;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-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px #0006;max-width:500px;padding:clamp(1.5rem,4vw,2.5rem);text-align:center;width:90%}.violation-content h2{color:var(--text-primary);margin:0 0 1rem}.violation-content p,.violation-content ul{color:var(--text-secondary);margin:0 0 1.5rem}.violation-content ul{padding-left:1.5rem;text-align:left}.violation-content li{margin-bottom:.5rem}.violation-content button{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:24px;color:var(--bg-primary);cursor:pointer;font-size:15px;font-weight:600;padding:14px 32px;transition:all .3s ease}.violation-content button:hover{box-shadow:0 6px 20px #0f66;transform:scale(1.05)}@media (max-width:768px){.community-page{flex-direction:column;padding-top:50px}.community-topbar{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;gap:12px;height:50px;left:0;padding:0 14px;position:fixed;right:0;top:0;z-index:100}.community-topbar .hamburger{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;padding:6px;width:36px}.community-topbar .hamburger:hover{background:var(--accent-primary);color:var(--bg-primary)}.community-topbar .topbar-title{color:var(--text-primary);font-size:16px;font-weight:700}.community-sidebar{bottom:0;box-shadow:4px 0 20px #0003;left:0;max-width:300px;position:fixed;top:0;transform:translateX(-110%);transition:transform .3s ease;width:85%;z-index:200}.community-sidebar.open{transform:translateX(0)}.community-main{padding-top:0}.msg-bubble{max-width:85%}}@media (max-width:480px){.chat-header-comm{align-items:flex-start;flex-direction:column}.header-actions{width:100%}.join-btn,.leave-btn{flex:1 1;justify-content:center}.msg-input-area form{gap:8px}.msg-input{padding:10px 14px}.msg-send{height:44px;width:44px}}.reports-container{background:var(--bg-primary);box-sizing:border-box;color:var(--text-primary);min-height:100vh;padding:clamp(1rem,3vw,2rem);position:relative;width:100vw}.reports-container:before{background:radial-gradient(circle at 20% 30%,#00ff660a 0,#0000 40%),radial-gradient(circle at 80% 70%,#3b82f60a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.reports-header{align-items:center;display:flex;gap:clamp(1rem,3vw,2rem);margin-bottom:clamp(1.5rem,4vw,2.5rem);position:relative;z-index:1}.reports-back-btn{font-size:.85rem;padding:.5rem .8rem}.reports-header h1{color:var(--text-primary);font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;margin:0}.reports-content{display:flex;flex-direction:column;gap:clamp(1.5rem,4vw,2.5rem);margin:0 auto;max-width:900px;position:relative;z-index:1}.upload-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 20px #0000001a;padding:clamp(1.5rem,4vw,2.5rem)}.upload-section h2{align-items:center;color:var(--text-primary);display:flex;font-size:clamp(1.1rem,2.5vw,1.4rem);gap:.75rem;margin-bottom:1.5rem}.upload-section h2 svg{color:var(--accent-primary)}.drop-zone{background:var(--bg-tertiary);border:2px dashed var(--border-color);border-radius:16px;cursor:pointer;padding:clamp(1.5rem,4vw,2.5rem);text-align:center;transition:all .3s ease}.drop-zone.active,.drop-zone:hover{background:#00ff660d;border-color:var(--accent-primary)}.file-input{display:none}.drop-label{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:.75rem}.drop-label p{color:var(--text-secondary);font-size:clamp(.9rem,2vw,1rem);margin:0}.drop-label .file-icon{color:var(--text-muted)}.drop-label .file-icon.success{color:var(--accent-primary)}.drop-label .file-name{color:var(--text-primary);font-weight:600}.drop-label .file-size{color:var(--text-muted);font-size:clamp(.8rem,1.8vw,.9rem)}.drop-hint{font-size:clamp(.8rem,1.8vw,.85rem);opacity:.7}.preview-container{border:1px solid var(--border-color);border-radius:12px;margin-top:1.5rem;overflow:hidden}.preview-image{background:var(--bg-tertiary);max-height:300px;object-fit:contain;width:100%}.upload-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}.btn{align-items:center;display:flex;gap:.5rem}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #0f66;transform:translateY(-2px)}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--hover-bg)}.btn:disabled{cursor:not-allowed;opacity:.5}.reports-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 20px #0000001a;padding:clamp(1.5rem,4vw,2.5rem)}.reports-section h2{align-items:center;color:var(--text-primary);display:flex;font-size:clamp(1.1rem,2.5vw,1.4rem);gap:.75rem;margin-bottom:1.5rem}.reports-section h2 svg{color:var(--accent-primary)}.loading-state{color:var(--text-secondary);padding:3rem;text-align:center}.spinner{border:3px solid var(--border-color);height:40px;width:40px}.empty-state{color:var(--text-muted);padding:3rem;text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p{color:var(--text-secondary);font-size:clamp(1rem,2.5vw,1.2rem);margin:0 0 .5rem}.empty-state span{font-size:clamp(.85rem,1.8vw,.95rem)}.reports-list{display:flex;flex-direction:column;gap:1.5rem}.report-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;transition:all .3s ease}.report-card:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-2px)}.report-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.5rem}.report-info h3{color:var(--text-primary);font-size:clamp(1rem,2.2vw,1.2rem);margin:0}.report-date{align-items:center;color:var(--text-muted);display:flex;font-size:clamp(.8rem,1.8vw,.9rem);gap:.4rem;margin-top:.25rem}.report-content{padding:1.5rem}.report-analysis{margin-bottom:1.5rem}.report-analysis h4{align-items:center;color:var(--accent-primary);display:flex;font-size:clamp(.9rem,2vw,1rem);gap:.5rem;margin:0 0 1rem}.analysis-item{border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;padding:.5rem 0}.analysis-item:last-child{border-bottom:none}.analysis-item .label{color:var(--text-secondary);font-weight:600;min-width:70px}.analysis-item .value{color:var(--text-primary)}.analysis-summary{background:var(--bg-secondary);border-radius:10px;margin-top:1rem;padding:1rem}.analysis-summary .label{color:var(--text-secondary);display:block;font-weight:600;margin-bottom:.5rem}.analysis-summary p{color:var(--text-primary);line-height:1.6;margin:0}.ocr-section{margin-top:1.5rem}.ocr-section h4{color:var(--text-secondary);font-size:clamp(.9rem,2vw,1rem);margin:0 0 .75rem}.ocr-text{word-wrap:break-word;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:clamp(.8rem,1.8vw,.9rem);margin:0;overflow-x:auto;padding:1rem;white-space:pre-wrap}.report-image{padding:1rem 1.5rem 1.5rem}.report-image img{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;max-height:400px;object-fit:contain;width:100%}@media (max-width:600px){.reports-header{align-items:flex-start;gap:1rem}.reports-header,.upload-actions{flex-direction:column}.btn{justify-content:center;width:100%}}.progress-container{background:var(--bg-primary);box-sizing:border-box;color:var(--text-primary);min-height:100vh;padding:clamp(1rem,3vw,2rem);position:relative;width:100vw}.progress-container:before{background:radial-gradient(circle at 20% 30%,#00ff660a 0,#0000 40%),radial-gradient(circle at 80% 70%,#3b82f60a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.progress-header{gap:clamp(1rem,3vw,2rem);margin-bottom:clamp(1.5rem,4vw,2.5rem);position:relative;z-index:1}.back-btn,.progress-header{align-items:center;display:flex}.back-btn{background:#0000;border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;font-size:clamp(.9rem,2vw,1rem);font-weight:600;gap:.5rem;padding:clamp(.5rem,1.5vw,.75rem) clamp(.75rem,2vw,1.2rem);transition:all .25s ease}.back-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.progress-header h1{color:var(--text-primary);font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;margin:0}.progress-back-btn{font-size:.85rem;padding:.5rem .8rem}.progress-content{display:flex;flex-direction:column;gap:clamp(1.5rem,4vw,2rem);margin:0 auto;max-width:800px;position:relative;z-index:1}.summary-card{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:20px;box-shadow:0 8px 30px #00ff664d;gap:1.5rem;padding:clamp(1.5rem,4vw,2rem)}.card-icon,.summary-card{align-items:center;display:flex}.card-icon{background:#fff3;border-radius:16px;color:#fff;flex-shrink:0;height:60px;justify-content:center;width:60px}.card-content{flex:1 1}.card-content h2{color:#fff;font-size:clamp(1.1rem,2.5vw,1.4rem);margin:0}.card-subtitle{color:#ffffffd9;font-size:clamp(.85rem,1.8vw,.95rem);margin:.25rem 0 0}.refresh-btn{align-items:center;background:#fff3;border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .25s ease;width:44px}.refresh-btn:hover{background:#ffffff4d;transform:scale(1.05)}.refresh-btn .spinning{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:3rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:50px;margin:0 auto 1rem;width:50px}.loading-card p{color:var(--text-secondary);margin:0}.empty-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:3rem;text-align:center}.empty-card svg{color:var(--text-muted);margin-bottom:1rem;opacity:.5}.empty-card h3{color:var(--text-primary);margin:0 0 .5rem}.empty-card p{color:var(--text-secondary);margin:0 0 1.5rem}.mood-overview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;flex-wrap:wrap;gap:2rem;padding:clamp(1.5rem,4vw,2rem)}.mood-overview,.mood-score{align-items:center;display:flex}.mood-score{gap:1rem}.mood-score .emoji{font-size:4rem}.score-details{display:flex;flex-direction:column}.score-value{color:var(--accent-primary);font-size:2.5rem;font-weight:700;line-height:1}.score-label{color:var(--text-muted);font-size:.9rem}.mood-stats{display:flex;flex:1 1;flex-wrap:wrap;gap:2rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{color:var(--text-muted);font-size:.85rem}.stat-value{align-items:center;color:var(--text-primary);display:flex;font-size:1.2rem;font-weight:600;gap:.4rem}.stat-value.trend.positive{color:var(--mood-high)}.stat-value.trend.negative{color:var(--mood-verylow)}.stat-value.trend.neutral{color:var(--mood-mid)}.trend-up{color:var(--mood-high)}.trend-down{color:var(--mood-verylow)}.trend-neutral{color:var(--mood-mid)}.worst-day-card{align-items:center;background:linear-gradient(135deg,var(--mood-verylow),#8b5cf6);border-radius:16px;box-shadow:0 6px 25px #ef444440;display:flex;gap:1rem;padding:clamp(1.25rem,3vw,1.5rem)}.worst-day-icon{align-items:center;background:#fff3;border-radius:12px;color:#fff;display:flex;flex-shrink:0;height:50px;justify-content:center;width:50px}.worst-day-content{flex:1 1}.worst-day-content h3{color:#ffffffe6;font-size:.95rem;font-weight:500;margin:0}.worst-day-date{color:#fff;font-size:1.1rem;font-weight:700;margin:.25rem 0 0}.worst-day-note{color:#fffc;font-size:.85rem;font-style:italic;margin:.25rem 0 0}.worst-day-score{align-items:center;display:flex;flex-direction:column;text-align:center}.worst-day-score .score{color:#fff;font-size:1.8rem;font-weight:700}.worst-day-score .label{color:#ffffffb3;font-size:.75rem}.best-day-card{background:linear-gradient(135deg,var(--mood-high),#10b981);border-radius:14px;box-shadow:0 6px 25px #10b98140;gap:1rem;padding:clamp(1rem,2.5vw,1.25rem)}.best-day-card,.best-day-icon{align-items:center;display:flex}.best-day-icon{background:#fff3;border-radius:10px;color:#fff;flex-shrink:0;height:44px;justify-content:center;width:44px}.best-day-content{flex:1 1}.best-day-content h3{color:#ffffffe6;font-size:.9rem;font-weight:500;margin:0}.best-day-date{color:#fff;font-size:1rem;font-weight:700;margin:.2rem 0 0}.best-day-note{color:#fffc;font-size:.8rem;margin:.2rem 0 0}.activity-summary{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-around;padding:clamp(1.25rem,3vw,1.5rem)}.activity-item{align-items:center;display:flex;flex-direction:column;gap:.25rem;text-align:center}.activity-value{color:var(--accent-primary);font-size:1.6rem;font-weight:700}.activity-label{color:var(--text-muted);font-size:.8rem}.narrative-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:clamp(1.5rem,4vw,2rem)}.narrative-card h3{color:var(--text-primary);font-size:clamp(1rem,2.2vw,1.2rem);margin:0 0 1rem}.narrative-card .headline{color:var(--accent-primary);font-size:clamp(1.1rem,2.5vw,1.3rem);font-weight:600;margin:0 0 .75rem}.narrative-card .detail{color:var(--text-secondary);line-height:1.7;margin:0}.keywords-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:clamp(1.5rem,4vw,2rem)}.keywords-card h3{align-items:center;color:var(--text-primary);display:flex;font-size:clamp(1rem,2.2vw,1.2rem);gap:.5rem;margin:0 0 1rem}.keywords-card h3 svg{color:var(--warning)}.keywords-list{display:flex;flex-wrap:wrap;gap:.75rem}.keyword-item{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;display:flex;gap:.5rem;padding:.5rem 1rem}.keyword-text{color:var(--text-primary);font-weight:500}.keyword-count{color:var(--text-muted);font-size:.85rem}.recommendations-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:clamp(1.5rem,4vw,2rem)}.recommendations-card h3{color:var(--text-primary);font-size:clamp(1rem,2.2vw,1.2rem);margin:0 0 1.5rem}.recommendation-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1rem;padding:1.25rem}.recommendation-item:last-child{margin-bottom:0}.recommendation-item h4{color:var(--accent-primary);font-size:clamp(.95rem,2vw,1.1rem);margin:0 0 .5rem}.recommendation-item .reason{color:var(--text-secondary);font-size:.9rem;margin:0 0 .75rem}.tips-list{color:var(--text-primary);margin:0;padding-left:1.25rem}.tips-list li{margin-bottom:.25rem}.tips-list li:last-child{margin-bottom:0}.tips-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:clamp(1.5rem,4vw,2rem)}.tips-card h3{color:var(--text-primary);font-size:clamp(1rem,2.2vw,1.2rem);margin:0 0 1rem}.tips-card ul{color:var(--text-secondary);margin:0;padding-left:1.25rem}.tips-card li{margin-bottom:.5rem}.tips-card li:last-child{margin-bottom:0}.btn{border:none;border-radius:12px;cursor:pointer;font-size:clamp(.9rem,2vw,1rem);font-weight:600;padding:clamp(.7rem,2vw,.9rem) clamp(1.2rem,3vw,2rem);transition:all .25s ease}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));box-shadow:0 4px 15px #00ff664d;color:var(--bg-primary)}.btn-primary:hover{box-shadow:0 6px 20px #0f66;transform:translateY(-2px)}@media (max-width:600px){.progress-header{align-items:flex-start;flex-direction:column;gap:1rem}.mood-overview,.summary-card{flex-direction:column;text-align:center}.mood-stats{justify-content:center}.best-day-card,.worst-day-card{flex-direction:column;text-align:center}.activity-summary{gap:.75rem}.activity-item{min-width:80px}}.settings-container{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-y:auto;padding:clamp(1rem,3vw,2.5rem);position:relative;transition:background-color .3s ease,color .3s ease;width:100vw}.settings-container:before{background:radial-gradient(circle at 10% 20%,#00ff6608 0,#0000 40%),radial-gradient(circle at 90% 80%,#3b82f608 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.settings-header{align-items:center;display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,2rem);margin-bottom:clamp(1.5rem,4vw,3rem);position:relative;z-index:1}.settings-back-btn{font-size:.85rem;padding:.5rem .8rem}.settings-header h1{color:var(--text-primary);font-size:clamp(1.5rem,4vw,2.5rem);margin:0;transition:color .3s ease}.settings-content{display:flex;flex-direction:column;gap:clamp(1.5rem,3vw,2.5rem);margin:0 auto;max-width:900px;position:relative;z-index:1}.settings-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 20px #0000001a;padding:clamp(1.2rem,3vw,2rem);transition:background-color .3s ease,box-shadow .3s ease}.section-desc{color:var(--text-secondary);font-size:clamp(.85rem,1.8vw,.95rem);margin-bottom:clamp(1rem,2vw,1.5rem);margin-top:-.5rem}.section-header{align-items:center;color:var(--accent-primary);display:flex;gap:clamp(.75rem,2vw,1.2rem);margin-bottom:clamp(.5rem,1.5vw,1rem)}.section-header h2{color:var(--text-primary);font-size:clamp(1.1rem,2.5vw,1.4rem);margin:0;transition:color .3s ease}.theme-grid{grid-gap:clamp(1rem,2.5vw,1.5rem);display:grid;gap:clamp(1rem,2.5vw,1.5rem);grid-template-columns:repeat(auto-fit,minmax(clamp(100px,25vw,150px),1fr))}.theme-option{align-items:center;background:#0000;border:2px solid var(--border-color);border-radius:16px;cursor:pointer;display:flex;flex-direction:column;gap:clamp(.75rem,1.5vw,1rem);overflow:hidden;padding:clamp(1rem,2vw,1.5rem);position:relative;transition:all .3s ease}.theme-option:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.theme-option.active,.theme-option:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.theme-option.active{box-shadow:0 0 20px #00ff664d}.theme-preview{align-items:center;border-radius:14px;box-shadow:0 4px 15px #0003;display:flex;height:clamp(60px,15vw,90px);justify-content:center;transition:transform .3s ease;width:clamp(60px,15vw,90px)}.theme-option:hover .theme-preview{transform:scale(1.08)}.theme-option p{color:var(--text-primary);font-size:clamp(.8rem,1.8vw,.95rem);font-weight:600;margin:0;text-align:center}.checkmark{align-items:center;background:var(--accent-primary);border-radius:50%;box-shadow:0 2px 10px #0f66;color:var(--bg-primary);display:flex;font-size:14px;font-weight:700;height:26px;justify-content:center;position:absolute;right:8px;top:8px;width:26px}.accent-color-grid{grid-gap:clamp(.8rem,2vw,1.2rem);display:grid;gap:clamp(.8rem,2vw,1.2rem);grid-template-columns:repeat(auto-fit,minmax(clamp(70px,15vw,100px),1fr))}.accent-option{align-items:center;background:#0000;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;overflow:hidden;padding:clamp(.6rem,1.5vw,1rem);position:relative;transition:all .3s ease}.accent-option:hover{border-color:var(--accent-primary);box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.accent-option.active{border-color:var(--accent-primary);box-shadow:0 0 15px #00ff664d}.accent-preview{border-radius:50%;box-shadow:0 2px 10px #0003;height:clamp(40px,10vw,55px);transition:transform .3s ease;width:clamp(40px,10vw,55px)}.accent-option:hover .accent-preview{transform:scale(1.1)}.accent-option p{color:var(--text-secondary);font-size:clamp(.7rem,1.5vw,.8rem);font-weight:500;margin:0;text-align:center}.accent-option.active p{color:var(--text-primary)}.bg-image-grid{grid-gap:clamp(.8rem,2vw,1.2rem);display:grid;gap:clamp(.8rem,2vw,1.2rem);grid-template-columns:repeat(auto-fit,minmax(clamp(80px,18vw,110px),1fr))}.bg-option{align-items:center;background:#0000;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;overflow:hidden;padding:clamp(.6rem,1.5vw,1rem);position:relative;transition:all .3s ease}.bg-option:hover{border-color:var(--accent-primary);box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.bg-option.active{border-color:var(--accent-primary);box-shadow:0 0 15px #00ff664d}.bg-preview{align-items:center;aspect-ratio:16/9;background-position:50%;background-size:cover;border-radius:8px;box-shadow:0 2px 10px #0003;color:#fff;display:flex;justify-content:center;transition:transform .3s ease;width:100%}.bg-option:hover .bg-preview{transform:scale(1.05)}.bg-option p{color:var(--text-secondary);font-size:clamp(.65rem,1.3vw,.75rem);font-weight:500;line-height:1.2;margin:0;text-align:center}.bg-option.active p{color:var(--text-primary)}.setting-item{align-items:center;border-radius:10px;display:flex;gap:1rem;margin-bottom:.5rem;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.8vw,1rem);gap:.75rem;width:100%}.setting-item input[type=checkbox]{accent-color:var(--accent-primary);cursor:pointer;height:clamp(18px,4vw,22px);width:clamp(18px,4vw,22px)}.about-text{color:var(--text-secondary);font-size:clamp(.85rem,1.8vw,1rem);line-height:1.6;margin:clamp(.5rem,1.5vw,1rem) 0;transition:color .3s ease}.about-text strong{color:var(--text-primary)}.about-info{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;margin-top:1rem;padding:1rem}.info-row{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;padding:.5rem 0}.info-row:last-child{border-bottom:none}.info-row span{color:var(--text-secondary)}.info-row span,.info-row strong{font-size:clamp(.85rem,1.8vw,.95rem)}.info-row strong{color:var(--text-primary)}.accent-dot{border-radius:50%;box-shadow:0 2px 6px #0003;height:16px;width:16px}@media (max-width:359px){.settings-container{padding:.75rem}.settings-header{align-items:flex-start;flex-direction:column;gap:.75rem}.theme-grid{grid-template-columns:repeat(2,1fr)}.accent-color-grid{grid-template-columns:repeat(3,1fr)}.bg-image-grid{grid-template-columns:repeat(2,1fr)}.settings-section{padding:1rem}}@media (min-width:360px) and (max-width:480px){.settings-container{padding:1rem}.settings-header{gap:.75rem}.accent-color-grid,.bg-image-grid,.theme-grid{grid-template-columns:repeat(3,1fr)}.settings-section{padding:1.2rem}}@media (min-width:481px) and (max-width:768px){.theme-grid{grid-template-columns:repeat(3,1fr)}.accent-color-grid,.bg-image-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:769px) and (max-width:1024px){.theme-grid{grid-template-columns:repeat(3,1fr)}.accent-color-grid,.bg-image-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1025px){.theme-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.accent-color-grid{grid-template-columns:repeat(auto-fit,minmax(90px,1fr))}.bg-image-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}}.help-container{background:var(--bg-primary);box-sizing:border-box;color:var(--text-primary);min-height:100vh;overflow-y:auto;padding:clamp(1rem,3vw,2rem);position:relative;width:100vw}.help-container:before{background:radial-gradient(circle at 15% 25%,#00ff660a 0,#0000 40%),radial-gradient(circle at 85% 75%,#3b82f60a 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.help-content{margin:0 auto;max-width:900px;padding:clamp(1rem,3vw,2rem);position:relative;z-index:1}.help-header{align-items:center;display:flex;gap:1.5rem;margin-bottom:clamp(1.5rem,4vw,2rem);padding-top:1rem}.help-back-btn{font-size:.85rem;padding:.5rem .8rem}.help-header h1{color:var(--text-primary);font-size:clamp(1.3rem,3.5vw,1.8rem);font-weight:700;margin:0;text-shadow:0 2px 15px #0000001a}.help-header p{color:var(--text-secondary);font-size:clamp(.95rem,2.5vw,1.2rem)}.help-tabs{border-bottom:2px solid var(--border-color);display:flex;gap:.5rem;margin-bottom:clamp(1.5rem,4vw,2.5rem);overflow-x:auto}.tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:var(--text-secondary);cursor:pointer;font-size:clamp(.9rem,2vw,1rem);font-weight:600;padding:clamp(.6rem,1.5vw,.9rem) clamp(1.2rem,3vw,2rem);transition:all .25s ease;white-space:nowrap}.tab-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab-btn.active{border-bottom-color:var(--accent-primary);color:var(--accent-primary)}.help-section,.tab-btn.active{background:var(--bg-secondary)}.help-section{border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 20px #0000001a;margin-bottom:clamp(1.5rem,4vw,2rem);padding:clamp(1.5rem,4vw,2.5rem);transition:all .3s ease}.help-section:hover{box-shadow:0 8px 30px #00000026}.help-section h3{align-items:center;color:var(--accent-primary);display:flex;font-size:clamp(1.1rem,3vw,1.5rem);font-weight:700;gap:.75rem;margin-bottom:1rem}.help-section li,.help-section p{color:var(--text-secondary);font-size:clamp(.9rem,2vw,1rem);line-height:1.7}.help-section ul{list-style:none;margin:1rem 0;padding:0}.help-section li{border-bottom:1px solid var(--border-color);padding:.6rem 0 .6rem 1.5rem;position:relative}.help-section li:last-child{border-bottom:none}.help-section li:before{color:var(--accent-primary);content:"•";font-size:1.2rem;font-weight:700;left:0;position:absolute}.faq-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1rem;padding:clamp(1rem,2.5vw,1.5rem);transition:all .25s ease}.faq-item:hover{border-color:var(--accent-primary);box-shadow:0 4px 15px #0000001a}.faq-item:last-child{margin-bottom:0}.faq-item strong{color:var(--text-primary);display:block;font-size:clamp(.95rem,2.2vw,1.1rem);margin-bottom:.5rem}.faq-item p{color:var(--text-secondary);margin:0}.contact-info{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.contact-item{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:1rem;padding:1rem}.contact-item span{color:var(--text-secondary);font-size:clamp(.9rem,2vw,1rem)}.features-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem}.feature-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;text-align:center;transition:all .25s ease}.feature-card:hover{border-color:var(--accent-primary);box-shadow:0 8px 25px #00000026;transform:translateY(-4px)}.feature-card h4{color:var(--accent-primary);font-size:clamp(.95rem,2vw,1.1rem);margin-bottom:.5rem}.feature-card p{font-size:clamp(.8rem,1.8vw,.9rem);margin:0}@media (max-width:600px){.help-tabs{border-bottom:none;flex-direction:column}.tab-btn{border:1px solid var(--border-color);border-radius:10px;margin-bottom:.5rem}.tab-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.features-grid{grid-template-columns:1fr}}@media (min-width:601px) and (max-width:900px){.features-grid{grid-template-columns:repeat(2,1fr)}}.games-page{background:var(--bg-primary);min-height:100vh;padding:clamp(1rem,3vw,2rem)}.games-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:clamp(1rem,3vw,1.5rem)}.games-back-btn{font-size:.85rem;padding:.5rem .8rem}.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.634d55a3.css.map*/