:root{--text:#5c4f3a;--text-h:#2c1f0e;--text-muted:#9a8b78;--bg-warm:#f7f3ec;--sidebar-bg:#faf7f2;--card-bg:#fffcf7;--card-hover:#b4824614;--card-active:#b4824624;--border:#e0d5c5;--accent:#b8860b;--accent-bg:#b8860b26;--accent-border:#b8860b73;--line-color:#c4a97a;--shadow-sm:0 2px 8px #2c1f0e14;--shadow-md:0 6px 20px #2c1f0e1f;--font-serif:"Georgia", "Noto Serif TC", "Songti TC", serif;--font-sans:system-ui, "Segoe UI", "Microsoft JhengHei", sans-serif;font-family:var(--font-sans);color:var(--text);background:var(--bg-warm);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}*,:before,:after{box-sizing:border-box}body{margin:0}#root{width:100%;min-height:100vh}button{font-family:inherit}img{max-width:100%}.login-page{background:linear-gradient(135deg,#f7f3ec 0%,#ede4d4 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--card-bg);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow-md);border-radius:16px;padding:40px 36px}.login-header{text-align:center;margin-bottom:32px}.login-logo{margin-bottom:12px;font-size:48px;display:block}.login-header h1{font-family:var(--font-serif);color:var(--text-h);letter-spacing:.05em;margin:0 0 8px;font-size:28px}.login-header p{color:var(--text-muted);margin:0;font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.login-form label{color:var(--text);flex-direction:column;gap:6px;font-size:14px;display:flex}.login-form input{border:1px solid var(--border);color:var(--text-h);background:#fff;border-radius:8px;padding:10px 14px;font-size:15px;transition:border-color .2s}.login-form input:focus{border-color:var(--accent);outline:none}.login-error{color:#c0392b;text-align:center;margin:0;font-size:14px}.login-form button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:4px;padding:12px;font-size:16px;font-weight:500;transition:opacity .2s}.login-form button:hover:not(:disabled){opacity:.9}.login-form button:disabled{opacity:.6;cursor:not-allowed}.auth-loading{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.app{background:var(--bg-warm);height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;padding:24px 16px;display:flex;overflow-y:auto}.sidebar-header{align-items:center;gap:10px;margin-bottom:28px;display:flex}.sidebar-logo{font-size:28px}.sidebar-header h1{font-family:var(--font-serif);color:var(--text-h);letter-spacing:.05em;margin:0;font-size:22px;font-weight:600}.sidebar-label{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:0 0 12px 4px;font-size:12px}.family-list{flex-direction:column;gap:8px;display:flex}.family-card{cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;width:100%;padding:10px 12px;transition:background .2s,border-color .2s,box-shadow .2s;display:flex}.family-card:hover{background:var(--card-hover)}.family-card.active{background:var(--card-active);border-color:var(--accent-border);box-shadow:var(--shadow-sm)}.family-card-thumb{object-fit:cover;border-radius:10px;flex-shrink:0;width:48px;height:48px}.family-card-name{color:var(--text-h);font-size:15px;font-weight:500}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:auto;padding-top:20px;display:flex}.sidebar-user{color:var(--text-muted);padding:0 4px;font-size:13px}.logout-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:8px;padding:8px 12px;font-size:14px;transition:background .2s}.logout-btn:hover{background:var(--card-hover)}.main{flex-direction:column;flex:1;display:flex;overflow-y:auto}.family-hero{flex-shrink:0;height:200px;position:relative;overflow:hidden}.family-cover{object-fit:cover;width:100%;height:100%;display:block}.family-hero-overlay{text-align:left;background:linear-gradient(#0000 0%,#1e140a33 40%,#1e140abf 100%);flex-direction:column;justify-content:flex-end;padding:24px 32px;display:flex;position:absolute;inset:0}.family-hero-overlay h2{font-family:var(--font-serif);color:#fff;text-shadow:0 2px 8px #0006;margin:0 0 4px;font-size:32px}.family-hero-overlay p{color:#fffc;letter-spacing:.15em;margin:0;font-size:14px}.tree-section{flex:1;padding:32px 24px 48px}.section-title{font-family:var(--font-serif);color:var(--text-muted);text-align:center;letter-spacing:.2em;margin:0 0 32px;font-size:18px}.tree-wrapper{min-height:300px;position:relative}.tree-svg{pointer-events:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.tree-line{fill:none;stroke:var(--line-color);stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.tree-levels{z-index:1;flex-direction:column;gap:56px;display:flex;position:relative}.tree-level{flex-wrap:wrap;justify-content:center;gap:32px 48px;display:flex}.person-node{border:2px solid var(--border);background:var(--card-bg);cursor:pointer;min-width:90px;box-shadow:var(--shadow-sm);border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.person-node:hover{box-shadow:var(--shadow-md);border-color:var(--accent-border);transform:translateY(-3px)}.person-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg), var(--shadow-md)}.person-avatar-wrap{border:3px solid var(--border);border-radius:50%;width:72px;height:72px;transition:border-color .2s;overflow:hidden}.person-node.selected .person-avatar-wrap{border-color:var(--accent)}.person-avatar{object-fit:cover;width:100%;height:100%;display:block}.person-name{color:var(--text-h);font-size:14px;font-weight:600}.detail-panel{border-left:1px solid var(--border);background:var(--card-bg);flex-shrink:0;width:320px;padding:28px 24px;overflow-y:auto}.person-detail.empty{text-align:center;height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.empty-icon{margin-bottom:8px;font-size:36px}.person-detail.empty p{color:var(--text-h);margin:0;font-size:16px;font-weight:500}.person-detail.empty span{font-size:13px}.detail-header{text-align:center;margin-bottom:24px}.detail-avatar{object-fit:cover;border:4px solid var(--accent-border);border-radius:50%;width:100px;height:100px;margin-bottom:12px}.detail-header h2{font-family:var(--font-serif);color:var(--text-h);margin:0;font-size:24px}.detail-story,.detail-gallery{margin-bottom:24px}.detail-story h3,.detail-gallery h3{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:0 0 10px;font-size:12px}.detail-story p{color:var(--text);margin:0;font-size:15px;line-height:1.7}.gallery-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.gallery-item{aspect-ratio:4/3;border-radius:10px;transition:transform .2s,box-shadow .2s;display:block;overflow:hidden}.gallery-item:hover{box-shadow:var(--shadow-md);transform:scale(1.03)}.gallery-item img{object-fit:cover;width:100%;height:100%;display:block}@media (width<=900px){.app{flex-direction:column;height:auto;overflow:auto}.sidebar{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap;align-items:center;width:100%;padding:16px}.sidebar-header{margin-bottom:0;margin-right:auto}.sidebar-label{display:none}.family-list{flex-flow:wrap}.detail-panel{border-left:none;border-top:1px solid var(--border);width:100%}}.ai-chat-widget{z-index:1000;font-family:var(--font-sans);position:fixed;bottom:24px;right:24px}.ai-chat-fab{background:var(--accent);color:#fff;cursor:pointer;width:56px;height:56px;box-shadow:var(--shadow-md);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;transition:transform .2s,box-shadow .2s;display:flex}.ai-chat-fab:hover{transform:scale(1.05);box-shadow:0 8px 24px #b8860b59}.ai-chat-panel{background:var(--card-bg);border:1px solid var(--border);width:380px;max-height:520px;box-shadow:var(--shadow-md);border-radius:16px;flex-direction:column;display:flex;position:absolute;bottom:68px;right:0;overflow:hidden}.ai-chat-header{border-bottom:1px solid var(--border);background:var(--sidebar-bg);justify-content:space-between;align-items:flex-start;padding:16px 18px 12px;display:flex}.ai-chat-header h3{font-family:var(--font-serif);color:var(--text-h);margin:0;font-size:18px}.ai-chat-header p{color:var(--text-muted);margin:2px 0 0;font-size:12px}.ai-chat-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px;line-height:1}.ai-chat-tabs{border-bottom:1px solid var(--border);display:flex}.ai-chat-tabs button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px;font-size:14px;transition:color .2s,border-color .2s}.ai-chat-tabs button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.ai-chat-messages{flex-direction:column;flex:1;gap:10px;min-height:280px;max-height:340px;padding:14px;display:flex;overflow-y:auto}.ai-msg{border-radius:12px;max-width:88%;padding:10px 14px;font-size:14px;line-height:1.5}.ai-msg p{white-space:pre-wrap;margin:0}.ai-msg--user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.ai-msg--assistant{background:var(--bg-warm);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start}.ai-msg-sources{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.ai-msg-sources span{background:var(--accent-bg);color:var(--accent);border-radius:4px;padding:2px 6px;font-size:11px}.ai-typing{color:var(--text-muted);font-style:italic}.ai-chat-input{border-top:1px solid var(--border);gap:8px;padding:12px 14px;display:flex}.ai-chat-input input{border:1px solid var(--border);border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.ai-chat-input input:focus{border-color:var(--accent);outline:none}.ai-chat-input button{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:8px 14px;font-size:14px}.ai-chat-input button:disabled{opacity:.5;cursor:not-allowed}.ai-docs-panel{flex:1;min-height:360px;padding:14px;overflow-y:auto}.ai-upload-area{text-align:center;border:2px dashed var(--border);border-radius:12px;margin-bottom:14px;padding:16px}.ai-upload-btn{background:var(--accent);color:#fff;cursor:pointer;border-radius:8px;padding:8px 20px;font-size:14px;display:inline-block}.ai-upload-hint{color:var(--text-muted);margin:8px 0 0;font-size:12px}.ai-upload-error{color:#c0392b;margin:8px 0 0;font-size:13px}.ai-doc-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.ai-doc-item{background:var(--bg-warm);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.ai-doc-item strong{color:var(--text-h);word-break:break-all;font-size:14px;display:block}.ai-doc-item span{color:var(--text-muted);font-size:12px}.ai-doc-item button{color:#c0392b;cursor:pointer;background:0 0;border:1px solid #c0392b;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:12px}.ai-doc-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:14px}
