:root{--bg:#0b1220;--surface:#0f172a;--text:#e5e7eb;--text-dim:#9ca3af;--border:#1f2937;--primary:#2563eb;--danger:#ef4444}body{background:#0b1220;background:var(--bg);color:#e5e7eb;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica Neue,Arial,Apple Color Emoji,Segoe UI Emoji}html:not([data-theme=dark]){--bg:#fff;--surface:#f8fafc;--text:#111827;--text-dim:#6b7280;--border:#e5e7eb}.hw-header{background:#0f172a;border-bottom:1px solid #1f2937;padding:12px 16px;z-index:20}.hw-title{cursor:pointer;font-weight:800;letter-spacing:-.02em;min-height:24px;min-width:32px}.hw-header .center{flex:1 1;gap:8px}.input{background:#0000;border:1px solid #1f2937;border-radius:8px;color:inherit;padding:8px 10px}.input.search{max-width:520px;width:100%}.btn{background:#2563eb;background:var(--primary);border:1px solid var(--primary);border-radius:8px;color:#fff;padding:8px 12px}.btn-ghost{background:#0000;border-color:#1f2937;color:#e5e7eb;color:var(--text)}.btn-danger{background:#ef4444;background:var(--danger);border-color:#ef4444;border-color:var(--danger)}.icon-btn{background:#0000;border:1px solid #1f2937;border-radius:8px;color:#e5e7eb;padding:6px 10px}.icon-btn.active{outline:2px solid #2563eb;outline:2px solid var(--primary)}.badge,.chip{border:1px solid #1f2937}.badge{align-items:center;border:1px solid var(--border);display:inline-flex}.dropdown{background:#0f172a;border:1px solid #1f2937;border-radius:10px;box-shadow:0 10px 30px #0003;color:#e5e7eb;color:var(--text);min-width:200px}.dropdown .item{padding:8px}.dropdown .item:hover{background:#94a3b81f}.panel{background:#0f172a;border:1px solid #1f2937;padding:12px}.modal{background:#00000080;display:grid;padding:16px;place-items:center}.modal-panel{max-width:720px;width:100%}.board{grid-gap:12px;gap:12px;grid-template-columns:repeat(4,minmax(220px,1fr));padding:16px}.column{display:flex;flex-direction:column;gap:8px}.column-title{padding:6px 2px}.list{gap:8px}.card,.list{display:flex;flex-direction:column}.card{background:#0f172a;border:1px solid #1f2937;padding:10px}.card-overdue{border-color:#ef4444}.card-title-row{align-items:center;display:flex}.title-area .title{font-weight:700}.notes{color:#9ca3af}.calendar{padding:16px}.calendar-header{margin-bottom:8px}.weekday-grid{grid-gap:4px;gap:4px;grid-template-columns:repeat(7,1fr)}.weekday{color:#9ca3af;font-weight:700}.calendar-grid{grid-gap:6px;gap:6px;grid-template-columns:repeat(7,1fr)}.calendar-cell{background:#0f172a;border:1px solid #1f2937;min-height:90px;position:relative}.calendar-date{color:#9ca3af;font-weight:700;margin-bottom:6px}.cal-task{background:#94a3b829;border-radius:6px;margin-bottom:4px}.cal-task.done{opacity:.6;text-decoration:line-through}.hero{padding:12px 16px}.hero-title{font-size:18px;margin:0 0 4px}.hero-subtitle{color:#9ca3af}.stat-cards{grid-gap:8px;gap:8px;grid-template-columns:repeat(4,minmax(100px,1fr));margin-top:8px}.stat-card{background:#0f172a;border:1px solid #1f2937;border-radius:10px;padding:10px}.stat-top{color:#9ca3af;color:var(--text-dim);justify-content:space-between;margin-bottom:6px}.fab,.stat-kpi{font-size:20px}.fab{border-radius:999px;bottom:16px;height:48px;right:16px;width:48px}.fade-in{animation:fadein .24s ease-out}.slide-in{animation:slidein .32s ease-out}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes slidein{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.due-tooltip{background:#0f172a;border:1px solid #1f2937;border-radius:8px;display:none;left:0;margin-top:4px;padding:6px 8px;top:100%}.due-wrap:focus .due-tooltip,.due-wrap:hover .due-tooltip{display:block}.timer{align-items:center;display:inline-flex;gap:6px}:root{--bg:#f8fafc;--surface:#fff;--surface-2:#f1f5f9;--text:#111827;--text-dim:#475569;--border:#e2e8f0;--accent:#2563eb;--accent-2:#7c3aed;--danger:#b91c1c}:root[data-theme=dark]{--bg:#0d1117;--surface:#111827;--surface-2:#0b1220;--text:#e5e7eb;--text-dim:#9ca3af;--border:#1f2937;--accent:#60a5fa;--accent-2:#a78bfa;--danger:#ef4444}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(1200px 600px at 10% -10%,#2563eb0f,#0000),radial-gradient(900px 500px at 100% 0,#7c3aed0d,#0000),#f8fafc;background:radial-gradient(1200px 600px at 10% -10%,#2563eb0f,#0000),radial-gradient(900px 500px at 100% 0,#7c3aed0d,#0000),var(--bg);color:#111827;color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;margin:0}.hw-app{display:grid;grid-template-rows:auto auto 1fr auto;min-height:100%}.hw-header{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fff;background:var(--surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 18px;top:0;z-index:10}.hw-title{color:#111827;color:var(--text);font-size:18px;font-weight:700;letter-spacing:.2px}.hw-header{gap:12px;position:-webkit-sticky;position:sticky}.hw-header .center{align-items:center;display:flex;left:50%;position:absolute;transform:translateX(-50%)}.hw-header .center .search{width:clamp(220px,45vw,540px)}.hw-header .right{align-items:center;display:flex;gap:8px;position:relative}.hw-stats{display:flex;gap:14px}.stat{display:grid;place-items:start}.stat-num{color:#2563eb;color:var(--accent);font-size:16px;font-weight:700}.toolbar{flex-wrap:wrap;gap:12px;justify-content:space-between;padding:12px 18px}.toolbar,.toolbar .left{align-items:center;display:flex}.toolbar .left{gap:8px}.filters{display:flex;flex-wrap:wrap;gap:8px}.input{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;color:#111827;color:var(--text);font:inherit;padding:10px 12px}.input.search{width:clamp(220px,35vw,420px)}.file-label{overflow:hidden;position:relative}.file-label input[type=file]{cursor:pointer;inset:0;opacity:0;position:absolute}.btn{background:linear-gradient(180deg,#60a5fa29,#60a5fa14);border:1px solid #2563eb;border:1px solid var(--accent);border-radius:10px;color:#111827;color:var(--text);cursor:pointer;font:inherit;padding:10px 12px}.btn:hover{filter:brightness(1.08)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-ghost{background:#fff;background:var(--surface);border-color:#e2e8f0;border-color:var(--border)}.btn-danger{background:linear-gradient(180deg,#ef444429,#ef444414);border-color:#7f1d1d}.icon-btn{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;color:#111827;color:var(--text);cursor:pointer;padding:8px 10px}.icon-btn:hover{filter:brightness(1.05)}.icon-btn.active{box-shadow:inset 0 0 0 2px #2563eb40}.dropdown{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;box-shadow:0 6px 14px #0206171f;box-shadow:var(--shadow-md);min-width:220px;padding:8px;position:absolute;right:0;top:calc(100% + 8px);z-index:20}.dropdown .item{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:8px 10px}.dropdown .item:hover{background:#f1f5f9;background:var(--surface-2)}.dropdown hr{border:none;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);margin:6px 4px}.panel{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;margin:0 18px 10px;padding:14px}.panel-title{color:#475569;color:var(--text-dim);font-size:13px;margin-bottom:10px}.task-form{grid-gap:14px;gap:14px;padding:4px}.form-section{grid-gap:10px;gap:10px;padding:12px}.form-row{grid-template-columns:repeat(6,minmax(0,1fr))}.form-row .field{grid-column:span 3}.form-row .field.wide{grid-column:span 6}.form-actions{gap:10px}.task-form .chips{gap:8px}.task-form .btn,.task-form .input,.task-form select,.task-form textarea{min-height:38px}.board{grid-gap:14px;align-items:start;display:grid;gap:14px;grid-template-columns:repeat(4,minmax(0,1fr));padding:10px 18px 18px}.notes,.title{overflow-wrap:anywhere;word-break:break-word}.badge,.cal-task,.chip{flex-shrink:0;overflow-wrap:normal;white-space:nowrap;word-break:normal}.notes-page{margin:10px 18px 18px}.notes-grid,.notes-page{grid-gap:12px;display:grid;gap:12px}.notes-grid{align-items:start;grid-template-columns:repeat(3,minmax(0,1fr))}.note-card{grid-gap:8px;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;display:grid;gap:8px;padding:12px}.note-title{color:#111827;color:var(--text);font-weight:700}.note-body{color:#475569;color:var(--text-dim);white-space:pre-wrap}.column{background:#f1f5f9;background:var(--surface-2);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;min-height:120px;padding:10px}.column-title{font-size:12px;margin:6px 4px 10px}.list{grid-gap:10px;display:grid;gap:10px}.empty{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;color:#475569;color:var(--text-dim);font-size:12px;text-align:center}.card,.empty{background:#fff;background:var(--surface);padding:12px}.card{grid-gap:10px;border:1px solid #e2e8f0;border:1px solid var(--border);display:grid;gap:10px;grid-template-columns:1fr auto}.card-overdue{box-shadow:inset 0 0 0 1px #ef44444d}.card-main{grid-gap:8px;display:grid;gap:8px}.card-title-row{grid-gap:10px;align-items:start;display:grid;gap:10px;grid-template-columns:auto 1fr}.checkbox{height:18px;margin-top:2px;width:18px}.title-area{grid-gap:6px;display:grid;gap:6px}.title{font-weight:600;letter-spacing:.2px}.meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.notes{font-size:13px;white-space:pre-wrap}.due-row,.notes{color:#475569;color:var(--text-dim)}.due-row{align-items:center;display:flex;font-size:12px;gap:8px;justify-content:space-between;white-space:nowrap}.due-date{max-width:90px;overflow:hidden;text-overflow:ellipsis}.due-label{color:#7c3aed;color:var(--accent-2)}.due-wrap{align-items:center;display:inline-flex;gap:6px;position:relative}.due-tooltip{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;box-shadow:0 6px 14px #0206171f;box-shadow:var(--shadow-md);color:#111827;color:var(--text);left:50%;opacity:0;padding:8px 10px;pointer-events:none;position:absolute;top:-8px;transform:translate(-50%,-100%) scale(.98);transition:opacity .15s ease,transform .15s ease;white-space:nowrap;z-index:5}.due-wrap:focus-within .due-tooltip,.due-wrap:hover .due-tooltip{opacity:1;transform:translate(-50%,-110%) scale(1)}.due-tooltip:after{background:#fff;background:var(--surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);border-left:1px solid #e2e8f0;border-left:1px solid var(--border);bottom:-6px;content:"";height:10px;left:50%;position:absolute;transform:translateX(-50%);transform:translateX(-50%) rotate(45deg);width:10px}.card-actions{align-items:stretch;display:flex;flex-wrap:wrap;gap:6px}.card-actions .btn{flex:1 1;min-height:36px;text-align:center}@media (max-width:1200px){.card-actions{align-items:stretch;flex-direction:column}.card-actions .btn{width:100%}}.badge{background:#a78bfa1f;border:1px solid #a78bfa66;border-radius:999px;color:#7c3aed;color:var(--accent-2);font-size:11px;padding:2px 8px}.status-done{background:#10b9811f;border-color:#10b98166;color:#34d399}.status-in_progress{background:#eab3081f;border-color:#eab30866;color:#fbbf24}.chip{align-items:center;background:#ffffff05;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:999px;display:inline-flex;font-size:11px;gap:6px;padding:2px 8px}.chip,.chip-muted{color:#475569;color:var(--text-dim)}.chip-low{background:#10b9811a;border-color:#10b98140;color:#34d399}.chip-medium{background:#3b82f61a;border-color:#3b82f640;color:#60a5fa}.chip-high{background:#ef44441a;border-color:#ef444440;color:#ef4444}.hw-footer{background:#fff;background:var(--surface);border-top:1px solid #e2e8f0;border-top:1px solid var(--border);color:#475569;color:var(--text-dim);font-size:12px;padding:12px 18px}.calendar{margin:0 18px 18px}.calendar-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:10px}.calendar-title{color:#475569;color:var(--text-dim);font-weight:600}.calendar-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,minmax(0,1fr))}.calendar-cell{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;display:grid;grid-template-rows:auto 1fr;min-height:120px;padding:8px}.calendar-date{color:#475569;color:var(--text-dim);font-size:12px;text-align:right}.calendar-tasks{grid-gap:6px;align-content:start;display:grid;gap:6px}.cal-task{align-items:center;background:#2563eb14;border:1px solid #2563eb40;border-radius:999px;color:#111827;color:var(--text);display:inline-flex;font-size:12px;gap:6px;padding:2px 6px}.cal-task.done{background:#10b9811f;border-color:#10b98159;color:#065f46}.timer-panel.expanded{border-color:var(--primary)}.timer-circle{pointer-events:none}.timer-actions,.timer-content,.timer-content *,.timer-edit-row{pointer-events:auto}.banner{background:#2563eb0f;border:1px solid #2563eb40;border-radius:10px;color:#111827;color:var(--text);font-size:13px;margin:0 18px 10px;padding:12px}.banner .btn{margin-left:8px}.subtasks{grid-gap:6px;display:grid;gap:6px}.subtask{align-items:center;color:#475569;color:var(--text-dim);display:flex;font-size:13px;gap:8px}.subtask input[type=checkbox]{height:16px;width:16px}.tabs{background:#f1f5f9;background:var(--surface-2);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:6px;padding:8px 18px 0}.tab{background:#0000;border:1px solid #0000;border-radius:10px 10px 0 0;color:#475569;color:var(--text-dim);cursor:pointer;font:inherit;padding:8px 12px}.tab-active,.tab:hover{background:#fff;background:var(--surface);color:#111827;color:var(--text)}.tab-active{border-color:#e2e8f0;border-color:var(--border);border-bottom-color:#fff;border-bottom-color:var(--surface)}.settings{margin:10px 18px 18px}.settings-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.settings-grid .field{grid-column:span 1}.settings-grid .field.wide{grid-column:span 2}.settings-actions{flex-wrap:wrap}.settings-body{grid-gap:12px;display:grid;gap:12px;padding:12px}.settings-section{grid-gap:10px;background:#fff;background:var(--surface);border-radius:12px;box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);display:grid;gap:10px;padding:12px}.settings-title{color:#111827;color:var(--text);font-size:13px;font-weight:700}.settings-desc{color:#475569;color:var(--text-dim);font-size:12px}.settings-row.inline{display:flex;flex-wrap:wrap;gap:8px}.settings-row .input{min-width:220px}.settings-actions .btn{min-height:36px}.settings-tabs{background:#f1f5f9;background:var(--surface-2);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);border-radius:12px 12px 0 0;padding:8px}.settings-tab{border:1px solid #0000;border-radius:10px;color:#475569;color:var(--text-dim);padding:8px 12px}.settings-tab-active,.settings-tab:hover{background:#fff;background:var(--surface);color:#111827;color:var(--text)}.settings-tab-active{border-color:#e2e8f0;border-color:var(--border)}@media (max-width:1200px){.board{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:700px){.board{grid-template-columns:1fr}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field:nth-child(3),.field:nth-child(4),.field:nth-child(5),.field:nth-child(6){grid-column:span 1}}@media (max-width:900px){.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:901px) and (max-width:1200px){.calendar-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}:root{--radius:12px;--radius-lg:16px;--shadow-sm:0 1px 2px #0206170f;--shadow-md:0 6px 14px #0206171f;--shadow-lg:0 20px 40px #0206172e}.btn{border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);position:relative;transition:transform .08s ease,box-shadow .2s ease,filter .2s ease}.btn:hover{box-shadow:0 6px 14px #0206171f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active{box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);transform:translateY(0)}.btn-primary{background:linear-gradient(180deg,#2563eb2e,#2563eb1f);border-color:#2563eb99}.btn-outline{background:#0000;border-color:#e2e8f0;border-color:var(--border)}.input{border-radius:12px;border-radius:var(--radius);transition:border-color .2s ease,box-shadow .2s ease}.input:focus{border-color:#2563eb99;box-shadow:0 0 0 3px #2563eb26;outline:none}.card{border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .2s ease,background .2s ease}.card:hover{background:linear-gradient(180deg,#ffffffa6,#ffffff59);box-shadow:0 6px 14px #0206171f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.hero{background:radial-gradient(900px 400px at 0 0,#2563eb1a,#0000),radial-gradient(700px 400px at 100% 0,#7c3aed1a,#0000),linear-gradient(180deg,#fff,#f1f5f9);background:radial-gradient(900px 400px at 0 0,#2563eb1a,#0000),radial-gradient(700px 400px at 100% 0,#7c3aed1a,#0000),linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);margin:10px 18px 14px;overflow:hidden}.hero-inner{grid-gap:14px;align-items:center;display:grid;gap:14px;grid-template-columns:1.2fr 1fr;padding:18px}.hero-title{color:#111827;color:var(--text);font-size:22px;font-weight:800;letter-spacing:.2px;margin:0}.hero-subtitle{color:#475569;color:var(--text-dim);font-size:13px;margin:0}.stat-cards{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card{grid-gap:8px;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);display:grid;gap:8px;padding:12px}.stat-top{align-items:center;display:flex;gap:8px}.stat-icon{background:#ffffff80;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;display:inline-grid;height:22px;place-items:center;width:22px}.stat-kpi{color:#111827;color:var(--text);font-size:22px;font-weight:800}.stat-label{color:#475569;color:var(--text-dim);font-size:11px}.tabs{position:-webkit-sticky;position:sticky;top:48px;z-index:8}.tab{background:#ffffff80;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:999px}.tab-active{background:linear-gradient(180deg,#2563eb1a,#7c3aed1a);border-color:#2563eb59}.subject-chip{border-style:solid;border-width:1px}.column-title{color:#475569;color:var(--text-dim);font-weight:700;letter-spacing:.5px;text-transform:uppercase}.weekday-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,minmax(0,1fr));margin:0 18px 6px}.weekday{color:#475569;color:var(--text-dim);font-size:12px;text-align:center}.fade-in{animation:fadeIn .18s ease}.slide-down{animation:slideDown .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (max-width:900px){.hero-inner{grid-template-columns:1fr}.stat-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}.modal{align-items:flex-start;background:#00000059;display:flex;inset:0;justify-content:center;padding:30px 16px;position:fixed;z-index:40}.modal-panel{width:min(920px,96vw)}*{box-sizing:border-box}.btn:focus-visible,.icon-btn:focus-visible,.input:focus-visible,select.input:focus-visible{box-shadow:0 0 0 3px #2563eb59;outline:none}.board{margin-left:auto;margin-right:auto;max-width:1400px}.column{min-width:0}.hero,.panel{margin-left:auto;margin-right:auto;max-width:1400px}.dropdown .item{background:#0000;border:none;color:#111827;color:var(--text)}.dropdown .item:focus-visible{box-shadow:0 0 0 3px #60a5fa59;outline:none}.icon-btn{border-radius:12px;border-radius:var(--radius);display:inline-grid;height:36px;padding:0;place-items:center;width:36px}@media (max-width:700px){.hw-header{flex-wrap:wrap}.hw-header .hw-title{order:1}.hw-header .right{order:2}.hw-header .center{order:3;padding-top:8px;width:100%}}@media (max-width:1200px){.notes-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:700px){.notes-grid{grid-template-columns:1fr}}.notes-layout-left{grid-gap:12px;align-items:stretch;display:grid;gap:12px;grid-template-columns:260px 1fr;grid-template-columns:var(--notes-sidebar-w,260px) 1fr;margin:10px 18px 18px}.notes-left{background:#fff;background:var(--surface);grid-template-rows:auto 1fr auto;min-width:0}.notes-canvas,.notes-left{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);display:grid;overflow:hidden}.notes-canvas{background-color:#fff;background-color:var(--surface);grid-template-rows:auto 1fr;min-height:72vh;position:relative}.notes-topbar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:8px;justify-content:space-between;padding:8px;position:-webkit-sticky;position:sticky;top:0;z-index:3}.notes-topbar .left{flex:1 1}.notes-topbar .right{display:flex;flex-wrap:wrap;gap:6px}.notes-topbar .btn.active{box-shadow:inset 0 0 0 2px #2563eb40}.rte-wrap{grid-gap:10px;box-sizing:border-box;display:grid;gap:10px;grid-template-rows:auto 1fr auto;height:100%;padding:10px}.rte-toolbar{align-items:center;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;display:flex;flex-wrap:wrap;gap:8px;padding:8px;position:-webkit-sticky;position:sticky;top:8px;z-index:2}.rte-editor,.rte-toolbar{background:#fff;background:var(--surface)}.rte-editor{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;color:#111827;color:var(--text);line-height:1.6;min-height:40vh;overflow:auto;padding:14px}.rte-editor:empty:before{color:#475569;color:var(--text-dim);content:attr(placeholder)}.rte-actions{align-items:center;display:flex;gap:8px;justify-content:flex-end}.canvas-stage{overflow:hidden}.canvas-toolbox{left:8px;position:absolute;top:60px;transform:none}.inspector-bar{top:8px}.canvas-zoom{bottom:8px}.canvas-overlay .quick-menu,.canvas-toolbox,.canvas-zoom,.inspector-bar{pointer-events:auto}@media (max-width:900px){.notes-layout-left{grid-template-columns:1fr}.notes-canvas{grid-template-rows:auto 1fr;min-height:68vh}.rte-wrap{gap:8px;padding:8px}.rte-toolbar{top:8px}.canvas-toolbox{bottom:70px}.canvas-toolbox,.inspector-bar{left:50%;top:auto;transform:translateX(-50%)}.inspector-bar{bottom:120px}.canvas-zoom{bottom:16px;right:10px}}.tool-btn{margin:0}.btn,.input{box-sizing:border-box}.notes-canvas>.canvas-stage,.notes-canvas>.rte-wrap{margin-top:0}.canvas-inner{-webkit-user-select:none;user-select:none}.canvas-item{cursor:grab}.canvas-item.grabbing{cursor:grabbing}.canvas-hint{left:8px}.canvas-hint,.canvas-status{background:#0000000f;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:999px;color:#475569;color:var(--text-dim);font-size:12px;padding:4px 8px;position:absolute;top:8px}.canvas-status{right:8px}.canvas-text{-webkit-user-select:text;user-select:text}.hero-message{min-height:28px;overflow:hidden;position:relative}.slide-in{animation:slideIn .42s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.slide-in{animation:none}}.dropdown{max-height:60vh;overflow:auto}.notes-list-item{transition:filter .15s ease,box-shadow .2s ease}.notes-layout-left{position:relative}.notes-left-toggle{left:8px;position:absolute;top:12px;z-index:7}.canvas-overlay{inset:0;pointer-events:none;position:absolute;z-index:6}.canvas-overlay .quick-menu{pointer-events:auto}@media (max-width:700px){.hero{display:none}.icon-btn,.tool-btn,.zoom-btn{height:44px;width:44px}.canvas-toolbox{border-radius:14px;bottom:10px;display:flex;gap:8px;left:50%}.canvas-toolbox,.inspector-bar{padding:8px;top:auto;transform:translateX(-50%)}.inspector-bar{border-radius:12px;bottom:64px}.canvas-zoom{bottom:64px;right:10px}.notes-canvas{height:68vh}.quick-menu{padding:8px}.quick-item{padding:10px 12px}.notes-left-toggle{left:10px;top:10px}}.date-picker{grid-gap:10px;background:#fff;background:var(--surface);border-radius:12px;display:grid;gap:10px;padding:12px}.date-picker-header{gap:8px}.date-picker-grid{grid-gap:6px;gap:6px;grid-template-columns:repeat(7,minmax(0,1fr))}.date-cell{border:1px solid #0000;border-radius:10px;color:#111827;color:var(--text);padding:10px 0;text-align:center}.date-cell:hover{background:#f1f5f9;background:var(--surface-2)}.date-cell.muted{color:#475569;color:var(--text-dim)}.date-cell.selected{background:#2563eb1f;border-color:#2563eb59}.chips{display:flex;flex-wrap:wrap;gap:6px}@media (max-width:700px){.canvas-toolbox{bottom:16px}.inspector-bar{bottom:88px}.canvas-zoom{bottom:16px}}.subtask-editor{grid-gap:8px;display:grid;gap:8px}.subtask-row{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr auto}.modal-panel{max-height:90vh;overflow:auto}.task-form{grid-gap:16px;display:grid;gap:16px;padding:8px}.form-section{grid-gap:12px;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;display:grid;gap:12px;padding:16px}.form-section .section-title{color:#475569;color:var(--text-dim);font-size:13px;font-weight:700}.form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}.form-row .field,.form-row .field.wide{grid-column:span 1}.schedule-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.schedule-grid .col{grid-gap:12px;display:grid;gap:12px}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:4px}.chip-group,.task-form .chips{display:flex;flex-wrap:wrap;gap:10px}.chip-btn{border-radius:10px;padding:8px 10px}.chip-btn.active{border-color:#2563eb;border-color:var(--accent);box-shadow:inset 0 0 0 2px #2563eb59;filter:brightness(1.02)}.input:focus-visible,select.input:focus-visible,textarea.input:focus-visible{box-shadow:inset 0 0 0 2px #2563eb59;outline:none}.btn:focus-visible{outline:2px solid #2563eb59;outline-offset:2px}@media (max-width:900px){.form-row,.schedule-grid{grid-template-columns:1fr}.task-form .btn{min-height:44px}}.canvas-stage{align-content:start;display:grid;justify-content:center;overflow:auto;padding:12px;position:relative}.canvas-inner{height:-webkit-max-content;height:max-content;inset:auto;position:relative;width:-webkit-max-content;width:max-content}.notes-left-header{gap:10px;padding:10px}.notes-left-body{gap:8px;padding:8px}@media (max-width:900px){.canvas-stage{padding:8px}}.af-form{grid-gap:16px;gap:16px;padding:8px}.af-section{grid-gap:12px;background:#fff;background:var(--surface);border-radius:12px;box-shadow:0 1px 2px #0206170f;box-shadow:var(--shadow-sm);display:grid;gap:12px;padding:16px}.af-title{font-size:13px}.af-label,.af-title{color:#475569;color:var(--text-dim)}.af-label{font-size:12px}.af-grid{grid-template-columns:1fr 1fr}.af-col{grid-gap:12px;display:grid;gap:12px}.seg-group{display:flex;flex-wrap:wrap;gap:8px}.seg-btn{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;padding:8px 10px}.seg-active{border-color:#2563eb;border-color:var(--accent);box-shadow:inset 0 0 0 2px #2563eb59}.af-actions{gap:12px}@media (max-width:900px){.af-grid{grid-template-columns:1fr}}.day-wrap{position:relative}.day-tooltip{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;box-shadow:0 6px 14px #0206171f;box-shadow:var(--shadow-md);color:#111827;color:var(--text);left:50%;min-width:220px;opacity:0;padding:10px 12px;pointer-events:none;position:absolute;top:-8px;transform:translate(-50%,-100%) scale(.98);transition:opacity .15s ease,transform .15s ease;white-space:nowrap;z-index:6}.day-wrap:focus-within .day-tooltip,.day-wrap:hover .day-tooltip{opacity:1;transform:translate(-50%,-110%) scale(1)}.day-tooltip:after{background:#fff;background:var(--surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);border-left:1px solid #e2e8f0;border-left:1px solid var(--border);bottom:-6px;content:"";height:10px;left:50%;position:absolute;transform:translateX(-50%) rotate(45deg);width:10px}.day-tip-title{color:#475569;color:var(--text-dim);font-size:12px;font-weight:700;margin-bottom:6px}.day-tip-list{grid-gap:4px;display:grid;gap:4px}.day-tip-item,.day-tip-more{color:#111827;color:var(--text);font-size:12px}.fab{background:linear-gradient(180deg,#60a5fa29,#60a5fa14);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:50%;bottom:18px;box-shadow:0 6px 14px #0206171f;box-shadow:var(--shadow-md);color:#111827;color:var(--text);cursor:pointer;display:grid;font-size:24px;height:56px;place-items:center;position:fixed;right:18px;width:56px;z-index:50}.fab:hover{filter:brightness(1.08);transform:translateY(-1px)}@media (max-width:700px){.fab{bottom:12px;height:56px;right:12px;width:56px}}.icon-btn.filter{display:inline-grid;height:40px;place-items:center;width:40px}.input.search{height:40px}.filter-dropdown{animation:fadeDown .16s ease}@keyframes fadeDown{0%{opacity:0;transform:translate(-50%,-6px)}to{opacity:1;transform:translate(-50%)}}.af-form{grid-gap:12px;display:grid;gap:12px}.af-section{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;padding:12px}.af-title{font-weight:700;margin-bottom:8px}.af-field{grid-gap:6px;display:grid;gap:6px;margin-bottom:8px}.af-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.af-actions{display:flex;gap:8px;justify-content:flex-end}.seg-group{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:999px;display:inline-flex;overflow:hidden}.seg-btn{background:#0000;border:none;color:#111827;color:var(--text);cursor:pointer;padding:6px 10px}.seg-active{background:#2563eb2e}.chip-group{display:flex;flex-wrap:wrap;gap:6px}.chip-btn.active{outline:2px solid var(--primary)}.weekday-grid{margin-bottom:6px}.date-picker{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;padding:8px}.date-picker-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.date-picker-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.date-cell{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:6px}.date-cell.selected{outline:2px solid var(--primary)}.date-cell.muted{opacity:.5}.dropdown.filter-dropdown{z-index:30}.panel-title{font-weight:800;margin-bottom:8px}.settings-tabs{display:flex;gap:6px;margin-bottom:10px}.settings-tab{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;color:#111827;color:var(--text);cursor:pointer;padding:6px 10px}.settings-tab-active{outline:2px solid var(--primary)}.settings-section{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:10px}.settings-row{grid-gap:8px;display:grid;gap:8px}.settings-row.inline{align-items:center;grid-auto-columns:1fr;grid-auto-flow:column}.settings-actions{align-items:center;display:flex;gap:8px;margin-top:8px}.settings-note{color:#475569;color:var(--text-dim);font-size:12px}.checkbox{height:16px;width:16px}.clock{color:#475569;color:var(--text-dim);font-weight:700}.timer-panel{grid-gap:10px;align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #00000040;display:grid;gap:10px;grid-template-columns:72px 1fr;height:110px;left:0;min-height:110px;padding:10px;position:fixed;top:0;width:320px;z-index:40}.timer-panel.collapsed{grid-template-columns:72px 1fr}.timer-collapsed-actions{display:inline-flex;gap:6px;position:absolute;right:10px;top:10px}.timer-panel.dragging,body.timer-grabbing{cursor:grabbing;-webkit-user-select:none;user-select:none}.timer-panel .timer-circle{flex:0 0 auto}.timer-panel .timer-content{min-width:0}
/*# sourceMappingURL=main.6da3ae4d.css.map*/