@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css";:root,[data-theme=light]{--bg: #fafafa;--bg-secondary: #ffffff;--bg-hover: #f0f0f0;--text: #1a1a2e;--text-secondary: #555;--border: #e0e0e0;--accent: #6c5ce7;--accent-hover: #5a4bd1;--accent-light: #e8e5ff;--danger: #e74c3c;--badge-bg: #d4edda;--badge-text: #155724;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--caret-color: #6c5ce7}[data-theme=dark]{--bg: #1a1a2e;--bg-secondary: #16213e;--bg-hover: #1f2b47;--text: #e0e0e0;--text-secondary: #a0a0a0;--border: #2d3548;--accent: #a29bfe;--accent-hover: #8b82f0;--accent-light: #2d2b55;--danger: #ff6b6b;--badge-bg: #1e3a2f;--badge-text: #7dcea0;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .4);--caret-color: #a29bfe}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Pretendard,Noto Sans KR,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}#root{max-width:none;margin:0;padding:0;text-align:left}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.header__left{display:flex;align-items:center;gap:12px}.header__title{font-size:1.25rem;font-weight:700;color:var(--accent)}.header__date{font-size:.9rem;color:var(--text-secondary)}.header__center{display:flex;align-items:center}.header__right{display:flex;align-items:center;gap:8px}.view-switcher{display:flex;gap:2px;background:var(--bg);border-radius:8px;padding:2px}.view-switcher__tab{display:flex;align-items:center;gap:4px;padding:5px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-family:inherit;font-weight:500;cursor:pointer;transition:all .15s}.view-switcher__tab:hover{color:var(--text);background:var(--bg-hover)}.view-switcher__tab--active{background:var(--bg-secondary);color:var(--accent);box-shadow:var(--shadow)}.view-switcher__icon{font-size:.85rem}.view-switcher__label{font-size:.78rem}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:240px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar__header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px 4px}.sidebar__title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.sidebar__search{padding:6px 14px 10px}.sidebar__search-input{width:100%;padding:6px 10px;font-size:.8rem;font-family:inherit;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);outline:none;transition:border-color .15s}.sidebar__search-input:focus{border-color:var(--accent)}.sidebar__search-input::placeholder{color:var(--text-secondary)}.sidebar__list{list-style:none;overflow-y:auto;flex:1}.sidebar__item{padding:10px 14px;cursor:pointer;border-left:3px solid transparent;transition:background .15s;position:relative}.sidebar__item:hover{background:var(--bg-hover)}.sidebar__item--active{background:var(--accent-light);border-left-color:var(--accent)}.sidebar__item-top{display:flex;justify-content:space-between;align-items:center}.sidebar__item-date{font-size:.8rem;font-weight:600;color:var(--text)}.sidebar__item-emotion{font-size:.65rem;color:var(--accent);background:var(--accent-light);padding:1px 6px;border-radius:999px}.sidebar__item-preview{display:block;font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}.sidebar__item-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.sidebar__item-delete{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;opacity:0;transition:opacity .15s;padding:0 4px;border-radius:4px}.sidebar__item:hover .sidebar__item-delete{opacity:1}.sidebar__item-delete:hover{color:var(--danger);background:var(--bg-hover)}.sidebar__empty{padding:20px 14px;text-align:center;color:var(--text-secondary);font-size:.8rem}.panels{flex:1;display:flex;overflow:hidden}.panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.panel__header{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.panel__header h2{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.panel__body{flex:1;overflow-y:auto}.panel--editor .panel__body{overflow:hidden}.panel--editor .cm-editor{height:100%}.divider{width:1px;background:var(--border);flex-shrink:0}.badge{font-size:.7rem;padding:2px 8px;border-radius:999px;background:var(--badge-bg);color:var(--badge-text);font-weight:500}.btn{border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:.85rem;font-family:inherit;cursor:pointer;background:var(--bg-secondary);color:var(--text);transition:all .15s}.btn:hover{background:var(--bg-hover);border-color:var(--accent)}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover{background:var(--accent-hover)}.btn--primary:disabled{opacity:.5;cursor:not-allowed}.btn--secondary{background:transparent}.btn--icon{border:none;background:none;font-size:1.2rem;padding:4px 8px;cursor:pointer;color:var(--text-secondary);border-radius:6px}.btn--icon:hover{background:var(--bg-hover);color:var(--text)}.organize-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;font-size:.9rem;font-weight:600;font-family:inherit;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;transition:all .2s}.organize-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.organize-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.organize-btn__icon{font-size:1rem}.organize-btn__spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.auto-format-bar{display:flex;padding:8px 16px;border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.auto-format-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;font-size:.82rem;font-weight:600;font-family:inherit;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);cursor:pointer;transition:all .2s}.auto-format-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.auto-format-btn:disabled{opacity:.4;cursor:not-allowed}.auto-format-btn__icon{font-size:1rem}.ai-preview{padding:20px;height:100%}.ai-preview--empty{display:flex;align-items:center;justify-content:center}.ai-preview__placeholder{text-align:center;color:var(--text-secondary);line-height:1.8;font-size:.95rem}.ai-preview--loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary)}.ai-preview__spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.ai-preview--error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--danger)}.ai-preview__icon{width:36px;height:36px;line-height:36px;text-align:center;border-radius:50%;background:var(--danger);color:#fff;font-weight:700;font-size:1.1rem}.ai-preview--content{line-height:1.8;font-size:.95rem}.ai-preview--content h1{font-size:1.4rem;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.ai-preview--content h2{font-size:1.15rem;margin:20px 0 8px;color:var(--accent)}.ai-preview--content h3{font-size:1rem;margin:14px 0 6px}.ai-preview--content p{margin:8px 0}.ai-preview--content ul,.ai-preview--content ol{margin:8px 0;padding-left:24px}.ai-preview--content li{margin:4px 0}.ai-preview--content code{background:var(--bg-hover);padding:2px 6px;border-radius:4px;font-size:.85em}.ai-preview--content pre{background:var(--bg-hover);padding:12px;border-radius:8px;overflow-x:auto;margin:12px 0}.ai-preview--content blockquote{border-left:3px solid var(--accent);padding-left:14px;color:var(--text-secondary);margin:12px 0}.ai-preview--content hr{border:none;border-top:1px solid var(--border);margin:16px 0}.ai-preview--content strong{color:var(--text)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-secondary);border-radius:12px;padding:28px;width:420px;max-width:90vw;box-shadow:var(--shadow-lg)}.modal h2{font-size:1.15rem;margin-bottom:8px}.modal__desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:16px;line-height:1.6}.modal__desc a{color:var(--accent);text-decoration:underline}.modal__input{width:100%;padding:10px 14px;font-size:.9rem;font-family:Fira Code,monospace;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);outline:none;transition:border-color .15s}.modal__input:focus{border-color:var(--accent)}.modal__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.tag{font-size:.7rem;padding:1px 7px;border-radius:4px;background:var(--accent-light);color:var(--accent);font-weight:500}.tag--small{font-size:.6rem;padding:0 5px}.panel__tags{display:flex;gap:4px;flex-wrap:wrap}.badge--emotion{background:var(--accent-light);color:var(--accent)}.panel--full{flex:1}.save-indicator{font-size:.75rem;padding:2px 8px;border-radius:4px}.save-indicator--dirty{color:var(--text-secondary)}.save-indicator--saved{color:var(--badge-text)}.btn--small{padding:3px 10px;font-size:.75rem;border-radius:6px}.zen{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;flex-direction:column}.zen__header{display:flex;justify-content:space-between;align-items:center;padding:12px 32px;opacity:.4;transition:opacity .3s}.zen__header:hover{opacity:1}.zen__date{font-size:.9rem;color:var(--text-secondary)}.zen__right{display:flex;align-items:center;gap:12px}.zen__exit{font-size:1.5rem}.zen__editor{flex:1;max-width:720px;width:100%;margin:0 auto;overflow:hidden}.zen__editor .cm-editor{height:100%}.zen__editor .cm-scroller{padding:0 24px}.voice-input{display:flex;align-items:center}.voice-input__btn{font-size:1.1rem}.voice-input__active{display:flex;align-items:center;gap:8px;padding:4px 12px;background:var(--accent-light);border-radius:8px;animation:voice-glow 1.5s ease-in-out infinite}.voice-input__pulse{width:10px;height:10px;border-radius:50%;background:#e74c3c;animation:pulse 1s ease-in-out infinite}.voice-input__time{font-size:.8rem;font-variant-numeric:tabular-nums;color:var(--text-secondary);min-width:32px}.voice-input__interim{font-size:.8rem;color:var(--accent);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic}.voice-input__stop{font-size:.75rem;padding:3px 10px}.btn--danger{background:#e74c3c;color:#fff;border:none;border-radius:6px;cursor:pointer;font-family:inherit}.btn--danger:hover{background:#c0392b}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes voice-glow{0%,to{box-shadow:0 0 #6c5ce700}50%{box-shadow:0 0 8px 2px #6c5ce733}}.cm-heading{font-weight:700}.cm-heading-1 .cm-line{font-size:1.6em;line-height:1.4}.cm-heading-2 .cm-line{font-size:1.35em;line-height:1.4}.cm-heading-3 .cm-line{font-size:1.15em;line-height:1.5}.cm-heading-1,.cm-heading-2,.cm-heading-3{font-weight:700}.cm-em{font-style:italic}.cm-strong{font-weight:700}.cm-strikethrough{text-decoration:line-through;opacity:.6}.cm-inline-code{background:var(--bg-hover);padding:1px 5px;border-radius:3px;font-family:Fira Code,Cascadia Code,monospace;font-size:.9em}.cm-blockquote-line{border-left:3px solid var(--accent);padding-left:12px!important;color:var(--text-secondary)}.cm-hr-widget{border:none;border-top:2px solid var(--border);margin:8px 0}.cm-checkbox-widget{font-size:1.1em;margin-right:4px;cursor:default}.cm-wikilink-widget{color:var(--accent);cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px;border-radius:2px;transition:background .15s}.cm-wikilink-widget:hover{background:var(--accent-light);text-decoration-style:solid}.backlinks-panel{border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.backlinks-panel__toggle{display:flex;align-items:center;gap:6px;width:100%;padding:8px 16px;border:none;background:none;color:var(--text-secondary);font-size:.8rem;font-family:inherit;font-weight:600;cursor:pointer;text-align:left}.backlinks-panel__toggle:hover{color:var(--text);background:var(--bg-hover)}.backlinks-panel__arrow{font-size:.6rem}.backlinks-panel__list{list-style:none;padding:0 16px 10px}.backlinks-panel__item{padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .15s;display:flex;flex-direction:column;gap:2px}.backlinks-panel__item:hover{background:var(--bg-hover)}.backlinks-panel__item-title{font-size:.8rem;font-weight:600;color:var(--accent)}.backlinks-panel__item-context{font-size:.7rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__tags{display:flex;flex-wrap:wrap;gap:4px;padding:0 14px 10px}.tag--cloud{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--text-secondary);font-size:.65rem;font-family:inherit;cursor:pointer;transition:all .15s}.tag--cloud:hover{border-color:var(--accent);color:var(--accent)}.tag--active{background:var(--accent);color:#fff;border-color:var(--accent)}.tag--active:hover{background:var(--accent-hover);color:#fff}.tag__count{font-size:.55rem;opacity:.7}.tag--clear{padding:2px 8px;border:1px dashed var(--border);border-radius:999px;background:none;color:var(--text-secondary);font-size:.65rem;font-family:inherit;cursor:pointer}.tag--clear:hover{color:var(--danger);border-color:var(--danger)}.search-highlight{background:#6c5ce740;color:var(--text);border-radius:2px;padding:0 1px}[data-theme=dark] .search-highlight{background:#a29bfe4d}.cm-tooltip-autocomplete{border:1px solid var(--border)!important;border-radius:8px!important;background:var(--bg-secondary)!important;box-shadow:var(--shadow-lg)!important;overflow:hidden}.cm-tooltip-autocomplete ul{font-family:Pretendard Variable,Pretendard,system-ui,sans-serif!important;font-size:.85rem!important}.cm-tooltip-autocomplete ul li{padding:4px 10px!important;color:var(--text)!important}.cm-tooltip-autocomplete ul li[aria-selected]{background:var(--accent-light)!important;color:var(--text)!important}.cm-completionDetail{color:var(--text-secondary)!important;font-size:.75rem!important;margin-left:8px!important}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.organize-btn--todo{background:#00b894;border-color:#00b894}.organize-btn--todo:hover:not(:disabled){background:#00a381;border-color:#00a381}.todo-panel{border-top:1px solid var(--border);padding:8px 12px}.todo-panel__toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-primary);font-size:.85rem;font-weight:600;cursor:pointer;padding:4px 0;width:100%;text-align:left}.todo-panel__toggle:hover{color:var(--accent)}.todo-panel__arrow{font-size:.7rem}.todo-panel__filters{display:flex;gap:4px;padding:6px 0}.todo-panel__filter{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:2px 8px;font-size:.72rem;color:var(--text-secondary);cursor:pointer;transition:all .15s}.todo-panel__filter:hover{border-color:var(--accent);color:var(--accent)}.todo-panel__filter--active{background:var(--accent);border-color:var(--accent);color:#fff}.todo-panel__list{list-style:none;margin:0;padding:0;max-height:240px;overflow-y:auto}.todo-panel__item{display:flex;align-items:flex-start;gap:6px;padding:6px 4px;border-bottom:1px solid var(--border);position:relative}.todo-panel__item:last-child{border-bottom:none}.todo-panel__item--done{opacity:.5}.todo-panel__item--done .todo-panel__text{text-decoration:line-through}.todo-panel__item--overdue .todo-panel__text{color:#e74c3c}.todo-panel__check{flex-shrink:0;margin-top:2px;cursor:pointer}.todo-panel__check input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--accent)}.todo-panel__content{flex:1;min-width:0}.todo-panel__text{font-size:.8rem;color:var(--text-primary);line-height:1.3;word-break:break-word}.todo-panel__meta{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px;align-items:center}.todo-panel__badge{font-size:.65rem;padding:1px 5px;border-radius:8px;font-weight:500}.todo-panel__badge--task{background:#a29bfe22;color:#6c5ce7}.todo-panel__badge--appointment{background:#74b9ff22;color:#0984e3}.todo-panel__badge--goal{background:#00b89422;color:#00b894}.todo-panel__badge--high{background:#e74c3c22;color:#e74c3c;font-weight:600}.todo-panel__deadline{font-size:.65rem;color:var(--text-secondary)}.todo-panel__deadline--overdue{color:#e74c3c;font-weight:600}.todo-panel__note-link{background:none;border:none;font-size:.65rem;color:var(--accent);cursor:pointer;padding:0;text-decoration:underline}.todo-panel__note-link:hover{opacity:.8}.todo-panel__delete{position:absolute;right:2px;top:6px;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.9rem;line-height:1;opacity:0;transition:opacity .15s;padding:0 4px}.todo-panel__item:hover .todo-panel__delete{opacity:1}.todo-panel__delete:hover{color:#e74c3c}.todo-panel__empty{font-size:.75rem;color:var(--text-secondary);padding:12px 0;text-align:center}.credit-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--accent);font-size:.75rem;font-family:inherit;font-weight:600;cursor:pointer;transition:all .15s}.credit-badge:hover{border-color:var(--accent);background:var(--accent-light)}.credit-badge__plan{font-weight:600}.credit-badge__count{font-variant-numeric:tabular-nums}.credit-badge--low{color:#e67e22;border-color:#e67e22}.credit-badge--low:hover{background:#e67e221a}.credit-badge--empty{color:var(--danger);border-color:var(--danger);animation:credit-pulse 1.5s ease-in-out infinite}.credit-badge--empty:hover{background:#e74c3c1a}@keyframes credit-pulse{0%,to{opacity:1}50%{opacity:.6}}.modal--subscription{width:560px;max-width:95vw}.plan-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.plan-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 10px;border:2px solid var(--border);border-radius:10px;background:var(--bg);cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text)}.plan-card:hover{border-color:var(--accent)}.plan-card--active{border-color:var(--accent);background:var(--accent-light)}.plan-card__badge{position:absolute;top:-8px;right:-6px;background:#00b894;color:#fff;font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:999px}.plan-card__name{font-size:.95rem;font-weight:700}.plan-card__price{font-size:1.1rem;font-weight:700;color:var(--accent)}.plan-card__desc{font-size:.7rem;color:var(--text-secondary);text-align:center}.plan-card__current{font-size:.65rem;color:var(--accent);font-weight:600}.subscription-info{background:var(--bg);border-radius:8px;padding:14px;margin-bottom:14px}.subscription-info h3{font-size:.85rem;margin-bottom:10px;color:var(--text)}.subscription-info__grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:.8rem}.subscription-info__grid span{color:var(--text-secondary)}.subscription-info__grid strong{color:var(--text)}.subscription-addon{background:var(--bg);border-radius:8px;padding:14px;margin-bottom:14px}.subscription-addon h3{font-size:.85rem;margin-bottom:4px;color:var(--text)}.subscription-addon__desc{font-size:.75rem;color:var(--text-secondary);margin-bottom:10px}.subscription-addon__row{display:flex;align-items:center;gap:8px}.subscription-addon__input{width:60px;padding:5px 8px;font-size:.85rem;font-family:inherit;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text);outline:none;text-align:center}.subscription-addon__input:focus{border-color:var(--accent)}.subscription-addon__price{font-size:.8rem;color:var(--text-secondary);min-width:80px}.credit-warning-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--danger);color:#fff;padding:10px 24px;border-radius:8px;font-size:.85rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:300;animation:toast-in .25s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.modal--auth{width:380px;max-width:90vw}.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px}.auth-tab{flex:1;padding:10px 0;border:none;background:none;color:var(--text-secondary);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;border-bottom:2px solid transparent}.auth-tab:hover{color:var(--text)}.auth-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-error{font-size:.8rem;color:var(--danger);background:#e74c3c14;padding:8px 12px;border-radius:6px;margin:0}.btn--auth{padding:5px 14px;font-size:.8rem;font-weight:600;font-family:inherit;border:1px solid var(--accent);border-radius:6px;background:var(--accent);color:#fff;cursor:pointer;transition:all .15s}.btn--auth:hover{background:var(--accent-hover)}.btn--auth-logout{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn--auth-logout:hover{color:var(--danger);border-color:var(--danger);background:#e74c3c0d}.oauth-buttons{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.oauth-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.oauth-btn svg{flex-shrink:0}.oauth-btn--google{background:#fff;color:#3c4043;border-color:#dadce0}.oauth-btn--google:hover{background:#f8f9fa;border-color:#c6c6c6}[data-theme=dark] .oauth-btn--google{background:#2d2d2d;color:#e0e0e0;border-color:#555}[data-theme=dark] .oauth-btn--google:hover{background:#3a3a3a}.oauth-btn--kakao{background:#fee500;color:#3c1e1e;border-color:#fee500}.oauth-btn--kakao:hover{background:#fada0a;border-color:#fada0a}.oauth-btn--naver{background:#03c75a;color:#fff;border-color:#03c75a}.oauth-btn--naver:hover{background:#02b350;border-color:#02b350}.oauth-divider{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:var(--text-secondary);font-size:.8rem}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.graph-view{position:relative;flex:1;overflow:hidden;background:var(--bg)}.graph-view__canvas{display:block;width:100%;height:100%}.graph-view__empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:.95rem;line-height:1.8;text-align:center;padding:24px}.graph-view__tooltip{position:fixed;z-index:50;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:8px 12px;box-shadow:var(--shadow-lg);pointer-events:none;max-width:200px}.graph-view__tooltip-title{font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:2px}.graph-view__tooltip-emotion{font-size:.65rem;color:var(--accent);background:var(--accent-light);padding:1px 6px;border-radius:999px}.graph-view__tooltip-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.graph-view__info{position:absolute;bottom:8px;right:12px;font-size:.7rem;color:var(--text-secondary);background:var(--bg-secondary);padding:3px 10px;border-radius:6px;border:1px solid var(--border);opacity:.8}.calendar-view{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);padding:16px 24px}.calendar-view__nav{display:flex;align-items:center;gap:12px;padding-bottom:16px;flex-shrink:0}.calendar-view__month-label{font-size:1.1rem;font-weight:700;color:var(--text);min-width:120px;text-align:center}.calendar-view__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden;flex:1}.calendar-view__weekday{padding:8px 0;text-align:center;font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary)}.calendar-view__weekday:first-child{color:var(--danger)}.calendar-view__weekday:last-child{color:#3498db}.calendar-view__cell{position:relative;background:var(--bg-secondary);padding:6px 8px;min-height:70px;cursor:pointer;transition:background .15s;overflow:hidden}.calendar-view__cell:hover{background:var(--bg-hover)}.calendar-view__cell--outside{background:var(--bg);opacity:.4;cursor:default;pointer-events:none}.calendar-view__cell--today{outline:2px solid var(--accent);outline-offset:-2px;z-index:1}.calendar-view__cell--selected{background:var(--accent-light)}.calendar-view__cell--has-note{font-weight:500}.calendar-view__cell-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.calendar-view__cell-date{font-size:.8rem;font-weight:600;color:var(--text)}.calendar-view__cell--today .calendar-view__cell-date{color:var(--accent)}.calendar-view__grid>.calendar-view__cell:nth-child(7n+8) .calendar-view__cell-date{color:var(--danger)}.calendar-view__grid>.calendar-view__cell:nth-child(7n+14) .calendar-view__cell-date{color:#3498db}.calendar-view__cell-emotion{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.calendar-view__cell-heat{position:absolute;inset:0;background:var(--accent);pointer-events:none;z-index:0}.calendar-view__cell-preview{position:relative;z-index:1;font-size:.6rem;color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-all}
