.page-graph{padding:0!important}.graph-wrapper-full{position:relative;width:100vw;margin-left:calc(-50vw + 50%);height:calc(100dvh - var(--nav-height));background:var(--bg);overflow:hidden}.graph-wrapper-full canvas{display:block}.graph-top-bar{position:absolute;top:0;left:0;right:0;z-index:10;padding:10px 12px;display:flex;align-items:center;gap:8px;pointer-events:none}.graph-top-bar>*{pointer-events:auto}.graph-family-title{font-size:1rem;font-weight:600;color:var(--text);background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:8px 14px}.graph-family-filter{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:4px}.graph-filter-pill{background:none;border:none;color:var(--text-muted);font-size:.8rem;padding:6px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .2s}.graph-filter-pill.active{background:var(--bg-input);color:var(--text)}.graph-filter-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.graph-actions{position:absolute;top:10px;right:12px;z-index:10;display:flex;gap:6px}.graph-action-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.graph-search{position:absolute;top:54px;left:12px;z-index:10}.graph-search-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.graph-search-input-wrap{position:relative;display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:0 8px;width:260px}.graph-search-icon{color:var(--text-muted);flex-shrink:0}.graph-search-input{background:transparent!important;border:none!important;color:var(--text);font-size:.9rem;padding:10px 8px!important;margin:0!important;outline:none;flex:1;min-width:0}.graph-search-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex}.graph-search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-top:4px;overflow:hidden;max-height:240px;overflow-y:auto}.graph-search-result{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text);padding:10px 12px;font-size:.9rem;cursor:pointer;text-align:left}.graph-search-result:last-child{border-bottom:none}.graph-search-result:hover{background:var(--bg-input)}.graph-search-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;flex-shrink:0}.graph-detail-overlay{position:absolute;inset:0;z-index:20;display:flex;align-items:flex-end;justify-content:center}.graph-detail-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:16px 16px 0 0;padding:20px;width:100%;max-width:400px;max-height:60%;overflow-y:auto;position:relative;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.graph-detail-close{position:absolute;top:12px;right:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);padding:6px;cursor:pointer;display:flex}.graph-detail-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.graph-detail-avatar{width:48px;height:48px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.3rem;flex-shrink:0}.graph-detail-name{font-size:1.1rem;display:flex;align-items:center}.graph-detail-role{color:var(--text-muted);font-size:.85rem;text-transform:capitalize}.graph-detail-family{display:block;color:var(--text-muted);font-size:.75rem;margin-top:2px}.graph-detail-field{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}.graph-detail-label{color:var(--text-muted)}.graph-detail-relations{margin-top:16px}.graph-detail-relations h4{font-size:.9rem;margin-bottom:10px;color:var(--text-muted)}.graph-detail-rel-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.9rem;flex-wrap:wrap}.graph-detail-empty{color:var(--text-muted);font-size:.9rem;margin-top:8px}.graph-legend{position:absolute;bottom:12px;right:12px;z-index:10;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;display:flex;flex-wrap:wrap;gap:8px;max-width:220px}.graph-legend-item{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-muted)}.graph-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.graph-legend-line{width:16px;height:3px;border-radius:2px;flex-shrink:0}.graph-legend-sep{width:1px;height:14px;background:var(--border);flex-shrink:0}.graph-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:8px}:root{--bg: #0f0f1a;--bg-card: #1a1a2e;--bg-input: #16213e;--text: #e0e0e0;--text-muted: #8888aa;--primary: #6c63ff;--primary-hover: #5a52e0;--danger: #e74c3c;--warning: #f39c12;--border: #2a2a4a;--nav-height: 60px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.app-content{flex:1;padding:16px;padding-bottom:calc(var(--nav-height) + 16px);max-width:600px;margin:0 auto;width:100%}.app-loading{display:flex;align-items:center;justify-content:center;height:100dvh;color:var(--text-muted);font-size:1.1rem}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:var(--bg-card);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--text-muted);font-size:.7rem;padding:6px 12px;transition:color .2s}.nav-tab.active{color:var(--primary)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px}.login-card{width:100%;max-width:360px;text-align:center}.login-card h1{font-size:2.5rem;color:var(--primary);margin-bottom:4px}.login-card h2{font-size:1.5rem;margin-bottom:8px}.subtitle{color:var(--text-muted);margin-bottom:32px}.btn{display:block;width:100%;padding:12px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-google{background:#fff;color:#333;font-weight:500;margin-bottom:16px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff;margin-top:24px}.btn-icon{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-back{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:4px;font-size:.9rem;margin-bottom:12px;padding:4px 0}.divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-muted);font-size:.85rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}input[type=email],input[type=text]{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text);font-size:1rem;margin-bottom:12px;outline:none}input:focus{border-color:var(--primary)}input[readonly]{opacity:.8;cursor:text}.error{color:var(--danger);margin-top:12px;font-size:.9rem}.otp-msg{color:var(--primary);font-size:.95rem;padding:16px 0}.page{padding-top:8px}.page h2{font-size:1.4rem;margin-bottom:16px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.page-header h2{margin-bottom:0}.header-actions{display:flex;gap:8px}.page-loading,.page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50dvh;color:var(--text-muted);text-align:center}.page-placeholder{color:var(--text-muted);padding:24px 0;text-align:center}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:400px}.modal-card h3{margin-bottom:16px;font-size:1.2rem}.modal-actions{display:flex;gap:8px;margin-top:8px}.modal-actions .btn{flex:1}.family-list{list-style:none}.family-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;cursor:pointer;position:relative;transition:border-color .2s}.family-card:hover{border-color:var(--primary)}.family-card h3{font-size:1.1rem;margin-bottom:4px}.family-card p{color:var(--text-muted);font-size:.9rem}.card-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1.2rem}.family-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:16px}.tab-bar{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:8px}.tab{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px 12px;font-size:.85rem;border-radius:6px;display:flex;align-items:center;gap:4px;transition:all .2s}.tab.active{background:var(--bg-input);color:var(--primary)}.members-list{display:flex;flex-direction:column;gap:8px}.member-card{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.member-info{flex:1;display:flex;align-items:center;justify-content:space-between}.member-name{font-size:.95rem;display:flex;align-items:center;gap:6px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;color:#fff;text-transform:capitalize}.badge-muted{background:var(--text-muted)!important}.relations-list{display:flex;flex-direction:column;gap:8px}.relation-card{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:.9rem}.rel-from,.rel-to{font-weight:500}.rel-type{color:var(--primary);font-size:.8rem;background:var(--bg-input);padding:2px 8px;border-radius:8px}.invite-panel{padding:8px 0}.invite-panel p{color:var(--text-muted);font-size:.9rem}.invite-result{display:flex;gap:8px;margin-top:12px}.invite-result input{flex:1;margin-bottom:0}.invite-result .btn{width:auto;padding:12px 20px;flex-shrink:0}.profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.profile-card p{margin-bottom:8px;font-size:.9rem;word-break:break-all}.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.media-thumb{aspect-ratio:1;background:var(--bg-card);border-radius:4px;overflow:hidden}.media-thumb{cursor:pointer}.thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-muted);padding:4px;text-align:center}.upload-bar{background:var(--primary);color:#fff;text-align:center;padding:8px;border-radius:8px;margin-bottom:12px;font-size:.9rem}.photo-view{border-radius:12px;overflow:hidden;margin-bottom:16px;background:var(--bg-card)}.photo-view img{width:100%;display:block}.photo-actions{margin-bottom:16px}.photo-meta{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.photo-meta h3{font-size:1rem;margin-bottom:12px}.meta-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:.85rem}.meta-row:last-child{border-bottom:none}.meta-label{color:var(--text-muted);display:flex;align-items:center;gap:4px}.meta-value{color:var(--text)}.share-group-list{display:flex;flex-direction:column;gap:8px}.share-group-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:12px;cursor:pointer;color:var(--text);font-size:.95rem;transition:border-color .2s}.share-group-item:hover{border-color:var(--primary)}.share-group-item:disabled{opacity:.6}.post-form{display:flex;gap:8px;margin-bottom:16px}.post-form input{flex:1;margin-bottom:0}.feed-list{display:flex;flex-direction:column;gap:12px}.feed-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.feed-card.pinned{border-color:var(--warning)}.pin-label{display:inline-block;font-size:.7rem;color:var(--warning);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.feed-body{font-size:.95rem;line-height:1.4;margin-bottom:8px}.feed-time{font-size:.75rem;color:var(--text-muted)}.feed-image{width:100%;border-radius:8px;margin-bottom:8px}.feed-share{padding:12px}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--text-muted);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.select-input,.date-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text);font-size:1rem;margin-bottom:12px;outline:none;appearance:none}.select-input:focus,.date-input:focus{border-color:var(--primary)}.section{margin-top:24px}.section-title{font-size:1rem;margin-bottom:12px;display:flex;align-items:center;gap:6px}.section-muted{color:var(--text-muted)}.event-card{display:flex;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:10px}.event-card.event-past{opacity:.5}.event-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:48px;background:var(--bg-input);border-radius:8px;padding:6px}.event-month{font-size:.65rem;text-transform:uppercase;color:var(--primary);letter-spacing:.5px}.event-day{font-size:1.3rem;font-weight:700;line-height:1}.event-info{flex:1;min-width:0}.event-title{font-weight:600;margin-bottom:4px}.event-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.event-group-name{font-size:.75rem;color:var(--text-muted)}.event-location,.event-time{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:4px;margin-top:2px}.group-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;transition:border-color .2s}.group-card:hover{border-color:var(--primary)}.consent-card{background:var(--bg-card);border:1px solid var(--warning);border-radius:10px;padding:12px;margin-bottom:8px}.consent-card p{font-size:.9rem;margin-bottom:8px}.consent-actions{display:flex;gap:8px}.btn-sm{padding:6px 16px;font-size:.85rem;width:auto}
