:root{--bg: #ffffff;--surface: #ffffff;--surface-muted: #fef6f0;--text: #1a1a1a;--text-muted: #6b6b6b;--primary: #E8751A;--primary-soft: #fde8d4;--accent: #E8751A;--success: #2f7a4f;--border: rgba(232, 117, 26, .16);--shadow: 0 8px 24px rgba(232, 117, 26, .08);--radius: 14px;--radius-lg: 18px;--control-hit: 44px;--focus-ring: 0 0 0 3px rgba(232, 117, 26, .28)}*{box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000026;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#00000040}::-webkit-scrollbar-button{display:none}html,body{margin:0;padding:0;font-family:Work Sans,sans-serif;background:var(--bg);color:var(--text)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}#app{min-height:100dvh}.app-shell{position:relative;min-height:100dvh;max-width:430px;margin:0 auto;background:var(--bg);border-left:1px solid var(--border);border-right:1px solid var(--border)}.app-header{position:sticky;top:0;z-index:15;height:64px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:#f6f8f8e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-group{display:flex;align-items:center;gap:8px;min-width:0}.header-logo{width:32px;height:32px;border-radius:999px;background:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;flex:0 0 auto}.header-title{font-size:20px;font-weight:700;line-height:1;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{border:0;background:transparent;color:var(--primary);width:var(--control-hit);height:var(--control-hit);border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--primary-soft)}.icon-btn:active{background:#194c4d29}.burger-panel{position:fixed;top:64px;bottom:72px;left:50%;transform:translate(-50%);width:100%;max-width:430px;z-index:16;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0 24px}.burger-item{display:flex;align-items:center;gap:16px;width:100%;padding:16px 24px;border:0;background:transparent;font-size:17px;font-family:inherit;color:var(--text);cursor:pointer;text-align:left;border-radius:14px;transition:background .15s;justify-content:center}.burger-item .material-symbols-outlined{font-size:26px;color:var(--text-secondary)}.burger-item:hover,.burger-item:active{background:var(--primary-soft)}.burger-item.active{color:var(--primary);background:var(--primary-soft);font-weight:600}.burger-item.active .material-symbols-outlined{color:var(--primary)}.view{padding:14px}.view--tree-canvas{padding:0;display:flex;flex-direction:column;height:calc(100dvh - 120px);position:relative}:where(.primary-btn,.secondary-btn,.ghost-btn,.icon-btn,.tab-btn,.chip,.segment-btn,.text-link,.person-tag,.fab,.person-node,.person-list-item,.chat-list-item):focus-visible{outline:none;box-shadow:var(--focus-ring)}:where(.primary-btn,.secondary-btn,.ghost-btn,.icon-btn,.tab-btn,.chip,.segment-btn,.text-link,.person-tag,.fab,.person-node,.person-list-item,.chat-list-item):disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.with-tabbar .view{padding-bottom:132px}.with-tabbar .view--tree-canvas{padding-bottom:0}.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:12px}.chip{border:1px solid var(--border);background:var(--surface);color:var(--primary);border-radius:999px;padding:6px 14px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.chip:active{transform:translateY(1px)}.chip-active{background:var(--primary);color:#fff;border-color:transparent}.card{background:var(--surface);border:1px solid rgba(25,76,77,.08);box-shadow:var(--shadow);border-radius:var(--radius)}.memory-list{display:flex;flex-direction:column;gap:12px}.memory-card{overflow:hidden}.memory-card.focused{outline:2px solid var(--accent);outline-offset:2px}.memory-head{display:flex;align-items:center;gap:10px;padding:14px 14px 10px}.avatar{width:38px;height:38px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.avatar-photo{position:relative;overflow:hidden}.avatar-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.avatar-initials{line-height:1}.avatar-photo.has-image:not(.is-broken) .avatar-initials{display:none}.person-hero-avatar{width:90px;height:90px;margin:0 auto;font-size:26px}.profile-avatar{width:94px;height:94px;margin:0 auto;font-size:28px}.meta-title{font-size:14px;font-weight:700;overflow-wrap:anywhere}.meta-subtitle{margin-top:2px;font-size:12px;color:var(--text-muted)}.memory-content{padding:12px 14px 16px}.memory-title{margin:0 0 6px;font-size:17px;font-weight:700;line-height:1.25;overflow-wrap:anywhere}.memory-preview{margin:0 14px 10px;background:linear-gradient(135deg,#dae8e8,#cddede);aspect-ratio:16 / 9;border-radius:10px;overflow:hidden;position:relative}.memory-preview img{width:100%;height:100%;object-fit:cover;display:block}.memory-preview-fallback{width:100%;height:100%;display:grid;place-items:center;font-size:13px;font-weight:700;color:#194c4dc2;letter-spacing:.04em;text-transform:uppercase}.memory-preview.has-image:not(.is-broken) .memory-preview-fallback{display:none}.memory-text{margin:0 0 12px;font-size:14px;color:var(--text-muted);line-height:1.55;overflow-wrap:anywhere}.inline-actions{display:flex;align-items:center;gap:12px;row-gap:6px;flex-wrap:wrap}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.text-link{border:0;background:transparent;color:var(--primary);font-weight:700;font-size:13px;cursor:pointer;min-height:var(--control-hit);display:inline-flex;align-items:center;padding:0 2px}.text-link:active{transform:translateY(1px)}.text-link-danger{color:#9b2f1f}.person-tags{margin-top:8px;margin-bottom:4px;display:flex;flex-wrap:wrap;gap:8px}.person-tag{border:1px solid var(--border);background:var(--surface-muted);color:var(--primary);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:2px;line-height:1;min-height:28px}.person-tag:active{transform:translateY(1px)}.memory-reactions{display:flex;gap:8px;margin-top:12px}.reaction-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:999px;padding:5px 12px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s;min-height:32px}.reaction-btn .material-symbols-outlined{font-size:18px}.reaction-btn:hover{border-color:var(--primary);color:var(--primary)}.reaction-btn.liked{color:#e53935;border-color:#e53935;background:#fff0f0}.reaction-btn.active{color:var(--primary);border-color:var(--primary);background:var(--surface-muted)}.reaction-btn--soon{opacity:.35;cursor:default}.reaction-count{font-size:13px;font-weight:600}.comments-thread{margin-top:12px;border-top:1px solid var(--border);padding-top:12px;display:flex;flex-direction:column;gap:10px}.comment{font-size:13px}.comment-with-avatar{display:flex;gap:8px;align-items:flex-start}.comment-with-avatar .avatar{width:28px;height:28px;font-size:10px;flex-shrink:0;margin-top:1px}.comment-body{flex:1;min-width:0}.comment-head{display:flex;gap:8px;align-items:baseline;margin-bottom:2px}.comment-author{font-size:12px;font-weight:600;color:var(--text)}.comment-date{font-size:11px;color:var(--text-muted)}.comment-text{margin:0;font-size:13px;color:var(--text-muted);line-height:1.45}.comment-actions{display:flex;gap:8px;margin-top:4px}.comments-empty{font-size:13px;color:var(--text-muted)}.comment-form{display:flex;gap:8px;align-items:center;margin-top:4px}.comment-input{flex:1;min-width:0}.comment-submit{flex-shrink:0;width:36px;height:36px;border-radius:999px;border:0;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.comment-submit:active{transform:scale(.95)}.comment-submit .material-symbols-outlined{font-size:18px}.search-overlay{position:fixed;inset:0;z-index:1000;background:var(--bg-primary, #fff);display:flex;flex-direction:column;overflow:hidden}.search-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.search-input-wrap{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:10px;font-size:20px;color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:10px 12px 10px 38px;border:1px solid var(--border);border-radius:10px;font-size:15px;background:var(--surface-muted);color:var(--text-primary);outline:none}.search-input:focus{border-color:var(--primary)}.search-close-btn{flex-shrink:0;font-size:14px}.search-results{flex:1;overflow-y:auto;padding:12px 16px}.search-hint{color:var(--text-muted);font-size:14px;text-align:center;margin-top:32px}.search-section{margin-bottom:20px}.search-section-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.search-result-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 0;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left}.search-result-item:last-child{border-bottom:none}.search-result-icon{font-size:20px;color:var(--text-muted);flex-shrink:0}.search-result-body{flex:1;min-width:0}.search-result-title{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-sub{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state{border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:18px;text-align:center}.empty-title{margin:0;font-size:20px}.empty-text{margin:8px 0 14px;color:var(--text-muted)}.primary-btn{border:0;border-radius:12px;background:var(--primary);color:#fff;padding:11px 16px;min-height:var(--control-hit);font-weight:700;cursor:pointer}.primary-btn:active{transform:translateY(1px)}.ghost-btn{border:1px solid var(--border);border-radius:12px;background:transparent;color:var(--primary);padding:10px 14px;min-height:var(--control-hit);font-weight:600;cursor:pointer}.ghost-btn:active{transform:translateY(1px)}.secondary-btn{border:0;border-radius:12px;background:var(--surface-muted);color:var(--primary);padding:11px 14px;min-height:var(--control-hit);font-weight:700;cursor:pointer}.secondary-btn:active{transform:translateY(1px)}.tabbar{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:min(100%,430px);background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border);z-index:14;padding:8px 10px 16px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}.tabbar--with-fab{grid-template-columns:1fr auto 1fr;align-items:end}.tab-fab{width:56px;height:56px;border-radius:999px;border:0;background:var(--primary);color:#fff;box-shadow:0 4px 16px #e8751a59;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:-16px 8px 0;position:relative;z-index:1}.tab-fab:active{transform:scale(.95)}.tab-fab .material-symbols-outlined{font-size:30px}.tab-btn{border:0;background:transparent;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:var(--control-hit);gap:2px;font-size:10px;font-weight:600;cursor:pointer}.tab-btn:active{transform:translateY(1px)}.tab-btn .material-symbols-outlined{font-size:22px}.tab-btn.active{color:var(--primary);font-weight:700}.fab{position:fixed;right:max(calc((100vw - 430px)/2 + 16px),16px);bottom:92px;width:56px;height:56px;border-radius:999px;border:0;background:var(--primary);color:#fff;box-shadow:0 12px 20px #103c3d40;cursor:pointer;z-index:16}.fab:active{transform:scale(.97)}.fab .material-symbols-outlined{font-size:30px}.segment{display:inline-flex;background:var(--surface-muted);border-radius:999px;padding:3px;margin-bottom:12px}.segment-btn{border:0;background:transparent;color:var(--primary);font-weight:600;font-size:13px;border-radius:999px;min-height:34px;padding:6px 14px;cursor:pointer}.segment-btn:active{transform:translateY(1px)}.segment-btn.active{background:#fff;box-shadow:0 2px 8px #1134341f}.tree-rows{display:flex;flex-direction:column;gap:56px;position:relative;padding:32px 40px 48px;width:max-content;min-width:100%}.tree-lines-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:0}.tree-canvas-wrap{overflow:hidden;position:relative;flex:1;touch-action:none;cursor:grab;user-select:none;-webkit-user-select:none}.tree-canvas-wrap.is-dragging{cursor:grabbing}.tree-canvas-inner{transform-origin:0 0;will-change:transform;display:inline-block}.tree-zoom-controls{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:row;gap:4px;z-index:15;background:#ffffffe0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:14px;padding:4px;box-shadow:var(--shadow)}.tree-zoom-btn{width:40px;height:40px;border:0;background:transparent;border-radius:10px;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text)}.tree-zoom-btn:hover{background:var(--surface-muted)}.tree-zoom-btn:active{background:var(--primary-soft);transform:scale(.95)}.view--tree-canvas .segment{flex-shrink:0;align-self:flex-start;margin:10px 14px 8px;padding:3px}.view--tree-canvas .person-list{padding:14px;overflow-y:auto;flex:1}.tree-row{display:flex;justify-content:center;gap:32px;position:relative;z-index:1}.person-node-wrap{position:relative;display:inline-flex}.person-node{border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:10px;width:118px;min-height:var(--control-hit);text-align:center;box-shadow:var(--shadow);cursor:pointer}.person-node:active{transform:translateY(1px)}.person-node.self{border-width:2px;border-color:var(--primary)}.person-node-edit{position:absolute;right:-12px;top:-12px;width:var(--control-hit);height:var(--control-hit);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow)}.person-node-delete{position:absolute;left:-12px;top:-12px;width:var(--control-hit);height:var(--control-hit);border:1px solid rgba(155,47,31,.24);background:#fff;color:#9b2f1f;box-shadow:var(--shadow)}.person-node-edit .material-symbols-outlined,.person-node-delete .material-symbols-outlined{font-size:18px}.node-name{margin-top:7px;font-size:13px;font-weight:700;overflow-wrap:anywhere}.node-role{margin-top:2px;font-size:11px;color:var(--text-muted);overflow-wrap:anywhere}.person-list{display:flex;flex-direction:column;gap:10px}.person-list-row{display:flex;align-items:center;gap:8px}.person-list-item{flex:1;display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:12px;background:var(--surface);min-height:var(--control-hit);padding:10px;cursor:pointer;text-align:left}.person-list-item:active{transform:translateY(1px)}.person-list-edit{width:var(--control-hit);height:var(--control-hit);border:1px solid var(--border);background:#fff}.person-list-delete{width:var(--control-hit);height:var(--control-hit);border:1px solid rgba(155,47,31,.24);background:#fff;color:#9b2f1f}.person-list-meta{font-size:12px;color:var(--text-muted);overflow-wrap:anywhere}.tree-row-fallback{margin-top:2px}.tree-fallback-note{margin:10px 0 0;font-size:12px;color:var(--text-muted)}.linked-memory-layout{display:flex;align-items:flex-start;gap:10px}.linked-memory-preview{width:104px;aspect-ratio:4 / 3;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#dae8e8,#cddede);flex:0 0 auto;position:relative}.linked-memory-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.linked-memory-preview .memory-preview-fallback{font-size:11px}.linked-memory-preview.has-image:not(.is-broken) .memory-preview-fallback{display:none}.linked-memory-meta{min-width:0;flex:1}.linked-memory-meta h4{overflow-wrap:anywhere}.person-details{display:flex;flex-direction:column;gap:14px}.person-hero{text-align:center;padding:6px 0 0}.person-name{font-size:26px;font-weight:700;margin:10px 0 6px;overflow-wrap:anywhere}.person-subline{margin:2px 0;color:var(--text-muted);overflow-wrap:anywhere}.bio-box{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:14px;color:var(--text-muted);line-height:1.5;overflow-wrap:anywhere}.section-title{margin:0 0 8px;font-size:18px;color:var(--primary)}.journal-group{margin-bottom:16px}.journal-new-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 14px 16px;margin-bottom:16px;box-shadow:var(--shadow)}.journal-new-title{margin:0 0 12px;font-size:17px;font-weight:700;color:var(--text)}.journal-type-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.journal-type-btn{border:1px solid var(--border);background:var(--surface-muted);border-radius:12px;padding:10px 4px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:background .15s,border-color .15s}.journal-type-btn:hover{background:var(--primary-soft);border-color:#194c4d40}.journal-type-btn:active{transform:translateY(1px)}.journal-type-icon{width:40px;height:40px;border-radius:10px;background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--primary);box-shadow:0 2px 6px #122c2d14}.journal-type-icon .material-symbols-outlined{font-size:20px}.journal-type-label{font-size:11px;font-weight:600;color:var(--text-muted)}.month-title{margin:0 0 8px;color:var(--primary);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.journal-list{display:flex;flex-direction:column;gap:10px}.journal-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:12px}.journal-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.journal-date{margin:0;font-size:18px;font-weight:700}.journal-time{margin:2px 0 0;font-size:12px;color:var(--text-muted)}.mood-badge{border-radius:999px;font-size:11px;font-weight:700;line-height:1;padding:4px 8px;color:#fff}.mood-happy{background:#3b8a58}.mood-reflective{background:#3f6a99}.mood-milestone{background:#a16b2d}.mood-calm{background:#5b6b73}.journal-text{margin:10px 0 0;color:var(--text-muted);line-height:1.5;overflow-wrap:anywhere}.journal-preview{margin-top:10px;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,#dce8ee,#cadde6);aspect-ratio:16 / 9;position:relative}.journal-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.journal-preview.has-image:not(.is-broken) .memory-preview-fallback{display:none}.profile-head{text-align:center;padding:8px 4px}.profile-name{margin:12px 0 4px;font-size:26px;font-weight:700;overflow-wrap:anywhere}.profile-subtitle{color:var(--primary);font-weight:600}.stats{margin-top:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-card{border:1px solid var(--border);border-radius:12px;background:var(--surface);text-align:center;padding:10px}.stat-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.stat-value{margin-top:4px;font-size:24px;font-weight:700;color:var(--primary)}.export-box{margin-top:16px;border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:16px;text-align:center}.export-box p{margin:0}.export-box .small{margin-top:6px;font-size:13px;color:var(--text-muted)}.chat-list{display:flex;flex-direction:column;gap:10px}.chat-list-intro{padding:12px 14px;background:linear-gradient(135deg,#f4f8f8,#edf3f3)}.chat-list-intro-title{margin:0;color:var(--primary);font-size:17px}.chat-list-intro-text{margin:6px 0 0;font-size:13px;color:var(--text-muted);line-height:1.35}.chat-list-item{width:100%;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);min-height:80px;padding:12px;display:flex;align-items:flex-start;gap:10px;text-align:left;cursor:pointer}.chat-list-item:hover{border-color:#194c4d4d}.chat-list-item:active{transform:translateY(1px)}.chat-avatar{width:var(--control-hit);height:var(--control-hit);border-radius:999px;background:linear-gradient(145deg,#dceceb,#cfe1e1);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex:0 0 auto}.chat-main{min-width:0;flex:1;display:grid;gap:4px}.chat-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.chat-title{font-size:15px;line-height:1.2;color:var(--primary);overflow-wrap:anywhere}.chat-time{margin-top:1px;font-size:11px;color:var(--text-muted);white-space:nowrap}.chat-subtitle,.chat-preview{margin:0;font-size:12px;color:var(--text-muted);line-height:1.35;overflow-wrap:anywhere}.chat-preview{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.chat-preview-sender{color:var(--primary);font-weight:700}.chat-unread{min-width:22px;height:22px;border-radius:999px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;font-size:11px;font-weight:700;flex:0 0 auto;margin-top:1px}.chat-room{display:grid;gap:10px}.chat-room-head{padding:12px;display:grid;gap:10px}.chat-back-btn{justify-self:flex-start;display:inline-flex;align-items:center;gap:6px;padding:8px 10px}.chat-back-btn .material-symbols-outlined{font-size:18px}.chat-room-meta{min-width:0}.chat-room-title{margin:0;font-size:20px;color:var(--primary);line-height:1.2;overflow-wrap:anywhere}.chat-room-subtitle{margin:6px 0 0;font-size:12px;color:var(--text-muted);line-height:1.35;overflow-wrap:anywhere}.chat-room-stats{margin:0;font-size:11px;font-weight:700;color:var(--primary);letter-spacing:.05em;text-transform:uppercase}.chat-thread{padding:8px 10px;background:linear-gradient(180deg,#fbfcfc,#f3f7f7)}.chat-messages{display:flex;flex-direction:column;gap:8px;max-height:45dvh;overflow:auto;padding-right:2px}.chat-message{display:flex;justify-content:flex-start}.chat-message.mine{justify-content:flex-end}.chat-bubble{max-width:min(88%,320px);border:1px solid var(--border);border-radius:12px 12px 12px 6px;padding:8px 10px;background:var(--surface)}.chat-message.mine .chat-bubble{background:var(--primary-soft);border-color:#194c4d33;border-radius:12px 12px 6px}.chat-sender{margin:0 0 4px;font-size:11px;font-weight:700;color:var(--primary)}.chat-text{margin:0;font-size:14px;line-height:1.4;color:var(--text);overflow-wrap:anywhere}.chat-meta{margin:6px 0 0;font-size:11px;color:var(--text-muted)}.chat-composer{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:12px;display:grid;gap:8px}.chat-input{resize:vertical;min-height:92px}.chat-composer-actions{display:flex;justify-content:flex-end}.chat-composer-actions .primary-btn{min-width:140px}.modal-backdrop{position:fixed;inset:0;background:#06161673;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:30;display:flex;align-items:flex-end;justify-content:center;animation:backdrop-in .25s ease}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.modal-sheet{width:min(100%,430px);max-height:88dvh;overflow-y:auto;overflow-x:hidden;background:var(--surface);border-radius:18px 18px 0 0;padding:16px;animation:sheet-up .3s cubic-bezier(.32,.72,0,1)}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-sheet--full{max-height:96dvh;height:96dvh;display:flex;flex-direction:column;overflow:hidden}.modal-sheet--full .modal-header-row{padding:16px 16px 0;flex-shrink:0}.modal-body-scroll{flex:1;overflow-y:auto;padding:0 16px 24px}.modal-sheet:not(.modal-sheet--full) .modal-body-scroll{padding:0}.modal-sheet--full>.modal-header-row{padding:16px 16px 0}.modal-sheet--full>.form-grid,.modal-sheet--full>.form-stack,.modal-sheet--full>div:not(.modal-header-row){flex:1;overflow-y:auto;padding:0 16px 24px}.story-create-sheet{position:relative;padding:20px 16px 24px;overflow-y:auto;flex:1}.story-create-close{position:absolute;top:8px;right:8px}.story-create-title{margin:0 0 4px;font-size:22px;font-weight:700;color:var(--primary);padding-right:44px}.modal-title{margin:0;font-size:22px;color:var(--primary)}.modal-subtitle{margin:4px 0 0;font-size:14px;color:var(--text-muted)}.modal-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:14px;flex-shrink:0}.modal-header-text{flex:1;min-width:0}.modal-close-btn{flex-shrink:0;margin-top:-4px}.form-grid{display:grid;gap:10px}.field-label{display:block;margin-bottom:6px;font-size:13px;color:var(--primary);font-weight:700}.field{width:100%;border:1px solid var(--border);border-radius:12px;padding:11px 12px;background:#fff;font-size:14px;font-family:inherit}.field:focus{outline:2px solid rgba(25,76,77,.18);outline-offset:0}.field-invalid{border-color:#b54a35;background:#fff6f3}.form-error-summary{border:1px solid rgba(181,74,53,.35);background:#b54a351a;border-radius:12px;padding:10px 12px;color:#7c2d1f}.form-error-title{margin:0 0 6px;font-size:13px;font-weight:700}.form-error-summary ul{margin:0;padding-left:18px;display:grid;gap:4px;font-size:12px}.field-error-text{margin-top:6px;font-size:12px;color:#8a2f20}.field-hint{margin-top:4px;color:var(--text-muted);font-size:12px}.check-grid{display:grid;gap:7px}.check-row{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;padding:8px 10px}.sheet-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}.top-note{margin-bottom:10px;padding:10px 12px;border-radius:10px;border:1px solid rgba(198,117,77,.28);background:#c6754d1f;color:#7b4f31;font-size:13px}.person-node-branch{position:absolute;left:50%;bottom:-14px;transform:translate(-50%);width:36px;height:36px;border:1px solid var(--border);background:#fff;color:var(--primary);box-shadow:var(--shadow)}.person-node-branch .material-symbols-outlined,.person-list-branch .material-symbols-outlined{font-size:18px}.node-branch-meta{margin-top:4px;font-size:10px;color:var(--text-muted);letter-spacing:.03em;text-transform:uppercase}.person-list-branch{width:var(--control-hit);height:var(--control-hit);border:1px solid var(--border);background:#fff}.person-meta-grid{display:grid;grid-template-columns:1fr;gap:10px}.person-meta-item .section-title{margin-bottom:6px}.person-meta-item .person-subline{margin:2px 0}.field[type=file]{padding:9px 10px}@media(max-width:520px){.app-shell{border-left:0;border-right:0;max-width:none}.tabbar{width:100%}.fab{right:16px}}.app-loading{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);font-size:15px;text-align:center;padding:24px}.app-loading-icon{font-size:40px;color:var(--text-muted)}#offline-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--text-primary);color:var(--bg-primary, #fff);text-align:center;font-size:13px;padding:8px 16px;pointer-events:none}.sync-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%) translateY(20px);z-index:9998;background:#333;color:#fff;font-size:13px;padding:10px 18px;border-radius:10px;max-width:min(90%,360px);text-align:center;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}.sync-toast--visible{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.sync-toast--error{background:#9b2f1f}.sync-toast--success{background:#2f7a4f}.sync-status{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;transition:color .2s}.sync-status .material-symbols-outlined{font-size:18px}.sync-status--ok{color:var(--success)}.sync-status--pending{color:var(--text-muted);animation:sync-spin 1s linear infinite}.sync-status--error{color:#9b2f1f}@keyframes sync-spin{to{transform:rotate(360deg)}}.upload-overlay{position:fixed;inset:0;z-index:9997;background:#00000059;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.upload-overlay--visible{opacity:1;pointer-events:auto}.upload-overlay-content{background:#fff;border-radius:14px;padding:20px 28px;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--text);box-shadow:0 8px 32px #00000026}.upload-spin{font-size:24px;color:var(--primary);animation:sync-spin 1s linear infinite}.auth-shell{min-height:100dvh;max-width:430px;margin:0 auto;padding:48px 20px 32px;display:flex;flex-direction:column;gap:24px;background:var(--bg);border-left:1px solid var(--border);border-right:1px solid var(--border)}.auth-brand{text-align:center;padding:0 8px}.auth-logo{width:64px;height:64px;border-radius:18px;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}.auth-logo .material-symbols-outlined{font-size:34px}.auth-title{margin:0 0 6px;font-size:28px;font-weight:700;color:var(--primary)}.auth-subtitle{margin:0;font-size:14px;color:var(--text-muted);line-height:1.4}.auth-card{padding:20px;display:flex;flex-direction:column;gap:14px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--surface-muted);border-radius:12px;padding:3px;gap:3px}.auth-tab{border:0;background:transparent;color:var(--text-muted);font-weight:600;font-size:14px;border-radius:10px;min-height:var(--control-hit);cursor:pointer;transition:background .15s,color .15s}.auth-tab.active{background:var(--surface);color:var(--primary);box-shadow:0 2px 8px #1134341a}.auth-tab:focus-visible{outline:none;box-shadow:var(--focus-ring)}.auth-error{border:1px solid rgba(181,74,53,.35);background:#b54a3514;border-radius:10px;padding:10px 12px;font-size:13px;color:#7c2d1f;line-height:1.4}.auth-success{border:1px solid rgba(34,139,34,.35);background:#228b2214;border-radius:10px;padding:10px 12px;font-size:13px;color:#1a5c1a;line-height:1.4}.auth-submit{width:100%;font-size:15px}.auth-forgot-btn{background:none;border:none;padding:0;color:var(--text-muted);font-size:13px;cursor:pointer;text-align:center;width:100%;margin-top:2px}.auth-forgot-btn:hover{color:var(--text-primary)}.auth-divider{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-magic-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px}.auth-magic-btn .material-symbols-outlined{font-size:18px}.auth-legal{margin:0;text-align:center;font-size:12px;color:var(--text-muted);line-height:1.4}.auth-back-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;padding:8px 10px;font-size:13px}.auth-back-btn .material-symbols-outlined{font-size:18px}.onboarding-options{display:flex;flex-direction:column;gap:10px}.onboarding-option{width:100%;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:16px;display:flex;align-items:center;gap:14px;text-align:left;cursor:pointer}.onboarding-option:hover{border-color:#194c4d4d}.onboarding-option:active{transform:translateY(1px)}.onboarding-option:focus-visible{outline:none;box-shadow:var(--focus-ring)}.onboarding-icon{font-size:28px;color:var(--primary);flex:0 0 auto}.onboarding-option-title{font-size:15px;font-weight:700;color:var(--text)}.onboarding-option-text{margin-top:2px;font-size:13px;color:var(--text-muted)}.onboarding-chevron{margin-left:auto;color:var(--text-muted);flex:0 0 auto}@media(max-width:520px){.auth-shell{border-left:0;border-right:0}}.stories-shell{min-height:100dvh;max-width:430px;margin:0 auto;display:flex;flex-direction:column;background:var(--bg);border-left:1px solid var(--border);border-right:1px solid var(--border);position:relative;overflow:hidden}.stories-skip{position:absolute;top:16px;right:16px;z-index:2;border:0;background:transparent;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;padding:8px 4px;min-height:var(--control-hit)}.stories-skip:hover{color:var(--text)}.stories-image-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:56px 24px 24px;min-height:0}.stories-image{width:100%;max-width:320px;max-height:55dvh;object-fit:contain;display:block;border-radius:var(--radius-lg)}.stories-body{padding:20px 24px 40px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.stories-title{margin:0;font-size:26px;font-weight:700;color:var(--text);line-height:1.2}.stories-subtitle{margin:0;font-size:14px;color:var(--text-muted);line-height:1.45}.stories-dots{display:flex;gap:6px;margin:6px 0 4px}.story-dot{width:8px;height:8px;border-radius:999px;background:var(--border);transition:width .2s,background .2s}.story-dot.active{width:24px;background:var(--accent)}.stories-next-btn{width:100%;max-width:360px;font-size:16px;padding:14px 16px;background:var(--accent);margin-top:4px}.stories-next-btn:hover{opacity:.92}@media(max-width:520px){.stories-shell{border-left:0;border-right:0;max-width:none}}.auth-demo-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;border-color:var(--accent);color:var(--accent)}.auth-demo-btn .material-symbols-outlined{font-size:18px}.profile-signout-btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#9b2f1f;border-color:#9b2f1f4d}.profile-signout-btn .material-symbols-outlined{font-size:18px}.profile-edit-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;margin-top:8px}.profile-edit-btn .material-symbols-outlined{font-size:16px}.profile-actions{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:16px}.profile-actions .ghost-btn{display:inline-flex;align-items:center;gap:8px;font-size:14px}.profile-actions .ghost-btn .material-symbols-outlined{font-size:18px}.auth-demo-row{display:flex;align-items:stretch;gap:8px;width:100%}.auth-demo-row .auth-demo-btn{flex:1 1 0;min-width:0}.auth-install-row{width:100%;margin-top:4px}.auth-install-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--primary);border-color:var(--primary)}.auth-install-btn .material-symbols-outlined{font-size:18px}.ios-install-hint{position:relative;margin-top:8px;background:var(--surface);border:1.5px solid var(--primary);border-radius:14px;padding:14px 36px 14px 14px;width:100%}.ios-install-hint-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:var(--primary);margin-bottom:10px}.ios-install-hint-title .material-symbols-outlined{font-size:18px}.ios-install-steps{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text);line-height:1.4}.ios-share-icon{display:inline-block;background:#007aff;color:#fff;border-radius:5px;padding:1px 5px;font-size:12px;font-style:normal}.ios-install-hint-close{position:absolute;top:10px;right:10px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-secondary);padding:2px 4px;line-height:1}.ios-install-hint-arrow{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid var(--primary);margin:10px auto 0}.auth-stories-btn{flex:0 0 var(--control-hit);width:var(--control-hit);min-width:var(--control-hit);height:var(--control-hit);display:flex;align-items:center;justify-content:center;padding:0}.auth-stories-btn .material-symbols-outlined{font-size:20px}.feed-greeting-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.feed-greeting-hello{font-size:13px;color:var(--text-muted)}.feed-greeting-name{font-size:22px;font-weight:700;color:var(--text);line-height:1.2;margin-top:2px}.feed-greeting-date{font-size:13px;color:var(--text-muted);margin-top:4px}.feed-header-avatar{width:52px;height:52px;flex:0 0 52px;border-radius:999px;font-size:18px;border:2.5px solid var(--primary)}.feed-banner{position:relative;overflow:hidden;padding:20px 16px 16px;margin-bottom:20px;background:linear-gradient(135deg,#194c4d,#2a6e6f 60%,#1a4a3a);border:none}.feed-banner:before{content:"";position:absolute;inset:0;background:url(/memories/onboarding-02.svg) center / cover no-repeat;opacity:.12}.feed-banner-text{position:relative}.feed-banner-title{font-size:24px;font-weight:700;color:#fff;line-height:1.2}.feed-banner-subtitle{font-size:13px;color:#ffffffb3;margin-top:4px}.feed-banner-stats{position:relative;display:flex;align-items:center;gap:0;margin-top:16px;background:#0003;border-radius:10px;padding:10px 4px}.feed-banner-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.feed-banner-stat-value{font-size:20px;font-weight:700;color:#fff;line-height:1}.feed-banner-stat-label{font-size:11px;color:#fff9;text-transform:lowercase}.feed-banner-stat-divider{width:1px;height:28px;background:#fff3}.feed-sections-title,.feed-memories-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:12px}.feed-memories-title{margin-top:4px}.feed-sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.feed-section-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:14px 12px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;cursor:pointer;text-align:left;box-shadow:var(--shadow)}.feed-section-card:active{transform:translateY(1px)}.feed-section-card:focus-visible{outline:none;box-shadow:var(--focus-ring)}.feed-section-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.feed-section-icon .material-symbols-outlined{font-size:22px}.feed-section-label{font-size:14px;font-weight:700;color:var(--text);line-height:1.2}.feed-section-sub{font-size:12px;color:var(--text-muted)}.voice-recorder{padding:8px 0 4px}.voice-idle,.voice-recording,.voice-recorded,.voice-loading,.voice-transcribed{display:flex;flex-direction:column;align-items:center;gap:12px}.voice-record-btn{width:72px;height:72px;border-radius:999px;border:0;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px #194c4d4d;transition:transform .15s,box-shadow .15s}.voice-record-btn:active{transform:scale(.95)}.voice-record-btn .material-symbols-outlined{font-size:32px}.voice-record-btn--active{background:#c0392b;box-shadow:0 8px 20px #c0392b59}.voice-pulse-ring{position:absolute;width:72px;height:72px;border-radius:999px;border:3px solid rgba(192,57,43,.4);animation:voice-pulse 1.4s ease-out infinite;pointer-events:none}.voice-recording{position:relative}@keyframes voice-pulse{0%{transform:scale(1);opacity:1}to{transform:scale(1.9);opacity:0}}.voice-timer{font-size:28px;font-weight:700;color:var(--primary);margin:0;font-variant-numeric:tabular-nums}.voice-hint{margin:0;font-size:13px;color:var(--text-muted);text-align:center}.voice-recorded-info{display:flex;align-items:center;gap:8px}.voice-done-icon{font-size:22px;color:var(--success)}.voice-recorded-label{margin:0;font-size:14px;font-weight:600;color:var(--text)}.voice-actions-row{display:flex;gap:8px;width:100%}.voice-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px}.voice-action-btn .material-symbols-outlined{font-size:18px}.voice-spinner{width:36px;height:36px;border:3px solid var(--primary-soft);border-top-color:var(--primary);border-radius:999px;animation:voice-spin .8s linear infinite}.voice-spinner--sm{width:18px;height:18px;border-width:2px}@keyframes voice-spin{to{transform:rotate(360deg)}}.voice-ai-loading{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);align-self:flex-start}.voice-section-label{margin:0;font-size:13px;font-weight:700;color:var(--primary);align-self:flex-start}.voice-text-area{width:100%;resize:vertical}.voice-tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;width:100%}.voice-tool-btn{border:1px solid var(--border);background:var(--surface-muted);border-radius:10px;padding:8px 4px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;font-size:11px;font-weight:600;color:var(--primary);transition:background .15s}.voice-tool-btn:hover{background:var(--primary-soft)}.voice-tool-btn:active{transform:translateY(1px)}.voice-tool-btn .material-symbols-outlined{font-size:20px}.voice-confirm-row{display:flex;gap:8px;width:100%;justify-content:flex-end;margin-top:4px}.voice-confirm-row .ghost-btn{display:flex;align-items:center;gap:6px;font-size:13px}.voice-confirm-row .ghost-btn .material-symbols-outlined{font-size:18px}.voice-ai-error{margin:0;font-size:12px;color:#8a2f20;background:#b54a3514;border:1px solid rgba(181,74,53,.25);border-radius:8px;padding:8px 10px;width:100%;text-align:left}.voice-error-box{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 0}.voice-error-icon{font-size:36px;color:#9b2f1f}.voice-error-text{margin:0;font-size:13px;color:#7c2d1f;text-align:center;line-height:1.4}.voice-transcribed{align-items:stretch}.voice-target-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.voice-target-btn{border:1px solid var(--border);background:var(--surface-muted);border-radius:10px;padding:10px 8px;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-muted);transition:background .15s,border-color .15s,color .15s}.voice-target-btn .material-symbols-outlined{font-size:18px}.voice-target-btn:active{transform:translateY(1px)}.voice-target-btn--active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.relations-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.relation-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border-radius:10px}.relation-type{font-size:12px;color:var(--text-secondary);min-width:120px}.spouse-pair{display:flex;align-items:flex-start;gap:4px}.spouse-connector{font-size:14px;color:var(--primary);align-self:center;padding:0 2px;line-height:1}.node-member-badge{font-size:8px;color:var(--primary);vertical-align:super}:root,[data-theme=heritage]{--bg: #ffffff;--surface: #ffffff;--surface-muted: #fef6f0;--text: #1a1a1a;--text-muted: #6b6b6b;--primary: #E8751A;--primary-soft: #fde8d4;--accent: #E8751A;--success: #2f7a4f;--border: rgba(232, 117, 26, .16);--shadow: 0 8px 24px rgba(232, 117, 26, .08);--radius: 14px;--radius-lg: 18px;--control-hit: 44px;--focus-ring: 0 0 0 3px rgba(232, 117, 26, .28)}[data-theme=legacy]{--bg: #f6f8f8;--surface: #ffffff;--surface-muted: #eef3f3;--text: #172121;--text-muted: #4f6161;--primary: #194c4d;--primary-soft: #d9e9e9;--accent: #c6754d;--success: #2f7a4f;--border: rgba(25, 76, 77, .16);--shadow: 0 8px 24px rgba(18, 44, 45, .08)}[data-theme=warm]{--bg: #faf7f2;--surface: #fffcf8;--surface-muted: #f2ece3;--text: #1e1510;--text-muted: #6b5344;--primary: #2d4a3e;--primary-soft: #d8e8e0;--accent: #d4714a;--success: #3a7a50;--border: rgba(45, 74, 62, .15);--shadow: 0 8px 24px rgba(30, 21, 16, .08)}[data-theme=slate]{--bg: #f4f6f9;--surface: #ffffff;--surface-muted: #eaeff5;--text: #0f1e30;--text-muted: #4a6080;--primary: #1e3a5f;--primary-soft: #d0dff0;--accent: #e8a020;--success: #2a7a50;--border: rgba(30, 58, 95, .14);--shadow: 0 8px 24px rgba(15, 30, 48, .08)}[data-theme=forest]{--bg: #0f1f1a;--surface: #1a2e28;--surface-muted: #243d35;--text: #e8f5f0;--text-muted: #7aab96;--primary: #4ade80;--primary-soft: #1a3d2a;--accent: #fbbf24;--success: #4ade80;--border: rgba(74, 222, 128, .15);--shadow: 0 8px 24px rgba(0, 0, 0, .3)}[data-theme=rose]{--bg: #fdf8f6;--surface: #ffffff;--surface-muted: #f5ece8;--text: #1e1010;--text-muted: #6b4040;--primary: #3d2c2c;--primary-soft: #f0ddd8;--accent: #c4706a;--success: #3a7a50;--border: rgba(61, 44, 44, .14);--shadow: 0 8px 24px rgba(30, 16, 16, .08)}.theme-section{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:14px}.theme-section-title{margin:0 0 12px;font-size:13px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em}.theme-swatches{display:flex;gap:10px;flex-wrap:wrap}.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:6px;border:none;background:none;cursor:pointer;padding:4px;border-radius:10px;transition:transform .15s}.theme-swatch:active{transform:scale(.95)}.theme-swatch-circle{width:44px;height:44px;border-radius:999px;border:3px solid transparent;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001f;transition:border-color .15s}.theme-swatch-circle:before{content:"";position:absolute;inset:0 50% 0 0}.theme-swatch-circle:after{content:"";position:absolute;inset:0 0 0 50%}.theme-swatch[data-theme-id=heritage] .theme-swatch-circle:before{background:#fff}.theme-swatch[data-theme-id=heritage] .theme-swatch-circle:after{background:#e8751a}.theme-swatch[data-theme-id=legacy] .theme-swatch-circle:before{background:#f6f8f8}.theme-swatch[data-theme-id=legacy] .theme-swatch-circle:after{background:#194c4d}.theme-swatch[data-theme-id=warm] .theme-swatch-circle:before{background:#faf7f2}.theme-swatch[data-theme-id=warm] .theme-swatch-circle:after{background:#2d4a3e}.theme-swatch[data-theme-id=slate] .theme-swatch-circle:before{background:#f4f6f9}.theme-swatch[data-theme-id=slate] .theme-swatch-circle:after{background:#1e3a5f}.theme-swatch[data-theme-id=forest] .theme-swatch-circle:before{background:#0f1f1a}.theme-swatch[data-theme-id=forest] .theme-swatch-circle:after{background:#4ade80}.theme-swatch[data-theme-id=rose] .theme-swatch-circle:before{background:#fdf8f6}.theme-swatch[data-theme-id=rose] .theme-swatch-circle:after{background:#3d2c2c}.theme-swatch.active .theme-swatch-circle{border-color:var(--accent)}.theme-swatch-label{font-size:11px;font-weight:600;color:var(--text-muted)}.theme-swatch.active .theme-swatch-label{color:var(--text)}.creation-hub{display:flex;flex-direction:column;gap:16px;position:relative;padding:16px 16px 24px;overflow-y:auto;flex:1}.creation-hub-close{position:absolute;top:8px;right:8px;z-index:1}.video-preview-area{border-radius:10px;overflow:hidden;margin-top:4px}.video-message-body{padding:4px 0}.video-message-illustration{text-align:center;padding:8px 0}.video-message-hint{font-size:14px;color:var(--text-muted);text-align:center;margin:0 0 12px;line-height:1.45}.creation-hub-header{text-align:center;padding:8px 0}.creation-hub-icon{width:48px;height:48px;border-radius:999px;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px}.creation-hub-icon .material-symbols-outlined{font-size:26px}.creation-hub-title{margin:0;font-size:22px;font-weight:700;color:var(--text)}.creation-hub-sub{margin:4px 0 0;font-size:14px;color:var(--text-muted)}.creation-hub-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.creation-hub-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;text-align:center;box-shadow:var(--shadow);position:relative}.creation-hub-card:active{transform:translateY(1px)}.creation-hub-card--disabled{opacity:.5;cursor:not-allowed}.creation-hub-card-icon{width:44px;height:44px;border-radius:999px;color:#fff;display:flex;align-items:center;justify-content:center}.creation-hub-card-icon .material-symbols-outlined{font-size:22px}.creation-hub-card-label{font-size:14px;font-weight:700;color:var(--text);line-height:1.2}.creation-hub-card-sub{font-size:12px;color:var(--text-muted);line-height:1.3}.creation-hub-card-badge{position:absolute;top:8px;right:8px;font-size:10px;font-weight:700;color:var(--text-muted);background:var(--surface-muted);border-radius:999px;padding:2px 8px}.stories-row{display:flex;gap:12px;padding:8px 16px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.stories-row::-webkit-scrollbar{display:none}.stories-section{border-bottom:1px solid var(--border);margin-bottom:4px}.stories-item{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;padding:0;min-width:64px}.stories-avatar-wrap{position:relative;width:56px;height:56px}.stories-avatar-wrap .avatar{width:56px;height:56px;font-size:18px}.stories-avatar--has-story{border-radius:50%;padding:2px;background:linear-gradient(135deg,var(--primary),#f5a623)}.stories-avatar--has-story .avatar{width:52px;height:52px;border:2px solid var(--bg)}.stories-add-badge{position:absolute;bottom:0;right:0;width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg)}.stories-item--add-new .stories-add-wrap{width:56px;height:56px;border-radius:50%;border:2px dashed var(--primary);background:var(--primary-soft);display:flex;align-items:center;justify-content:center}.stories-add-icon{font-size:26px;color:var(--primary)}.stories-name{font-size:11px;color:var(--text-muted);max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-section-heading{font-size:22px;font-weight:700;padding:8px 16px 4px;color:var(--text)}.memory-action-bar{display:flex;align-items:center;justify-content:space-between;padding:4px 0 2px;margin-bottom:10px}.memory-action-bar-left,.memory-action-bar-right{display:flex;align-items:center;gap:4px}.memory-action-bar .reaction-btn{padding:6px}.memory-action-bar .reaction-btn .material-symbols-outlined{font-size:22px}.reaction-btn.bookmarked .material-symbols-outlined{color:var(--primary)}.reaction-btn--with-count{gap:6px;padding:5px 10px 5px 8px}.reaction-btn-count{font-size:13px;font-weight:700;line-height:1}.memory-likes-count{font-size:13px;font-weight:600;color:var(--text);padding:0 0 4px}.comments-link{display:block;background:none;border:none;color:var(--text-muted);font-size:13px;padding:6px 0 2px;margin-top:10px;cursor:pointer;text-align:left}.comments-link:hover{color:var(--text)}.memory-hashtags{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0}.hashtag{background:none;border:none;color:var(--primary);font-size:13px;font-weight:500;cursor:pointer;padding:0}.hashtag:hover{text-decoration:underline}.chips--tags{padding:0 16px 8px}.chip-clear{background:var(--primary);color:#fff;font-weight:700;min-width:32px}.stories-viewer{position:fixed;inset:0;z-index:9999;background:#000;display:flex;flex-direction:column}.story-progress{display:flex;gap:3px;padding:8px 8px 0}.story-progress-seg{flex:1;height:3px;border-radius:2px;background:#ffffff4d}.story-progress-seg.done{background:#fff}.story-progress-seg.active{background:linear-gradient(to right,#fff var(--progress, 0%),rgba(255,255,255,.3) var(--progress, 0%))}.story-header{display:flex;align-items:center;justify-content:space-between;padding:12px}.story-author{display:flex;align-items:center;gap:8px}.story-author .avatar{width:36px;height:36px;font-size:13px}.story-author-name{color:#fff;font-size:14px;font-weight:600}.story-author-time{color:#fff9;font-size:12px}.story-close{background:none;border:none;color:#fff;cursor:pointer;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.story-media{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.story-media img{max-width:100%;max-height:100%;object-fit:contain}.story-media-placeholder{width:100%;height:100%;background:#222}.story-caption{color:#fff;font-size:15px;padding:12px 16px;text-align:center}.story-nav{position:absolute;inset:80px 0;display:flex;pointer-events:none}.story-nav-btn{flex:1;background:none;border:none;cursor:pointer;pointer-events:auto}.story-actions{display:flex;gap:12px;padding:8px 16px 24px;justify-content:center}.story-actions .reaction-btn{color:#fff}.story-create-illustration{text-align:center;padding:24px 0 8px}.story-create-subtitle{text-align:center;font-size:18px;font-weight:600;color:var(--text);margin-bottom:16px}.story-media-pick{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.media-pick-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 24px;border:2px dashed var(--primary);border-radius:var(--radius);cursor:pointer;color:var(--primary);font-size:13px;font-weight:500;transition:background .15s}.media-pick-btn:hover{background:var(--primary-soft)}.media-pick-btn .material-symbols-outlined{font-size:28px}.story-preview-area{text-align:center;margin-bottom:12px}.story-preview-area img{max-width:100%;max-height:200px;border-radius:var(--radius);object-fit:cover}.story-ideas{background:var(--surface-muted);border-radius:var(--radius);padding:12px;margin-bottom:12px}.tips-title{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}.tips-list{margin:0;padding-left:20px;font-size:13px;color:var(--text-muted);line-height:1.6}.story-editor{position:fixed;inset:0;z-index:9998;background:#000;display:flex;flex-direction:column}.story-editor-header{display:flex;align-items:center;justify-content:space-between;padding:12px}.story-editor-header .icon-btn{color:#fff}.story-editor-title{color:#fff;font-size:16px;font-weight:600}.primary-btn--sm{padding:6px 16px;font-size:13px}.story-editor-canvas-wrap{flex:1;position:relative;overflow:hidden}.story-editor-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:2}.story-editor-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:1}.story-editor-caption{display:flex;gap:8px;padding:8px 12px;align-items:center}.story-editor-caption .field{flex:1;background:#ffffff1a;color:#fff;border-color:#fff3}.pill-btn--ai{background:var(--primary);color:#fff;border:none;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer}.pill-btn--ai:disabled{opacity:.5}.story-editor-toolbar{display:flex;justify-content:center;gap:4px;padding:8px 12px 24px}.story-tool{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:#ffffffb3;cursor:pointer;padding:8px 12px;border-radius:8px;font-size:11px;transition:background .15s,color .15s}.story-tool:hover,.story-tool.active{background:#ffffff26;color:#fff}.story-tool .material-symbols-outlined{font-size:22px}.media-upload-area{display:flex;gap:12px;padding:16px;background:var(--surface);border-radius:12px;border:2px dashed var(--border)}.media-pick-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;border-radius:10px;background:var(--bg);cursor:pointer;transition:background .15s;font-size:13px;color:var(--text-secondary)}.media-pick-btn:hover{background:var(--primary-light, rgba(232,117,26,.08))}.media-pick-btn .material-symbols-outlined{font-size:28px;color:var(--primary)}.media-current{border-radius:10px;overflow:hidden;max-height:200px}.media-current img{width:100%;height:100%;object-fit:cover;display:block}.media-preview-area{border-radius:10px;overflow:hidden;max-height:220px;margin-top:4px}.media-preview-area img{width:100%;height:100%;object-fit:cover;display:block}.field-group-ai{display:flex;flex-direction:column;gap:6px}.ai-tools-row{display:flex;gap:6px;flex-wrap:wrap}.ai-tool-chip{border:1px solid var(--primary);background:transparent;color:var(--primary);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.ai-tool-chip:hover:not(:disabled){background:var(--primary);color:#fff}.ai-tool-chip:disabled{opacity:.5;cursor:not-allowed}.ai-undo-btn{border:1px solid var(--text-muted);background:transparent;color:var(--text-muted);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.ai-undo-btn:hover{background:var(--surface-muted);color:var(--text)}.pill-btn--ai{align-self:flex-end;font-size:12px;padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:not-allowed;opacity:.6}.form-tips{background:var(--surface);border-radius:10px;padding:12px 14px;border-left:3px solid var(--primary)}.tips-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--primary);margin-bottom:8px}.tips-list{margin:0;padding-left:18px;font-size:12px;color:var(--text-secondary);line-height:1.6}.mood-picker{display:flex;flex-direction:column;gap:8px}.mood-picker-row{display:flex;gap:8px;overflow-x:auto;overflow-y:visible;padding-bottom:4px;-webkit-overflow-scrolling:touch;width:100%;min-width:0}.mood-pill{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;white-space:nowrap;transition:border-color .15s,background .15s;font-size:13px}.mood-pill:hover{border-color:var(--primary)}.mood-pill--active,.mood-pill:has(input:checked){border-color:var(--primary);background:var(--primary-light, rgba(232,117,26,.1))}.mood-pill-emoji{font-size:18px}.mood-pill-label{color:var(--text);font-weight:500}.privacy-toggle{padding:4px 0}.toggle-row{display:flex;align-items:center;gap:10px;cursor:pointer}.toggle-row input[type=checkbox]{display:none}.toggle-slider{width:44px;height:24px;background:var(--border);border-radius:12px;position:relative;transition:background .2s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-row input:checked+.toggle-slider{background:var(--primary)}.toggle-row input:checked+.toggle-slider:after{transform:translate(20px)}.toggle-label{font-size:14px;color:var(--text);font-weight:500}.gallery-view{padding:0 0 80px}.gallery-header{display:flex;align-items:center;gap:12px;padding:12px 16px;position:sticky;top:0;background:var(--bg);z-index:10}.gallery-title{font-size:18px;font-weight:700;color:var(--text);margin:0}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding:2px}.gallery-item{position:relative;aspect-ratio:1;overflow:hidden;background:var(--surface)}.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.gallery-item-badge{position:absolute;bottom:4px;left:4px;font-size:10px;padding:2px 6px;border-radius:4px;background:#0009;color:#fff}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 20px;color:var(--text-secondary);text-align:center}.modal-sheet--no-header{padding-top:16px}.person-modal-hero{display:flex;flex-direction:column;align-items:center;gap:6px;padding-bottom:12px}.person-hero-avatar{width:80px;height:80px;font-size:28px}.person-modal-name{font-size:20px;font-weight:700;color:var(--text);margin:0;text-align:center}.person-modal-role{font-size:14px;color:var(--text-secondary);margin:0}.person-tabs-row{display:flex;border-bottom:1.5px solid var(--border);margin:0 -20px;padding:0 20px}.person-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0;background:none;border:none;border-bottom:2.5px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.person-tab .material-symbols-outlined{font-size:18px}.person-tab--active{color:var(--primary);border-bottom-color:var(--primary)}.person-tab-body{padding-top:16px}.person-info-grid{display:flex;flex-direction:column;gap:14px}.person-info-row{display:flex;align-items:flex-start;gap:12px}.person-info-icon{font-size:20px;color:var(--primary);margin-top:2px;flex-shrink:0}.person-info-label{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.person-info-value{font-size:14px;color:var(--text)}.person-section{margin-top:16px}.person-section-title{font-size:14px;font-weight:600;color:var(--text);margin:0 0 10px}.relation-pills-row{display:flex;flex-wrap:wrap;gap:8px}.relation-pill{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;font-size:13px;transition:border-color .15s}.relation-pill:hover{border-color:var(--primary)}.relation-pill-type{font-weight:600;color:var(--primary);font-size:11px;text-transform:uppercase}.relation-pill-name{color:var(--text)}.relation-pill-compact{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text)}.relation-edit-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}.person-modal-actions{margin-top:16px;display:flex;gap:8px}.person-media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}.person-media-item{aspect-ratio:1;overflow:hidden;border-radius:4px;background:var(--surface)}.person-media-item img{width:100%;height:100%;object-fit:cover;display:block}.person-empty-tab{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;color:var(--text-secondary);text-align:center}.form-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.chats-list-v2{padding:0 0 80px}.chats-search{display:flex;align-items:center;gap:8px;margin:12px 16px;padding:10px 14px;background:var(--surface);border-radius:12px;border:1px solid var(--border)}.chats-search-icon{font-size:20px;color:var(--text-secondary)}.chats-search-input{flex:1;border:none;background:none;font-size:14px;color:var(--text);outline:none}.chats-filter-row{display:flex;gap:8px;padding:0 16px 12px}.chats-filter-chip{padding:6px 16px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.chats-filter-chip--active{background:var(--primary);border-color:var(--primary);color:#fff}.chats-items{display:flex;flex-direction:column}.chat-list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;width:100%;transition:background .1s}.chat-list-item:hover{background:var(--surface)}.chat-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0;overflow:hidden}.chat-avatar.has-image{background:var(--surface)}.chat-avatar img{width:100%;height:100%;object-fit:cover}.chat-avatar--group{background:var(--primary-soft);color:var(--primary)}.chat-avatar--group .material-symbols-outlined{font-size:24px}.chat-item-body{flex:1;min-width:0}.chat-item-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.chat-item-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-item-time{font-size:12px;color:var(--text-secondary);flex-shrink:0}.chat-item-bottom{display:flex;align-items:center;gap:8px;margin-top:2px}.chat-item-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;flex:1}.chat-preview-sender{font-weight:600;color:var(--text)}.chat-unread-badge{background:var(--primary);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.chat-room-v2{display:flex;flex-direction:column;height:100%}.view--chat{padding:0;height:calc(100dvh - 64px);overflow:hidden}.chat-room-header{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.chat-room-header .chat-avatar{width:40px;height:40px;font-size:14px}.chat-room-info{flex:1;min-width:0}.chat-room-name{font-size:15px;font-weight:600;color:var(--text)}.chat-room-status{font-size:12px;color:var(--text-secondary)}.chat-room-actions{display:flex;gap:4px}.chat-messages-v2{flex:1;overflow-y:auto;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:60px 20px;color:var(--text-secondary);text-align:center}.chat-bubble-row{display:flex;align-items:flex-end;gap:8px;max-width:75%;align-self:flex-start}.chat-bubble-row--mine{align-self:flex-end;flex-direction:row-reverse}.chat-bubble-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;overflow:hidden}.chat-bubble-avatar.has-image{background:transparent}.chat-bubble-avatar img{width:100%;height:100%;object-fit:cover;display:block}.chat-bubble-row--no-avatar{padding-left:0}.chat-bubble{padding:8px 12px;border-radius:16px 16px 16px 4px;background:var(--surface);border:1px solid var(--border);min-width:60px;max-width:100%;overflow:hidden}.chat-bubble--mine{background:var(--primary);color:#fff;border-radius:16px 16px 4px;border-color:transparent}.chat-bubble-sender{font-size:11px;font-weight:600;color:var(--primary);margin-bottom:2px}.chat-bubble--mine .chat-bubble-sender{color:#ffffffb3}.chat-bubble-text{font-size:14px;line-height:1.4;word-break:break-word;white-space:pre-wrap}.chat-bubble-img{width:100%;max-width:240px;border-radius:8px;margin-top:6px;display:block}.chat-bubble-audio{width:100%;max-width:240px;margin-top:6px;height:32px}.chat-bubble-time{font-size:10px;opacity:.6;margin-top:4px;text-align:right}.chat-bubble-footer{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-top:4px}.chat-bubble-footer .chat-bubble-time{margin-top:0}.chat-bubble-delete{background:none;border:none;cursor:pointer;padding:0;opacity:0;transition:opacity .15s;color:inherit}.chat-bubble-delete .material-symbols-outlined{font-size:14px}.chat-bubble:hover .chat-bubble-delete,.chat-bubble-row--mine:active .chat-bubble-delete{opacity:.5}.chat-create-people{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.chat-create-person{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:14px}.chat-create-person:has(input:checked){border-color:var(--primary);background:var(--primary-soft)}.chat-create-person input{accent-color:var(--primary)}.chats-new-btn{margin-left:auto;width:36px;height:36px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.chats-new-btn .material-symbols-outlined{font-size:18px}.chat-composer-v2{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.chat-composer-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.chat-composer-btn:hover:not(:disabled){background:var(--surface-muted);color:var(--primary)}.chat-composer-btn .material-symbols-outlined{font-size:22px}.chat-input-wrap{flex:1;position:relative;display:flex;align-items:center;background:var(--surface-muted);border-radius:20px;border:1px solid var(--border);min-width:0}.chat-input-v2{flex:1;border:none;background:transparent;padding:9px 36px 9px 14px;font-size:14px;color:var(--text);outline:none;min-width:0}.chat-emoji-btn{position:absolute;right:2px;width:32px;height:32px}.chat-send-btn{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.chat-send-btn .material-symbols-outlined{font-size:20px}.profile-v2{padding:0 0 80px}.profile-hero-v2{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 16px 16px}.profile-hero-v2 .profile-avatar{width:90px;height:90px;font-size:32px}.profile-name-v2{font-size:20px;font-weight:700;color:var(--text);margin:0}.profile-role-v2{font-size:14px;color:var(--text-secondary);margin:0}.profile-edit-btn-v2{margin-top:8px;padding:6px 20px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);font-size:13px;font-weight:500;color:var(--text);cursor:pointer;transition:border-color .15s}.profile-edit-btn-v2:hover{border-color:var(--primary)}.profile-stats-v2{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:16px;text-align:center}.profile-stat-value{font-size:20px;font-weight:700;color:var(--text)}.profile-stat-label{font-size:11px;color:var(--text-secondary);margin-top:2px}.profile-bio-v2{padding:0 16px 12px;font-size:14px;color:var(--text);line-height:1.5}.profile-quick-actions{display:flex;gap:10px;padding:0 16px 16px}.profile-quick-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:10px;background:var(--surface);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text);cursor:pointer;transition:border-color .15s}.profile-quick-btn:hover{border-color:var(--primary)}.profile-quick-btn .material-symbols-outlined{font-size:18px;color:var(--primary)}.profile-members{padding:0 16px 12px}.profile-members-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.profile-members-list{display:flex;flex-wrap:wrap;gap:8px}.profile-member{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}.profile-member-name{font-size:13px;font-weight:500;color:var(--text)}.invite-modal-body{padding:4px 0}.invite-hint{font-size:13px;color:var(--text-muted);line-height:1.45;margin:0 0 14px}.invite-url-box{display:flex;gap:8px;margin-bottom:14px}.invite-url-input{flex:1;min-width:0;font-size:12px}.invite-copy-btn{flex-shrink:0;padding:8px 14px;font-size:13px}.invite-code-label{font-size:12px;color:var(--text-muted);margin:0 0 6px}.invite-code{font-family:monospace;font-size:12px;padding:8px 12px;background:var(--surface-muted);border-radius:8px;word-break:break-all;color:var(--text)}.profile-tabs-v2{display:flex;border-bottom:1.5px solid var(--border);margin:0 16px}.profile-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0;background:none;border:none;border-bottom:2.5px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.profile-tab-btn .material-symbols-outlined{font-size:18px}.profile-tab-btn--active{color:var(--primary);border-bottom-color:var(--primary)}.profile-tab-content{padding:12px 16px}.profile-tab-empty{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:14px}.profile-post-card{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.profile-post-img{width:60px;height:60px;border-radius:8px;object-fit:cover;flex-shrink:0}.profile-post-body{flex:1;min-width:0}.profile-post-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-post-text{font-size:13px;color:var(--text-secondary);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.profile-post-date{font-size:11px;color:var(--text-secondary);margin-top:4px}.profile-actions-v2{display:flex;flex-direction:column;gap:8px;padding:16px}.about-page{background:#f9f9f9;color:#1a1c1c;min-height:100dvh;-webkit-font-smoothing:antialiased;overflow-x:hidden;scroll-behavior:smooth}.about-header{position:fixed;top:0;left:0;right:0;z-index:50;background:#f9f9f9cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.about-header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;max-width:1280px;margin:0 auto}.about-header-brand{display:flex;align-items:center;gap:8px}.about-header-icon{color:var(--primary);font-size:24px}.about-header-title{font-size:18px;font-weight:800;letter-spacing:-.02em;color:#1a1c1c}.about-header-nav{display:none;align-items:center;gap:28px}.about-nav-link{font-size:14px;font-weight:500;color:#6b6b6b;text-decoration:none;letter-spacing:.02em;transition:color .2s}.about-nav-link:hover{color:var(--primary)}.about-nav-link--active{color:var(--primary);font-weight:700;border-bottom:2px solid var(--primary);padding-bottom:2px}.about-nav-cta{padding:8px 24px;border-radius:12px;font-size:14px;font-weight:700;background:#ff8c00;color:#623200;box-shadow:0 1px 3px #00000014;transition:background .2s}.about-nav-cta:hover{background:var(--primary);color:#fff}.about-main{padding-top:64px}.about-hero{max-width:1280px;margin:0 auto;padding:48px 24px 40px;display:flex;flex-direction:column-reverse;gap:32px;align-items:center}.about-hero-text{text-align:center}.about-hero-label{display:block;text-transform:uppercase;letter-spacing:.2em;font-size:11px;font-weight:600;color:#564334;margin-bottom:16px}.about-hero-title{font-size:40px;line-height:1.1;font-weight:800;letter-spacing:-.02em;margin:0 0 20px;color:#1a1c1c}.about-hero-accent{color:#ff8c00}.about-hero-subtitle{font-size:17px;color:#564334;line-height:1.65;margin:0 0 28px;max-width:520px}.about-hero-form{display:flex;flex-direction:column;gap:12px;max-width:420px;padding-top:8px}.about-hero-input{background:transparent;border:none;border-bottom:2px solid #ddc1ae;padding:12px 0;font-size:17px;outline:none;color:#1a1c1c;font-family:inherit;transition:border-color .2s}.about-hero-input:focus{border-color:#ff8c00}.about-hero-input::placeholder{color:#897362}.about-hero-btn{padding:14px 28px;border-radius:12px;font-size:16px;font-weight:700;background:#ff8c00;color:#623200;box-shadow:0 4px 16px #904d0033;white-space:nowrap;transition:transform .15s,background .2s}.about-hero-btn:active{transform:scale(.96)}.about-hero-btn:hover{background:var(--primary);color:#fff}.about-hero-visual{position:relative;width:100%;max-width:360px}.about-hero-img-wrap{aspect-ratio:4/5;border-radius:24px;overflow:hidden;box-shadow:0 16px 48px #00000026;position:relative;z-index:1}.about-hero-img{width:100%;height:100%;object-fit:cover;display:block}.about-hero-deco-rect{display:none;position:absolute;bottom:-32px;left:-32px;width:180px;height:180px;background:#b0a99c;border-radius:16px;z-index:0}.about-hero-deco-circle{display:none;position:absolute;top:-24px;right:-24px;width:120px;height:120px;border:4px solid rgba(255,140,0,.2);border-radius:50%;z-index:0}.about-pain{background:#f3f3f3;padding:64px 24px}.about-pain-inner{max-width:1280px;margin:0 auto}.about-pain-header{max-width:640px;margin-bottom:40px}.about-pain-title{font-size:28px;font-weight:700;letter-spacing:-.01em;margin:0 0 12px}.about-pain-subtitle{color:#564334;margin:0;line-height:1.5}.about-pain-grid{display:flex;flex-direction:column;gap:32px}.about-pain-card{display:flex;flex-direction:column;gap:12px}.about-pain-icon{font-size:36px;color:var(--primary)}.about-pain-card-title{font-size:20px;font-weight:700;margin:0}.about-pain-card-text{color:#564334;line-height:1.6;margin:0}.about-solution{padding:80px 24px}.about-solution-inner{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:40px}.about-solution-quote{background:#e9e2d3;padding:40px 28px;border-radius:24px;position:relative}.about-quote-icon{position:absolute;top:20px;right:20px;font-size:64px;color:#cdc6b8}.about-quote-text{font-size:22px;font-weight:700;line-height:1.35;margin:0 0 16px;position:relative;z-index:1}.about-quote-author{color:#4b463c;font-style:italic;margin:0}.about-solution-title{font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0 0 16px}.about-solution-desc{font-size:17px;color:#564334;line-height:1.65;margin:0}.about-features-section{padding:64px 24px;background:#f9f9f9}.about-features-grid{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.about-feat{border-radius:24px;padding:32px 24px}.about-feat--journal{background:#fff;border:1px solid rgba(137,115,98,.1);box-shadow:0 1px 4px #0000000a}.about-feat--tree{background:#ff8c0014;border:1px solid rgba(255,140,0,.15)}.about-feat--feed{background:#b0a99c26}.about-feat--why{background:#2f3131;color:#f1f1f1;display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.about-feat-badge{display:inline-block;padding:4px 14px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;background:#ffdcc3;color:#6e3900}.about-feat-badge--primary{background:#ff8c00;color:#623200}.about-feat-badge--tertiary{background:#635e53;color:#fff}.about-feat-title{font-size:24px;font-weight:700;margin:16px 0 8px}.about-feat-title--lg{font-size:28px}.about-feat-desc{color:#564334;line-height:1.6;margin:0;font-size:15px}.about-feat--why .about-feat-desc{color:#dadada}.about-feat-img-wrap{border-radius:16px;overflow:hidden;aspect-ratio:16/9;margin-top:20px}.about-feat-img{width:100%;height:100%;object-fit:cover;display:block}.about-feat-icon-big{text-align:center;padding:16px 0}.about-feat-icon-big .material-symbols-outlined{font-size:100px;color:#904d0040}.about-feat-why-text{position:relative;z-index:1}.about-feat-why-icon{font-size:120px;opacity:.08;position:absolute;right:-20px;bottom:-20px}.about-offer{padding:64px 24px;background:#f3f3f3}.about-offer-inner{max-width:900px;margin:0 auto;text-align:center}.about-offer-heading{font-size:28px;font-weight:700;letter-spacing:-.01em;margin:0 0 32px}.about-offer-card{background:#fff;padding:40px 24px;border-radius:24px;box-shadow:0 1px 4px #0000000a;border:1px solid rgba(137,115,98,.1)}.about-offer-text{font-size:17px;margin:0 0 24px;color:#564334}.about-offer-form{display:flex;flex-direction:column;gap:12px;max-width:480px;margin:0 auto}.about-offer-field{background:#f3f3f3;border:none;border-radius:12px;padding:14px 20px;font-size:15px;font-family:inherit;outline:none;color:#1a1c1c;transition:box-shadow .15s;width:100%}.about-offer-field:focus{box-shadow:0 0 0 2px #ff8c00}.about-offer-btn{padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;background:#ff8c00;color:#623200;transition:background .2s;white-space:nowrap;width:100%}.about-offer-btn:hover{background:var(--primary);color:#fff}.about-proof{padding:48px 24px}.about-proof-inner{max-width:1280px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:32px;opacity:.5;filter:grayscale(1)}.about-proof-item{font-size:18px;font-weight:700;white-space:nowrap}.about-steps{padding:80px 24px;background:#f9f9f9}.about-steps-inner{max-width:1280px;margin:0 auto}.about-steps-header{text-align:center;margin-bottom:48px}.about-steps-title{font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0 0 12px}.about-steps-subtitle{font-size:17px;color:#564334;margin:0}.about-steps-grid{display:flex;flex-direction:column;gap:40px}.about-step{text-align:center}.about-step-num{width:56px;height:56px;border-radius:50%;margin:0 auto 24px;background:#ff8c00;color:#623200;font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center}.about-step-title{font-size:20px;font-weight:700;margin:0 0 8px}.about-step-text{color:#564334;line-height:1.6;margin:0;max-width:320px;margin-inline:auto}.about-faq{padding:64px 24px;background:#f3f3f3}.about-faq-inner{max-width:720px;margin:0 auto}.about-faq-title{font-size:28px;font-weight:700;text-align:center;margin:0 0 32px}.about-faq-list{display:flex;flex-direction:column;gap:12px}.about-faq-item{background:#fff;padding:20px 24px;border-radius:16px}.about-faq-q{font-size:16px;font-weight:700;margin:0 0 8px}.about-faq-a{color:#564334;line-height:1.55;margin:0;font-size:14px}.about-final-cta{padding:48px 24px}.about-final-cta-inner{max-width:1280px;margin:0 auto;background:var(--primary);border-radius:32px;padding:48px 24px;text-align:center;position:relative;overflow:hidden}.about-final-cta-content{position:relative;z-index:1}.about-final-cta-title{font-size:32px;font-weight:800;color:#fff;margin:0 0 16px;line-height:1.15}.about-final-cta-desc{font-size:16px;color:#ffdcc3cc;margin:0 0 28px;max-width:560px;margin-inline:auto;line-height:1.5}.about-final-cta-btn{display:inline-block;background:#ff8c00;color:#623200;padding:16px 40px;border-radius:16px;font-size:18px;font-weight:700;border:none;cursor:pointer;box-shadow:0 8px 32px #0003;transition:background .2s,transform .15s}.about-final-cta-btn:hover{background:#f9f9f9;color:#1a1c1c}.about-final-cta-btn:active{transform:scale(.96)}.about-final-cta-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--primary),var(--primary),#ff8c00);opacity:.5}.about-footer{background:#f3f3f3;padding:56px 24px 32px}.about-footer-inner{max-width:1280px;margin:0 auto}.about-footer-top{display:flex;flex-direction:column;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(0,0,0,.08)}.about-footer-col{display:flex;flex-direction:column;gap:10px}.about-footer-brand{font-size:18px;font-weight:800;color:#1a1c1c}.about-footer-tagline{font-size:14px;color:#6b6b6b;margin:0;line-height:1.5;max-width:280px}.about-footer-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#1a1c1c;margin-bottom:4px}.about-footer-contact{display:flex;align-items:center;gap:10px;font-size:14px}.about-footer-contact .material-symbols-outlined{font-size:18px;color:#897362}.about-footer-contact a{color:#6b6b6b;text-decoration:none;transition:color .2s}.about-footer-contact a:hover{color:var(--primary)}.about-footer-nav{display:flex;flex-direction:column;gap:8px}.about-footer-nav a{color:#6b6b6b;text-decoration:none;font-size:14px;transition:color .2s}.about-footer-nav a:hover{color:var(--primary)}.about-footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;gap:16px;flex-wrap:wrap}.about-footer-copy{font-size:13px;color:#6b6b6b;margin:0;text-decoration:none}@media(min-width:768px){.about-header-inner{padding:14px 32px}.about-header-nav{display:flex}.about-hero{flex-direction:row;padding:80px 32px 60px;text-align:left;gap:40px}.about-hero-text{order:1;flex:1;text-align:left}.about-hero-visual{order:2;max-width:340px}.about-hero-form{flex-direction:row}.about-hero-title{font-size:48px}.about-hero-deco-rect,.about-hero-deco-circle{display:block}.about-pain{padding:80px 32px}.about-pain-grid{flex-direction:row;gap:40px}.about-pain-card{flex:1}.about-pain-title{font-size:32px}.about-solution-inner{flex-direction:row;gap:48px;align-items:center}.about-solution-quote,.about-solution-text{flex:1}.about-solution{padding:100px 32px}.about-features-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.about-feat--journal{grid-column:span 8}.about-feat--tree,.about-feat--feed{grid-column:span 4}.about-feat--why{grid-column:span 8;flex-direction:row;align-items:center}.about-feat-why-icon{font-size:180px;position:absolute;right:-40px;bottom:-20px}.about-offer-form{flex-direction:row;align-items:stretch;max-width:520px;margin:0 auto}.about-offer-field{flex:1;width:auto}.about-offer-btn{flex:none;width:auto}.about-offer-heading{font-size:32px}.about-proof-inner{gap:48px}.about-proof-item{font-size:20px}.about-steps-grid{flex-direction:row;gap:48px}.about-step{flex:1}.about-steps-title{font-size:38px}.about-final-cta-inner{padding:64px 48px;border-radius:40px}.about-final-cta-title{font-size:40px}.about-footer-inner{flex-direction:row;justify-content:space-between;text-align:left}.about-footer-left{margin-bottom:0}.about-footer-top{flex-direction:row;justify-content:space-between}.about-footer-nav{flex-direction:column}}@media(min-width:1024px){.about-header-inner{padding:16px 48px}.about-hero{padding:100px 48px 80px;gap:64px}.about-hero-title{font-size:60px}.about-hero-subtitle{font-size:19px}.about-hero-visual{max-width:420px}.about-hero-img-wrap{border-radius:28px}.about-pain{padding:96px 48px}.about-pain-title{font-size:36px}.about-pain-card-title{font-size:22px}.about-solution{padding:120px 48px}.about-solution-inner{gap:64px}.about-solution-quote{padding:48px 40px;border-radius:28px}.about-quote-text{font-size:26px}.about-solution-title{font-size:40px}.about-features-section{padding:96px 48px}.about-feat{padding:40px 32px}.about-feat-title--lg{font-size:32px}.about-offer{padding:96px 48px}.about-offer-card{padding:48px 40px}.about-steps{padding:120px 48px}.about-steps-title{font-size:42px}.about-faq{padding:96px 48px}.about-faq-title{font-size:32px}.about-final-cta{padding:64px 48px}.about-final-cta-inner{padding:80px 64px;border-radius:48px}.about-final-cta-title{font-size:56px}.about-final-cta-desc{font-size:20px}.about-footer{padding:48px}}@media(min-width:1280px){.about-hero{padding:120px 64px 100px}.about-hero-title{font-size:68px}.about-hero-visual{max-width:460px}.about-hero-img-wrap{box-shadow:0 24px 64px #0000002e}.about-feat--journal{padding:48px 40px}.about-feat-title--lg{font-size:36px}.about-final-cta-title{font-size:64px}}.about-footer-proto{opacity:.15;font-size:11px;cursor:default}.about-footer-proto:hover{opacity:.4;color:var(--primary);cursor:pointer}.about-feat-img-wrap--auto{aspect-ratio:auto}.about-feat-img-wrap--auto .about-feat-img{width:100%;height:auto;object-fit:contain}.about-final-cta-form{display:flex;flex-direction:column;gap:12px;max-width:420px;margin:0 auto}.about-final-cta-input{background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);border-radius:16px;padding:16px 20px;font-size:16px;font-family:inherit;color:#fff;outline:none;transition:box-shadow .15s}.about-final-cta-input::placeholder{color:#ffdcc399}.about-final-cta-input:focus{box-shadow:0 0 0 2px #ff8c00}@media(min-width:768px){.about-final-cta-form{flex-direction:row;max-width:520px}.about-final-cta-input{flex:1}.about-final-cta-btn{white-space:nowrap}}.legal-article{max-width:720px;margin:0 auto;padding:48px 24px 80px}.legal-heading{font-size:28px;font-weight:800;margin:0 0 32px}.legal-body h2{font-size:18px;font-weight:700;margin:28px 0 12px}.legal-body p{color:#564334;line-height:1.65;margin:0 0 12px}.legal-body ul{color:#564334;line-height:1.65;padding-left:20px;margin:0 0 12px}.legal-body li{margin-bottom:6px}.legal-body a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}.legal-contact-grid{display:flex;flex-direction:column;gap:16px;margin:24px 0}.legal-contact-card{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f3f3f3;border-radius:14px}.legal-contact-card .material-symbols-outlined{font-size:22px;color:var(--primary)}.legal-contact-card h3{font-size:14px;font-weight:700;margin:0;min-width:80px}.legal-contact-card a{color:#564334;text-decoration:none}.legal-contact-card a:hover{color:var(--primary)}@media(min-width:768px){.legal-article{padding:64px 32px 80px}.legal-heading{font-size:36px}.legal-contact-grid{flex-direction:row}.legal-contact-card{flex:1;flex-direction:column;text-align:center;padding:24px}.legal-contact-card h3{min-width:auto}}
