@import "https://fonts.googleapis.com/css2?family=Noto+Serif+KR:wght@300;400;500;600;700&family=Noto+Sans+KR:wght@300;400;500;600;700&family=IBM+Plex+Sans+KR:wght@300;400;500;600;700&family=Gowun+Dodum&family=Sunflower:wght@300;500;700&display=swap";@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";:root{--color-bg:#f5f0e8;--color-surface:#faf7f2;--color-surface-raised:#fffdf9;--color-border:#7864461a;--color-grid-gap:#e8e0d0;--color-text:#2c2518;--color-text-secondary:#7a6e5f;--color-text-muted:#b0a490;--color-accent:#7a8c6e;--color-accent-hover:#67785c;--color-accent-subtle:#eef1ea;--color-danger:#a87060;--color-danger-hover:#8f5c4d;--color-danger-subtle:#a8706014;--color-important:#f0b44c;--color-sunday:#a87060;--color-saturday:#7a8c6e;--color-today-bg:#7a8c6e;--color-today-text:#fff;--color-other-month-bg:#ede8df;--color-other-month-text:#c0b8a8;--color-cell-hover:#faf6ee2f;--event-bar-bg:#78644612;--color-todo-section-label:var(--color-text-secondary);--color-todo-date-label:var(--color-text-muted);--radius-sm:4px;--radius-md:7px;--radius-lg:11px;--radius-xl:14px;--radius-full:999px;font-family:var(--font-family-global,"Noto Serif KR", serif);font-size:var(--font-size-base,14px);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;line-height:1.5}[data-theme=dark]{--color-bg:#0e0e12;--color-surface:#15151b;--color-surface-raised:#1c1e25;--color-border:#6478aa24;--color-grid-gap:#07070b;--color-text:#d4dbe8;--color-text-secondary:#788090;--color-text-muted:#3c4455;--color-accent:#547b9e;--color-accent-hover:#6d96b9;--color-accent-subtle:#101c32;--color-danger:#c87070;--color-danger-hover:#da8585;--color-danger-subtle:#c870701a;--color-important:#f2cf7d;--color-sunday:#c06868;--color-saturday:#5a96cc;--color-today-bg:#5984af;--color-today-text:#fff;--color-other-month-bg:#090a12;--color-other-month-text:#20283a;--color-cell-hover:#506eaa0d;--event-bar-bg:#6478aa1a;--color-todo-section-label:var(--color-text-secondary);--color-todo-date-label:var(--color-text-muted)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-bg);min-height:100vh}::view-transition-old(root){animation-duration:.4s;animation-timing-function:ease}::view-transition-new(root){animation-duration:.4s;animation-timing-function:ease}::view-transition-old(root){animation-name:theme-fade-out}::view-transition-new(root){animation-name:theme-fade-in}@keyframes theme-fade-out{0%{opacity:1}to{opacity:0}}@keyframes theme-fade-in{0%{opacity:0}to{opacity:1}}#root{width:100%;min-height:100vh}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;text-align:left;background:0 0;border:none;line-height:1.5}input,textarea,select{font-family:inherit;font-size:inherit;line-height:1.5}ul,li{list-style:none}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--color-surface);align-items:center;gap:12px;padding:12px 24px;display:flex}.app-header-inner{flex:1;align-items:center;gap:16px;display:flex}.app-logo{align-items:center;gap:8px;display:flex}.app-logo-icon{opacity:.75;font-size:20px}.app-logo-text{color:var(--color-text);letter-spacing:-.2px;font-size:16px;font-weight:600}.app-content{flex:1;min-height:0;display:flex}.sidebar-wrapper{z-index:300;width:12px;height:100dvh;position:fixed;top:0;left:0}.app-sidebar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:0 var(--radius-xl) var(--radius-xl) 0;flex-direction:column;align-items:center;gap:4px;width:45px;height:75%;padding:16px 0;transition:transform .22s;display:flex;position:absolute;top:12.5%;left:0;transform:translate(-100%)}.sidebar-wrapper:hover .app-sidebar{transform:translate(0)}.sidebar-item{border-radius:var(--radius-lg);width:37px;color:var(--color-text-muted);background:0 0;flex-direction:column;align-items:center;gap:4px;padding:clamp(7px,1.2vh,12px) 0;transition:background .15s,color .15s;display:flex}.sidebar-item:hover{background:var(--color-border);color:var(--color-text-secondary)}.sidebar-item.active{background:var(--color-accent-subtle);color:var(--color-accent)}html:not([data-theme=dark]) .sidebar-item.active{color:#4e3218;background:#ece4d5}.sidebar-label{letter-spacing:.2px;font-size:10px;font-weight:500}.app-main{flex:1;min-width:0;padding:16px 20px 28px 40px}.app-body{grid-template-columns:3fr 2fr;align-items:start;gap:20px;display:grid}.app-body--diary{grid-template-columns:1fr;width:100%;max-width:70%;margin:0 auto}.theme-toggle-btn{width:34px;height:34px;color:var(--color-text-muted);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.theme-toggle-btn:hover{background:var(--color-border);color:var(--color-text-secondary)}.nl-input-container{padding:4px 0}.nl-input-form{display:flex}.nl-input-wrap{flex:1;align-items:center;display:flex;position:relative}.nl-input{border:.75px solid var(--color-border);border-radius:var(--radius-xl);color:var(--color-text);background:var(--color-surface-raised);outline:none;flex:1;padding:12px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s;box-shadow:0 4px 18px -4px #0000002e,inset 0 1px 3px #ffffff0a}.nl-input:focus{border-color:#c8b9a0cc;box-shadow:0 6px 24px -4px #00000038,inset 0 1px 3px #ffffff0a}[data-theme=dark] .nl-input{box-shadow:0 4px 20px -4px #00143c80,inset 0 1px 2px #ffffff08}[data-theme=dark] .nl-input:focus{border-color:#5a96cc4d;box-shadow:0 6px 28px -4px #00143c99,0 0 0 3px #5a96cc0f,inset 0 1px 2px #ffffff08}.nl-input::placeholder{color:var(--color-text-muted)}.nl-input:disabled{opacity:.5;cursor:not-allowed}.nl-loading-spinner{border:1.5px solid var(--color-border);border-top-color:var(--color-accent);pointer-events:none;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;position:absolute;right:12px}@keyframes spin{to{transform:rotate(360deg)}}.nl-error{background:var(--color-danger-subtle);border-radius:var(--radius-md);color:var(--color-danger);align-items:center;gap:8px;margin-top:10px;padding:8px 12px;font-size:13px;animation:.2s nlErrorSlideIn;display:flex}.nl-error.exiting{animation:.35s forwards nlErrorSlideOut}@keyframes nlErrorSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes nlErrorSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}.error-icon{background:var(--color-danger);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex}.calendar-section{border-radius:var(--radius-lg);overflow:auto}.diary-zoom-wrapper{touch-action:none;width:100%}.calendar-view{flex-direction:column;display:flex}.calendar-header{justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.calendar-title{color:var(--color-text);letter-spacing:-.2px;background:var(--color-surface);border-radius:var(--radius-full);padding:6px 14px;font-size:15px;font-weight:600;display:inline-block}.calendar-header-right{align-items:center;gap:4px;display:flex}.cal-nav-btn{border-radius:var(--radius-md);color:var(--color-text-secondary);background:0 0;padding:5px 11px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.cal-nav-btn:hover{background:var(--color-border);color:var(--color-text)}.cal-nav-btn.icon-btn{padding:5px 9px;font-size:15px}.view-mode-btn{width:32px;height:32px;color:var(--color-text-muted);background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.view-mode-btn:hover{background:var(--color-border);color:var(--color-text-secondary)}.calendar-day-headers{grid-template-columns:repeat(7,1fr);padding:0 2px;display:grid}.day-header{text-align:center;color:var(--color-text-muted);letter-spacing:.3px;padding:6px 4px;font-size:11px;font-weight:500}.day-header.sunday{color:var(--color-sunday);opacity:.7}.day-header.saturday{color:var(--color-saturday);opacity:.7}.calendar-grid-wrapper{-webkit-user-select:none;user-select:none;position:relative}.calendar-grid{background:var(--color-grid-gap);grid-template-rows:repeat(5,119px);grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-grid--weekly{grid-template-rows:119px}.calendar-grid--6weeks{grid-template-rows:repeat(6,119px)}@keyframes slide-in-from-right{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-from-left{0%{opacity:0;transform:translate(-32px)}to{opacity:1;transform:translate(0)}}.calendar-anim-wrapper{overflow:hidden}.calendar-anim-wrapper.slide-forward{animation:.22s ease-out slide-in-from-right}.calendar-anim-wrapper.slide-backward{animation:.22s ease-out slide-in-from-left}.calendar-events-overlay{pointer-events:none;position:absolute;inset:0;overflow:hidden}.calendar-cell{background:var(--color-bg);cursor:pointer;padding:6px 5px 4px;transition:background .1s;overflow:hidden}.calendar-cell:hover{background:var(--color-cell-hover)}.calendar-cell.other-month .cell-day{color:var(--color-other-month-text)}.calendar-cell.today{background:var(--color-bg)}.calendar-cell.today:hover{background:var(--color-cell-hover)}.cell-day{width:22px;height:22px;color:var(--color-text-secondary);border-radius:50%;justify-content:center;align-items:center;margin-bottom:2px;font-size:12px;font-weight:400;display:inline-flex}.calendar-grid>.calendar-cell:nth-child(7n+1) .cell-day{color:var(--color-sunday)}.calendar-grid>.calendar-cell:nth-child(7n) .cell-day{color:var(--color-saturday)}.cell-day.today-badge{background:var(--color-today-bg);font-weight:600;color:var(--color-today-text)!important}.cell-events-wrap{position:relative}.cell-events{scrollbar-width:none;flex-direction:column;gap:2px;max-height:84px;display:flex;overflow-y:auto}.cell-events::-webkit-scrollbar{display:none}.event-chip{border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;z-index:1;align-items:center;gap:3px;width:100%;min-height:18px;padding:2px 5px;font-size:10.5px;transition:filter .25s;display:flex;position:relative;overflow:visible}.event-chip:hover{filter:brightness(.78)}.event-bar{pointer-events:all;cursor:pointer;color:var(--color-text);white-space:nowrap;align-items:center;padding:0 6px;font-size:11px;transition:filter .25s;display:flex;position:absolute;overflow:visible}.event-bar:hover{filter:brightness(.78)}.event-bar-title{text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}[data-bold-mode=title] .event-bar-title,[data-bold-mode=bold] .event-bar-title,[data-bold-mode=bold] .event-time{font-weight:600}.event-time{opacity:.85;flex-shrink:0;font-size:10px;font-weight:500}.event-title-chip{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}[data-bold-mode=title] .event-title-chip,[data-bold-mode=bold] .event-title-chip{font-weight:600}.event-overflow{color:var(--color-text-muted);padding:1px 4px;font-size:11px}.side-panel{flex-direction:column;gap:16px;display:flex;position:sticky;top:16px}html:not([data-theme=dark]) .todo-list{--color-accent:#1a1a1a;--color-accent-hover:#333;--color-accent-subtle:#f0f0f0;--color-text:#1a1a1a;--color-text-secondary:#777;--color-text-muted:#aaa;--color-border:#ececec}[data-theme=dark] .todo-list{--color-accent:#e5e5e5;--color-accent-hover:#fff;--color-accent-subtle:#2c2c2e;--color-text:#f2f2f7;--color-text-secondary:#8e8e93;--color-text-muted:#6e6e73}.todo-list{border-radius:var(--radius-lg);overflow:hidden}.todo-header{align-items:center;padding:0 0 8px;display:flex}.todo-header h3{background:var(--color-surface);border-radius:var(--radius-full);color:var(--color-text);padding:6px 14px;font-size:14px;font-weight:600;display:inline-block}.todo-count{background:var(--color-accent);color:#fff;border-radius:var(--radius-full);opacity:.85;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:600;display:flex}.todo-empty{text-align:center;padding:20px 16px 24px}.todo-empty p{color:var(--color-text-muted);font-size:12.5px;line-height:1.7}.todo-items{padding:0 0 4px}.todo-group{border-top:1px solid var(--color-border);margin-top:4px;padding-top:4px}.todo-group:first-of-type{border-top:none;margin-top:0}.todo-group-label{color:var(--color-text-secondary);letter-spacing:.3px;text-transform:uppercase;padding:2px 16px 10px;font-size:13px;font-weight:700}.todo-section-label{color:var(--color-todo-date-label);text-transform:uppercase;letter-spacing:.6px;padding:1px 16px 6px;font-size:10px;font-weight:600}.completed-section .todo-item{opacity:.5}.todo-item{align-items:flex-start;gap:10px;padding:5px 4px 5px 28px;transition:background .1s;display:flex;position:relative}.todo-item:before{content:"";background:var(--todo-color);border-radius:999px 0 0 999px;width:3px;position:absolute;top:6px;bottom:6px;left:16px}.todo-item:hover{background:0 0}.todo-date-group-label{color:var(--color-todo-date-label);letter-spacing:.3px;padding:2px 4px 6px 16px;font-size:11px;font-weight:600;list-style:none}.todo-date-group-label:first-child{padding-top:0}.todo-item.completed{animation:.55s ease-out forwards todo-complete-sweep}@keyframes todo-complete-sweep{0%{-webkit-mask-image:linear-gradient(90deg,#00000061 0% 45%,#000 55% 100%);mask-image:linear-gradient(90deg,#00000061 0% 45%,#000 55% 100%);-webkit-mask-position:100% 0;mask-position:100% 0;-webkit-mask-size:200% 100%;mask-size:200% 100%}to{-webkit-mask-image:linear-gradient(90deg,#00000061 0% 45%,#000 55% 100%);mask-image:linear-gradient(90deg,#00000061 0% 45%,#000 55% 100%);-webkit-mask-position:0 0;mask-position:0 0;-webkit-mask-size:200% 100%;mask-size:200% 100%}}.todo-item.completed .todo-title{color:var(--color-text-muted);text-decoration:line-through}.todo-check{border:1.5px solid var(--color-text-muted);border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;margin-top:2px;font-size:10px;transition:background .15s,border-color .15s,color .15s;display:flex}.todo-check.checked{background:var(--color-accent);border-color:var(--color-accent)}.todo-check:hover:not(.checked){border-color:var(--color-accent)}[data-theme=dark] .todo-check.checked{border-color:var(--color-accent);color:var(--color-accent);background:0 0}.todo-content{flex-direction:column;flex:1;gap:3px;display:flex;overflow:hidden}.todo-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}[data-bold-mode=title] .todo-title,[data-bold-mode=bold] .todo-title,[data-bold-mode=bold] .todo-desc,[data-bold-mode=bold] .todo-time,[data-bold-mode=bold] .todo-date{font-weight:600}[data-bold-mode=bold] .todo-section-label,[data-bold-mode=bold] .todo-date-group-label{font-weight:800}.todo-date{color:var(--color-text-muted);align-items:center;gap:8px;font-size:11px;display:flex}.todo-date--overdue{color:var(--color-danger)}.todo-title-row{align-items:baseline;gap:7px;display:flex;overflow:hidden}.todo-desc{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0;font-size:11.5px;overflow:hidden}.todo-item.completed .todo-desc{color:var(--color-text-muted);opacity:.6}.todo-delete{border-radius:var(--radius-sm);width:18px;height:18px;color:var(--color-text-muted);opacity:0;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:10px;transition:opacity .15s,background .15s,color .15s;display:flex}.todo-item:hover .todo-delete{opacity:1}.todo-delete:hover{background:var(--color-danger-subtle);color:var(--color-danger)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--color-surface-raised);border-radius:var(--radius-xl);width:100%;max-width:420px;animation:.18s ease-out modal-in;position:relative;overflow:hidden}@keyframes modal-in{0%{opacity:0;transform:scale(.96)translateY(6px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-header h3{color:var(--color-text);font-size:15px;font-weight:600}.modal-close{border-radius:var(--radius-sm);width:26px;height:26px;color:var(--color-text-muted);justify-content:center;align-items:center;font-size:12px;transition:background .15s;display:flex}.modal-close:hover{background:var(--color-border);color:var(--color-text-secondary)}.modal-form{flex-direction:column;gap:12px;padding:0 20px 20px;display:flex}.form-group{flex-direction:column;gap:5px;display:flex}.form-title-row{align-items:center;gap:8px;display:flex}.form-title-row input{flex:1;min-width:0}.color-picker{flex-shrink:0;position:relative}.color-picker-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;justify-content:center;align-items:center;width:30px;height:30px;padding:0;transition:border-color .15s;display:flex}.color-picker-btn:hover{background:var(--color-surface)}.color-picker-dot{border-radius:50%;width:16px;height:16px;display:block}.color-picker-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.form-group label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.form-group input[type=text],.form-group input[type=date],.form-group input[type=time],.form-group textarea{border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);background:var(--color-surface);outline:none;padding:8px 12px;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-accent)}.form-group textarea{resize:vertical;min-height:56px}.form-group-row{flex-direction:row;align-items:center}.checkbox-label{cursor:pointer;align-items:center;gap:8px;display:flex;color:var(--color-text-secondary)!important;text-transform:none!important;letter-spacing:normal!important;font-size:13px!important;font-weight:400!important}.checkbox-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--color-accent);cursor:pointer}.modal-shift-actions{background:var(--color-surface-raised);flex-direction:row;justify-content:space-between;align-items:center;gap:2px;padding:0 20px 10px;display:flex}.modal-shift-actions-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.btn-shift{color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:5px;padding:4px 6px;font-size:12px;transition:color .15s,background .15s;display:inline-flex}.btn-shift:hover{color:var(--color-accent);background:var(--color-bg)}.modal-actions{background:var(--color-surface-raised);justify-content:flex-end;gap:7px;padding:14px 20px;display:flex}.btn-primary{background:var(--color-accent);color:#fff;border-radius:var(--radius-md);padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,opacity .15s}.btn-primary:hover{background:var(--color-accent-hover)}.btn-primary--danger{background:var(--color-danger)}.btn-primary--danger:hover{background:color-mix(in srgb, var(--color-danger) 85%, black)}.diary-clear-confirm{background:var(--color-surface-raised);border-radius:18px;width:320px;max-width:calc(100vw - 40px);padding:24px 24px 20px;box-shadow:0 8px 32px #0000002e}.diary-clear-confirm__title{color:var(--color-text);margin-bottom:8px;font-size:18px;font-weight:600}.diary-clear-confirm__message{color:var(--color-text-secondary);margin-bottom:24px;font-size:14px}.diary-clear-confirm__actions{justify-content:space-between;gap:10px;display:flex}.diary-clear-confirm__cancel{color:var(--color-text);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:0 0;padding:10px 24px;font-size:14px;font-weight:400;transition:background .15s}.diary-clear-confirm__cancel:hover{background:var(--color-border)}.diary-clear-confirm__delete{background:var(--color-danger);color:#fff;border-radius:var(--radius-md);padding:10px 24px;font-size:14px;font-weight:500;transition:background .15s}.diary-clear-confirm__delete:hover{background:var(--color-danger-hover)}.btn-secondary{color:var(--color-text-secondary);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:0 0;padding:8px 16px;font-size:13px;font-weight:400;transition:background .15s,color .15s}.btn-secondary:hover{background:var(--color-border);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff;border-radius:var(--radius-md);padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s}.btn-danger:hover{background:var(--color-danger-hover)}.duration-toggle{border:1.5px solid var(--color-border);border-radius:var(--radius-md);display:flex;overflow:hidden}.duration-btn{color:var(--color-text-secondary);text-align:center;background:0 0;flex:1;padding:7px 0;font-size:13px;font-weight:500;transition:background .15s,color .15s}.duration-btn+.duration-btn{border-left:1.5px solid var(--color-border)}.duration-btn.active{background:var(--color-accent);color:#fff}.time-picker{align-items:center;gap:8px;display:flex}.time-picker select{border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);background:var(--color-surface);cursor:pointer;outline:none;flex:1;padding:8px 10px;font-size:13px}.time-picker select:focus{border-color:var(--color-accent)}.time-picker input[type=time]{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:108px;color:var(--color-text);background:var(--color-surface);outline:none;padding:8px 10px;font-size:13px}.time-picker input[type=time]:focus{border-color:var(--color-accent)}.day-checkboxes{flex-wrap:wrap;gap:5px;display:flex}.day-chip{width:32px;height:32px;color:var(--color-text-secondary);background:var(--color-border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:500;transition:background .15s,color .15s;display:flex}.day-chip input[type=checkbox]{display:none}.day-chip.selected{background:var(--color-accent);color:#fff}.recurrence-select{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);background:var(--color-surface);cursor:pointer;outline:none;padding:8px 12px;font-size:13px}.recurrence-select:focus{border-color:var(--color-accent)}.form-date-time-row{grid-template-columns:1fr 1fr;align-items:start;gap:8px;display:grid}.form-recurrence-row{grid-template-columns:auto 1fr;align-items:start;gap:8px;display:grid}.form-group--disabled,.time-picker--disabled{opacity:.4;pointer-events:none}.day-summary-overlay{align-items:flex-end;padding-bottom:48px}@media (width>=600px){.day-summary-overlay{align-items:center;padding-bottom:20px}}.day-summary-card{background:var(--color-surface-raised);border-radius:var(--radius-xl);width:100%;max-width:300px;animation:.16s ease-out modal-in;overflow:hidden}.day-summary-header{justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.day-summary-date{color:var(--color-text);font-size:14px;font-weight:600}.day-summary-empty{color:var(--color-text-muted);padding:12px 16px 18px;font-size:13px}.day-summary-list{padding:2px 0 10px}.day-summary-item{text-align:left;align-items:center;gap:9px;width:100%;padding:7px 16px;transition:background .12s;display:flex}.day-summary-item:hover{background:var(--color-cell-hover)}.day-summary-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.day-summary-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.day-summary-time{color:var(--color-text-muted);flex-shrink:0;font-size:11.5px}.event-detail-body{flex-direction:column;gap:12px;padding:4px 20px 20px;display:flex}.event-detail-title{color:var(--color-text);letter-spacing:-.2px;font-size:18px;font-weight:600}.event-detail-meta{flex-direction:column;gap:7px;display:flex}.meta-row{color:var(--color-text-secondary);align-items:center;gap:10px;font-size:13.5px;display:flex}.meta-icon{text-align:center;opacity:.65;width:20px;font-size:15px}.event-detail-desc{background:var(--color-surface);border-radius:var(--radius-md);padding:10px 12px}.event-detail-desc p{color:var(--color-text-secondary);font-size:13.5px;line-height:1.6}.landing{background:var(--color-bg);min-height:100dvh;font-family:var(--font-family-global,"Noto Serif KR", serif);justify-content:center;align-items:center;display:flex;position:relative}.landing-theme-btn{border-radius:var(--radius-full);border:1px solid var(--color-border);width:34px;height:34px;color:var(--color-text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;top:16px;right:20px}.landing-theme-btn:hover{background:var(--color-surface);color:var(--color-text)}.landing-inner{flex-direction:column;align-items:center;gap:48px;width:min(560px,90vw);display:flex}.landing-logo{flex-direction:column;align-items:center;gap:14px;display:flex}.landing-logo-icon{font-size:56px;line-height:1}.landing-title{letter-spacing:-.5px;color:var(--color-text-primary);margin:0;font-size:26px;font-weight:700}.landing-prompt-section{flex-direction:column;align-items:center;gap:14px;width:100%;display:flex}.landing-question{color:var(--color-text);letter-spacing:-.3px;margin:0;font-size:30px;font-weight:600}.landing-input-form{width:100%}.landing-input{border:.75px solid var(--color-border);border-radius:var(--radius-xl);width:100%;color:var(--color-text);background:var(--color-surface-raised);box-sizing:border-box;outline:none;padding:14px 20px;font-size:15px;transition:border-color .2s,box-shadow .2s;box-shadow:0 4px 20px -4px #0000001f,inset 0 1px 3px #ffffff0a}.landing-input:focus{border-color:#c8b9a0cc;box-shadow:0 6px 28px -4px #00000029,inset 0 1px 3px #ffffff0a}[data-theme=dark] .landing-input:focus{border-color:#5a96cc4d;box-shadow:0 6px 28px -4px #00143c8c,0 0 0 3px #5a96cc0f}.landing-input::placeholder{color:var(--color-text-muted)}.landing-hint{color:var(--color-text-muted);margin:0;font-size:12px}@keyframes landing-exit{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-24px)scale(.97)}}@keyframes app-enter{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}[data-transitioning=landing]::view-transition-old(root){animation:.35s cubic-bezier(.4,0,.2,1) forwards landing-exit}[data-transitioning=landing]::view-transition-new(root){animation:.4s cubic-bezier(.4,0,.2,1) forwards app-enter}.recurring-delete-body{flex-direction:column;gap:6px;padding:4px 20px 16px;display:flex}.recurring-delete-info{flex-direction:column;gap:3px;display:flex}.recurring-delete-event-name{color:var(--color-text);font-size:15px;font-weight:600}.recurring-delete-date{color:var(--color-text-secondary);font-size:13px}.recurring-delete-question{color:var(--color-text-muted);margin-top:4px;font-size:13px}.recurring-delete-actions{flex-wrap:wrap;gap:6px}.delete-confirm-panel{border-top:1px solid var(--color-border);margin-top:4px}.trash-list{flex:1;padding:4px 0;overflow-y:auto}.trash-item{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:10px;padding:10px 20px;transition:background .1s;display:flex}.trash-item:last-child{border-bottom:none}.trash-item:hover{background:var(--color-cell-hover)}.trash-item-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.trash-item-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:500;overflow:hidden}.trash-item-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.trash-item-type{color:var(--color-text-muted);background:var(--color-border);border-radius:var(--radius-full);padding:1px 6px;font-size:11px}.trash-item-occurrence{color:var(--color-text-secondary);font-size:11px}.trash-item-time{color:var(--color-text-muted);font-size:11px}.trash-item-actions{flex-shrink:0;gap:5px;display:flex}.trash-btn-restore{border-radius:var(--radius-md);background:var(--color-accent-subtle);color:var(--color-accent);padding:5px 10px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.trash-btn-restore:hover{background:var(--color-accent);color:#fff}.trash-btn-delete{border-radius:var(--radius-md);color:var(--color-text-muted);background:0 0;padding:5px 10px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.trash-btn-delete:hover{background:var(--color-danger-subtle);color:var(--color-danger)}.trash-footer{background:var(--color-surface);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 20px 14px;display:flex}.trash-footer-note{color:var(--color-text-muted);text-align:center;font-size:11.5px}.trash-btn-clear-all{border:1px solid var(--color-danger-subtle);color:var(--color-danger);cursor:pointer;opacity:.7;background:0 0;border-radius:4px;flex-shrink:0;padding:3px 8px;font-size:11px;transition:opacity .15s}.trash-btn-clear-all:hover{opacity:1;background:var(--color-danger-subtle)}.settings-body{flex-direction:column;gap:12px;padding:16px 20px 20px;display:flex}.settings-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-label{color:var(--color-text-secondary);font-size:14px}.settings-select{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:5px 8px;font-size:13px}.settings-toggle{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;padding:5px 14px;font-size:13px;transition:background .15s,color .15s}.settings-toggle.active{font-weight:600}.settings-toggle--bold-bold{color:#5e7057;background:#e8ede4;border-color:#8a9e82}.settings-toggle--bold-title{color:#7a7040;background:#f5f0e0;border-color:#b8aa70}[data-theme=dark] .settings-toggle--bold-bold{color:#8aab80;background:#2a3327;border-color:#5a7052}[data-theme=dark] .settings-toggle--bold-title{color:#b0a860;background:#2e2c1e;border-color:#7a7040}.settings-row--col{flex-direction:column;align-items:flex-start;gap:8px}.settings-api-key-row{align-items:center;gap:6px;width:100%;display:flex}.settings-input-wrap{flex:1;align-items:center;display:flex;position:relative}.settings-input{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);outline:none;padding:5px 30px 5px 8px;font-size:13px}.settings-input:focus{border-color:var(--color-primary)}.settings-api-key-actions{gap:4px;display:flex}.settings-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;white-space:nowrap;padding:5px 10px;font-size:12px}.settings-btn:disabled{opacity:.4;cursor:default}.settings-btn--icon{color:var(--color-text-secondary);background:0 0;border:none;align-items:center;padding:4px 5px;display:flex;position:absolute;right:4px}.settings-btn--save{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.settings-btn--delete{color:var(--color-danger,#e05252);border-color:var(--color-danger,#e05252)}.settings-divider{border:none;border-top:1px solid var(--color-border);margin:12px 0}.settings-logout-wrap{justify-content:center;display:flex}.checkbox-label--important{color:var(--color-important);font-weight:500}.settings-footer-links{justify-content:center;gap:16px;padding:4px 0;display:flex}.settings-footer-link{color:var(--color-text-muted);font-size:12px;text-decoration:none}.settings-footer-link:hover{color:var(--color-text-secondary);text-decoration:underline}.settings-keywords-wrap{flex-direction:column;gap:8px;width:100%;display:flex}.settings-keywords-list{flex-wrap:wrap;gap:6px;display:flex}.settings-keyword-chip{background:color-mix(in srgb, var(--color-primary) 12%, transparent);border:1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);color:var(--color-text-primary);border-radius:12px;align-items:center;gap:4px;padding:3px 8px 3px 10px;font-size:12px;display:inline-flex}.settings-keyword-chip-delete{width:14px;height:14px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:inline-flex}.settings-keyword-chip-delete:hover:not(:disabled){color:var(--color-danger,#e05252)}.settings-keyword-chip-delete:disabled{opacity:.3;cursor:default}.settings-keyword-input-row{align-items:center;gap:6px;display:flex}.settings-input--keyword{flex:1}.settings-upcoming-wrap{align-items:center;gap:10px;display:flex}.settings-upcoming-slider{accent-color:var(--color-accent,#6c7aff);cursor:pointer;flex:1}.settings-upcoming-value{color:var(--text-secondary);text-align:right;min-width:24px;font-size:.82rem}.logout-confirm-overlay{border-radius:var(--radius-lg);z-index:10;background:#00000059;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.logout-confirm-dialog{background:var(--color-surface);border-radius:var(--radius-md);flex-direction:column;gap:20px;min-width:220px;padding:24px 28px;display:flex;box-shadow:0 4px 20px #00000026}.logout-confirm-message{text-align:center;color:var(--color-text);margin:0;font-size:15px}.logout-confirm-actions{justify-content:center;gap:10px;display:flex}.settings-btn--logout{width:auto;color:var(--color-text-muted);border-color:var(--color-border);text-align:center}@media (width<=900px){.app-header{padding:12px 16px}.sidebar-label{display:none}.app-main{padding:12px 14px 28px 24px}.app-body{grid-template-columns:1fr}.side-panel{position:static}.calendar-cell{min-height:75px;padding:4px 3px}.event-chip{padding:1px 4px;font-size:10px}.event-time{display:none}}.event-chip-delete{cursor:pointer;z-index:10;width:13px;height:13px;color:var(--color-text-secondary);background:0 0;border:none;border-radius:0;flex-shrink:0;justify-content:center;align-items:center;font-size:9px;line-height:1;transition:color .1s;display:none;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.event-chip:hover .event-chip-delete{display:flex}.event-chip-delete:hover{color:var(--color-danger)}.drag-ghost-chip{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;will-change:transform, left, top;border-radius:0 2px 2px 0;align-items:center;gap:3px;max-width:160px;padding:2px 8px;font-family:inherit;font-size:10.5px;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden;transform:scale(1.08);box-shadow:0 4px 16px #00000040}.drag-ghost-chip--landing{box-shadow:none;transform:scale(1)}.event-chip--dragging{opacity:0!important;pointer-events:none!important}.calendar-cell--drag-over{outline:1.5px solid var(--color-accent);outline-offset:-1.5px;background:var(--color-accent-subtle)!important}.event-bar-delete{background:var(--color-surface-raised);border:.75px solid var(--color-border);cursor:pointer;z-index:10;width:13px;height:13px;color:var(--color-text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:8px;line-height:1;transition:background .1s,color .1s;display:none;position:absolute;top:50%;right:2px;transform:translateY(-50%)}.event-bar:hover .event-bar-delete{display:flex}.event-bar-delete:hover{background:var(--color-danger-subtle);color:var(--color-danger)}.trash-modal-card{flex-direction:column;width:min(480px,92vw);max-height:70vh;display:flex}.trash-empty{text-align:center;color:var(--color-text-secondary);flex-direction:column;gap:4px;padding:32px 0;font-size:14px;display:flex}.trash-empty-sub{color:var(--color-text-muted);font-size:12px}.date-panel-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:900;opacity:0;pointer-events:none;background:#00000059;transition:opacity .25s;position:fixed;inset:0}.date-panel-overlay--visible{opacity:1;pointer-events:auto}.date-click-panel{background:var(--color-surface-raised);border-left:1px solid var(--color-border);z-index:910;flex-direction:column;width:320px;height:100vh;transition:transform .28s cubic-bezier(.22,1,.36,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-6px 0 32px #0000001f}.date-click-panel--open{transform:translate(0)}.date-click-panel__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 20px 14px;display:flex}.date-click-panel__header-text{flex-direction:column;gap:3px;display:flex}.date-click-panel__label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.date-click-panel__date{color:var(--color-text);font-size:15px;font-weight:600}.date-click-panel__body{flex-direction:column;flex:1;display:flex;overflow-y:auto}.date-click-panel__form{flex-direction:column;gap:14px;padding:18px 20px;display:flex}.date-click-panel__existing{border-top:1px solid var(--color-border);padding:16px 20px 20px}.date-click-panel__existing-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:10px;font-weight:600}.date-click-panel__existing-item{background:var(--color-surface-hover,#00000008);border-radius:var(--radius-sm,4px);align-items:flex-start;margin-bottom:4px;padding:8px 8px 8px 20px;display:flex;position:relative}[data-theme=dark] .date-click-panel__existing-item{background:#ffffff0d}.date-click-panel__existing-item:before{content:"";background:var(--todo-color);border-radius:999px;width:3px;position:absolute;top:6px;bottom:6px;left:8px}.date-click-panel__existing-content{flex-direction:column;gap:2px;min-width:0;display:flex}.date-click-panel__existing-title-row{align-items:baseline;gap:6px;min-width:0;display:flex}.date-click-panel__existing-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.date-click-panel__existing-desc{color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.date-click-panel__existing-time{color:var(--color-text-muted);font-size:11px}.date-click-panel__footer{border-top:1px solid var(--color-border);background:var(--color-surface-raised);flex-shrink:0;padding:12px 20px 16px}.diary-toolbar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px;padding:6px 10px;display:flex}.diary-toolbar-section{align-items:center;gap:4px;display:flex}.diary-tool-btn{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;transition:background .15s;display:flex}.diary-tool-btn:hover{background:var(--color-cell-hover)}.diary-tool-btn.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.diary-tool-btn--danger{color:var(--color-danger);border-color:var(--color-danger);font-size:14px}.diary-tool-btn--danger:hover{background:var(--color-danger);color:#fff}.diary-tool-label{font-size:11px}.diary-toolbar-zoom{gap:2px;margin-left:auto}.diary-zoom-label{color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);text-align:center;background:0 0;border:none;min-width:36px;padding:2px 4px;font-size:11px;font-weight:600;transition:color .15s,background .15s}.diary-zoom-label:hover{color:var(--color-text);background:var(--color-hover)}.diary-color-swatch{background:var(--swatch-color);cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:transform .1s}.diary-color-swatch:hover{transform:scale(1.15)}.diary-color-swatch.active{border-color:var(--color-text);transform:scale(1.1)}.diary-width-btn{border:1px solid var(--color-border);cursor:pointer;width:32px;height:24px;color:var(--color-text);background:0 0;border-radius:4px;justify-content:center;align-items:center;transition:background .15s;display:flex}.diary-width-btn:hover{background:var(--color-cell-hover)}.diary-width-btn.active{border-color:var(--color-accent);background:var(--color-accent-subtle)}.calendar-cell{position:relative}.diary-canvas-layer{pointer-events:none;z-index:2;position:absolute;inset:0}.diary-canvas-layer--active{pointer-events:all;cursor:crosshair}.diary-canvas-layer--eraser{cursor:cell}.login-modal-card{max-width:380px}.login-tabs{border-bottom:1px solid var(--color-border);gap:4px;padding:0 20px;display:flex}.login-tab{color:var(--color-text-muted);border-bottom:2px solid #0000;border-radius:0;margin-bottom:-1px;padding:8px 14px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.login-tab:hover{color:var(--color-text-secondary)}.login-tab.active{color:var(--color-text);border-bottom-color:var(--color-accent)}.login-form{flex-direction:column;gap:10px;padding:20px 20px 12px;display:flex}.login-input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);outline:none;padding:9px 12px;font-size:13px;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #7a8c6e1f}[data-theme=dark] .login-input:focus{box-shadow:0 0 0 2px #547b9e2e}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--color-danger);padding:2px;font-size:12px;line-height:1.4}.login-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;text-align:center;border:none;width:100%;margin-top:2px;padding:9px 0;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.login-btn:hover:not(:disabled){background:var(--color-accent-hover)}.login-btn:disabled{opacity:.55;cursor:not-allowed}.login-footer{justify-content:center;padding:4px 20px 18px;display:flex}.login-offline-btn{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:12px;transition:color .15s,background .15s}.login-offline-btn:hover:not(:disabled){color:var(--color-text-secondary);background:var(--color-border)}.login-offline-btn:disabled{opacity:.4;cursor:not-allowed}.login-divider{align-items:center;gap:8px;margin:4px 20px 8px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.login-divider__label{color:var(--color-text-muted);white-space:nowrap;font-size:11px}.login-social-buttons{flex-direction:row;justify-content:center;gap:12px;padding:0 20px;display:flex}.login-social-btn--google{justify-content:center;align-items:center;width:44px;height:44px;min-height:44px;display:flex}.login-social-btn--google iframe{border-radius:50%}.login-social-btn--apple,.login-social-btn--kakao{cursor:not-allowed;border:1px solid var(--color-border);opacity:.45;background:var(--color-surface);width:44px;height:44px;color:var(--color-text);border-radius:50%;justify-content:center;align-items:center;padding:0;transition:none;display:flex}.login-social-notice{color:var(--color-text-muted);text-align:center;margin:0;padding:8px 20px 0;font-size:11px;line-height:1.5}.auth-callback-page{justify-content:center;align-items:center;height:100dvh;display:flex}.auth-callback-page__message{color:var(--color-text-muted);font-size:15px}.login-social-btn--apple.login-social-btn--active{color:#fff;cursor:pointer;opacity:1;background:#000;border-color:#000}.login-social-btn--apple.login-social-btn--active:hover{background:#1a1a1a}[data-theme=dark] .login-social-btn--apple.login-social-btn--active{color:#000;background:#fff;border-color:#fff}[data-theme=dark] .login-social-btn--apple.login-social-btn--active:hover{background:#e6e6e6}.mobile-warning-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.mobile-warning-card{background:var(--color-surface,#fff);border-radius:var(--radius-xl);text-align:center;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:320px;padding:36px 28px;display:flex;box-shadow:0 12px 48px #00000047}.mobile-warning-icon{font-size:52px}.mobile-warning-title{margin:0;font-size:20px;font-weight:700}.mobile-warning-desc{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.7}.mobile-warning-store-btn{background:var(--color-accent,#6c7aff);color:#fff;border-radius:var(--radius-full);box-sizing:border-box;width:100%;margin-top:4px;padding:12px 28px;font-size:14px;font-weight:600;text-decoration:none;display:block}.mobile-warning-continue-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;text-decoration:underline}
