*{box-sizing:border-box;margin:0;padding:0}:root{--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 26px;--ease: cubic-bezier(.2, .8, .2, 1);--h-work: 255;--h-personal: 8;--h-study: 292;--h-creative: 64;--h-fitness: 178}[data-theme=midnight]{--bg: oklch(.165 .014 264);--bg-grad: radial-gradient(1200px 700px at 78% -8%, oklch(.24 .04 280 / .5), transparent 60%), radial-gradient(900px 600px at -5% 110%, oklch(.22 .05 200 / .35), transparent 55%);--surface: oklch(.205 .016 264);--surface-2: oklch(.245 .018 264);--surface-3: oklch(.285 .02 264);--border: oklch(.32 .018 264);--border-soft: oklch(.27 .016 264 / .7);--text: oklch(.965 .006 264);--text-dim: oklch(.74 .012 264);--text-faint: oklch(.56 .014 264);--accent: oklch(.83 .13 84);--accent-2: oklch(.8 .14 84);--accent-ink: oklch(.22 .04 84);--accent-soft: oklch(.83 .13 84 / .14);--today-ring: var(--accent);--shadow-lg: 0 24px 60px -20px oklch(.1 .02 264 / .8), 0 8px 24px -12px oklch(0 0 0 / .6);--shadow-sm: 0 4px 18px -8px oklch(0 0 0 / .55);--font-display: "Unbounded", system-ui, sans-serif;--font-body: "Onest", system-ui, sans-serif;--cat-l: .72;--cat-c: .13;--chip-bg-a: .18;--chip-text-l: .86;--chip-text-c: .07;--grid-line: oklch(.3 .016 264 / .55);--weekend-tint: oklch(.22 .02 300 / .35);--scrim: oklch(.1 .02 264 / .62)}[data-theme=paper]{--bg: oklch(.925 .022 84);--bg-grad: none;--surface: oklch(.975 .014 86);--surface-2: oklch(.945 .02 84);--surface-3: oklch(.91 .026 80);--border: oklch(.82 .03 72);--border-soft: oklch(.86 .025 75 / .8);--text: oklch(.3 .028 58);--text-dim: oklch(.46 .03 56);--text-faint: oklch(.62 .028 58);--accent: oklch(.56 .14 38);--accent-2: oklch(.52 .15 38);--accent-ink: oklch(.99 .01 80);--accent-soft: oklch(.56 .14 38 / .12);--today-ring: var(--accent);--shadow-lg: 0 22px 50px -24px oklch(.45 .06 60 / .45), 0 6px 18px -10px oklch(.5 .05 60 / .3);--shadow-sm: 0 3px 12px -6px oklch(.5 .06 60 / .3);--font-display: "Lora", Georgia, serif;--font-body: "Golos Text", system-ui, sans-serif;--cat-l: .55;--cat-c: .14;--chip-bg-a: .16;--chip-text-l: .4;--chip-text-c: .11;--grid-line: oklch(.84 .026 74);--weekend-tint: oklch(.9 .03 72 / .55);--scrim: oklch(.45 .06 60 / .4)}[data-theme=clean]{--bg: oklch(.975 .003 256);--bg-grad: none;--surface: oklch(1 0 0);--surface-2: oklch(.965 .004 256);--surface-3: oklch(.93 .006 256);--border: oklch(.9 .006 256);--border-soft: oklch(.93 .005 256);--text: oklch(.24 .012 262);--text-dim: oklch(.5 .012 262);--text-faint: oklch(.66 .01 262);--accent: oklch(.55 .17 258);--accent-2: oklch(.5 .18 258);--accent-ink: oklch(1 0 0);--accent-soft: oklch(.55 .17 258 / .1);--today-ring: var(--accent);--shadow-lg: 0 18px 44px -22px oklch(.4 .04 260 / .35), 0 4px 14px -8px oklch(.4 .03 260 / .18);--shadow-sm: 0 2px 10px -6px oklch(.4 .03 260 / .22);--font-display: "Onest", system-ui, sans-serif;--font-body: "Onest", system-ui, sans-serif;--cat-l: .55;--cat-c: .15;--chip-bg-a: .12;--chip-text-l: .42;--chip-text-c: .12;--grid-line: oklch(.92 .005 256);--weekend-tint: oklch(.965 .006 256);--scrim: oklch(.35 .03 260 / .35)}.cat-work{--h: var(--h-work)}.cat-personal{--h: var(--h-personal)}.cat-study{--h: var(--h-study)}.cat-creative{--h: var(--h-creative)}.cat-fitness{--h: var(--h-fitness)}html,body{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}#root{height:100vh}::selection{background:var(--accent-soft)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:20px;border:3px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--text-faint);background-clip:padding-box}*::-webkit-scrollbar-track{background:transparent}.app{height:100vh;display:grid;grid-template-columns:272px 1fr;background:var(--bg);background-image:var(--bg-grad)}.sidebar{border-right:1px solid var(--border-soft);display:flex;flex-direction:column;min-height:0;background:color-mix(in oklab,var(--surface) 88%,var(--bg))}.brand{display:flex;align-items:center;gap:12px;padding:22px 22px 16px}.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(140deg,var(--accent),var(--accent-2));color:var(--accent-ink);display:grid;place-items:center;flex:none;font-family:var(--font-display);font-weight:700;box-shadow:var(--shadow-sm),inset 0 1px #ffffff40;position:relative}.brand-name{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.02em}.brand-sub{font-size:11.5px;color:var(--text-faint);margin-top:1px}.create-btn{margin:4px 20px 18px;display:flex;align-items:center;justify-content:center;gap:9px;padding:12px 16px;border:none;cursor:pointer;background:var(--accent);color:var(--accent-ink);border-radius:var(--r-md);font-family:var(--font-body);font-weight:600;font-size:14.5px;box-shadow:var(--shadow-sm);transition:transform .15s var(--ease),filter .15s var(--ease)}.create-btn:hover{filter:brightness(1.06);transform:translateY(-1px)}.create-btn:active{transform:translateY(0)}.side-scroll{overflow-y:auto;padding:0 14px 20px;flex:1;min-height:0}.mini-cal{padding:4px 6px 14px}.mini-head{display:flex;align-items:center;justify-content:space-between;padding:2px 6px 8px}.mini-title{font-size:13px;font-weight:600}.mini-nav{display:flex;gap:2px}.mini-nav button,.icon-btn{background:transparent;border:none;cursor:pointer;color:var(--text-dim);width:26px;height:26px;border-radius:7px;display:grid;place-items:center;transition:background .15s,color .15s}.mini-nav button:hover,.icon-btn:hover{background:var(--surface-2);color:var(--text)}.mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.mini-dow{font-size:10px;color:var(--text-faint);text-align:center;padding:3px 0;font-weight:600}.mini-day{aspect-ratio:1;display:grid;place-items:center;font-size:11.5px;border-radius:7px;cursor:pointer;color:var(--text-dim);position:relative;transition:background .12s}.mini-day:hover{background:var(--surface-2)}.mini-day.out{color:var(--text-faint);opacity:.5}.mini-day.today{background:var(--accent);color:var(--accent-ink);font-weight:700}.mini-day.sel{box-shadow:inset 0 0 0 1.5px var(--accent);color:var(--text)}.mini-day .dot{position:absolute;bottom:3px;width:3px;height:3px;border-radius:50%;background:var(--accent)}.mini-day.today .dot{background:var(--accent-ink)}.side-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-weight:700;padding:8px 8px 6px}.cat-list{display:flex;flex-direction:column;gap:1px}.cat-row{display:flex;align-items:center;gap:11px;padding:9px 8px;border-radius:var(--r-sm);cursor:pointer;transition:background .12s;-webkit-user-select:none;user-select:none}.cat-row:hover{background:var(--surface-2)}.cat-check{width:17px;height:17px;border-radius:5px;flex:none;position:relative;background:oklch(var(--cat-l) var(--cat-c) var(--h));box-shadow:inset 0 0 0 1px oklch(var(--cat-l) var(--cat-c) var(--h) / .5);transition:opacity .15s,transform .15s;display:grid;place-items:center}.cat-row.off .cat-check{background:transparent;box-shadow:inset 0 0 0 1.6px var(--border)}.cat-check svg{width:12px;height:12px;color:var(--accent-ink);opacity:1;transition:opacity .12s}[data-theme=midnight] .cat-check svg{color:#090d16}.cat-row.off .cat-check svg{opacity:0}.cat-icon{width:16px;height:16px;color:oklch(var(--cat-l) var(--cat-c) var(--h));flex:none}.cat-name{font-size:13.5px;flex:1;color:var(--text)}.cat-row.off .cat-name{color:var(--text-faint)}.cat-count{font-size:11.5px;color:var(--text-faint);font-variant-numeric:tabular-nums}.main{display:flex;flex-direction:column;min-width:0;min-height:0}.topbar{display:flex;align-items:center;gap:14px;padding:16px 22px;border-bottom:1px solid var(--border-soft)}.period-nav{display:flex;align-items:center;gap:4px}.today-btn{padding:8px 15px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-sm);cursor:pointer;font-family:var(--font-body);font-weight:600;font-size:13.5px;transition:background .14s,border-color .14s}.today-btn:hover{background:var(--surface-2);border-color:var(--text-faint)}.nav-arrows{display:flex;gap:2px;margin-left:4px}.period-title{font-family:var(--font-display);font-size:23px;font-weight:600;letter-spacing:-.015em;margin-left:8px;white-space:nowrap;text-transform:capitalize}.period-title .yr{color:var(--text-faint);font-weight:500}.topbar-spacer{flex:1}.search-box{display:flex;align-items:center;gap:9px;padding:0 13px;height:40px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);width:230px;transition:width .25s var(--ease),border-color .14s,box-shadow .14s}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);width:280px}.search-box svg{color:var(--text-faint);flex:none}.search-box input{border:none;background:transparent;outline:none;color:var(--text);font-family:var(--font-body);font-size:14px;width:100%}.search-box input::placeholder{color:var(--text-faint)}.search-clear{background:transparent;border:none;cursor:pointer;color:var(--text-faint);display:grid;place-items:center}.search-clear:hover{color:var(--text)}.view-switch{display:flex;gap:2px;padding:3px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md)}.view-switch button{border:none;background:transparent;cursor:pointer;color:var(--text-dim);padding:7px 13px;border-radius:8px;font-family:var(--font-body);font-weight:600;font-size:13px;transition:color .14s,background .14s}.view-switch button:hover{color:var(--text)}.view-switch button.active{background:var(--surface-3);color:var(--text);box-shadow:var(--shadow-sm)}.theme-switch{display:flex;gap:5px;align-items:center}.theme-dot{width:26px;height:26px;border-radius:8px;cursor:pointer;border:1.5px solid var(--border);position:relative;transition:transform .14s,border-color .14s;padding:0}.theme-dot:hover{transform:translateY(-1px)}.theme-dot.active{border-color:var(--accent)}.theme-dot.active:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:11px;border:1.5px solid var(--accent);opacity:.5}.theme-dot.t-midnight{background:linear-gradient(135deg,#11161f,#776542,#efc05b)}.theme-dot.t-paper{background:linear-gradient(135deg,#f5eee0,#daa088,#b75131)}.theme-dot.t-clean{background:linear-gradient(135deg,#fff,#94b8ec,#276ed2)}.avatar{width:38px;height:38px;border-radius:50%;flex:none;cursor:pointer;background:linear-gradient(135deg,oklch(var(--cat-l) .13 var(--h-creative)),oklch(var(--cat-l) .14 var(--h-personal)));display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;box-shadow:var(--shadow-sm)}.cal-wrap{flex:1;min-height:0;overflow:hidden;padding:18px 22px 22px}.cal-card{height:100%;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.month-dow{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border-soft)}.month-dow div{padding:12px 14px;font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-faint)}.month-dow div.we{color:oklch(var(--cat-l) var(--cat-c) var(--h-personal))}.month-grid{flex:1;display:flex;flex-direction:column;min-height:0}.week-row{flex:1;display:grid;grid-template-columns:repeat(7,1fr);min-height:0;border-bottom:1px solid var(--grid-line)}.week-row:last-child{border-bottom:none}.day-cell{min-width:0;border-right:1px solid var(--grid-line);padding:7px 8px 6px;min-height:0;overflow:hidden;cursor:pointer;position:relative;display:flex;flex-direction:column;gap:4px;transition:background .12s}.day-cell:last-child{border-right:none}.day-cell:hover{background:var(--surface-2)}.day-cell.weekend{background:var(--weekend-tint)}.day-cell.out{opacity:.45}.day-cell.drop-target{background:var(--accent-soft);box-shadow:inset 0 0 0 2px var(--accent)}.day-num{font-size:13px;font-weight:600;color:var(--text-dim);width:26px;height:26px;display:grid;place-items:center;border-radius:8px;flex:none;align-self:flex-start;font-variant-numeric:tabular-nums}.day-cell.today .day-num{background:var(--accent);color:var(--accent-ink);font-weight:700}.day-chips{display:flex;flex-direction:column;gap:3px;overflow:hidden}.chip{display:flex;align-items:center;gap:6px;padding:3px 7px;border-radius:6px;font-size:11.5px;font-weight:500;cursor:pointer;position:relative;background:oklch(var(--cat-l) var(--cat-c) var(--h) / var(--chip-bg-a));color:oklch(var(--chip-text-l) var(--chip-text-c) var(--h));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:filter .12s,transform .12s;border:1px solid transparent}.chip:hover{filter:brightness(1.08);border-color:oklch(var(--cat-l) var(--cat-c) var(--h) / .35)}.chip.dragging{opacity:.4}.chip .chip-dot{width:6px;height:6px;border-radius:50%;background:oklch(var(--cat-l) var(--cat-c) var(--h));flex:none}.chip .chip-time{color:oklch(var(--chip-text-l) calc(var(--chip-text-c) * .6) var(--h));font-variant-numeric:tabular-nums;opacity:.85}.chip .chip-title{overflow:hidden;text-overflow:ellipsis}.chip.solid{background:oklch(var(--cat-l) var(--cat-c) var(--h));color:var(--accent-ink)}[data-theme=midnight] .chip.solid{color:#090d16}.chip.solid .chip-dot{background:currentColor}.chip.solid .chip-time{color:currentColor}.more-link{font-size:11px;color:var(--text-faint);font-weight:600;padding:1px 7px;cursor:pointer}.more-link:hover{color:var(--accent)}.timegrid-head{display:grid;border-bottom:1px solid var(--border-soft);position:relative}.tg-corner{border-right:1px solid var(--grid-line)}.tg-dayhead{padding:10px 6px;text-align:center;border-right:1px solid var(--grid-line);cursor:pointer}.tg-dayhead:hover{background:var(--surface-2)}.tg-dow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint)}.tg-dow.we{color:oklch(var(--cat-l) var(--cat-c) var(--h-personal))}.tg-dnum{font-family:var(--font-display);font-size:22px;font-weight:600;margin-top:3px;width:38px;height:38px;display:grid;place-items:center;border-radius:11px;margin-inline:auto;font-variant-numeric:tabular-nums}.tg-dayhead.today .tg-dnum{background:var(--accent);color:var(--accent-ink)}.timegrid-scroll{flex:1;overflow-y:auto;min-height:0}.timegrid-body{display:grid;position:relative}.tg-hours{border-right:1px solid var(--grid-line)}.tg-hour-label{height:60px;position:relative;padding-right:9px;text-align:right;font-size:11px;color:var(--text-faint);font-variant-numeric:tabular-nums}.tg-hour-label span{position:relative;top:-7px}.tg-daycol{border-right:1px solid var(--grid-line);position:relative}.tg-hour-line{height:60px;border-bottom:1px solid var(--grid-line)}.tg-event{position:absolute;left:4px;right:4px;border-radius:7px;padding:5px 8px;overflow:hidden;background:oklch(var(--cat-l) var(--cat-c) var(--h) / .92);cursor:pointer;color:#fff;font-size:11.5px;box-shadow:var(--shadow-sm);border-left:3px solid oklch(calc(var(--cat-l) - .15) var(--cat-c) var(--h));transition:filter .12s,box-shadow .12s;z-index:2}[data-theme=paper] .tg-event,[data-theme=clean] .tg-event{color:#fffbf4}.tg-event:hover{filter:brightness(1.08);z-index:30;min-width:140px;box-shadow:var(--shadow-lg)}.tg-event .te-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-event .te-time{opacity:.85;font-size:10.5px;font-variant-numeric:tabular-nums}.now-line{position:absolute;left:0;right:0;height:0;border-top:2px solid oklch(.6 .2 25);z-index:6;pointer-events:none}.now-line:before{content:"";position:absolute;left:-5px;top:-5px;width:8px;height:8px;border-radius:50%;background:#de3b3d}.agenda{flex:1;overflow-y:auto;padding:8px 0}.agenda-day{display:grid;grid-template-columns:132px 1fr;gap:18px;padding:16px 26px;border-bottom:1px solid var(--border-soft)}.agenda-day:hover{background:var(--surface-2)}.agenda-date{position:sticky;top:0}.agenda-dnum{font-family:var(--font-display);font-size:30px;font-weight:600;line-height:1}.agenda-dow{font-size:12.5px;color:var(--text-dim);margin-top:4px;font-weight:600}.agenda-today-badge{display:inline-block;margin-top:7px;font-size:11px;font-weight:700;color:var(--accent-ink);background:var(--accent);padding:2px 8px;border-radius:20px}.agenda-events{display:flex;flex-direction:column;gap:8px}.agenda-event{display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:var(--r-md);background:var(--surface-2);cursor:pointer;transition:transform .12s,background .12s;border:1px solid transparent}.agenda-event:hover{transform:translate(3px);border-color:var(--border)}.agenda-bar{width:4px;align-self:stretch;border-radius:4px;background:oklch(var(--cat-l) var(--cat-c) var(--h));flex:none}.agenda-ev-icon{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none;background:oklch(var(--cat-l) var(--cat-c) var(--h) / .16);color:oklch(var(--cat-l) var(--cat-c) var(--h))}.agenda-ev-icon svg{width:17px;height:17px}.agenda-ev-main{flex:1;min-width:0}.agenda-ev-title{font-weight:600;font-size:14.5px}.agenda-ev-meta{font-size:12.5px;color:var(--text-dim);margin-top:2px;display:flex;gap:10px;align-items:center}.agenda-ev-time{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text-dim);font-size:13px;text-align:right;flex:none}.agenda-empty{padding:60px;text-align:center;color:var(--text-faint)}.year-grid{flex:1;overflow-y:auto;padding:22px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.year-month{cursor:pointer}.ym-title{font-family:var(--font-display);font-size:15px;font-weight:600;margin-bottom:9px;text-transform:capitalize;padding-left:3px}.ym-title:hover{color:var(--accent)}.ym-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.ym-dow{font-size:9.5px;color:var(--text-faint);text-align:center;padding-bottom:3px;font-weight:600}.ym-day{aspect-ratio:1;display:grid;place-items:center;font-size:11px;border-radius:6px;position:relative;color:var(--text-dim);cursor:pointer}.ym-day:hover{background:var(--surface-2)}.ym-day.out{opacity:.35}.ym-day.today{background:var(--accent);color:var(--accent-ink);font-weight:700}.ym-day .ym-dot{position:absolute;bottom:2px;width:3px;height:3px;border-radius:50%;background:oklch(var(--cat-l) var(--cat-c) var(--h))}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim);display:grid;place-items:center;z-index:100;padding:24px;animation:fade .18s var(--ease)}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(10px) scale(.97)}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:480px;max-width:100%;overflow:hidden;animation:pop .22s var(--ease)}.modal-head{padding:22px 24px 4px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-title-input{font-family:var(--font-display);font-size:21px;font-weight:600;color:var(--text);border:none;background:transparent;outline:none;width:100%;letter-spacing:-.01em}.modal-title-input::placeholder{color:var(--text-faint)}.modal-close{flex:none}.modal-body{padding:8px 24px 22px;display:flex;flex-direction:column;gap:16px}.field{display:flex;align-items:center;gap:13px}.field-ico{width:20px;color:var(--text-faint);flex:none;display:grid;place-items:center}.field-main{flex:1;min-width:0}.field-label{font-size:11px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.input,.select,textarea.input{width:100%;padding:9px 12px;border:1px solid var(--border);background:var(--surface-2);border-radius:var(--r-sm);color:var(--text);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .14s,box-shadow .14s}.input:focus,.select:focus,textarea.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea.input{resize:vertical;min-height:64px}.time-row{display:flex;gap:10px;align-items:center}.time-row .input{width:auto;flex:1}.cat-picker{display:flex;flex-wrap:wrap;gap:8px}.cat-pick{display:flex;align-items:center;gap:7px;padding:7px 12px;border-radius:20px;cursor:pointer;border:1.5px solid var(--border);background:var(--surface-2);font-size:13px;font-weight:600;color:var(--text-dim);transition:all .14s}.cat-pick .cp-dot{width:11px;height:11px;border-radius:50%;background:oklch(var(--cat-l) var(--cat-c) var(--h))}.cat-pick.active{border-color:oklch(var(--cat-l) var(--cat-c) var(--h));background:oklch(var(--cat-l) var(--cat-c) var(--h) / .14);color:oklch(var(--cat-l) var(--cat-c) var(--h))}.modal-foot{padding:16px 24px;border-top:1px solid var(--border-soft);display:flex;gap:10px;justify-content:space-between;align-items:center}.btn{padding:10px 18px;border-radius:var(--r-sm);cursor:pointer;font-family:var(--font-body);font-weight:600;font-size:14px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);transition:all .14s}.btn:hover{background:var(--surface-3)}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:transparent}.btn-primary:hover{filter:brightness(1.06);background:var(--accent)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-dim)}.btn-ghost:hover{color:#de3b3d;background:#de3b3d1a}.detail-banner{height:80px;position:relative;display:flex;align-items:flex-end;padding:16px 24px;background:linear-gradient(120deg,oklch(var(--cat-l) var(--cat-c) var(--h)),oklch(calc(var(--cat-l) + .08) calc(var(--cat-c) - .02) calc(var(--h) + 25)))}.detail-banner .db-icon{width:44px;height:44px;border-radius:12px;background:#ffffff38;display:grid;place-items:center;color:#fff}.detail-banner .db-icon svg{width:22px;height:22px}.detail-banner .modal-close{position:absolute;top:14px;right:14px}.detail-banner .modal-close .icon-btn{color:#fff;background:#ffffff26}.detail-banner .modal-close .icon-btn:hover{background:#ffffff4d}.detail-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.detail-title{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-.01em}.detail-row{display:flex;align-items:center;gap:13px;font-size:14px;color:var(--text-dim)}.detail-row svg{width:18px;color:var(--text-faint);flex:none}.detail-row strong{color:var(--text);font-weight:600}.detail-cat-tag{display:inline-flex;align-items:center;gap:7px;padding:4px 11px;border-radius:20px;background:oklch(var(--cat-l) var(--cat-c) var(--h) / .15);color:oklch(var(--cat-l) var(--cat-c) var(--h));font-size:12.5px;font-weight:600}.detail-cat-tag .cp-dot{width:9px;height:9px;border-radius:50%;background:currentColor}.detail-notes{font-size:14px;color:var(--text-dim);line-height:1.55}.popover{position:fixed;z-index:90;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);width:220px;padding:12px;animation:pop .16s var(--ease)}.popover-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.popover-date{font-family:var(--font-display);font-size:19px;font-weight:600}.popover-dow{font-size:11px;color:var(--text-faint);text-transform:uppercase}.popover .day-chips{gap:4px}.kbd{display:inline-block;padding:1px 6px;border-radius:5px;border:1px solid var(--border);background:var(--surface-2);font-size:11px;font-family:var(--font-body);color:var(--text-dim)}@media (prefers-reduced-motion: no-preference){.agenda-day,.year-month{animation:cellin .35s var(--ease) both}}@keyframes cellin{0%{opacity:0;transform:translateY(4px)}}@media (max-width: 920px){.app{grid-template-columns:1fr}.sidebar{display:none}.period-title{font-size:19px}.search-box{width:150px}.search-box:focus-within{width:180px}.view-switch button{padding:7px 9px}}.auth-wrap{min-height:100vh;display:grid;place-items:center;background:var(--bg);background-image:var(--bg-grad);padding:24px}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:30px 28px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.auth-title{font-family:var(--font-display);font-size:22px;color:var(--text);margin-bottom:18px}.auth-input{width:100%;margin-bottom:12px}.auth-error{color:#d74745;font-size:13px;margin:2px 0 12px}.auth-submit{width:100%;justify-content:center;margin-top:4px}.auth-toggle{background:none;border:none;color:var(--text-dim);font-size:13px;margin-top:14px;cursor:pointer}.auth-toggle:hover{color:var(--accent)}.error-card-center{text-align:center;align-items:center}.error-code{font-family:var(--font-display);font-weight:700;font-size:56px;line-height:1;letter-spacing:-.03em;color:var(--accent)}.error-title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text);margin-top:8px}.error-sub{font-size:13.5px;color:var(--text-dim);margin-top:6px}.error-home{margin-top:18px;text-decoration:none;justify-content:center}.side-section-title{display:flex;align-items:center;justify-content:space-between}.cat-manage-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:3px;color:var(--text-dim);cursor:pointer;display:inline-flex}.cat-manage-btn:hover{color:var(--accent);border-color:var(--accent)}.logout-btn{margin-top:12px;background:none;border:1px solid var(--border);border-radius:var(--r-md);padding:9px;color:var(--text-dim);cursor:pointer;font-size:13px}.logout-btn:hover{color:var(--accent);border-color:var(--accent)}.version-btn{margin-top:12px;align-self:center;background:none;border:none;cursor:pointer;color:var(--text-faint);font-size:11.5px;letter-spacing:.04em;padding:2px 8px;border-radius:var(--r-sm);transition:color .15s var(--ease)}.version-btn:hover{color:var(--accent)}.version-btn+.logout-btn{margin-top:4px}.modal.whatsnew{width:560px}.wn-body{max-height:min(64vh,600px);overflow-y:auto;gap:10px}.wn-release{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-lg);padding:14px 16px 15px}.wn-release.latest{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.wn-release-head{display:flex;align-items:center;gap:10px}.wn-version{font-family:var(--font-display);font-size:12.5px;font-weight:600;color:var(--text);background:var(--surface-3);border:1px solid var(--border-soft);padding:2px 9px;border-radius:999px}.wn-release.latest .wn-version{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.wn-badge{color:var(--accent);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em}.wn-date{color:var(--text-faint);font-size:12px;margin-left:auto}.wn-title{font-weight:600;font-size:15.5px;margin-top:10px;color:var(--text);letter-spacing:-.01em}.wn-items{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}.wn-items li{display:flex;gap:11px;align-items:flex-start;font-size:13.5px;line-height:1.5;color:var(--text-dim)}.wn-ico{flex:none;width:28px;height:28px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}.wn-ico svg{width:15px;height:15px}.wn-text{padding-top:4px}.timegrid-allday{display:grid;background:var(--surface);border-bottom:1px solid var(--border)}.tg-allday-label{display:flex;align-items:center;justify-content:flex-end;padding:5px 10px 5px 0;font-size:10.5px;color:var(--text-faint);text-align:right;line-height:1.1}.tg-allday-cell{display:flex;flex-direction:column;gap:3px;padding:4px 5px;min-height:28px;border-left:1px solid var(--grid-line)}.tg-allday-chip{cursor:pointer}.cat-editor{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-top:10px}.icon-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.icon-choice{width:34px;height:34px;display:grid;place-items:center;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer}.icon-choice:hover{color:var(--text)}.icon-choice.active{border-color:oklch(var(--cat-l) var(--cat-c) var(--h));color:oklch(var(--cat-l) var(--cat-c) var(--h));background:oklch(var(--cat-l) var(--cat-c) var(--h) / .12)}.weekday-row{display:flex;gap:5px;margin-top:9px;flex-wrap:wrap}.weekday-chip{min-width:34px;padding:6px 8px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s var(--ease)}.weekday-chip:hover{color:var(--text);border-color:var(--text-faint)}.weekday-chip.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.reminder-mode{display:inline-flex;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:3px}.reminder-mode button{border:none;background:none;color:var(--text-dim);font-size:12.5px;padding:4px 10px;border-radius:7px;cursor:pointer}.reminder-mode button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.reminder-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px;align-items:center}.reminder-chip{padding:5px 9px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:12.5px;cursor:pointer}.reminder-chip:hover{color:var(--text)}.reminder-chip.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.reminder-hint{font-size:12px;color:var(--text-faint)}.settings-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.settings-ok{color:#3b9555;font-weight:600;font-size:14px}.settings-msg{margin-top:8px;font-size:12.5px;color:var(--text-dim)}.invite-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.invite-row{display:flex;align-items:center;gap:10px}.invite-row.used{opacity:.5}.invite-code{font-family:ui-monospace,monospace;background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:3px 8px;font-size:12.5px}.invite-state{font-size:12px;color:var(--text-faint)}.import-preview{margin-top:10px;display:flex;flex-direction:column;gap:8px;align-items:flex-start;font-size:13px;color:var(--text-dim)}.import-sub-add{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}.import-sub-add>input.input{flex:1;min-width:160px}.import-sub-add select.input{flex:none;max-width:160px}.import-sub-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.import-sub-row{display:flex;align-items:center;gap:8px}.import-sub-main{flex:1;min-width:0}.import-sub-cat{flex:none;max-width:130px;padding:4px 8px;font-size:12px}.import-sub-url{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-sub-meta{font-size:11.5px;color:var(--text-faint)}
