:root{--c-bg:#f8f9fc;--c-surface:#fff;--c-border:#e4e7ef;--c-text:#374151;--c-muted:#6b7280;--c-heading:#111827;--c-accent:#6366f1;--c-accent-lt:#eef2ff;--c-accent-bd:#a5b4fc;--c-ok:#16a34a;--c-ok-bg:#dcfce7;--c-err:#dc2626;--c-err-bg:#fee2e2;--c-code-bg:#f1f5f9;--sidebar-w:240px;--topbar-h:56px;--bottom-nav-h:64px;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "SF Mono", Consolas, monospace;font-family:var(--sans);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-size:15px;line-height:1.6}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--c-bg)}h1{color:var(--c-heading);letter-spacing:-.5px;font-size:1.6rem;font-weight:700}h2{color:var(--c-heading);font-size:1.15rem;font-weight:600}h3{color:var(--c-heading);font-size:1rem;font-weight:600}p{color:var(--c-muted);font-size:.9rem}code{font-family:var(--mono);background:var(--c-code-bg);color:var(--c-accent);border-radius:4px;padding:2px 6px;font-size:.8rem}button{font-family:var(--sans);cursor:pointer}input{font-family:var(--sans)}ul{list-style:none}.layout{min-height:100dvh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--c-surface);border-right:1px solid var(--c-border);z-index:200;flex-direction:column;flex-shrink:0;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--c-border);align-items:center;gap:10px;padding:20px 18px 16px;display:flex}.logo-mark{background:var(--c-accent);color:#fff;border-radius:8px;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:16px;font-weight:800;display:grid}.logo-text{color:var(--c-heading);flex:1;font-size:1rem;font-weight:700}.sidebar-close{display:none}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.nav-item{border-radius:var(--radius-sm);width:100%;color:var(--c-muted);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--c-accent-lt);color:var(--c-accent)}.nav-item--active{background:var(--c-accent-lt);color:var(--c-accent);font-weight:600}.nav-icon{align-items:center;display:flex}.sidebar-footer{color:var(--c-muted);border-top:1px solid var(--c-border);padding:14px 18px;font-size:.75rem}.overlay{z-index:190;background:#00000059;position:fixed;inset:0}.main{min-width:0;margin-left:var(--sidebar-w);flex-direction:column;flex:1;display:flex}.topbar{height:var(--topbar-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);z-index:100;align-items:center;gap:12px;padding:0 16px;display:none;position:sticky;top:0}.topbar-menu{color:var(--c-text);background:0 0;border:none;padding:4px;display:flex}.topbar-title{color:var(--c-heading);font-weight:600}.content{flex:1;overflow-y:auto}.bottom-nav{height:var(--bottom-nav-h);background:var(--c-surface);border-top:1px solid var(--c-border);z-index:200;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--c-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 0;font-size:.7rem;font-weight:500;transition:color .15s;display:flex}.bottom-nav-item--active{color:var(--c-accent)}.page{max-width:700px;padding:28px 28px 48px}.page-title{margin-bottom:24px}.page-title h1{margin-bottom:4px}.page-subtitle{color:var(--c-muted);font-size:.85rem}.search-form{margin-bottom:24px}.search-box{background:var(--c-surface);border:1.5px solid var(--c-border);box-shadow:var(--shadow-sm);border-radius:50px;align-items:center;gap:8px;padding:4px 4px 4px 16px;transition:border-color .2s;display:flex}.search-box:focus-within{border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-lt)}.search-icon{flex-shrink:0;font-size:16px}.search-box input{color:var(--c-heading);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:.95rem}.search-box input::placeholder{color:var(--c-muted)}.search-box button{background:var(--c-accent);color:#fff;border:none;border-radius:50px;flex-shrink:0;padding:9px 20px;font-size:.88rem;font-weight:600;transition:opacity .2s}.search-box button:disabled{opacity:.5;cursor:default}.suggestions{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.suggestion-chip{background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text);border-radius:50px;padding:5px 14px;font-size:.8rem;transition:background .15s,border-color .15s,color .15s}.suggestion-chip:hover{background:var(--c-accent-lt);border-color:var(--c-accent-bd);color:var(--c-accent)}.today-card{border-radius:var(--radius);color:#1e293b;box-shadow:var(--shadow-md);margin-bottom:16px;padding:28px 28px 24px;position:relative;overflow:hidden}.today-top{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.today-city{color:#1e293b;font-size:1.25rem;font-weight:700}.today-region{color:#475569;margin-top:2px;font-size:.8rem}.today-emoji{filter:drop-shadow(0 2px 4px #0000001a);font-size:3.5rem;line-height:1}.today-temp{color:#0f172a;letter-spacing:-2px;margin-bottom:4px;font-size:4.5rem;font-weight:800;line-height:1}.today-label{color:#334155;margin-bottom:20px;font-size:1rem;font-weight:500}.today-meta{color:#334155;background:#ffffff73;border-radius:8px;flex-wrap:wrap;gap:16px;padding:10px 14px;font-size:.85rem;font-weight:500;display:flex}.forecast-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.forecast-header{color:var(--c-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--c-border);padding:14px 18px 10px;font-size:.8rem;font-weight:600}.forecast-row{border-bottom:1px solid var(--c-border);grid-template-columns:80px 40px 1fr 60px 72px;align-items:center;gap:10px;padding:13px 18px;transition:background .12s;display:grid}.forecast-row:last-child{border-bottom:none}.forecast-row:hover{background:var(--c-bg)}.fc-day{flex-direction:column;display:flex}.fc-day-short{color:var(--c-heading);font-size:.88rem;font-weight:600}.fc-day-long{color:var(--c-muted);font-size:.75rem}.fc-emoji{text-align:center;font-size:1.5rem}.fc-label{color:var(--c-text);font-size:.82rem}.fc-precip{color:#3b82f6;text-align:right;font-size:.8rem}.fc-no-precip{color:var(--c-muted)}.fc-temps{justify-content:flex-end;gap:6px;display:flex}.fc-max{color:var(--c-heading);font-size:.9rem;font-weight:700}.fc-min{color:var(--c-muted);font-size:.9rem}.weather-loading,.weather-empty{color:var(--c-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.weather-empty-icon{font-size:3rem}.spinner{font-size:2rem;animation:1.5s linear infinite spin;display:block}@keyframes spin{to{transform:rotate(360deg)}}.weather-error{background:var(--c-err-bg);color:var(--c-err);border-radius:var(--radius-sm);border:1px solid #fecaca;align-items:center;gap:8px;padding:14px 16px;font-size:.9rem;display:flex}.database-page{flex-direction:column;gap:20px;display:flex}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px}.status-card-title{text-transform:uppercase;letter-spacing:.5px;color:var(--c-muted);margin-bottom:14px;font-size:.75rem;font-weight:600}.status-grid{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.status-row{align-items:center;gap:10px;display:flex}.db-icon{font-size:1.1rem}.db-name{color:var(--c-heading);min-width:110px;font-size:.9rem;font-weight:600}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge.ok{background:var(--c-ok-bg);color:var(--c-ok)}.badge.err{background:var(--c-err-bg);color:var(--c-err)}.badge.loading{background:var(--c-code-bg);color:var(--c-muted)}.error-msg{color:var(--c-err);font-size:.75rem;font-family:var(--mono);background:var(--c-err-bg);word-break:break-all;border-radius:6px;padding:6px 10px}.btn-secondary{border-radius:var(--radius-sm);border:1.5px solid var(--c-border);background:var(--c-bg);color:var(--c-text);padding:8px 18px;font-size:.85rem;font-weight:500;transition:border-color .15s,background .15s}.btn-secondary:hover:not(:disabled){border-color:var(--c-accent-bd);background:var(--c-accent-lt);color:var(--c-accent)}.btn-secondary:disabled{opacity:.6;cursor:default}.db-section{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px}.db-section-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.db-section-icon{font-size:1.2rem}.add-form{gap:8px;margin-bottom:14px;display:flex}.add-form input{border:1.5px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-bg);min-width:0;color:var(--c-heading);outline:none;flex:1;padding:9px 13px;font-size:.9rem;transition:border-color .2s}.add-form input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-lt)}.add-form button{border-radius:var(--radius-sm);background:var(--c-accent);color:#fff;border:none;flex-shrink:0;padding:9px 18px;font-size:.88rem;font-weight:600;transition:opacity .2s}.add-form button:disabled{opacity:.5;cursor:default}.item-list{flex-direction:column;gap:6px;display:flex}.item-list li{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:9px 12px;font-size:.88rem;display:flex}.item-id{color:var(--c-muted);font-family:var(--mono);flex-shrink:0;min-width:32px;font-size:.78rem}.item-name{color:var(--c-heading);word-break:break-word;flex:1;font-weight:500}.item-date{color:var(--c-muted);white-space:nowrap;flex-shrink:0;font-size:.75rem}.del-btn{color:var(--c-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;flex-shrink:0;padding:3px 7px;font-size:.78rem;transition:background .12s,color .12s}.del-btn:hover{background:var(--c-err-bg);color:var(--c-err)}.empty{color:var(--c-muted);padding:6px 0;font-size:.85rem;font-style:italic}.ideas-add-card{margin-bottom:16px}.ideas-input-row{align-items:stretch;gap:8px;display:flex}.ideas-input{border:1.5px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-bg);min-width:0;color:var(--c-heading);outline:none;flex:1;padding:9px 13px;font-size:.9rem;transition:border-color .2s}.ideas-input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-lt)}.ideas-select{border:1.5px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-bg);color:var(--c-text);font-size:.85rem;font-family:var(--sans);cursor:pointer;outline:none;flex-shrink:0;padding:9px 10px;transition:border-color .2s}.ideas-select:focus{border-color:var(--c-accent)}.ideas-add-btn{border-radius:var(--radius-sm);background:var(--c-accent);color:#fff;border:none;flex-shrink:0;padding:9px 18px;font-size:.88rem;font-weight:600;transition:opacity .2s}.ideas-add-btn:disabled{opacity:.5;cursor:default}.ideas-tabs{border-bottom:2px solid var(--c-border);gap:0;margin-bottom:16px;display:flex}.ideas-tab{color:var(--c-muted);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;margin-bottom:-2px;padding:10px 18px;font-size:.9rem;font-weight:500;transition:color .15s,border-color .15s;display:flex}.ideas-tab:hover{color:var(--c-accent)}.ideas-tab--active{color:var(--c-accent);border-bottom-color:var(--c-accent);font-weight:600}.ideas-tab-count{background:var(--c-accent);color:#fff;border-radius:20px;padding:1px 7px;font-size:.7rem;font-weight:700;line-height:1.5}.ideas-tab-count--done{background:var(--c-ok)}.ideas-list{flex-direction:column;gap:6px;display:flex}.idea-item{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);align-items:center;gap:10px;padding:10px 14px;transition:background .12s;display:flex}.idea-item--done .idea-content{color:var(--c-muted);text-decoration:line-through}.idea-check{border:2px solid var(--c-border);background:var(--c-bg);width:22px;height:22px;color:var(--c-ok);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;transition:border-color .15s,background .15s;display:flex}.idea-check:hover,.idea-item--done .idea-check{border-color:var(--c-ok);background:var(--c-ok-bg)}.idea-content{color:var(--c-heading);word-break:break-word;flex:1;font-size:.9rem}.priority-badge{color:var(--p-color);background:color-mix(in srgb, var(--p-color) 12%, transparent);white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 9px;font-size:.72rem;font-weight:600}.ideas-empty{color:var(--c-muted);justify-content:center;align-items:center;padding:48px 20px;font-size:.9rem;font-style:italic;display:flex}.chat-join{min-height:calc(100dvh - var(--topbar-h));justify-content:center;align-items:center;padding:24px;display:flex}.chat-join-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-md);text-align:center;width:100%;max-width:380px;padding:36px 32px}.chat-join-card h1{margin-bottom:8px}.chat-join-card p{margin-bottom:24px}.chat-join-form{flex-direction:column;gap:12px;display:flex}.chat-join-input{border:1.5px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-bg);width:100%;color:var(--c-heading);text-align:center;outline:none;padding:11px 14px;font-size:1rem;transition:border-color .2s}.chat-join-input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-lt)}.chat-join-btn{border-radius:var(--radius-sm);background:var(--c-accent);color:#fff;border:none;padding:11px;font-size:.95rem;font-weight:600;transition:opacity .2s}.chat-join-btn:disabled{opacity:.4;cursor:default}.chat-layout{height:calc(100dvh - var(--topbar-h));flex-direction:column;display:flex}@media (width>=769px){.chat-layout{height:100dvh}}.chat-header{background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:10px;padding:12px 20px;display:flex}.chat-room-name{color:var(--c-heading);flex:1;font-weight:600}.chat-status{border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.chat-status--on{background:var(--c-ok-bg);color:var(--c-ok)}.chat-status--off{background:var(--c-code-bg);color:var(--c-muted)}.chat-nick-badge{color:var(--c-accent);background:var(--c-accent-lt);text-overflow:ellipsis;white-space:nowrap;border-radius:20px;max-width:120px;padding:3px 10px;font-size:.8rem;font-weight:600;overflow:hidden}.chat-messages{flex-direction:column;flex:1;gap:10px;padding:16px 20px;display:flex;overflow-y:auto}.chat-empty{color:var(--c-muted);margin:auto;font-size:.9rem;font-style:italic}.chat-msg{flex-direction:column;align-self:flex-start;max-width:72%;display:flex}.chat-msg--own{align-self:flex-end}.chat-msg-meta{align-items:baseline;gap:6px;margin-bottom:3px;padding:0 4px;display:flex}.chat-msg--own .chat-msg-meta{flex-direction:row-reverse}.chat-msg-nick{color:var(--c-accent);font-size:.78rem;font-weight:600}.chat-msg--own .chat-msg-nick{color:var(--c-ok)}.chat-msg-time{color:var(--c-muted);font-size:.72rem}.chat-msg-bubble{background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-heading);word-break:break-word;border-radius:12px 12px 12px 2px;padding:9px 14px;font-size:.9rem;line-height:1.45}.chat-msg--own .chat-msg-bubble{background:var(--c-accent);border-color:var(--c-accent);color:#fff;border-radius:12px 12px 2px}.chat-input-row{background:var(--c-surface);border-top:1px solid var(--c-border);flex-shrink:0;gap:8px;padding:12px 16px;display:flex}.chat-input{border:1.5px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-bg);min-width:0;color:var(--c-heading);outline:none;flex:1;padding:10px 14px;font-size:.9rem;transition:border-color .2s}.chat-input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-lt)}.chat-send-btn{border-radius:var(--radius-sm);background:var(--c-accent);color:#fff;border:none;flex-shrink:0;padding:10px 20px;font-size:.88rem;font-weight:600;transition:opacity .2s}.chat-send-btn:disabled{opacity:.4;cursor:default}@media (width<=768px){.chat-layout{height:calc(100dvh - var(--topbar-h) - var(--bottom-nav-h))}.chat-msg{max-width:85%}.chat-input-row{padding:10px 12px}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0);box-shadow:4px 0 20px #0000001f}.sidebar-close{color:var(--c-muted);background:0 0;border:none;justify-content:center;align-items:center;margin-left:auto;padding:4px;display:flex}.topbar{display:flex}.main{margin-left:0}.bottom-nav{display:flex}.content{padding-bottom:var(--bottom-nav-h)}.page{padding:20px 16px 32px}.ideas-input-row{flex-wrap:wrap}.ideas-select{flex:1}.ideas-tab{padding:10px 12px;font-size:.85rem}.today-card{padding:22px 18px 18px}.today-temp{font-size:3.5rem}.today-emoji{font-size:2.8rem}.today-meta{gap:10px;font-size:.8rem}.forecast-row{grid-template-columns:64px 36px 1fr 52px 60px;gap:6px;padding:11px 14px}.fc-label{font-size:.75rem}}
