:root{color-scheme:light;--bg: #f4f5f8;--texture: url(/pattern.svg);--surface: #ffffff;--surface-2: #f0f2f5;--text: #1a1e27;--muted: #6a7280;--border: #e4e7ec;--primary: #4f46e5;--primary-hover: #4338ca;--primary-contrast: #ffffff;--primary-soft: #eef0fe;--danger: #dc2626;--danger-soft: #fef2f2;--danger-border: #fecaca;--success: #16a34a;--success-soft: #ecfdf3;--ring: rgba(79, 70, 229, .35);--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);--shadow: 0 6px 22px rgba(16, 24, 40, .1);--radius: 14px;--radius-sm: 10px}[data-theme=dark]{color-scheme:dark;--bg: #0e1016;--texture: url(/pattern-dark.svg);--surface: #171a21;--surface-2: #1f232c;--text: #e7e9ee;--muted: #969eac;--border: #2a2f3a;--primary: #6366f1;--primary-hover: #818cf8;--primary-contrast: #ffffff;--primary-soft: #20233a;--danger: #f87171;--danger-soft: #2a1518;--danger-border: #4c2326;--success: #4ade80;--success-soft: #11271c;--ring: rgba(99, 102, 241, .45);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 8px 26px rgba(0, 0, 0, .55)}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background-color:var(--bg);background-image:var(--texture);background-repeat:repeat;background-size:380px 380px;background-attachment:fixed;color:var(--text);line-height:1.5;transition:background-color .25s ease,color .25s ease}h1,h2,h3{margin:0 0 .75rem;font-weight:700;letter-spacing:-.01em}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:1px solid transparent;border-radius:var(--radius-sm);padding:.6rem 1rem;font:inherit;font-weight:600;font-size:.95rem;cursor:pointer;background:var(--surface-2);color:var(--text);transition:background .15s ease,transform .05s ease,box-shadow .15s ease,opacity .15s ease}.btn svg{width:18px;height:18px}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--primary-contrast);box-shadow:0 2px 8px var(--ring)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface-2);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-small{padding:.35rem .7rem;font-size:.85rem}.btn-block{width:100%}.icon-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.icon-btn:hover{background:var(--surface-2)}.icon-btn.is-active{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}.icon-btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary);box-shadow:0 2px 8px var(--ring)}.icon-btn.primary:hover{background:var(--primary-hover)}.icon-action{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;transition:background .15s ease,color .15s ease}.icon-action:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.icon-action.danger:hover:not(:disabled){background:var(--danger-soft);color:var(--danger)}.icon-action.complete.is-done,.icon-action.success{color:var(--success)}.icon-action.complete:hover:not(:disabled),.icon-action.success:hover:not(:disabled){background:var(--success-soft);color:var(--success)}.icon-action:disabled{opacity:.4;cursor:not-allowed}.field{margin-bottom:1rem;display:flex;flex-direction:column;gap:.4rem}.field-inline{flex-direction:row;align-items:center;gap:.5rem}.field label{font-weight:600;font-size:.88rem}.field input[type=text],.field input[type=email],.field input[type=password],.field input[type=datetime-local],.field input[type=date],.field input[type=time],.field textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font:inherit;transition:border-color .15s ease,box-shadow .15s ease}.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.field input:disabled{background:var(--surface-2);color:var(--muted);cursor:not-allowed}.field-hint{margin:.15rem 0 0;font-size:.82rem;color:var(--muted)}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--surface) 88%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.header-actions{display:flex;align-items:center;gap:.6rem}.app-main{max-width:760px;margin:0 auto;padding:1.75rem 1.5rem 3rem;display:flex;flex-direction:column;gap:1.25rem}.logo{display:flex;align-items:center;gap:.55rem}.logo-text{font-size:1.3rem;font-weight:800;letter-spacing:-.02em}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.4rem}.panel h2{font-size:1.1rem}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-head h2{margin:0}.selection-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:.6rem .85rem;margin-bottom:1rem;background:var(--primary-soft);border:1px solid color-mix(in srgb,var(--primary) 25%,transparent);border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;color:var(--primary)}.selection-actions{display:flex;gap:.4rem}.select-all{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.85rem;font-size:.88rem;font-weight:600;color:var(--muted);cursor:pointer}.select-all input{width:17px;height:17px;accent-color:var(--primary);cursor:pointer}.user-menu{position:relative}.avatar-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--primary-soft);color:var(--primary);cursor:pointer;transition:filter .15s ease}.avatar-btn:hover{filter:brightness(.97)}.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:230px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:.4rem;z-index:50}.user-dropdown-header{display:flex;flex-direction:column;padding:.5rem .6rem .65rem;border-bottom:1px solid var(--border);margin-bottom:.3rem}.user-dropdown-name{font-weight:700}.user-dropdown-email{font-size:.8rem;color:var(--muted);word-break:break-all}.dropdown-item{display:flex;align-items:center;gap:.6rem;width:100%;text-align:left;background:none;border:none;padding:.6rem;border-radius:9px;font:inherit;cursor:pointer;color:var(--text);text-decoration:none}.dropdown-item:hover{text-decoration:none}.dropdown-item svg{width:18px;height:18px;color:var(--muted)}.dropdown-item:hover{background:var(--surface-2)}.dropdown-item-danger{color:var(--danger)}.dropdown-item-danger svg{color:var(--danger)}.todo-form-actions{display:flex;gap:.6rem}.due-input{display:flex;gap:.5rem;align-items:center}.due-input input{flex:1}.todo-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.todo-item{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:.9rem 1rem;display:flex;align-items:flex-start;gap:.8rem;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.todo-item:hover{box-shadow:var(--shadow-sm);border-color:color-mix(in srgb,var(--primary) 35%,var(--border))}.todo-item.is-completed{opacity:.78}.todo-item.is-completed .todo-title{text-decoration:line-through;color:var(--muted)}.todo-item.is-selected{border-color:var(--primary);background:var(--primary-soft)}.todo-select{width:18px;height:18px;margin-top:2px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.todo-item-main{flex:1;min-width:0}.todo-title{font-weight:600;word-break:break-word}.todo-description{margin:.35rem 0 0;color:var(--muted);font-size:.9rem;white-space:pre-wrap;word-break:break-word}.todo-due{display:inline-flex;align-items:center;gap:.3rem;margin:.5rem 0 0;font-size:.8rem;color:var(--primary);background:var(--primary-soft);border:1px solid color-mix(in srgb,var(--primary) 25%,transparent);padding:.12rem .5rem;border-radius:999px}.todo-due svg{width:13px;height:13px}.todo-due.is-overdue{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-border)}.todo-item-actions{display:flex;gap:.25rem;flex-shrink:0}.todo-item-editing{display:block}.empty-state{color:var(--muted);text-align:center;padding:1.75rem 0}.loading-state{display:flex;align-items:center;gap:.6rem;color:var(--muted);padding:1.2rem 0;justify-content:center}.spinner{width:1.05rem;height:1.05rem;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:var(--danger-soft);border:1px solid var(--danger-border);color:var(--danger);padding:.6rem .8rem;border-radius:var(--radius-sm);margin-bottom:.9rem;font-size:.9rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c148c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;padding:1.5rem;overflow-y:auto;z-index:100}.modal-panel{margin:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;width:100%;max-width:440px}.modal-panel.modal-wide{max-width:560px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.modal-title{margin:0}.modal-close{display:grid;place-items:center;width:34px;height:34px;border:none;background:none;color:var(--muted);border-radius:9px;cursor:pointer}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-message{color:var(--text)}.modal-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.25rem}.toast-container{position:fixed;top:1rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:.5rem;z-index:200}.toast{background:var(--text);color:var(--surface);padding:.6rem .9rem;border-radius:999px;box-shadow:var(--shadow);display:flex;align-items:center;gap:.8rem;min-width:220px;font-size:.9rem}.toast-success{background:var(--success);color:#04210f}.toast-info{background:var(--primary);color:#fff}.toast-close{background:none;border:none;color:inherit;font-size:1.1rem;cursor:pointer;line-height:1}.auth-page{min-height:100vh;display:grid;place-items:center;padding:1.5rem;position:relative}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;width:100%;max-width:400px}.auth-card h1{text-align:center}.auth-switch{margin-top:1rem;text-align:center;font-size:.9rem}.auth-theme-toggle{position:fixed;top:1rem;right:1rem;z-index:10}.google-signin{display:flex;flex-direction:column;align-items:center;margin-top:1rem}.auth-divider{width:100%;text-align:center;border-bottom:1px solid var(--border);line-height:.1em;margin:.75rem 0 1.25rem}.auth-divider span{background:var(--surface);padding:0 .6rem;color:var(--muted);font-size:.82rem}.account-section{margin-bottom:.5rem}.account-section h3{font-size:1rem}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin:.25rem 0 1.25rem}.tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;padding:.6rem .95rem;font:inherit;font-weight:600;color:var(--muted);cursor:pointer;transition:color .15s ease,border-color .15s ease}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.profile-head{display:flex;align-items:center;gap:1rem;padding:.1rem 0 1.25rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border)}.profile-avatar{flex-shrink:0;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-size:1.6rem;font-weight:800}.profile-id{min-width:0}.profile-name{font-weight:700;font-size:1.05rem}.profile-email{color:var(--muted);font-size:.88rem;word-break:break-all}.badge{display:inline-block;margin-top:.4rem;font-size:.72rem;font-weight:600;padding:.12rem .55rem;border-radius:999px;background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}.profile-meta{color:var(--muted);font-size:.84rem;margin:.2rem 0 1rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}@media (max-width: 480px){.form-grid{grid-template-columns:1fr}}.account-divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.account-note{background:var(--primary-soft);border:1px solid color-mix(in srgb,var(--primary) 25%,transparent);color:var(--primary);padding:.55rem .7rem;border-radius:var(--radius-sm);font-size:.88rem;margin:0 0 .8rem}.settings-list{margin:.25rem 0 0}.settings-list>div{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.settings-list dt{color:var(--muted);font-size:.9rem}.settings-list dd{margin:0;font-weight:600;text-align:right;word-break:break-all}.calendar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c1466;z-index:80}.calendar-sidebar{position:fixed;top:0;right:0;height:100vh;width:350px;max-width:90vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow);transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:90;display:flex;flex-direction:column;padding:1.1rem;overflow-y:auto}.calendar-sidebar.open{transform:translate(0)}.calendar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem}.calendar-head h2{margin:0}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}.calendar-month{font-weight:700}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday{text-align:center;font-size:.7rem;color:var(--muted);padding-bottom:.3rem;font-weight:600}.calendar-cell{position:relative;aspect-ratio:1;border:none;background:none;border-radius:9px;font:inherit;font-size:.85rem;color:var(--text);cursor:default}.calendar-cell.empty{visibility:hidden}.calendar-cell.has-todos{background:var(--primary-soft);color:var(--primary);font-weight:700;cursor:pointer}.calendar-cell.has-todos:hover{filter:brightness(.96)}.calendar-cell.is-today{outline:2px solid var(--primary);outline-offset:-2px}.calendar-cell.is-selected{background:var(--primary);color:var(--primary-contrast)}.calendar-dot{position:absolute;bottom:5px;left:50%;transform:translate(-50%);width:5px;height:5px;border-radius:50%;background:currentColor}.calendar-day-list{margin-top:1rem;border-top:1px solid var(--border);padding-top:.8rem}.calendar-day-list h3{font-size:.95rem;margin:0 0 .5rem}.calendar-day-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.calendar-day-list li{display:flex;gap:.6rem;font-size:.88rem}.calendar-day-list li.done span:last-child{text-decoration:line-through;color:var(--muted)}.calendar-todo-time{color:var(--muted);min-width:64px}.calendar-hint{color:var(--muted);font-size:.85rem}.about-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;flex-direction:column;background:var(--bg);background-image:var(--texture);background-size:380px 380px}.about-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.5rem;background:color-mix(in srgb,var(--surface) 88%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.about-progress{flex-shrink:0;height:4px;background:var(--surface-2);overflow:hidden}.about-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#38bdf8);transition:width .35s cubic-bezier(.4,0,.2,1)}.about-stage{flex:1;min-height:0;display:flex;padding:1.5rem}.about-slide{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:100%;max-width:1100px;margin:0 auto;padding:1.75rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);animation:about-fade .4s ease}@keyframes about-fade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.about-slide-head{flex-shrink:0;text-align:center}.about-eyebrow{margin:0 0 .3rem;font-size:.8rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--primary)}.about-title{font-size:clamp(1.4rem,2.5vw,2.1rem);margin:0}.about-figure{flex:1;min-height:0;width:100%;display:grid;place-items:center;overflow:hidden}.about-figure svg{max-width:100%;max-height:100%;height:auto;color:var(--muted)}.about-points{flex-shrink:0;list-style:none;margin:0;padding:0;max-width:820px;display:flex;flex-direction:column;gap:.55rem}.about-points li{position:relative;padding-left:1.5rem;color:var(--text);line-height:1.5;font-size:.96rem}.about-points li:before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#38bdf8)}.about-controls{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem}.about-dots{display:flex;gap:.5rem}.about-dot{width:10px;height:10px;padding:0;border:none;border-radius:50%;background:var(--border);cursor:pointer;transition:background .15s ease,transform .15s ease}.about-dot:hover{background:var(--muted)}.about-dot.is-active{background:var(--primary);transform:scale(1.25)}.about-counter{flex-shrink:0;text-align:center;color:var(--muted);font-size:.82rem;margin:.5rem 0 .9rem}@media (max-width: 680px){.about-stage{padding:1rem}.about-slide{padding:1.25rem 1.1rem;gap:.9rem}.about-points li{font-size:.9rem}.about-dots{display:none}}
