@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&family=Manrope:wght@300;400;500;600&display=swap";:root{--ivory: #FAFAF8;--ivory-dark: #F0EFE9;--ivory-hover: #E8E7E1;--black: #1A1A1A;--black-soft: #2D2D2D;--muted: #5a5652;--accent: #1B4332;--accent-light: #2D6A4F;--accent-hover: #40916C;--accent-coral: #e26d5c;--stroke: rgba(26, 26, 26, .12);--stroke-dark: rgba(26, 26, 26, .25);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 18px 50px rgba(0, 0, 0, .12);--shadow-xl: 0 32px 64px rgba(0, 0, 0, .16);--radius: 4px;--radius-lg: 6px;--radius-xl: 8px}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--ivory);color:var(--black);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}#root{width:100vw;height:100vh;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1a1a1a26;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#1a1a1a40}::selection{background:#1b433233;color:var(--black)}.auth-gate{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--ivory);position:relative}.auth-gate:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 25% 25%,rgba(27,67,50,.03) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(27,67,50,.02) 0%,transparent 50%);pointer-events:none}.auth-card{background:#fff;padding:48px 56px;border-radius:var(--radius-lg);border:1px solid var(--stroke);box-shadow:var(--shadow-lg);width:100%;max-width:420px;position:relative;animation:cardSlideUp .5s cubic-bezier(.23,1,.32,1)}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-logo{display:block;max-width:200px;height:auto;margin:0 auto 32px}.auth-card form{display:flex;flex-direction:column;gap:16px}.auth-card input[type=password]{width:100%;padding:14px 18px;font-family:Manrope,sans-serif;font-size:15px;border:1px solid var(--stroke);border-radius:var(--radius);background:var(--ivory);color:var(--black);transition:all .2s ease;outline:none}.auth-card input[type=password]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1b43321a;background:#fff}.auth-card input[type=password]::placeholder{color:var(--muted);opacity:.6}.auth-error{padding:12px 16px;background:#e26d5c1a;border:1px solid rgba(226,109,92,.3);color:#b91c1c;border-radius:var(--radius);font-size:13px;text-align:center;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.btn-primary{width:100%;background:var(--accent);color:var(--ivory);border:none;padding:14px 24px;border-radius:var(--radius);font-family:Manrope,sans-serif;font-size:14px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all .2s ease;margin-top:8px}.btn-primary:hover:not(:disabled){background:var(--accent-light);transform:translateY(-1px);box-shadow:0 8px 20px #1b433240}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-hint{text-align:center;color:var(--muted);font-size:12px;margin-top:24px;opacity:.7}.auth-card:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:60px;height:3px;background:var(--accent);border-radius:2px 2px 0 0}@media(max-width:480px){.auth-card{padding:36px 28px;margin:16px;max-width:none}.auth-card h1{font-size:24px}}.file-tree{display:flex;flex-direction:column;height:100%;background:#fff}.tree-header{padding:16px 20px 12px;border-bottom:1px solid var(--stroke);background:var(--ivory);position:relative;z-index:2;box-shadow:0 2px 8px #0000000a}.tree-header h3{margin:0 0 8px;font-family:Manrope,sans-serif;font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.tree-breadcrumb{display:flex;gap:4px;flex-wrap:wrap;font-size:13px;color:var(--muted)}.crumb{cursor:pointer;transition:color .15s ease}.crumb:hover{color:var(--accent)}.crumb:last-child{color:var(--black);font-weight:500}.crumb-sep{margin:0 2px;color:var(--stroke-dark);opacity:.6}.tree-content{flex:1;overflow-y:auto;padding:8px 0}.tree-content.drop-active{background:#1b433208;outline:2px dashed var(--accent);outline-offset:-8px}.tree-node{-webkit-user-select:none;user-select:none}.tree-node.drop-target .node-content{background:#1b433214;border-left:2px solid var(--accent)}.node-content{display:flex;align-items:center;padding:10px 20px;cursor:pointer;transition:all .15s ease;gap:10px;border-left:3px solid transparent;margin:0}.node-content:hover{background:var(--ivory-dark)}.node-content.active{background:var(--accent);color:var(--ivory);border-left-color:var(--accent);border-radius:0}.node-content.active:hover{background:var(--accent-light)}.node-icon{display:flex;align-items:center;color:var(--muted);flex-shrink:0}.node-content.active .node-icon{color:var(--ivory);opacity:.85}.node-name{flex:1;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-size{font-size:11px;color:var(--muted);opacity:.6}.node-content.active .node-size{color:var(--ivory);opacity:.7}.node-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease}.node-content:hover .node-actions,.node-content.active .node-actions{opacity:1}.icon-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--stroke);background:#fff;color:var(--muted);border-radius:var(--radius);cursor:pointer;transition:all .15s ease}.icon-btn:hover{background:var(--ivory-dark);border-color:var(--stroke-dark);color:var(--black)}.node-content.active .icon-btn{background:#ffffff26;border-color:#ffffff40;color:var(--ivory)}.node-content.active .icon-btn:hover{background:#ffffff40}.icon-btn.danger{color:var(--accent-coral)}.icon-btn.danger:hover{background:#e26d5c1a;border-color:#e26d5c4d}.node-content.active .icon-btn.danger{color:#ffb4a9}.tree-loading,.tree-empty{padding:48px 24px;text-align:center;color:var(--muted);font-size:13px}.tree-empty:before{content:"";display:block;width:48px;height:48px;margin:0 auto 16px;background:var(--ivory-dark);border-radius:var(--radius-lg)}.code-editor{display:flex;flex-direction:column;height:100%;background:#fdfbf7}.editor-empty{display:flex;align-items:center;justify-content:center;height:100%;background:#fdfbf7}.empty-state{text-align:center;color:var(--muted)}.empty-state h2{margin-bottom:.5rem;font-size:1.5rem;font-weight:500}.empty-state p{font-size:.95rem}.editor-tabs{display:flex;gap:2px;background:#f6f0e6;padding:0 .75rem;overflow-x:auto}.editor-tab{display:flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;background:#0e0c0a0d;color:var(--muted);cursor:pointer;border-top:2px solid transparent;transition:all .15s;white-space:nowrap}.editor-tab:hover{background:#0e0c0a1a;color:var(--ink)}.editor-tab.active{background:#fdfbf7;color:#0e0c0a;border-top-color:#0e0c0a}.tab-name{display:flex;align-items:center;gap:.25rem;font-size:.85rem}.unsaved-indicator{color:#f59e0b;font-size:1.2rem;line-height:1}.tab-close{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:.125rem;transition:all .15s}.tab-close:hover{background:#0e0c0a1a;color:#0e0c0a}.editor-toolbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:#f6f0e6;border-bottom:1px solid var(--stroke)}.toolbar-btn{display:flex;align-items:center;gap:.5rem;padding:.4rem .875rem;background:#0e0c0a;color:#f7f4ef;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .15s}.toolbar-btn:hover:not(:disabled){background:#1d1a17}.toolbar-btn.secondary{background:#f5e9d9;color:#0e0c0a}.toolbar-btn.secondary:hover{background:#f1dbc2}.toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.toolbar-status{font-size:.85rem;color:#d97706}.editor-container{flex:1;overflow:hidden}.binary-preview{display:flex;flex-direction:column;height:100%;color:var(--ink)}.binary-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:#f6f0e6;border-bottom:1px solid var(--stroke)}.binary-content{flex:1;padding:1rem 1.25rem;overflow:auto;background:#fdfbf7}.binary-fallback{padding:1rem;background:#0e0c0a0a;border:1px solid var(--stroke);border-radius:4px}.share-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0e0c0a80;display:flex;align-items:center;justify-content:center;z-index:1000}.share-modal{background:#fdfbf7;border-radius:8px;padding:1.5rem;min-width:400px;max-width:90vw;box-shadow:0 8px 32px #0e0c0a33}.share-modal h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#0e0c0a}.share-loading{color:var(--muted);font-size:.9rem}.share-error{color:#dc2626;font-size:.9rem}.share-info{font-size:.85rem;color:var(--muted);margin-bottom:.75rem}.share-url-container{display:flex;gap:.5rem;margin-bottom:1rem}.share-url-input{flex:1;padding:.6rem .75rem;border:1px solid var(--stroke);border-radius:4px;font-size:.85rem;background:#f6f0e6;color:#0e0c0a}.share-copy-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:#0e0c0a;color:#f7f4ef;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .15s}.share-copy-btn:hover{background:#1d1a17}.share-expiry-options{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;font-size:.85rem;color:var(--muted)}.share-expiry-options button{padding:.3rem .6rem;background:#f5e9d9;color:#0e0c0a;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .15s}.share-expiry-options button:hover{background:#f1dbc2}.share-close-btn{display:block;width:100%;padding:.6rem;background:#f5e9d9;color:#0e0c0a;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .15s}.share-close-btn:hover{background:#f1dbc2}.mindmap-shell{position:relative;height:100%;background:var(--ivory)}.top-nav{position:sticky;top:0;z-index:10;background:var(--ivory);border-bottom:1px solid var(--stroke);padding:12px 24px;display:flex;justify-content:space-between;align-items:center}.nav-left{display:flex;align-items:center;gap:16px}.nav-title{font-family:Playfair Display,serif;font-size:18px;font-weight:500;letter-spacing:-.02em;color:var(--black)}.nav-breadcrumb{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}.search-input{width:100%;padding:10px 16px 10px 40px;font-family:Manrope,sans-serif;font-size:13px;border:1px solid var(--stroke);border-radius:var(--radius);background:#fff;outline:none;transition:all .2s ease}.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s ease}.result-name{font-size:13px;font-weight:500}.result-meta{font-size:11px;color:var(--muted)}.mindmap-canvas{position:relative;height:calc(100vh - 57px);overflow:hidden;background:var(--ivory)}.mindmap-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.mindmap-line{stroke:var(--stroke-dark);stroke-width:1;fill:none}.mindmap-node{position:absolute;transform:translate(-50%,-50%);cursor:pointer;transition:all .3s cubic-bezier(.23,1,.32,1)}.node-content{background:#fff;border:1px solid var(--stroke);border-radius:var(--radius-lg);padding:16px 20px;text-align:center;min-width:120px;box-shadow:var(--shadow-md);transition:all .2s ease}.mindmap-node:hover .node-content{background:var(--ivory-dark);border-color:var(--stroke-dark);transform:translateY(-2px)}.mindmap-node.root .node-content{background:var(--black);color:var(--ivory);border-color:var(--black);min-width:140px;padding:20px 28px}.mindmap-node.root:hover .node-content{background:var(--black-soft)}.mindmap-node.active .node-content{background:var(--accent);color:var(--ivory);border-color:var(--accent);box-shadow:0 8px 24px #1b433240}.mindmap-node.active:hover .node-content{background:var(--accent-light)}.mindmap-node.child .node-content{min-width:100px;padding:10px 14px}.node-label{font-size:12px;font-weight:500}.node-count{font-size:10px;color:var(--muted);margin-top:2px;opacity:.7}.mindmap-node.active .node-count,.mindmap-node.root .node-count{color:var(--ivory);opacity:.7}.return-pill{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:var(--black);color:var(--ivory);font-size:11px;font-weight:500;letter-spacing:.05em;padding:10px 20px;border-radius:20px;cursor:pointer;box-shadow:var(--shadow-lg);transition:all .2s ease}.return-pill:hover{transform:translate(-50%) translateY(-2px);box-shadow:0 8px 24px #0003}.file-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;display:none;align-items:center;justify-content:center;padding:40px}.file-modal-overlay.active{display:flex}.file-modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:720px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-xl);display:flex;flex-direction:column}.modal-hero{height:200px;background:var(--ivory);border-bottom:1px solid var(--stroke);position:relative;display:flex;align-items:center;justify-content:center}.modal-badge{position:absolute;top:16px;left:16px;background:var(--accent);color:var(--ivory);font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:var(--radius)}.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border:none;background:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all .2s ease}.modal-content{padding:28px 32px;overflow-y:auto}.modal-type{font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}.modal-title{font-family:Playfair Display,serif;font-size:28px;font-weight:400;letter-spacing:-.02em;margin-bottom:8px}.modal-subtitle{font-size:13px;color:var(--muted);margin-bottom:24px}.modal-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--stroke);border:1px solid var(--stroke);border-radius:var(--radius);overflow:hidden;margin-bottom:24px}.meta-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.7;margin-bottom:4px}.meta-value{font-size:14px;font-weight:500}.modal-actions{display:flex;gap:8px}.btn{font-family:Manrope,sans-serif;font-size:12px;font-weight:500;padding:12px 24px;border:1px solid var(--stroke-dark);border-radius:var(--radius);background:transparent;cursor:pointer;transition:all .2s ease}.btn:hover{background:var(--ivory-dark)}.btn-primary{background:var(--accent);color:var(--ivory);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-light)}@media(max-width:768px){.search-container{width:200px}.search-shortcut{display:none}.modal-meta{grid-template-columns:1fr}.mindmap-canvas{height:calc(100vh - 56px)}.modal-content{padding:20px}.modal-title{font-size:22px}}.file-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:40px;animation:fadeIn .2s ease}.file-modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:720px;max-height:90vh;overflow:hidden;position:relative;display:flex;flex-direction:column;animation:modalSlideUp .3s cubic-bezier(.23,1,.32,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-hero{height:200px;background:var(--ivory);border-bottom:1px solid var(--stroke);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.modal-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.02));pointer-events:none}.modal-hero svg{width:64px;height:64px;stroke:var(--muted);stroke-width:1;fill:none;opacity:.25}.modal-hero img{max-width:100%;max-height:100%;object-fit:contain}.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border:none;background:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all .2s ease;z-index:1}.modal-close:hover{background:var(--ivory-dark);transform:scale(1.05)}.modal-close svg{width:16px;height:16px;stroke:var(--black);stroke-width:2;fill:none}.modal-body{padding:32px 40px;overflow-y:auto;flex:1}.modal-header{margin-bottom:28px}.modal-category{font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.modal-title{font-family:Playfair Display,serif;font-size:28px;font-weight:400;letter-spacing:-.02em;color:var(--black);line-height:1.3;margin:0}.modal-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--stroke);border:1px solid var(--stroke);border-radius:var(--radius);overflow:hidden;margin-bottom:28px}.meta-item{background:var(--ivory);padding:16px;text-align:center}.meta-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.7;margin-bottom:6px}.meta-value{font-size:14px;font-weight:500;color:var(--black)}.modal-description{font-size:15px;line-height:1.7;color:var(--black-soft);margin-bottom:28px;font-style:italic;padding-left:16px;border-left:2px solid var(--accent)}.modal-preview{margin-bottom:32px}.preview-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.7;margin-bottom:10px}.modal-preview-text{background:var(--ivory);border:1px solid var(--stroke);border-radius:var(--radius);padding:20px;font-family:Georgia,serif;font-size:14px;line-height:1.8;color:var(--black-soft);max-height:160px;overflow-y:auto;position:relative}.modal-btn{font-family:Manrope,sans-serif;font-size:13px;font-weight:500;padding:12px 24px;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s ease}.modal-btn.primary{background:var(--accent);color:var(--ivory)}.modal-btn.primary:hover{background:var(--accent-light);transform:translateY(-1px);box-shadow:0 6px 16px #1b433240}.modal-btn.secondary{background:transparent;color:var(--black);border:1px solid var(--stroke-dark)}.modal-btn.secondary:hover{background:var(--ivory-dark);border-color:var(--stroke-dark)}@media(max-width:768px){.file-modal-backdrop{padding:20px}.file-modal{max-height:95vh}.modal-hero{height:160px}.modal-body{padding:24px}.modal-title{font-size:22px}.modal-meta{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-btn{width:100%}}.three-wrapper{position:relative;width:100%;height:100%;background:var(--ivory)}.three-topbar{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:linear-gradient(180deg,var(--ivory) 0%,transparent 100%)}.nav-title{font-family:Playfair Display,serif;font-size:16px;font-weight:500;letter-spacing:-.02em;color:var(--black);cursor:pointer;transition:color .2s ease}.nav-title:hover{color:var(--accent)}.search-container{position:relative;width:320px}.search-input{width:100%;padding:10px 16px 10px 40px;font-family:Manrope,sans-serif;font-size:13px;border:1px solid var(--stroke);border-radius:var(--radius);background:#fff;color:var(--black);outline:none;transition:all .2s ease}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1b43321a}.search-input::placeholder{color:var(--muted);opacity:.5}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;stroke:var(--muted);stroke-width:2;fill:none;opacity:.4}.search-shortcut{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;font-weight:500;color:var(--muted);opacity:.4;padding:2px 6px;border:1px solid var(--stroke);border-radius:3px;background:var(--ivory)}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:400px;overflow-y:auto;display:none;z-index:200}.search-results.active{display:block}.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:all .15s ease;border-bottom:1px solid var(--stroke)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--ivory-dark)}.search-result-item.selected{background:var(--accent);color:var(--ivory)}.result-icon{width:32px;height:32px;background:var(--ivory);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.search-result-item.selected .result-icon{background:#ffffff26}.result-icon svg{width:16px;height:16px;stroke:var(--muted);stroke-width:1.5;fill:none}.search-result-item.selected .result-icon svg{stroke:var(--ivory)}.result-info{flex:1;min-width:0}.result-name{font-size:13px;font-weight:500;margin-bottom:2px}.result-meta{font-size:11px;color:var(--muted);opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-item.selected .result-meta{color:var(--ivory);opacity:.7}.search-empty{padding:24px 16px;text-align:center;color:var(--muted);font-size:13px}.three-label{background:#fff;color:var(--black);border:1px solid var(--stroke);border-radius:var(--radius);padding:6px 12px;font-family:Manrope,sans-serif;font-size:11px;font-weight:500;letter-spacing:.01em;white-space:nowrap;box-shadow:var(--shadow-md);transition:all .2s ease;pointer-events:none}.three-label .label-name{max-width:120px;overflow:hidden;text-overflow:ellipsis}.three-label .label-meta{font-size:9px;color:var(--muted);margin-top:2px}.three-label.root{background:var(--black);color:var(--ivory);border-color:var(--black);font-size:12px;font-weight:600;padding:8px 16px}.three-label.hovered{background:var(--accent);color:var(--ivory);border-color:var(--accent);transform:scale(1.05)}.three-label-flag{display:flex;align-items:stretch;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden;font-family:Manrope,sans-serif;white-space:nowrap;pointer-events:none;transition:all .2s ease}.three-label-flag .flag-letter{display:flex;align-items:center;justify-content:center;width:28px;min-width:28px;padding:6px 0;color:#fff;font-size:14px;font-weight:700;letter-spacing:-.02em}.three-label-flag .flag-name{padding:6px 12px 6px 10px;font-size:11px;font-weight:500;color:var(--black);max-width:140px;overflow:hidden;text-overflow:ellipsis}.three-label-flag.hovered{transform:scale(1.05);box-shadow:var(--shadow-lg)}.three-label-flag.hovered .flag-name{font-weight:600}.alpha-legend{position:absolute;bottom:24px;left:24px;display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid var(--stroke);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-md);z-index:10}.alpha-legend-item{display:flex;align-items:center;gap:10px}.alpha-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.alpha-range{font-family:Manrope,sans-serif;font-size:11px;font-weight:600;letter-spacing:.05em;color:var(--black)}@media(max-width:768px){.three-topbar{padding:12px 16px;flex-direction:column;gap:12px;align-items:stretch}.search-container{width:100%}.search-shortcut{display:none}.alpha-legend{bottom:12px;left:12px;padding:8px 12px;gap:4px}.alpha-dot{width:10px;height:10px}.alpha-range{font-size:10px}}.app{display:flex;flex-direction:column;height:100vh;background:var(--ivory);color:var(--black)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:var(--ivory);border-bottom:1px solid var(--stroke);min-height:57px}.header-logo-large{height:48px;width:auto;cursor:pointer;transition:opacity .2s ease}.header-logo-large:hover{opacity:.8}.header-actions{display:flex;gap:8px;align-items:center}.header-right{display:flex;gap:12px;align-items:center}.text-btn{font-family:Manrope,sans-serif;font-size:12px;font-weight:500;padding:8px 16px;border:1px solid var(--stroke);border-radius:var(--radius);background:#fff;color:var(--black);cursor:pointer;transition:all .2s ease}.text-btn:hover{background:var(--ivory-dark);border-color:var(--stroke-dark)}.text-btn:active{transform:translateY(.5px)}.view-switch{display:inline-flex;background:var(--ivory-dark);border:1px solid var(--stroke);border-radius:var(--radius);overflow:hidden}.switch-btn{font-family:Manrope,sans-serif;font-size:11px;font-weight:500;letter-spacing:.02em;border:none;background:transparent;padding:8px 14px;cursor:pointer;color:var(--muted);transition:all .2s ease}.switch-btn.active{background:var(--accent);color:var(--ivory)}.switch-btn:hover:not(.active){background:var(--ivory-hover);color:var(--black)}.logout-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--black);color:var(--ivory);border:1px solid var(--black);border-radius:var(--radius);font-family:Manrope,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:var(--black-soft);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{background:#fff;border-right:1px solid var(--stroke);display:flex;flex-direction:column;min-width:240px;max-width:400px}.resizer{width:8px;cursor:col-resize;background:transparent;position:relative;flex-shrink:0}.resizer:before{content:"";position:absolute;top:0;bottom:0;left:3px;width:2px;background:transparent;transition:background .2s ease}.resizer:hover:before,.resizer.dragging:before{background:var(--accent);opacity:.3}.main-content{flex:1;overflow:hidden;background:var(--ivory);position:relative}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:420px;padding:32px 40px;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal h2{font-family:Playfair Display,serif;font-size:22px;font-weight:500;color:var(--black);margin-bottom:24px;letter-spacing:-.02em}.modal input[type=text]{width:100%;padding:12px 16px;font-family:Manrope,sans-serif;font-size:14px;border:1px solid var(--stroke);border-radius:var(--radius);background:var(--ivory);color:var(--black);outline:none;transition:all .2s ease;margin-bottom:24px}.modal input[type=text]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1b43321a;background:#fff}.modal input[type=text]::placeholder{color:var(--muted);opacity:.6}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.error-toast{position:fixed;top:80px;right:24px;z-index:2000;background:var(--accent-coral);color:#fff;padding:16px 20px;border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:slideInRight .3s ease;max-width:400px}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.error-content{font-size:14px;line-height:1.5}.error-content strong{font-weight:600}@media(max-width:768px){.app-header{padding:12px 16px;flex-wrap:wrap;gap:12px}.header-actions{order:3;width:100%;justify-content:center}.sidebar{position:fixed;left:0;top:57px;bottom:0;z-index:100;transform:translate(-100%);transition:transform .3s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.modal{width:95%;padding:24px 20px}}
