:root{--ink:#1a1208;--paper:#f5f0e8;--aged:#e8dfc8;--sepia:#8b6914;--rust:#c0392b;--gold:#d4a017;--mist:#6b7280;--cream:#faf7f0;--shadow:#1a120826}*{box-sizing:border-box;margin:0;padding:0}html,body{overscroll-behavior-x:none;max-width:100vw;overflow-x:hidden}body{background:var(--paper);color:var(--ink);background-image:radial-gradient(at 20%,#d4a0170f 0%,#0000 60%),radial-gradient(at 80% 20%,#c0392b0a 0%,#0000 50%),url("data:image/svg+xml,%3Csvg width='400' height='400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");min-height:100vh;font-family:Noto Serif KR,serif}header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#f5f0e8f2;border-bottom:1px solid #8b691440;justify-content:space-between;align-items:center;padding:20px 40px;display:flex;position:sticky;top:0}.logo{letter-spacing:6px;color:var(--ink);font-family:Playfair Display,serif;font-size:28px;font-weight:700}.logo span{color:var(--gold);font-style:italic}.header-meta{color:var(--mist);letter-spacing:1px;font-family:JetBrains Mono,monospace;font-size:11px}.token-badge{background:var(--ink);color:var(--gold);letter-spacing:1px;border-radius:2px;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:11px}.app-container{grid-template-columns:300px 1fr 280px;height:calc(100vh - 65px);display:grid;overflow:hidden}.sidebar-left{background:#e8dfc866;border-right:1px solid #8b691433;padding:24px 20px;overflow-y:auto}.sidebar-section{margin-bottom:28px}.sidebar-title{letter-spacing:3px;color:var(--sepia);text-transform:uppercase;border-bottom:1px solid #8b691433;margin-bottom:12px;padding-bottom:6px;font-family:JetBrains Mono,monospace;font-size:10px}.novel-setup-btn{color:#fff;cursor:pointer;letter-spacing:1px;text-align:left;background:#c2620a;border:none;align-items:center;gap:10px;width:100%;padding:14px;font-family:Noto Serif KR,serif;font-size:14px;transition:all .2s;display:flex}.novel-setup-btn:hover{background:#a3520a}.novel-setup-btn .icon{font-size:18px}.world-card{background:var(--cream);cursor:pointer;border:1px solid #8b691433;margin-bottom:8px;padding:12px;transition:all .2s;position:relative}.world-card:hover{border-color:var(--gold)}.world-card.active{border-color:var(--gold);background:#d4a01714}.world-card-name{margin-bottom:4px;font-family:Playfair Display,serif;font-size:13px;font-weight:700}.world-card-role{color:var(--mist);font-size:11px;font-style:italic}.world-card-tag{color:var(--sepia);letter-spacing:1px;font-family:JetBrains Mono,monospace;font-size:9px;position:absolute;top:8px;right:8px}.chapter-item{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:2px;align-items:center;gap:6px;padding:7px 8px;font-size:12px;font-weight:600;transition:all .15s;display:flex;position:relative}.chapter-item:hover{background:#8b69141a}.chapter-item.active{background:#8b691426}.chapter-num{color:var(--sepia);min-width:20px;font-family:JetBrains Mono,monospace;font-size:10px}.chapter-charcount{color:var(--mist);white-space:nowrap;margin-left:auto;font-family:JetBrains Mono,monospace;font-size:9px}.chapter-toggle{color:var(--mist);min-width:10px;font-size:9px;transition:transform .15s}.chapter-toggle.open{transform:rotate(90deg)}.scene-tree-item{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:2px;align-items:center;gap:4px;padding:5px 6px 5px 22px;font-size:11px;transition:all .15s;display:flex;position:relative}.scene-tree-item:hover{background:#8b691414}.scene-tree-item.active{border-left:2px solid var(--gold);background:#d4a0171f;padding-left:20px}.scene-tree-item.compressed{opacity:.6}.scene-tree-item.dragging{opacity:.4}.scene-tree-item.drag-over{border-top:2px solid var(--rust)}.scene-tree-num{color:var(--sepia);min-width:18px;font-family:JetBrains Mono,monospace;font-size:9px}.scene-tree-preview{color:#4a3f2f;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.scene-tree-chars{color:var(--mist);white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:9px}.scene-tree-actions{align-items:center;gap:2px;display:none}.scene-tree-item:hover .scene-tree-actions{display:flex}.scene-action-btn{cursor:pointer;opacity:1;filter:sepia()saturate(3)hue-rotate(5deg)brightness(.75);background:0 0;border:none;border-radius:2px;padding:2px 3px;font-size:13px;line-height:1;transition:filter .1s,background .1s}.scene-action-btn:hover{filter:sepia()saturate(4)hue-rotate(5deg)brightness(.55);background:#8b691426}@keyframes sparkle{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.ai-rewrite-btn{filter:sepia()saturate(2)hue-rotate(340deg)brightness(.6);animation:2s infinite sparkle}.ai-rewrite-btn:hover{filter:sepia()saturate(3)hue-rotate(340deg)brightness(.45)}.scene-delete-btn{font-size:12px;font-weight:700;color:#dc2626!important;filter:none!important}.scene-delete-btn:hover{color:#b91c1c!important;background:#dc26261f!important}.scene-edit-panel{background:var(--cream);border:1px solid #8b691440;border-radius:2px;margin:4px 0 4px 22px;overflow:hidden}.scene-edit-textarea{width:100%;color:var(--ink);resize:vertical;background:0 0;border:none;outline:none;min-height:80px;padding:8px 10px;font-family:Noto Serif KR,serif;font-size:12px;line-height:1.8}.scene-edit-footer{border-top:1px solid #8b691426;flex-wrap:wrap;align-items:center;gap:6px;padding:6px 8px;display:flex}.scene-rewrite-input{background:var(--paper);min-width:0;color:var(--ink);border:1px solid #8b691440;border-radius:2px;outline:none;flex:1;padding:4px 8px;font-family:Noto Serif KR,serif;font-size:11px}.scene-save-btn{background:var(--sepia);color:#fff;cursor:pointer;border:none;border-radius:2px;padding:4px 10px;font-family:Noto Serif KR,serif;font-size:11px}.scene-rewrite-submit-btn{background:var(--rust);color:#fff;cursor:pointer;border:none;border-radius:2px;align-items:center;gap:4px;padding:4px 10px;font-family:Noto Serif KR,serif;font-size:11px;display:flex}.scene-cancel-btn{color:var(--mist);cursor:pointer;background:0 0;border:1px solid #8b691440;border-radius:2px;padding:4px 8px;font-family:Noto Serif KR,serif;font-size:11px}.book-header{background:var(--ink);color:#fff;border-radius:2px;margin-bottom:6px;padding:8px 10px;font-family:Playfair Display,serif;font-size:12px;font-weight:700}.book-header-sub{color:#fff9;margin-top:3px;font-family:JetBrains Mono,monospace;font-size:9px;font-weight:400}.main-editor{flex-direction:column;display:flex;overflow:hidden}.editor-toolbar{background:#f5f0e8cc;border-bottom:1px solid #8b691426;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 24px;display:flex}.toolbar-btn{color:var(--ink);cursor:pointer;background:0 0;border:1px solid #8b69144d;border-radius:2px;padding:6px 14px;font-family:Noto Serif KR,serif;font-size:12px;transition:all .15s}.toolbar-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}.toolbar-btn.primary{background:var(--ink);color:var(--gold);border-color:var(--ink)}.toolbar-btn.primary:hover{background:#2d2010}.toolbar-select{background:var(--cream);color:var(--ink);cursor:pointer;border:1px solid #8b69144d;border-radius:2px;padding:6px 10px;font-family:Noto Serif KR,serif;font-size:12px}.toolbar-divider{background:#8b691433;width:1px;height:24px}.chapter-title-bar{border-bottom:1px solid #8b69141a;padding:16px 40px 12px}.chapter-title-input{color:var(--ink);background:0 0;border:none;outline:none;width:100%;font-family:Playfair Display,serif;font-size:22px;font-weight:700}.chapter-title-input::placeholder{color:#1a12084d;font-style:italic}.novel-content-area{flex:1;padding:30px 60px;position:relative;overflow-y:auto}.scene-block{margin-bottom:32px;position:relative}.scene-label{letter-spacing:2px;color:var(--sepia);text-transform:uppercase;align-items:center;gap:8px;margin-bottom:10px;font-family:JetBrains Mono,monospace;font-size:9px;display:flex}.scene-label:after{content:"";background:#8b691426;flex:1;height:1px}.scene-summary{color:var(--mist);border-left:2px solid var(--gold);background:#8b69140d;margin-bottom:8px;padding:6px 10px;font-size:11px;font-style:italic}.novel-text{color:var(--ink);white-space:pre-wrap;font-family:Noto Serif KR,serif;font-size:16px;line-height:2}.novel-text-placeholder{color:#1a120840;text-align:center;padding:60px 20px;font-size:15px;font-style:italic;line-height:2}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.streaming-cursor{background:var(--rust);vertical-align:middle;width:2px;height:18px;margin-left:2px;animation:.8s infinite cursor-blink;display:inline-block}.generation-panel{background:#e8dfc880;border-top:1px solid #8b691433;padding:16px 24px}.gen-controls{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.direction-input{background:var(--cream);min-width:200px;color:var(--ink);border:1px solid #8b69144d;border-radius:2px;outline:none;flex:1;padding:10px 14px;font-family:Noto Serif KR,serif;font-size:13px;transition:border-color .2s}.direction-input:focus{border-color:var(--gold)}.direction-input::placeholder{color:#1a120859}.gen-btn{background:var(--rust);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:2px;align-items:center;gap:6px;padding:10px 20px;font-family:Noto Serif KR,serif;font-size:13px;transition:all .2s;display:flex}.gen-btn:hover{background:#a93226}.gen-btn:disabled{background:var(--mist);cursor:not-allowed}.token-info{align-items:center;gap:16px;display:flex}.token-stat{color:var(--mist);align-items:center;gap:4px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.token-stat strong{color:var(--sepia)}.sidebar-right{background:#e8dfc84d;border-left:1px solid #8b691433;padding:20px 16px;font-size:12px;overflow-y:auto}.memory-block{background:var(--cream);border:1px solid #8b691426;border-radius:2px;margin-bottom:12px;padding:12px}.memory-block-title{letter-spacing:2px;color:var(--sepia);text-transform:uppercase;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:9px}.memory-text{color:#4a3f2f;font-size:11px;line-height:1.7}.modal-overlay{z-index:200;opacity:0;pointer-events:none;background:#1a1208b3;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.modal-overlay.visible{opacity:1;pointer-events:all}.modal{background:var(--cream);border:1px solid #8b69144d;width:680px;max-width:95vw;max-height:90vh;transition:transform .3s;overflow-y:auto;transform:translateY(20px)}.modal-overlay.visible .modal{transform:translateY(0)}.modal-header{border-bottom:1px solid #8b691433;justify-content:space-between;align-items:center;padding:24px 28px 16px;display:flex}.modal-title{font-family:Playfair Display,serif;font-size:22px;font-weight:700}.modal-close{cursor:pointer;color:var(--mist);background:0 0;border:none;padding:4px;font-size:20px}.modal-body{padding:24px 28px}.form-group{margin-bottom:20px}.form-label{letter-spacing:2px;color:var(--sepia);text-transform:uppercase;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:10px;display:block}.form-input,.form-textarea,.form-select{background:var(--paper);width:100%;color:var(--ink);border:1px solid #8b69144d;border-radius:2px;outline:none;padding:10px 14px;font-family:Noto Serif KR,serif;font-size:13px;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--gold)}.form-textarea{resize:vertical;min-height:80px;line-height:1.7}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.character-list{flex-direction:column;gap:10px;margin-bottom:12px;display:flex}.character-entry{background:var(--paper);border:1px solid #8b691433;padding:12px}.char-entry-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;display:grid}.char-entry-grid input{background:var(--cream);border:1px solid #8b691440;border-radius:2px;outline:none;width:100%;padding:7px 10px;font-family:Noto Serif KR,serif;font-size:12px}.char-entry-grid input:focus{border-color:var(--gold)}.char-traits{background:var(--cream);resize:none;border:1px solid #8b691440;border-radius:2px;outline:none;width:100%;min-height:48px;padding:7px 10px;font-family:Noto Serif KR,serif;font-size:12px}.char-traits:focus{border-color:var(--gold)}.add-char-btn{color:var(--sepia);cursor:pointer;background:0 0;border:1px dashed #8b691466;border-radius:2px;width:100%;padding:8px 16px;font-family:Noto Serif KR,serif;font-size:12px;transition:all .15s}.add-char-btn:hover{background:#8b691414}.remove-char-btn{float:right;color:var(--rust);cursor:pointer;background:0 0;border:none;margin-bottom:6px;font-size:12px}.modal-footer{justify-content:flex-end;gap:10px;padding:16px 28px 24px;display:flex}.btn-cancel{color:var(--ink);cursor:pointer;background:0 0;border:1px solid #8b69144d;border-radius:2px;padding:10px 20px;font-family:Noto Serif KR,serif;font-size:13px}.btn-start{background:var(--ink);color:var(--gold);cursor:pointer;border:none;border-radius:2px;padding:10px 24px;font-family:Noto Serif KR,serif;font-size:13px;font-weight:600}.btn-start:hover{background:#2d2010}.btn-start:disabled{background:var(--mist);cursor:not-allowed}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#8b691440;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#8b691466}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}.status-bar{height:28px;color:var(--mist);letter-spacing:.5px;background:#e8dfc899;border-top:1px solid #8b691426;align-items:center;gap:20px;padding:0 24px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.status-dot{background:var(--mist);border-radius:50%;width:6px;height:6px}.status-dot.active{background:#22c55e}.mobile-tab-bar{padding-bottom:env(safe-area-inset-bottom,0px);height:calc(56px + env(safe-area-inset-bottom,0px));background:var(--ink);z-index:300;border-top:2px solid #d4a01740;grid-template-columns:repeat(3,1fr);display:none;position:fixed;bottom:0;left:0;right:0}.mobile-tab-btn{color:#ffffffa6;letter-spacing:.5px;cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:6px 0;font-family:JetBrains Mono,monospace;font-size:9px;transition:color .15s;display:flex}.mobile-tab-btn .tab-icon{font-size:19px;line-height:1}.mobile-tab-btn.active{color:#fff}body.dark .mobile-tab-bar{background:#e8e0d0;border-top-color:#8b69144d}body.dark .mobile-tab-btn{color:#1e140a8c}body.dark .mobile-tab-btn.active{color:#1a1208}@media (width<=768px){header{height:52px;padding:11px 14px}.logo{letter-spacing:1px;white-space:nowrap;font-size:15px}.header-meta{display:none}.token-badge{padding:3px 8px;font-size:10px}.app-container{height:calc(100vh - 52px);display:block;position:relative;overflow:hidden}.sidebar-left,.main-editor,.sidebar-right{top:0;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));border:none;width:100%;display:none;position:absolute;overflow:hidden auto}.sidebar-left.mobile-active{display:block}.main-editor.mobile-active{display:flex}.sidebar-right.mobile-active{display:block}.mobile-tab-bar{display:grid}.novel-content-area{padding:18px 16px 8px}.chapter-title-bar{padding:10px 16px 8px}.chapter-title-input{font-size:16px}.editor-toolbar{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:6px;padding:8px 10px;overflow-x:auto}.editor-toolbar::-webkit-scrollbar{display:none}.toolbar-divider{display:none}.generation-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#e8dfc8f7;border-top:1px solid #8b691433;padding:10px 12px;position:sticky;bottom:0}.gen-controls{flex-wrap:wrap;gap:7px}.direction-input{width:100%;min-width:unset;font-size:14px}.gen-btn{flex:1;justify-content:center;font-size:13px}.token-info{flex-wrap:wrap;gap:8px}.token-stat{font-size:10px}.sidebar-left{padding:14px 12px}.sidebar-right{padding:12px 10px}.modal{border-radius:0;margin:0;width:100%!important;max-width:100vw!important;max-height:calc(100vh - 52px)!important}.modal-overlay{align-items:flex-end}.modal-body,.modal-header{padding:14px 16px}.modal-footer{padding:10px 16px 90px}.form-grid{grid-template-columns:1fr;gap:0}.site-footer{display:none}.scene-tree-item{padding:7px 4px 7px 16px}.scene-tree-actions{display:flex!important}.scene-action-btn{padding:4px 6px;font-size:15px}.novel-text{font-size:15px;line-height:1.95}.status-bar{gap:8px;height:22px;padding:0 10px;font-size:9px}.scene-edit-panel{margin-left:6px}.scene-edit-textarea{min-height:100px;font-size:13px}.book-header{padding:7px 9px;font-size:11px}.chapter-item{padding:6px;font-size:11px}.scene-tree-preview{font-size:11px}}@media (width>=769px) and (width<=1080px){.app-container{grid-template-columns:230px 1fr}.sidebar-right{display:none}.novel-content-area{padding:24px 30px}}body.dark{--ink:#e8e0d0;--paper:#111;--aged:#1e1e1e;--sepia:#c9a84c;--gold:#d4a017;--mist:#9ca3af;--cream:#1a1a1a;--shadow:#00000080;color:#e8e0d0;background:#111}body.dark header{background:#111111f7;border-bottom-color:#d4a01733}body.dark .sidebar-left{background:#181818;border-right-color:#d4a01726}body.dark .sidebar-right{background:#14120ecc;border-left-color:#d4a01726}body.dark .editor-toolbar{background:#111111e6;border-bottom-color:#d4a0171f}body.dark .toolbar-select{color:#e8e0d0;background:#1e1e1e;border-color:#d4a01740}body.dark .toolbar-btn{color:#e8e0d0;border-color:#d4a01740}body.dark .toolbar-btn:hover{color:#e8e0d0;background:#2a2a2a;border-color:#d4a01766}body.dark .generation-panel{background:#14120ee6;border-top-color:#d4a01726}body.dark .direction-input{color:#e8e0d0;background:#1e1e1e;border-color:#d4a01740}body.dark .direction-input::placeholder{color:#e8e0d04d}body.dark .status-bar{background:#111111f2;border-top-color:#d4a0171f}body.dark .world-card{background:#232323;border-color:#d4a01726}body.dark .world-card:hover{border-color:var(--gold)}body.dark .scene-edit-panel{background:#1e1e1e;border-color:#d4a01733}body.dark .scene-edit-textarea{color:#e8e0d0}body.dark .scene-edit-footer{border-top-color:#d4a0171f}body.dark .scene-rewrite-input{color:#e8e0d0;background:#111;border-color:#d4a01733}body.dark .memory-block{background:#232323;border-color:#d4a0171f}body.dark .novel-setup-btn{color:#e8e0d0!important;background:#232323!important}body.dark .novel-list-btn--active{color:#e8e0d0!important;background:#2a2a2a!important}body.dark .book-header{color:#e8e0d0;background:#2a2a2a}body.dark .memory-text,body.dark .scene-tree-preview{color:#b5a98a}body.dark .scene-tree-item:hover{background:#d4a0170f}body.dark .chapter-item:hover{background:#d4a01714}body.dark .chapter-item.active{background:#d4a0171f}body.dark .chapter-title-input{color:#e8e0d0}body.dark .chapter-title-input::placeholder{color:#e8e0d033}body.dark .chapter-title-bar{border-bottom-color:#d4a01714}body.dark .novel-text{color:#d4d4c9}body.dark .novel-text-placeholder{color:#e8e0d033}body.dark .scene-label{color:#c9a84c}body.dark .scene-summary{background:#d4a0170d}body.dark .modal{background:#1a1a1a;border-color:#d4a01740}body.dark .modal-header{border-bottom-color:#d4a01726}body.dark .modal-close{color:#9ca3af}body.dark .form-input,body.dark .form-textarea,body.dark .form-select{color:#e8e0d0;background:#111;border-color:#d4a01740}body.dark .form-input:focus,body.dark .form-textarea:focus{border-color:var(--gold)}body.dark .character-entry{background:#111;border-color:#d4a01726}body.dark .char-entry-grid input,body.dark .char-traits{color:#e8e0d0;background:#1a1a1a;border-color:#d4a01733}body.dark .btn-cancel{color:#e8e0d0;border-color:#d4a01740}body.dark .btn-cancel:hover{background:#2a2a2a}body.dark .add-char-btn{color:#c9a84c;border-color:#d4a0174d}body.dark .add-char-btn:hover{background:#d4a0170f}body.dark .scene-cancel-btn{color:#9ca3af;border-color:#d4a01733}body.dark ::-webkit-scrollbar-thumb{background:#d4a01733}body.dark ::-webkit-scrollbar-thumb:hover{background:#d4a01759}.dark-mode-btn{color:var(--ink);cursor:pointer;background:0 0;border:1px solid #8b69144d;border-radius:2px;padding:4px 10px;font-size:14px;line-height:1;transition:all .15s}.dark-mode-btn:hover{background:#8b69141a}body.dark .dark-mode-btn{color:#e8e0d0;border-color:#d4a0174d}body.dark .dark-mode-btn:hover{background:#d4a0171a}.site-footer{text-align:center;color:var(--mist);border-top:1px solid #8b691426;margin-bottom:56px;padding:14px;font-family:JetBrains Mono,monospace;font-size:10px}.site-footer a{color:var(--mist);letter-spacing:.5px;text-decoration:none;transition:color .15s}.site-footer a:hover{color:var(--gold)}body.dark .site-footer{border-top-color:#d4a0171a}@media (width>=769px){.site-footer{margin-bottom:0}}.auth-page{background:var(--paper);justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:48px 40px 36px;box-shadow:0 4px 32px #1a12081a}.auth-logo{flex-direction:column;align-items:center;gap:8px;margin-bottom:28px;display:flex}.auth-logo-icon{background:var(--sepia);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-family:Playfair Display,serif;font-size:28px;display:flex}.auth-logo h1{color:var(--ink);letter-spacing:2px;font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700}.auth-title{color:var(--ink);text-align:center;margin-bottom:8px;font-family:Noto Serif KR,serif;font-size:1.2rem;font-weight:700}.auth-subtitle{color:var(--mist);text-align:center;margin-bottom:24px;font-size:.88rem}.auth-form{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.auth-email-form{flex-direction:column;gap:10px;margin-top:10px;display:flex}.auth-input{width:100%;color:var(--ink);background:#faf7f0;border:1px solid #e0d8cc;border-radius:10px;outline:none;padding:12px 16px;font-family:Noto Serif KR,serif;font-size:.95rem;transition:border-color .15s}.auth-input:focus{border-color:var(--sepia);background:#fff}.auth-input:disabled{opacity:.6;cursor:not-allowed}.auth-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;padding:13px 16px;font-family:Noto Serif KR,serif;font-size:.95rem;font-weight:600;transition:background .15s,opacity .15s;display:flex}.auth-btn:disabled{opacity:.55;cursor:not-allowed}.auth-btn--email{background:var(--ink);color:#fff}.auth-btn--email:hover:not(:disabled){background:#2d2010}.auth-btn--google{color:#333;background:#fff;border:1.5px solid #e0d8cc}.auth-btn--google:hover:not(:disabled){background:#f8f4ee}.auth-btn--primary{background:var(--sepia);color:#fff}.auth-btn--primary:hover:not(:disabled){background:#6d5010}.auth-btn--outline{color:var(--ink);background:#fff;border:1.5px solid #e0d8cc}.auth-btn--outline:hover:not(:disabled){background:#f8f4ee}.auth-btn-icon{font-size:1rem}.auth-btn-icon-img{width:18px;height:18px}.auth-or{color:var(--mist);align-items:center;gap:12px;margin:4px 0;font-size:.8rem;display:flex}.auth-or:before,.auth-or:after{content:"";background:#e0d8cc;flex:1;height:1px}.auth-divider{background:#e0d8cc;height:1px;margin:20px 0 16px}.auth-switch{color:var(--mist);justify-content:center;align-items:center;gap:8px;font-size:.88rem;display:flex}.auth-link{color:var(--sepia);cursor:pointer;background:0 0;border:none;padding:0;font-family:Noto Serif KR,serif;font-size:.88rem;font-weight:600;text-decoration:underline}.auth-link:hover{color:var(--ink)}.auth-msg{text-align:center;border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:.85rem}.auth-msg--ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.auth-msg--err{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.auth-terms{color:var(--mist);text-align:center;margin-top:20px;font-size:.75rem;line-height:1.6}.auth-terms a{color:var(--mist);text-decoration:underline}body.dark .auth-card{background:#1e1a14;border:1px solid #d4a01726}body.dark .auth-title,body.dark .auth-logo h1{color:#e8d5b0}body.dark .auth-input{color:#e8d5b0;background:#2a2218;border-color:#d4a01733}body.dark .auth-input:focus{border-color:var(--gold);background:#1e1a14}body.dark .auth-btn--google,body.dark .auth-btn--outline{color:#e8d5b0;background:#2a2218;border-color:#d4a01733}body.dark .auth-btn--google:hover:not(:disabled),body.dark .auth-btn--outline:hover:not(:disabled){background:#332b1c}body.dark .auth-divider,body.dark .auth-or:before,body.dark .auth-or:after{background:#d4a01726}@media (width<=480px){.auth-card{padding:36px 24px 28px}}
