:root{--primary: #475569;--primary-light: #94A3B8;--primary-bg: #F1F5F9;--accent: #2563EB;--accent-bg: #EFF6FF;--success: #16A34A;--danger: #DC2626;--warning: #CA8A04;--surface: #FFFFFF;--sidebar: #F8FAFC;--text: #0F172A;--text-secondary: #64748B;--border: #CBD5E1;--hover: #F1F5F9;--gray-50: #F8FAFC;--gray-100: #F1F5F9;--gray-200: #E2E8F0;--gray-300: #CBD5E1;--gray-400: #94A3B8;--gray-500: #64748B;--gray-600: #475569;--gray-700: #334155;--btn-success-bg: #DCFCE7;--btn-success-color: #166534;--btn-success-border: transparent;--btn-warning-bg: #FEF9C3;--btn-warning-color: #854D0E;--btn-warning-border: transparent;--btn-danger-bg: #FEE2E2;--btn-danger-color: #991B1B;--btn-danger-border: transparent;--btn-info-bg: #F1F5F9;--btn-info-color: #475569;--btn-info-border: transparent;--btn-radius: 8px;--sidebar-width: 240px;--sidebar-collapsed: 52px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;font-size:14px;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;color:var(--text);background:var(--gray-50)}.btn{display:inline-flex;align-items:center;gap:6px;background-color:var(--primary);color:#fff;border:1px solid transparent;padding:6px 14px;border-radius:var(--btn-radius);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn:hover{filter:brightness(.95)}.btn:disabled{background-color:var(--gray-300);cursor:not-allowed;opacity:.7}.btn.success{background:var(--btn-success-bg);color:var(--btn-success-color);border-color:var(--btn-success-border)}.btn.warning{background:var(--btn-warning-bg);color:var(--btn-warning-color);border-color:var(--btn-warning-border)}.btn.danger{background:var(--btn-danger-bg);color:var(--btn-danger-color);border-color:var(--btn-danger-border)}.btn.info{background:var(--btn-info-bg);color:var(--btn-info-color);border-color:var(--btn-info-border)}.btn-sm{font-size:.88rem;padding:5px 14px;border-radius:var(--btn-radius);justify-content:center;background-color:var(--gray-100);color:var(--gray-600)}.btn-sm:hover{background-color:var(--gray-200)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover{background:var(--hover)}.btn-icon{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--btn-radius);border:none;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s}.btn-icon:hover{background:var(--hover);color:var(--primary)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.app-header-left{display:flex;align-items:center;gap:16px}.app-header-title{font-size:1.14rem;font-weight:700;color:var(--primary)}.app-nav{display:flex;gap:2px}.app-nav-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:.88rem;font-weight:500;border:none;border-radius:var(--btn-radius);cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s}.app-nav-btn:hover{background:var(--hover);color:var(--primary)}.app-nav-btn.active{background:var(--primary-bg);color:var(--primary);font-weight:600}.app-nav-btn i{font-size:.82rem}.app-header-right{display:flex;align-items:center;gap:12px}.user-info{font-size:1rem;color:var(--text-secondary)}.dashboard{display:flex;flex-direction:column;height:100vh}.dashboard-body{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--gray-200);display:flex;flex-direction:column;overflow:hidden;position:relative}.sidebar.collapsed{width:var(--sidebar-collapsed);transition:width .25s ease}.sidebar-header{display:flex;align-items:center;padding:10px 12px;border-bottom:1px solid var(--gray-200);gap:8px;height:45px;box-sizing:border-box}.sidebar-toggle{background:none;border:none;cursor:pointer;color:var(--gray-500);padding:4px;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.sidebar-toggle:hover{color:var(--primary)}.sidebar-title{font-size:.79rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.08em;flex:1;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-title{display:none}.projects-section{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0}.sidebar.collapsed .projects-section{padding:0}.sidebar.collapsed .projects-list{padding:8px 6px}.projects-header{display:flex;justify-content:space-between;align-items:center;padding:0 18px;height:45px;box-sizing:border-box;border-bottom:1px solid var(--gray-200);flex-shrink:0}.sidebar.collapsed .projects-header{justify-content:center}.projects-title{font-size:.79rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em}.sidebar.collapsed .projects-title{display:none}.projects-header button{background:none;border:none;color:var(--gray-500);cursor:pointer;padding:4px;font-size:1rem;transition:color .2s}.projects-header button:hover{color:var(--primary)}.projects-list{flex:1;overflow-y:auto;padding:8px 14px}.project-item{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:4px;border-radius:8px;color:var(--gray-600);font-size:1rem;cursor:pointer;transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-item:hover{background-color:var(--gray-100)}.project-item.active{background-color:var(--primary-bg);color:var(--primary);font-weight:600}.project-item .project-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.project-item .project-name i{width:18px;text-align:center;font-size:1rem;margin-right:8px}.project-item .count{font-size:.88rem;color:var(--gray-400);background:var(--gray-100);padding:2px 8px;border-radius:10px;flex-shrink:0}.project-item.active .count{background:var(--accent-bg);color:var(--accent)}.sidebar.collapsed .project-item{padding:8px;justify-content:center}.sidebar.collapsed .project-item .project-name{font-size:0}.sidebar.collapsed .project-item .project-name i{font-size:1rem;margin-right:0}.sidebar.collapsed .project-item .count{display:none}.sidebar-footer{margin-top:auto;padding:8px;border-top:1px solid var(--gray-200);display:flex;gap:4px;justify-content:center}.sidebar.collapsed .sidebar-footer .btn-sm span{display:none}.content{flex:1;display:flex;flex-direction:column;background-color:var(--gray-50);overflow:hidden}.content-toolbar{display:flex;align-items:center;gap:6px;padding:0 20px;border-bottom:1px solid var(--gray-200);background:var(--gray-50);flex-shrink:0;height:45px;box-sizing:border-box;overflow:visible;white-space:nowrap;position:relative;z-index:10}.toolbar-spacer{flex:1}.toolbar-divider{width:1px;height:20px;background:var(--gray-200);margin:0 6px;flex-shrink:0}.style-switcher{display:flex;gap:4px;flex-shrink:0}.style-btn{padding:4px 10px;font-size:.82rem;font-weight:600;border:none;border-radius:var(--btn-radius);cursor:pointer;background:var(--hover);color:var(--text-secondary);transition:all .2s;height:auto;white-space:nowrap;position:relative;display:inline-flex;align-items:center;gap:4px}.style-btn:hover{background:var(--gray-200)}.style-btn.active{background:var(--primary);color:#fff}.style-btn-remove{font-size:.75rem;line-height:1;opacity:.7;cursor:pointer;margin-left:2px;font-weight:400}.style-btn-remove:hover{opacity:1}.csl-search{position:relative;flex-shrink:0}.csl-search-input-wrap{display:flex;align-items:center;gap:5px;background:var(--hover);border-radius:var(--btn-radius);padding:0 8px;height:28px;border:1px solid transparent;transition:all .2s}.csl-search-input-wrap:focus-within{border-color:var(--primary);background:#fff;box-shadow:0 0 0 2px #4755691a}.csl-search-icon{font-size:11px;color:var(--text-secondary);flex-shrink:0}.csl-search-input{border:none;outline:none;background:transparent;font-size:.8rem;color:var(--text-primary);width:120px;font-family:inherit}.csl-search-input::placeholder{color:var(--gray-400);font-size:.78rem}.csl-search-input:disabled{cursor:not-allowed;opacity:.5}.csl-search-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--gray-200);border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:100;min-width:220px;max-width:280px;overflow:hidden}.csl-search-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;font-size:.83rem;color:var(--text-primary);text-align:left;transition:background .1s;font-family:inherit}.csl-search-item:hover{background:var(--gray-50)}.csl-search-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.csl-search-item-add{font-size:.75rem;color:var(--primary);font-weight:600;flex-shrink:0;margin-left:8px}.csl-search-empty{padding:12px;text-align:center;font-size:.8rem;color:var(--text-secondary)}.toolbar-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;font-size:.88rem;font-weight:500;border:none;border-radius:var(--btn-radius);cursor:pointer;background:var(--hover);color:var(--text-secondary);transition:all .2s}.toolbar-btn:hover{background:var(--gray-200)}.toolbar-btn i{font-size:14px}.toolbar-btn-icon{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--btn-radius);cursor:pointer;transition:all .2s}.toolbar-btn-icon.warning{background:var(--btn-warning-bg);color:var(--btn-warning-color)}.toolbar-btn-icon.danger{background:var(--btn-danger-bg);color:var(--btn-danger-color)}.toolbar-btn-icon:hover{filter:brightness(.92)}.toolbar-btn-icon i{font-size:14px}.font-size-control{display:flex;align-items:center;gap:2px;margin-right:4px}.font-size-control .toolbar-btn-icon{width:26px;height:26px;background:var(--hover);color:var(--text-secondary)}.font-size-control .toolbar-btn-icon i{font-size:11px}.font-size-display{font-size:.8rem;color:var(--text-secondary);min-width:22px;text-align:center;font-variant-numeric:tabular-nums}.content-header-row{display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--gray-200);background:var(--gray-50);flex-shrink:0;gap:16px;height:45px;box-sizing:border-box}.project-title{font-size:1.14rem;font-weight:600;color:var(--primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}.project-date{font-size:.75rem;font-weight:400;color:var(--gray-400);margin-left:6px}.header-actions{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.header-actions .btn{font-size:.82rem;padding:4px 10px;gap:4px}.search-container{flex:0 0 200px}.search-wrapper{position:relative;display:flex;align-items:center;width:100%}.search-wrapper .form-input{width:100%;padding-right:32px;height:32px;border-radius:6px;border:1px solid var(--gray-300);padding-left:12px;font-size:1rem;transition:all .2s ease}.search-wrapper .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-clear{position:absolute;right:8px;background:none;border:none;color:var(--gray-400);padding:2px;cursor:pointer;display:flex;align-items:center;justify-content:center}.search-clear:hover{color:var(--gray-600)}.citations-area{flex:1;overflow-y:auto;padding:12px 20px}.citation-item{display:flex;align-items:baseline;gap:10px;padding:8px 0;border-bottom:1px dashed var(--gray-200);font-size:1rem}.citation-item:last-child{border-bottom:none}.citation-item:hover{background:var(--hover)}.cite-num{font-size:.88rem;font-weight:700;color:var(--primary-light);width:24px;text-align:right;flex-shrink:0}.cite-type{font-size:.75rem;color:var(--accent);font-weight:600;border:1px solid var(--gray-200);border-radius:4px;padding:1px 6px;flex-shrink:0;line-height:1.6}.cite-t-paper{color:#2563eb;border-color:#93bbfd;background:#eff5ff}.cite-t-book{color:#16a34a;border-color:#86e0a5;background:#f0fdf4}.cite-t-chapter{color:#0d9488;border-color:#7dd3c8;background:#f0fdfa}.cite-t-website{color:#9333ea;border-color:#c4a5f0;background:#faf5ff}.cite-t-magazine{color:#ea580c;border-color:#fdba8c;background:#fff7ed}.cite-t-thesis{color:#db2777;border-color:#f0a0c8;background:#fdf2f8}.cite-t-etc{color:#6b7280;border-color:#d1d5db;background:#f9fafb}.cite-text{flex:1;line-height:1.5;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cite-text i,.cite-text em{font-style:italic}.mini-actions{display:flex;gap:4px;flex-shrink:0}.mini-actions button{border:none;background:none;cursor:pointer;font-size:.88rem;padding:3px 5px;border-radius:4px;color:var(--text-secondary)}.mini-actions button.edit-btn,.mini-actions button.copy-btn{color:var(--accent)}.mini-actions button.delete-btn{color:var(--danger)}.mini-actions button.pdf-btn{color:#d32f2f;font-size:.75rem;font-weight:600}.mini-actions button.pdf-btn:hover{background:#fce4ec}.mini-actions button:hover{background:var(--gray-100)}.empty-state{text-align:center;padding:2rem;color:var(--gray-500)}.empty-state .icon{font-size:3rem;margin-bottom:1rem;color:var(--gray-300)}.empty-state p{margin-bottom:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--surface);border-radius:12px;width:860px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0000002e}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;border-bottom:1px solid var(--gray-200)}.modal-title{font-size:1.14rem;font-weight:600;color:var(--gray-700)}.modal-close{background:none;border:none;font-size:1.43rem;color:var(--gray-500);cursor:pointer;padding:4px;transition:color .2s}.modal-close:hover{color:var(--gray-700)}.modal-body{flex:1;overflow-y:auto;padding:20px 28px}.modal-footer{flex-shrink:0;padding:16px 28px;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:10px;background:var(--surface)}.citation-tabs{position:sticky;top:0;background:var(--surface);z-index:10;padding-bottom:12px;display:flex;gap:5px}.tab-btn{padding:8px 18px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--btn-radius);transition:all .2s;font-size:1rem;font-weight:600;min-width:90px;text-align:center}.tab-btn:hover{background-color:var(--gray-100)}.tab-btn.active{background-color:var(--primary);color:#fff}.form-group{margin-bottom:10px;display:flex;align-items:center;gap:16px}.form-group label{width:140px;font-size:1rem;color:var(--gray-600);font-weight:500;text-align:right;flex-shrink:0}.form-input{flex:1;min-width:0;padding:8px 12px;border:1px solid var(--gray-200);border-radius:6px;font-size:1rem;transition:all .2s;background:var(--surface);height:36px}.form-input:focus{outline:none;border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px #2563eb1a}textarea.form-input{min-height:90px;resize:vertical;height:auto;line-height:1.4}.required-label:after{content:"*";color:var(--danger);margin-left:2px;font-size:1rem}.optional-label:after{content:"(선택)";color:var(--gray-400);font-size:1rem;margin-left:4px}.category-group{margin-bottom:16px;display:flex;align-items:center;gap:16px}.category-group>label{width:140px;font-size:1rem;color:var(--gray-600);font-weight:500;text-align:right;flex-shrink:0}.radio-group{display:flex;gap:16px;flex-wrap:wrap;flex:1;padding:4px 0}.radio-group label{font-size:1rem;color:var(--gray-600);display:flex;align-items:center;gap:6px;cursor:pointer;padding:4px 0;width:auto;text-align:left}.radio-group input[type=radio]{width:18px;height:18px;margin:0}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--success);color:#fff;padding:10px 20px;border-radius:8px;font-size:1rem;z-index:9999;box-shadow:0 4px 12px #00000026;animation:toast-in .25s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.spinner{display:inline-block;width:24px;height:24px;border:2px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text-secondary);font-size:1.07rem}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--gray-50)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.cite-text-wrap{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:4px}.cite-c-author{font-weight:700;color:var(--primary)}.cite-memo-btn{background:none;border:none;cursor:pointer;color:var(--warning);font-size:.88rem;padding:0 3px;vertical-align:middle;opacity:.7;transition:opacity .15s}.cite-memo-btn:hover{opacity:1}.cite-memo-layer{width:280px;max-height:240px;background:var(--surface);border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 8px 24px #00000026;display:flex;flex-direction:column;overflow:hidden;animation:memo-layer-in .12s ease-out}@keyframes memo-layer-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cite-memo-layer-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:.88rem;font-weight:700;color:var(--primary);border-bottom:1px solid var(--gray-100)}.cite-memo-layer-close{background:none;border:none;cursor:pointer;color:var(--gray-400);font-size:.88rem;padding:2px}.cite-memo-layer-close:hover{color:var(--text)}.cite-memo-layer-body{padding:10px 12px;font-size:.95rem;line-height:1.55;color:var(--text);white-space:pre-wrap;word-break:break-word;overflow-y:auto;flex:1}.cite-tag{padding:1px 6px;border-radius:6px;font-size:.72rem;background:var(--hover);color:var(--text-secondary);border:1px solid var(--border);white-space:nowrap}.mini-actions button.link-btn{color:var(--accent)}.tag-filter{display:flex;align-items:center;gap:8px;padding:6px 20px;border-bottom:1px solid var(--border);overflow-x:auto;white-space:nowrap;flex-shrink:0}.tag-filter-label{font-size:.88rem;color:var(--text-secondary);flex-shrink:0}.tag-filter-list{display:flex;gap:5px}.tag-chip{padding:3px 10px;border-radius:10px;font-size:.82rem;font-weight:600;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .2s}.tag-chip:hover{background:var(--hover)}.tag-chip.active{background:var(--accent);color:#fff;border-color:transparent}.export-dropdown{position:relative}.export-menu{display:none;position:absolute;top:100%;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000001f;z-index:100;min-width:120px;padding:4px;margin-top:4px}.export-menu.show{display:block}.export-menu button{display:block;width:100%;padding:8px 14px;font-size:.95rem;text-align:left;border:none;background:none;border-radius:4px;color:var(--text);cursor:pointer}.export-menu button:hover{background:var(--hover)}.toolbar-btn.active{background:var(--primary);color:#fff}.toolbar-btn.info{background:var(--btn-info-bg);color:var(--btn-info-color)}.stats-modal{width:560px}.stats-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:20px}.stat-card{background:var(--hover);border-radius:10px;padding:14px;text-align:center}.stat-num{font-size:1.43rem;font-weight:700;color:var(--text)}.stat-label{font-size:.88rem;color:var(--text-secondary);margin-top:4px}.stats-section{margin-bottom:20px}.stats-section h5{font-size:1rem;color:var(--text);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.stat-bar-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.95rem}.stat-bar-label{width:70px;color:var(--text-secondary);flex-shrink:0}.stat-bar-track{flex:1;height:10px;background:var(--hover);border-radius:5px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:5px;background:var(--accent)}.stat-bar-count{width:36px;text-align:right;color:var(--text-secondary);font-size:.88rem}.stat-missing-list{list-style:none;padding:0}.stat-missing-list li{display:flex;justify-content:space-between;padding:5px 0;font-size:.95rem;color:var(--text-secondary);border-bottom:1px solid var(--hover)}.stat-missing-list li span:last-child{font-weight:600;color:var(--danger)}.reference-list-header{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--gray-200);margin-bottom:12px;flex-wrap:wrap;gap:8px}.reference-list-header .citation-tabs.reference-tabs{display:flex;gap:4px;position:static;padding-bottom:0}.reference-list-header .citation-tabs.reference-tabs .tab-btn{min-width:auto;padding:5px 12px;font-size:.95rem}.reference-actions{display:flex;align-items:center;gap:8px}.reference-style-btns{display:flex;gap:3px}.ref-style-btn{padding:4px 10px;font-size:.82rem;font-weight:600;border:none;background:var(--hover);color:var(--text-secondary);border-radius:var(--btn-radius);cursor:pointer;transition:all .2s}.ref-style-btn:hover{background:var(--gray-200)}.ref-style-btn.active{background:var(--primary);color:#fff}.reference-list-container{flex:1;overflow-y:auto;background:var(--gray-50);border-radius:8px;padding:16px}.reference-list-item{display:flex;align-items:flex-start;margin-bottom:12px;line-height:1.5}.reference-number{flex-shrink:0;width:40px;font-weight:700;color:var(--primary);margin-right:12px;text-align:right}.reference-text{flex:1;word-break:break-word}.reference-text i,.reference-text em{font-style:italic}.ref-section-title{font-size:1rem;font-weight:700;color:var(--primary);margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid var(--gray-200)}.project-modal{width:620px}.project-timestamps{background:var(--gray-50);border-radius:8px;padding:16px;margin-bottom:20px}.timestamp-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--gray-600);font-size:1rem}.timestamp-item:last-child{margin-bottom:0}.timestamp-item i{color:var(--primary);width:18px;text-align:center}.timestamp-label{font-weight:500;width:90px}.timestamp-value{color:var(--gray-700)}.form-section-title{font-size:1.05rem;font-weight:600;color:var(--gray-700);margin:18px 0 12px;padding-left:140px}.input-with-unit{display:flex;align-items:center;gap:4px}.unit{color:var(--gray-600);font-size:1rem}input[type=number].form-input{width:90px;flex:none}select.form-input{cursor:pointer}.sidebar-resizer{position:absolute;right:-2px;top:0;bottom:0;width:5px;cursor:col-resize;z-index:10;background:transparent;transition:background .15s}.sidebar-resizer:hover,.sidebar-resizer.active{background:var(--primary-light)}.color-picker{display:flex;gap:8px;flex-wrap:wrap;padding:6px 0;margin-bottom:8px}.color-chip{width:28px;height:28px;border-radius:50%;border:2px solid var(--gray-200);cursor:pointer;padding:0;transition:all .15s}.color-chip:hover{transform:scale(1.15)}.color-chip.active{border-color:var(--text);box-shadow:0 0 0 2px var(--surface)}.dday-badge{font-size:.72rem;font-weight:700;color:#fff;background:var(--danger);padding:1px 6px;border-radius:4px;flex-shrink:0;line-height:1.4;white-space:nowrap}.sidebar.collapsed .dday-badge{display:none}.project-item[draggable]{cursor:grab}.project-item[draggable]:active{cursor:grabbing}.project-item.dragging{opacity:.3}.project-item.drag-over{background:var(--primary-bg);box-shadow:inset 0 -2px 0 0 var(--primary)}.home-page{flex:1;overflow-y:auto;padding:32px 40px;background:var(--gray-50)}.home-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:32px}.home-stat-card{background:var(--surface);border-radius:12px;padding:20px;text-align:center;border:1px solid var(--gray-200);cursor:pointer;transition:all .2s}.home-stat-card:hover{box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.home-stat-icon{font-size:1.21rem;color:var(--primary);margin-bottom:8px}.home-stat-num{font-size:1.57rem;font-weight:700;color:var(--text)}.home-stat-label{font-size:.85rem;color:var(--text-secondary);margin-top:4px}.home-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}.home-section{background:var(--surface);border-radius:12px;padding:20px 24px;border:1px solid var(--gray-200)}.home-section h3{font-size:1.05rem;color:var(--primary);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:8px}.home-section h3 i{font-size:.95rem}.home-empty{text-align:center;padding:24px 0;color:var(--gray-400);font-size:.9rem}.home-dday-list{display:flex;flex-direction:column;gap:8px}.home-dday-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;transition:background .15s}.home-dday-item:hover{background:var(--hover)}.home-dday-badge{font-size:.75rem;font-weight:700;color:#fff;background:var(--primary);padding:2px 8px;border-radius:4px;flex-shrink:0;min-width:52px;text-align:center}.home-dday-badge.urgent{background:var(--warning)}.home-dday-badge.overdue{background:var(--danger)}.home-dday-name{flex:1;font-size:.92rem;color:var(--text);display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-dday-name i{font-size:.88rem;flex-shrink:0}.home-dday-date{font-size:.8rem;color:var(--gray-400);flex-shrink:0}.home-recent-list{display:flex;flex-direction:column;gap:4px}.home-recent-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .15s}.home-recent-item:hover{background:var(--hover)}.home-recent-item>i{font-size:.95rem;color:var(--primary);flex-shrink:0}.home-recent-name{flex:1;font-size:.92rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-recent-count{font-size:.82rem;color:var(--accent);font-weight:600;flex-shrink:0}.home-recent-date{font-size:.8rem;color:var(--gray-400);flex-shrink:0}.home-archive-item{opacity:.7}.home-archive-item:hover{opacity:1}.home-unarchive-btn{font-size:.79rem;padding:2px 8px;border-radius:6px;background:var(--gray-100);color:var(--gray-600);border:none;cursor:pointer;flex-shrink:0;transition:all .15s}.home-unarchive-btn:hover{background:var(--accent-bg);color:var(--accent)}.home-backup-section h3 .backup-count{font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--gray-100);padding:2px 8px;border-radius:10px;margin-left:auto}.backup-actions-top{margin-bottom:12px}.backup-actions-top .btn-sm i{margin-right:4px}.backup-loading{display:flex;align-items:center;gap:8px;padding:16px 0;color:var(--text-secondary);font-size:.9rem}.backup-progress{display:flex;align-items:center;gap:12px;padding:24px 0;color:var(--primary);font-size:.95rem}.backup-list{display:flex;flex-direction:column;gap:4px}.backup-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:8px;transition:background .15s}.backup-item:hover{background:var(--hover)}.backup-info{display:flex;align-items:center;gap:12px}.backup-date{font-size:.92rem;color:var(--text)}.backup-size{font-size:.82rem;color:var(--gray-400)}.backup-item-actions{display:flex;align-items:center;gap:6px}.backup-restore-btn{font-size:.79rem;padding:3px 10px;border-radius:6px;background:var(--accent-bg);color:var(--accent);border:none;cursor:pointer;transition:all .15s}.backup-restore-btn:hover{filter:brightness(.92)}.backup-delete-btn{font-size:.79rem;padding:3px 8px;border-radius:6px;background:var(--btn-danger-bg);color:var(--btn-danger-color);border:none;cursor:pointer;transition:all .15s}.backup-delete-btn:hover{filter:brightness(.92)}.about-page{flex:1;overflow-y:auto;padding:32px 48px;background:var(--surface);max-width:960px;margin:0 auto;width:100%}.about-section{margin-bottom:36px}.about-section h2{color:var(--primary);font-size:1.21rem;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--primary-light)}.about-section h3{color:var(--gray-700);font-size:1rem;margin:24px 0 14px}.about-section p,.about-section li{font-size:.95rem;line-height:1.65;color:var(--gray-600)}.about-section ul{padding-left:20px;margin:8px 0}.about-section li{margin-bottom:5px}.about-version-badge{font-size:.72rem;font-weight:700;color:var(--primary);background:var(--primary-bg);padding:2px 10px;border-radius:10px;margin-left:8px;vertical-align:middle}.about-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:16px 0}.about-feature-item{background:var(--gray-50);padding:18px;border-radius:10px;border:1px solid var(--gray-200)}.about-feature-item i{color:var(--primary);font-size:1.07rem;margin-bottom:8px;display:block}.about-feature-item h4{color:var(--gray-700);margin-bottom:6px;font-size:.92rem}.about-feature-item p{font-size:.82rem}.about-step{display:flex;align-items:flex-start;margin-bottom:20px;gap:14px}.about-step-num{background:var(--primary);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;flex-shrink:0}.about-step-num i{font-size:11px}.about-step-body{flex:1}.about-step-body h4{color:var(--gray-700);margin-bottom:6px;font-size:.95rem}.about-label{display:inline-flex;align-items:center;gap:4px;background:var(--gray-100);padding:2px 8px;border-radius:4px;font-size:.82rem;color:var(--gray-700);font-weight:500}.about-label i{font-size:.75rem}.about-label.success{background:var(--success);color:#fff}.about-label.warning{background:var(--warning);color:#fff}.about-label.danger{background:var(--danger);color:#fff}.about-label.info{background:var(--primary-light);color:#fff}.about-label.gray{background:var(--gray-500);color:#fff}.about-note{background:var(--gray-50);border-left:4px solid var(--primary-light);padding:14px 16px;margin:12px 0;border-radius:4px;font-size:.9rem;display:flex;align-items:flex-start;gap:10px;color:var(--gray-600);line-height:1.55}.about-note i{color:var(--primary);flex-shrink:0;margin-top:2px}.about-footer{text-align:center;padding:24px 0;margin-top:20px;border-top:1px solid var(--gray-200);font-size:.85rem;color:var(--gray-400)}.research-note-header{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--gray-200);margin-bottom:12px;font-size:1rem;font-weight:600;color:var(--primary)}.research-note-summary{font-size:.88rem;font-weight:400;color:var(--text-secondary)}.research-note-date-section{background:var(--surface);border:1px solid var(--gray-200);border-radius:8px;margin-bottom:12px;overflow:hidden}.research-note-date-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--gray-50);border-bottom:1px solid var(--gray-200);font-size:.95rem;font-weight:600;color:var(--text)}.research-note-date-count{font-size:.82rem;color:var(--text-secondary);font-weight:400}.research-note-citation-row{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--gray-100)}.research-note-citation-row:hover{background:var(--hover)}.research-note-cite-num{font-size:.82rem;font-weight:700;color:var(--primary-light);width:28px;text-align:right;flex-shrink:0}.research-note-cite-title{flex:1;font-size:.92rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.research-note-memo{width:100%;min-height:70px;padding:12px 16px;border:none;border-top:1px solid var(--gray-200);resize:vertical;font-size:.92rem;line-height:1.5;font-family:inherit;color:var(--text);background:var(--surface)}.research-note-memo:focus{outline:none;background:var(--accent-bg)}.research-note-memo::placeholder{color:var(--gray-400)}.book-search-modal{width:600px}.book-search-input-row{display:flex;gap:8px;margin-bottom:16px}.book-search-input{flex:1}.book-search-results{max-height:60vh;overflow-y:auto}.book-search-item{display:flex;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background .15s}.book-search-item:hover{background:var(--hover)}.book-search-item+.book-search-item{border-top:1px solid var(--gray-100)}.book-search-thumb{width:48px;height:68px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--gray-100)}.book-search-info{flex:1;min-width:0}.book-search-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:4px;line-height:1.3}.book-search-meta{font-size:.82rem;color:var(--text-secondary);margin-bottom:4px}.book-search-sep{margin:0 4px}.book-search-desc{font-size:.78rem;color:var(--gray-500);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-search-link{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:32px;height:32px;border-radius:6px;color:var(--text-secondary);transition:all .15s;align-self:center;font-size:.82rem}.book-search-link:hover{background:var(--gray-200);color:var(--accent)}.figure-list-header{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--gray-200);margin-bottom:12px}.figure-list-title{font-size:1rem;font-weight:600;color:var(--primary)}.figure-list-actions{display:flex;align-items:center;gap:8px}.figure-view-toggle{display:flex;gap:2px}.figure-view-toggle button{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--btn-radius);cursor:pointer;background:var(--hover);color:var(--text-secondary);transition:all .2s;font-size:.88rem}.figure-view-toggle button:hover{background:var(--gray-200)}.figure-view-toggle button.active{background:var(--primary);color:#fff}.figure-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.figure-card{background:var(--surface);border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}.figure-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.figure-card-thumb{position:relative;aspect-ratio:4 / 3;overflow:hidden;background:var(--gray-100);display:flex;align-items:center;justify-content:center}.figure-card-thumb img{width:100%;height:100%;object-fit:cover}.figure-card-no-image{font-size:2rem;color:var(--gray-300)}.figure-card-number{position:absolute;top:6px;left:6px;background:#000000a6;color:#fff;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:4px}.figure-card-info{padding:10px 12px;flex:1}.figure-card-title{font-size:.92rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px}.figure-card-meta{display:flex;gap:6px;font-size:.78rem;color:var(--text-secondary)}.figure-card-actions{display:flex;justify-content:flex-end;gap:4px;padding:6px 10px;border-top:1px solid var(--gray-100)}.figure-card-actions button{border:none;background:none;cursor:pointer;font-size:.82rem;padding:3px 6px;border-radius:4px;color:var(--text-secondary);transition:all .15s}.figure-card-actions button:hover{background:var(--gray-100);color:var(--accent)}.figure-card-actions button.danger:hover{color:var(--danger)}.figure-list-rows{display:flex;flex-direction:column}.figure-list-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px dashed var(--gray-200);cursor:pointer;transition:background .15s}.figure-list-row:hover{background:var(--hover)}.figure-list-row-num{font-size:.82rem;font-weight:700;color:var(--primary-light);width:48px;text-align:right;flex-shrink:0}.figure-list-row-thumb{width:40px;height:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:4px;background:var(--gray-100)}.figure-list-row-thumb img{width:100%;height:100%;object-fit:cover}.figure-list-row-thumb i{font-size:.88rem;color:var(--gray-300)}.figure-list-row-title{flex:1;font-size:.92rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.figure-list-row-artist{font-size:.82rem;color:var(--text-secondary);flex-shrink:0}.figure-list-row-year{font-size:.82rem;color:var(--gray-400);flex-shrink:0;width:48px;text-align:center}.figure-list-row-actions{display:flex;gap:4px;flex-shrink:0}.figure-list-row-actions button{border:none;background:none;cursor:pointer;font-size:.82rem;padding:3px 5px;border-radius:4px;color:var(--text-secondary)}.figure-list-row-actions button:hover{background:var(--gray-100);color:var(--accent)}.figure-list-row-actions button.danger:hover{color:var(--danger)}.figure-modal{width:720px}.figure-image-dropzone{border:2px dashed var(--gray-300);border-radius:10px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:20px;background:var(--gray-50)}.figure-image-dropzone:hover{border-color:var(--primary);background:var(--accent-bg)}.figure-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-secondary)}.figure-image-placeholder i{font-size:2rem;color:var(--gray-400)}.figure-image-placeholder span{font-size:.92rem}.figure-image-hint{font-size:.78rem;color:var(--gray-400)}.figure-image-preview{position:relative;display:inline-block;max-width:100%}.figure-image-preview img{max-width:100%;max-height:300px;border-radius:8px;object-fit:contain}.figure-image-remove{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:background .15s}.figure-image-remove:hover{background:var(--danger)}@media(max-width:768px){.sidebar{width:200px}.sidebar.collapsed{width:var(--sidebar-collapsed)}.landing-features{grid-template-columns:1fr}.modal-box{width:95vw}.stats-grid{grid-template-columns:1fr 1fr}.reference-list-header{flex-direction:column}.about-page{padding:20px 16px}.about-features{grid-template-columns:1fr}.home-page{padding:20px 16px}.home-columns{grid-template-columns:1fr}.home-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.figure-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.figure-modal{width:95vw}.figure-list-header{flex-direction:column;gap:8px;align-items:flex-start}}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-50, #F8FAFC);font-family:Pretendard Variable,sans-serif;padding:20px}.register-card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:40px;width:100%;max-width:440px}.register-header{text-align:center;margin-bottom:28px}.register-header h1{font-size:1.5rem;font-weight:700;color:#0f172a;margin-bottom:8px}.register-header p{font-size:.9rem;color:#64748b}.register-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:40px 0;color:#64748b}.register-google-btn{width:100%;padding:12px;border:1px solid #E2E8F0;border-radius:10px;background:#fff;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}.register-google-btn:hover{background:#f8fafc}.register-form{display:flex;flex-direction:column;gap:18px}.register-field label{display:block;font-size:.85rem;font-weight:600;color:#334155;margin-bottom:6px}.register-optional{font-weight:400;color:#94a3b8;font-size:.8rem}.register-field input{width:100%;padding:10px 12px;border:1px solid #E2E8F0;border-radius:8px;font-size:.9rem;background:#f8fafc;color:#0f172a}.register-field input[readonly]{color:#64748b;cursor:default}.register-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.register-terms{display:flex;align-items:flex-start;gap:4px}.register-terms label{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#334155;cursor:pointer}.register-terms input[type=checkbox]{width:16px;height:16px;accent-color:#2563EB;flex-shrink:0}.register-terms a{color:#2563eb;text-decoration:underline}.register-submit-btn{width:100%;padding:12px;border:none;border-radius:10px;background:#2563eb;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.register-submit-btn:hover:not(:disabled){background:#1d4ed8}.register-submit-btn:disabled{opacity:.5;cursor:not-allowed}.register-notice{display:flex;gap:12px;align-items:flex-start;background:#eff6ff;border:1px solid #BFDBFE;border-radius:10px;padding:14px 16px;margin-bottom:4px;color:#1e40af;font-size:.85rem;line-height:1.5}.register-notice i{font-size:1.1rem;margin-top:2px;flex-shrink:0}.register-notice strong{display:block;margin-bottom:2px}.register-notice p{margin:0;color:#1e40af;opacity:.85}
