@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap";:root{--bg: #ffffff;--fg: #111827;--muted: #6b7280;--brand: #2563eb;--surface: #f9fafb;--border: #e5e7eb;--radius: 10px;--shadow: 0 6px 18px rgba(0,0,0,.12)}@media (prefers-color-scheme: dark){:root{--bg: #0b0f13;--fg: #e5e7eb;--muted: #9ca3af;--brand: #3b82f6;--surface: #111827;--border: #1f2937;--shadow: 0 6px 18px rgba(0,0,0,.35)}}body{background:var(--bg);color:var(--fg)}.cal,.tasks-panel,.settings-panel{border-color:var(--border);background:var(--bg)}.event{background:var(--brand);box-shadow:0 2px 6px #0000001a;border-radius:var(--radius)}.event-title{font-weight:600}.event:hover{box-shadow:var(--shadow);transform:translateY(-1px);transition:box-shadow .15s ease,transform .15s ease}.cal-scroll{max-height:calc(100vh - 180px);overflow-y:auto;position:relative}.time-cell,.grid-cell{height:48px}.event{position:absolute;padding:6px 8px;color:#fff;cursor:pointer}.create-preview{position:absolute;left:8px;right:8px;background:#2563eb33;border:1px dashed rgba(37,99,235,.8);border-radius:8px;pointer-events:none}.empty-state{padding:24px;border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);text-align:center;color:var(--muted)}.empty-illustration{font-size:42px;margin-bottom:6px}.empty-btn{margin-top:10px;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--fg)}.skeleton-cal .row{height:20px;margin:8px 0;border-radius:8px;background:linear-gradient(90deg,#f0f0f0,#eaeaea,#f0f0f0);background-size:400% 100%;animation:shimmer 1.2s infinite}.skeleton-tasks .line{height:14px;margin:10px 0;border-radius:6px;background:linear-gradient(90deg,#f0f0f0,#eaeaea,#f0f0f0);background-size:400% 100%;animation:shimmer 1.2s infinite}@keyframes shimmer{0%{background-position:0% 0}to{background-position:100% 0}}.error-boundary{border:1px solid var(--border);padding:12px;border-radius:var(--radius);background:var(--surface)}.error-boundary pre{background:#0000000d;padding:8px;border-radius:6px}.day-head{display:flex;align-items:center;justify-content:space-between;gap:6px;padding-right:6px}.quick-add{border:1px solid var(--border);background:var(--bg);border-radius:8px;width:26px;height:26px;line-height:24px}.quick-add:hover{filter:brightness(.98)}:root{--bg: #ffffff;--fg: #0f172a;--muted: #64748b;--surface: #f8fafc;--surface-2: #eef2f6;--border: #e5e7eb;--brand: #2563eb;--brand-weak: #eaf2ff;--radius: 12px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 6px 18px rgba(0,0,0,.1);--hour: 48px}html,body{font-family:Roboto,ui-sans-serif,system-ui,-apple-system,Segoe UI,Helvetica Neue,Arial;color:var(--fg);background:var(--bg)}h1,h2,h3,h4{font-weight:700;margin:0 0 8px}p{margin:0 0 8px;line-height:1.45}small{color:var(--muted)}.app{display:block}.container{max-width:1400px;margin:0 auto;padding:0 12px}.topbar{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.topbar .nav .btn{margin-left:6px}.main{display:grid;grid-template-columns:1fr 320px;gap:16px;padding:12px}.left,.right{background:var(--bg)}button{font:inherit;border-radius:10px;padding:6px 10px;border:1px solid var(--border);background:var(--surface);color:var(--fg)}button:hover{filter:brightness(.985)}button:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb40}.btn{padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface)}.btn.primary{background:var(--brand);color:#fff;border-color:transparent}.btn.ghost{background:transparent}.btn.danger{background:#dc2626;color:#fff;border-color:transparent}input,select,textarea{font:inherit;border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:var(--bg);color:var(--fg)}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb40}.nlp-box{display:grid;grid-template-columns:1fr auto;gap:8px;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.nlp-box input{border:none;background:transparent;padding:8px}.nlp-box input:focus-visible{box-shadow:none;outline:none}.nlp-box button{border-radius:10px}.cal{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg)}.cal-head{display:grid;grid-template-columns:80px repeat(7,1fr);background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}.time-col{width:80px;border-right:1px solid var(--border);background:var(--surface);position:relative}.day-head{padding:10px 8px;font-weight:700;display:flex;align-items:center;justify-content:center;text-align:center;gap:6px}.day-head .weekday{display:block;font-weight:700}.day-head .date{display:block;font-weight:500;color:var(--muted);margin-left:6px}.cal-body{display:grid;grid-template-columns:80px repeat(7,1fr)}.cal-scroll{height:min(calc(12 * var(--hour)),calc(100vh - 168px));overflow-y:auto;position:relative}.time-cell,.grid-cell{height:var(--hour);border-bottom:1px solid var(--border);position:relative}.time-cell .hh{position:absolute;top:0;transform:translateY(-50%);right:8px;font-size:12px;color:var(--muted)}.day-col{position:relative}.day-col.today{background-image:linear-gradient(to bottom,#2563eb12,#2563eb08)}.day-col.today:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;border-left:2px solid var(--brand);border-right:2px solid var(--brand);pointer-events:none}.event{position:absolute;padding:6px 10px;border-radius:10px;color:#fff;box-shadow:var(--shadow-sm);transition:box-shadow .15s ease,transform .15s ease}.event:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.event .event-title{font-weight:700;font-size:13px}.event .event-time{font-size:12px;opacity:.9}.event[data-color]{background:color-mix(in oklab,var(--event-color, #2563eb) 86%,white);border:1px solid color-mix(in oklab,var(--event-color, #2563eb) 60%,white)}.event:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--event-color, #2563eb);border-top-left-radius:10px;border-bottom-left-radius:10px}.ev-actions{position:absolute;top:4px;right:4px;display:flex;gap:4px;opacity:0;transition:opacity .12s ease}.event:hover .ev-actions{opacity:1}.ev-actions button{border:none;background:#00000040;color:#fff;border-radius:6px;padding:2px 6px}.ev-actions button:hover{background:#0006}.create-preview{position:absolute;left:8px;right:8px;background:#2563eb29;border:1px dashed rgba(37,99,235,.55);border-radius:10px;pointer-events:none}.drag-ghost{position:absolute;left:8px;right:8px;pointer-events:none;background:#2563eb33;border:1px solid rgba(37,99,235,.55);border-radius:10px}.now-line{position:absolute;left:0;right:0;height:2px;background:#ef4444;pointer-events:none;z-index:2}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:flex;align-items:center;justify-content:center;z-index:50}.card{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:var(--radius);padding:16px;min-width:420px}.form-row{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:8px;margin-bottom:10px}.card.tasks-panel{padding:12px}:root{--bg: #faf8f5;--fg: #3e3832;--muted: #8b7d6b;--surface: #f5f2ed;--surface-2: #efe9e1;--border: #e5ddd0;--brand: #c17456;--brand-weak: #f9ede8;--brand-hover: #a96246;--accent-warm: #d4a574;--accent-cool: #9b9080;--success: #7a9b6c;--warning: #d9a86c;--danger: #c46d5e;--radius: 12px;--shadow-sm: 0 1px 3px rgba(62, 56, 50, .08);--shadow-md: 0 4px 12px rgba(62, 56, 50, .12);--shadow-lg: 0 10px 30px rgba(62, 56, 50, .15);--today-tint: rgba(193, 116, 86, .06);--today-pill-bg: #c17456;--today-pill-fg: #faf8f5;--hour: 48px;--grid-line: rgba(139, 125, 107, .15);--time-text: #8b7d6b}html,body{background:var(--bg);color:var(--fg)}.topbar{background:var(--bg);border-bottom:1px solid var(--border);box-shadow:0 1px 2px #3e38320a}button,.btn{background:var(--surface);color:var(--fg);border-color:var(--border);box-shadow:0 1px 2px #3e38320a}button:hover,.btn:hover{background:var(--surface-2);box-shadow:0 2px 4px #3e383214}.btn.primary{background:var(--brand);color:var(--today-pill-fg);border-color:var(--brand)}.btn.primary:hover{background:var(--brand-hover);border-color:var(--brand-hover)}.btn.danger{background:var(--danger);color:var(--today-pill-fg)}input,select,textarea{background:var(--bg);color:var(--fg);border-color:var(--border)}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #c174561f}.nlp-box{background:var(--surface);border-color:var(--border)}.nlp-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #c174561a}.cal{background:var(--bg);border-color:var(--border);box-shadow:var(--shadow-sm)}.cal-head{background:var(--surface);border-bottom:1px solid var(--border)}.time-col{background:var(--surface);border-right:1px solid var(--border)}.day-head{background:var(--surface)}.day-head:hover{background:var(--surface-2)}.day-col.today{background-color:var(--today-tint)}.day-col.today:before{background:var(--brand)}.day-head.today .weekday{background:var(--today-pill-bg);color:var(--today-pill-fg)}.day-head.today .date{color:var(--today-pill-bg)}.day-head.today .weekday:after{background:var(--today-pill-bg)}.time-cell,.grid-cell{border-bottom:1px solid var(--grid-line)}.grid-cell:nth-child(2n){background:var(--surface-2)}.time-cell .hh{color:var(--time-text)}.time-cell:hover .hh{color:var(--brand)}.day-col{border-left:1px solid var(--grid-line)}.event{background:var(--brand);color:var(--today-pill-fg);box-shadow:var(--shadow-sm);border:1px solid rgba(193,116,86,.3)}.event:hover{box-shadow:var(--shadow-md)}.event[data-color]{background:color-mix(in oklab,var(--event-color, var(--brand)) 88%,white);border:1px solid color-mix(in oklab,var(--event-color, var(--brand)) 60%,white)}.event:before{background:var(--event-color, var(--brand))}.ev-actions button{background:#3e383240;color:var(--bg)}.ev-actions button:hover{background:#3e383266}.drag-ghost{background:#c1745633;border:2px solid rgba(193,116,86,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.now-line{background:var(--danger);box-shadow:0 0 8px #c46d5e80}.now-line:before{background:var(--danger);box-shadow:0 0 6px #c46d5ecc}.modal{background:#3e383240;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card{background:var(--bg);border-color:var(--border);box-shadow:var(--shadow-lg)}.tasks-panel{background:var(--bg);border-color:var(--border)}.task-row{background:var(--surface);border-color:var(--border)}.task-row:hover{background:var(--surface-2);border-color:var(--brand);box-shadow:0 2px 6px #c174561a}.task-title{color:var(--fg)}.task-sub{color:var(--muted)}.empty-state{background:var(--surface);border-color:var(--border);color:var(--muted)}.skeleton-cal .row,.skeleton-tasks .line{background:linear-gradient(90deg,var(--surface),var(--surface-2),var(--surface))}.cal-scroll::-webkit-scrollbar-track{background:var(--surface)}.cal-scroll::-webkit-scrollbar-thumb{background:var(--border)}.cal-scroll::-webkit-scrollbar-thumb:hover{background:var(--brand)}*:focus-visible{outline-color:var(--brand)}button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:0 0 0 3px #c1745633}.quick-add{background:var(--surface);border-color:var(--border);color:var(--fg)}.quick-add:hover{background:var(--brand);border-color:var(--brand);color:var(--today-pill-fg)}.suggest-card{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow-lg)}.sug-list li{background:var(--surface);border-color:var(--border)}.sug-list li:hover{background:var(--surface-2);border-color:var(--brand)}.sug-sub{color:var(--muted)}.loading{background:var(--fg);color:var(--bg);box-shadow:var(--shadow-md)}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4{text-shadow:0 1px 2px rgba(62,56,50,.05)}.event-title{font-weight:600;letter-spacing:.01em}:root{--today-tint: rgba(37, 99, 235, .06);--today-pill-bg: #2563eb;--today-pill-fg: #ffffff}.day-col.today{background-image:none;background-color:var(--today-tint)}.day-col.today:after{content:none}:root{--topbar-h: 56px;--page-pad: 12px;--sidebar-w: 320px;--hour: 48px}.container{width:clamp(1024px,96vw,1280px);margin:0 auto;padding:0 var(--page-pad)}.main{display:grid;grid-template-columns:1fr var(--sidebar-w);gap:16px;height:calc(100vh - var(--topbar-h) - (var(--page-pad) * 2))}.topbar{min-height:var(--topbar-h)}.cal{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.day-col.today{background:none;position:relative}.day-col.today:before{content:"";position:absolute;top:0;bottom:0;left:0;width:3px;background:#2563eb;border-top-left-radius:6px;border-bottom-left-radius:6px;opacity:.8}.day-head.today .weekday:after{content:"";display:inline-block;width:6px;height:6px;margin-left:6px;background:#2563eb;border-radius:999px;vertical-align:middle}@media (prefers-reduced-motion: no-preference){.event{transition:transform .16s ease,box-shadow .16s ease}.event:hover{transform:translateY(-1px)}.modal[data-anim]{animation:fadeIn .14s ease both}.modal[data-anim] .card{animation:popIn .16s ease both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.98);opacity:0}to{transform:scale(1);opacity:1}}.btn,input,.nlp-box{transition:box-shadow .12s ease,background-color .12s ease,border-color .12s ease}.btn:active{transform:translateY(1px)}}.card.tasks-panel{min-width:0!important;width:100%!important;box-sizing:border-box}@media (prefers-reduced-motion: no-preference){.event{transition:box-shadow .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1),opacity .2s ease;will-change:transform}.event:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 8px 24px #00000026,0 2px 8px #2563eb1a}.event:active{transform:translateY(-1px) scale(1.005);transition:transform .1s ease}@keyframes eventFadeIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.event[data-new]{animation:eventFadeIn .3s cubic-bezier(.34,1.56,.64,1)}.drag-ghost{animation:ghostPulse 1.5s ease-in-out infinite;transition:top .15s ease-out,height .15s ease-out;box-shadow:0 4px 16px #2563eb40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes ghostPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.4;transform:scale(1.01)}}.grid-cell{transition:background-color .15s ease}.day-col{position:relative;overflow:hidden}@keyframes ripple{0%{transform:scale(0);opacity:.4}to{transform:scale(4);opacity:0}}.day-col:after{content:"";position:absolute;border-radius:50%;background:#2563eb33;width:20px;height:20px;pointer-events:none;opacity:0}.day-col:active:after{animation:ripple .6s ease-out}.now-line{box-shadow:0 0 8px #ef444480;animation:nowLinePulse 2s ease-in-out infinite}.now-line:before{content:"";position:absolute;left:0;top:-4px;width:8px;height:8px;background:#ef4444;border-radius:50%;box-shadow:0 0 6px #ef4444cc;animation:nowDotPulse 2s ease-in-out infinite}@keyframes nowLinePulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes nowDotPulse{0%,to{transform:scale(1);box-shadow:0 0 6px #ef4444cc}50%{transform:scale(1.2);box-shadow:0 0 12px #ef4444}}.day-col.today{animation:todayGlow 3s ease-in-out infinite}@keyframes todayGlow{0%,to{background-color:#2563eb0a}50%{background-color:#2563eb0f}}.day-col.today:before{animation:todayBarSlide .4s cubic-bezier(.34,1.56,.64,1)}@keyframes todayBarSlide{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:.8}}.ev-actions{opacity:0;transform:translateY(-4px);transition:opacity .2s ease,transform .2s cubic-bezier(.34,1.56,.64,1)}.event:hover .ev-actions{opacity:1;transform:translateY(0)}.ev-actions button{transition:all .15s ease;transform:scale(1)}.ev-actions button:hover{transform:scale(1.1);background:#00000080}.ev-actions button:active{transform:scale(.95)}.modal{animation:modalFadeIn .2s ease}.modal .card{animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}button,.btn{transition:all .15s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}button:hover,.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}button:active,.btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}button:before,.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}button:active:before,.btn:active:before{width:300px;height:300px;transition:width 0s,height 0s}input,select,textarea{transition:all .2s ease}input:focus,select:focus,textarea:focus{transform:scale(1.01);box-shadow:0 0 0 3px #2563eb26,0 4px 12px #0000000d}.nlp-box{transition:all .2s ease}.nlp-box:focus-within{transform:scale(1.005);box-shadow:0 4px 16px #2563eb1a;border-color:var(--brand)}.day-head{transition:background-color .2s ease}.day-head:hover{background:#2563eb0a}.day-head.today .weekday{animation:todayPillPulse 2s ease-in-out infinite}@keyframes todayPillPulse{0%,to{box-shadow:0 0 #2563eb66}50%{box-shadow:0 0 0 4px #2563eb00}}.cal-scroll{scroll-behavior:smooth}.cal-scroll::-webkit-scrollbar{width:8px}.cal-scroll::-webkit-scrollbar-track{background:var(--surface);border-radius:10px}.cal-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;transition:background .2s ease}.cal-scroll::-webkit-scrollbar-thumb:hover{background:var(--brand)}.time-cell{transition:background-color .15s ease}.time-cell:hover{background-color:#2563eb08}.time-cell .hh{transition:color .15s ease,transform .15s ease}.time-cell:hover .hh{color:var(--brand);transform:translateY(-50%) scale(1.05)}@keyframes spin{to{transform:rotate(360deg)}}.loading{animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.task-row{transition:all .2s ease}.task-row:hover{transform:translate(4px);box-shadow:0 2px 8px #00000014;border-color:var(--brand)}.tasks-list .task-row,.sug-list li{animation:slideInFromLeft .3s ease backwards}.tasks-list .task-row:nth-child(1){animation-delay:0s}.tasks-list .task-row:nth-child(2){animation-delay:.05s}.tasks-list .task-row:nth-child(3){animation-delay:.1s}.tasks-list .task-row:nth-child(4){animation-delay:.15s}.tasks-list .task-row:nth-child(5){animation-delay:.2s}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.event:before{transition:width .2s ease}.event:hover:before{width:5px}.quick-add{transition:all .2s cubic-bezier(.34,1.56,.64,1)}.quick-add:hover{transform:rotate(90deg) scale(1.1);background:var(--brand);color:#fff;border-color:var(--brand)}.quick-add:active{transform:rotate(90deg) scale(.95)}}.event{background-image:linear-gradient(135deg,#ffffff1a,#fff0)}.event[data-color]{box-shadow:0 2px 8px #0000001a,0 1px 2px var(--event-color, transparent)}*:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}*{transition:background-color .2s ease,border-color .2s ease,color .2s ease}.grid-cell{position:relative}.grid-cell:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--border) 10%,var(--border) 90%,transparent 100%)}.drag-ghost{background:linear-gradient(135deg,#2563eb40,#2563eb26);border:2px solid rgba(37,99,235,.6)}.day-head.today .weekday{position:relative;overflow:hidden}.day-head.today .weekday:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);animation:shine 3s infinite}@keyframes shine{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;color:#222}*{box-sizing:border-box}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #eee}.nav{display:flex;align-items:center;gap:8px}.nav button{padding:4px 8px}.main{display:grid;grid-template-columns:1fr 340px;gap:16px;padding:16px}.left{display:flex;flex-direction:column;gap:12px}.right{position:relative}.nlp-form{display:flex;gap:8px}.nlp-form input{flex:1;padding:8px;border:1px solid #ddd;border-radius:6px}.nlp-form button{padding:8px 12px}.cal{border:1px solid #eee;border-radius:8px;overflow:hidden}.cal-head{display:grid;grid-template-columns:64px repeat(7,1fr);background:#fafafa;border-bottom:1px solid #eee}.time-col{width:64px}.time-cell{height:48px;font-size:12px;color:#777;display:flex;align-items:center;justify-content:center;border-bottom:1px dashed #f0f0f0}.day-head{padding:8px;font-weight:600;border-left:1px solid #eee}.cal-body{display:grid;grid-template-columns:64px repeat(7,1fr);position:relative}.day-col{position:relative;border-left:1px solid #f3f3f3;min-height:624px}.grid-cell{height:48px;border-bottom:1px dashed #f7f7f7}.event{position:absolute;left:8px;right:8px;background:#3b82f6;color:#fff;border-radius:6px;padding:6px 8px;box-shadow:0 2px 6px #0000001a}.event-title{font-weight:600;font-size:12px}.event-time{font-size:11px;opacity:.9}.tasks-panel{border:1px solid #eee;border-radius:8px;padding:12px}.task-form{display:flex;gap:8px;margin-bottom:8px}.task-form input{padding:8px;border:1px solid #ddd;border-radius:6px}.task-form button{padding:8px 12px}.tasks-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.task-row{display:flex;align-items:center;justify-content:space-between;padding:8px;border:1px solid #eee;border-radius:6px}.task-title{font-weight:600}.task-sub{color:#777;font-size:12px}.task-actions{display:flex;gap:8px}.task-actions button{padding:6px 10px}.loading{position:fixed;bottom:12px;right:12px;background:#111;color:#fff;padding:8px 10px;border-radius:6px}.suggest-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:flex;align-items:center;justify-content:center}.suggest-card{background:#fff;width:420px;max-width:92vw;padding:16px;border-radius:8px;box-shadow:0 10px 30px #00000026}.sug-list{list-style:none;padding:0;margin:12px 0;display:flex;flex-direction:column;gap:8px}.sug-list li{display:flex;align-items:center;justify-content:space-between;border:1px solid #eee;border-radius:6px;padding:8px}.sug-sub{color:#777;font-size:12px}.suggest-card .close{margin-top:8px}.month{border:1px solid #eee;border-radius:8px;overflow:hidden}.month-head{display:grid;grid-template-columns:repeat(7,1fr);background:#fafafa;border-bottom:1px solid #eee}.mhd{padding:8px;font-weight:600;text-align:center}.month-body{display:grid;grid-template-columns:repeat(7,1fr)}.mcell{min-height:100px;border-left:1px solid #f3f3f3;border-bottom:1px solid #f3f3f3;padding:6px}.mcell.other{background:#fcfcfc;color:#777}.mdn{font-size:12px;font-weight:600;margin-bottom:4px}.mlist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.mitem{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000047;display:flex;align-items:center;justify-content:center}.card{background:#fff;width:420px;max-width:92vw;padding:16px;border-radius:8px;box-shadow:0 10px 30px #00000026}.form-row{display:grid;grid-template-columns:80px 1fr;align-items:center;gap:8px;margin-bottom:8px}.form-row input{padding:8px;border:1px solid #ddd;border-radius:6px}.actions{display:flex;gap:8px;justify-content:flex-end}:root{--today-pill-bg: #2563eb;--today-pill-fg: #ffffff}.container{max-width:none;width:100%;margin:0;padding:0 12px}.day-col.today{background:none}.day-head.today .weekday{background:var(--today-pill-bg);color:var(--today-pill-fg);padding:2px 8px;border-radius:9999px}.day-head.today .date{color:var(--today-pill-bg);font-weight:700}html,body,#root{height:100%}body{margin:0;overflow-x:hidden}:root{--topbar-h: 56px;--page-pad: 12px;--sidebar-w: 340px;--hour: 48px}.container{width:100%;max-width:100vw;margin:0 auto;padding:0 var(--page-pad)}.main{display:grid;grid-template-columns:minmax(0,1fr) var(--sidebar-w);gap:16px;height:calc(100vh - var(--topbar-h) - var(--page-pad) * 2)}.left,.right{display:flex;flex-direction:column;min-height:0}.cal{display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.cal-body.cal-scroll{flex:1 1 auto;height:auto;overflow-y:auto}.right{position:sticky;top:var(--topbar-h);height:calc(100vh - var(--topbar-h) - var(--page-pad) * 2);overflow:hidden}.tasks-panel{display:flex;flex-direction:column;height:100%;min-height:0}.tasks-panel .scroll{flex:1 1 auto;min-height:0;overflow-y:auto}@media (max-width: 1100px){.main{grid-template-columns:1fr;height:auto}.right{position:static;height:auto;overflow:visible;margin-top:12px}}.time-cell .hh{top:0;transform:translateY(-50%)}html,body,#root{height:100%!important}body{margin:0!important;overflow-x:hidden!important}:root{--topbar-h: 56px;--page-pad: 12px;--sidebar-w: 340px}.container,.app>.container{width:100%!important;max-width:100vw!important;margin:0 auto!important;padding-left:var(--page-pad)!important;padding-right:var(--page-pad)!important}.app .main{display:grid!important;grid-template-columns:minmax(0,1fr) var(--sidebar-w)!important;gap:16px!important;align-items:start!important;height:calc(100vh - var(--topbar-h) - (var(--page-pad) * 2))!important;max-width:100%!important;overflow:hidden!important}.app .left{min-height:0!important;display:flex!important;flex-direction:column!important}.app .cal{flex:1 1 auto!important;min-height:0!important;display:flex!important;flex-direction:column!important}.app .cal-body.cal-scroll{flex:1 1 auto!important;height:auto!important;overflow-y:auto!important}.app .right{position:sticky!important;top:var(--topbar-h)!important;height:calc(100vh - var(--topbar-h) - (var(--page-pad) * 2))!important;overflow:hidden!important;width:var(--sidebar-w)!important}.app .tasks-panel{display:flex!important;flex-direction:column!important;height:100%!important;min-height:0!important}.app .tasks-panel .scroll{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important}@media (max-width: 1100px){.app .main{grid-template-columns:1fr!important;height:auto!important}.app .right{position:static!important;height:auto!important;overflow:visible!important;margin-top:12px!important}}
