:root{--color-primary: #667eea;--color-primary-hover: #5a6fd6;--color-primary-light: rgba(102, 126, 234, .1);--color-bg: #f5f5f5;--color-bg-card: #fff;--color-bg-graph: #fafafa;--color-bg-overlay: rgba(0, 0, 0, .5);--color-text: #222;--color-text-secondary: #444;--color-text-muted: #999;--color-border: #e0e0e0;--color-border-light: #eee;--color-input-bg: #fff;--color-input-border: #ddd;--color-error-bg: #fde8e8;--color-error-text: #c62828;--color-danger: #f44336;--color-danger-hover: #d32f2f;--color-secondary-btn: #e0e0e0;--color-secondary-btn-text: #444;--color-toolbar-bg: rgba(255, 255, 255, .95);--color-chip-bg: #ede9fe;--color-chip-text: #6d28d9;--color-node-label: #334155;--color-edge-label: #64748b;--color-link: #cbd5e1;--color-link-active: #94a3b8;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .15)}.dark{--color-primary: #818cf8;--color-primary-hover: #6366f1;--color-primary-light: rgba(129, 140, 248, .15);--color-bg: #0f172a;--color-bg-card: #1e293b;--color-bg-graph: #111827;--color-bg-overlay: rgba(0, 0, 0, .7);--color-text: #e2e8f0;--color-text-secondary: #cbd5e1;--color-text-muted: #64748b;--color-border: #334155;--color-border-light: #1e293b;--color-input-bg: #1e293b;--color-input-border: #475569;--color-error-bg: #450a0a;--color-error-text: #fca5a5;--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-secondary-btn: #334155;--color-secondary-btn-text: #e2e8f0;--color-toolbar-bg: rgba(30, 41, 59, .95);--color-chip-bg: #312e81;--color-chip-text: #c4b5fd;--color-node-label: #cbd5e1;--color-edge-label: #94a3b8;--color-link: #475569;--color-link-active: #94a3b8;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.dark .auth-page{background:linear-gradient(135deg,#312e81,#4c1d95)}.auth-card{background:var(--color-bg-card);border-radius:12px;padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-card h1{font-size:28px;color:var(--color-primary);margin-bottom:4px}.auth-card h2{font-size:18px;color:var(--color-text-muted);margin-bottom:24px;font-weight:400}.auth-link{text-align:center;margin-top:16px;color:var(--color-text-muted)}.auth-link a{color:var(--color-primary);text-decoration:none;font-weight:500}.form-group{margin-bottom:16px;flex:1}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--color-text-secondary);margin-bottom:4px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--color-input-border);border-radius:8px;font-size:14px;background:var(--color-input-bg);color:var(--color-text);transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-row{display:flex;gap:12px}.required{color:var(--color-error-text)}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,opacity .2s;text-decoration:none;display:inline-block;text-align:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-secondary-btn);color:var(--color-secondary-btn-text)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger-hover)}.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-primary-light)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 32px;font-size:16px;border-radius:10px}.btn-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-muted);line-height:1}.btn-icon{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:var(--color-text-muted);font-size:18px;line-height:1;transition:background .15s}.btn-icon:hover{background:var(--color-primary-light)}.error-message{background:var(--color-error-bg);color:var(--color-error-text);padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:14px}.dashboard{display:flex;flex-direction:column;height:100vh;overflow:hidden}.dashboard-header{background:var(--color-bg-card);padding:10px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border);z-index:10;flex-shrink:0}.dashboard-header h1{font-size:22px;color:var(--color-primary);margin-right:16px}.header-left{display:flex;align-items:center;gap:12px}.header-center{flex:1;text-align:center}.header-right{display:flex;align-items:center;gap:10px}.header-right .btn-primary{width:auto}.user-name{font-size:14px;color:var(--color-text-muted)}.node-count{font-size:13px;color:var(--color-text-muted)}.dashboard-body{display:flex;flex:1;overflow:hidden;position:relative}.dashboard-main{flex:1;position:relative;overflow:hidden}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--color-bg-card);border-radius:12px;padding:28px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{font-size:20px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.modal-actions .btn{width:auto}.loading{text-align:center;padding:40px;color:var(--color-text-muted)}.graph-svg{width:100%;height:100%;background:var(--color-bg-graph);cursor:grab}.graph-svg:active{cursor:grabbing}.toolbar-floating{position:absolute;bottom:20px;left:20px;display:flex;align-items:center;background:var(--color-toolbar-bg);border:1px solid var(--color-border);border-radius:8px;padding:4px;box-shadow:var(--shadow-sm);z-index:5}.toolbar-btn{width:36px;height:36px;border:none;background:transparent;border-radius:6px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:background .15s}.toolbar-btn:hover{background:var(--color-primary-light)}.toolbar-zoom-level{width:auto;padding:0 8px;font-size:12px;font-weight:600;color:var(--color-text-muted)}.toolbar-divider{width:1px;height:24px;background:var(--color-border);margin:0 4px}.detail-sidebar{width:340px;background:var(--color-bg-card);border-left:1px solid var(--color-border);overflow-y:auto;flex-shrink:0;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.node-detail{padding:20px}.node-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;position:relative}.node-detail-header .btn-close{position:absolute;top:-4px;right:-4px}.node-detail-avatar{width:56px;height:56px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:20px;flex-shrink:0}.node-detail-header h2{font-size:18px;margin-bottom:2px}.node-detail-alias{font-size:13px;color:var(--color-text-muted);font-style:italic}.node-detail-notes{font-size:13px;color:var(--color-text-secondary);line-height:1.5;white-space:pre-wrap;word-break:break-word}.node-detail-section{margin-bottom:20px}.node-detail-section h3{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--color-border-light)}.text-muted{font-size:13px;color:var(--color-text-muted)}.connection-list{list-style:none}.connection-item{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--color-border-light);font-size:13px;gap:8px}.connection-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.connection-name{font-weight:500;color:var(--color-text)}.connection-strength{display:flex;align-items:center;gap:8px}.strength-bar{flex:1;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.strength-bar-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.strength-label{font-size:11px;color:var(--color-text-muted);min-width:30px;text-align:right}.connection-roles{display:flex;gap:4px;flex-wrap:wrap}.connection-actions{display:flex;gap:4px;flex-shrink:0;padding-top:2px}.btn-icon-sm{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-card);color:var(--color-text-muted);cursor:pointer;font-size:13px;transition:all .15s}.btn-icon-sm:hover{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.btn-icon-danger:hover{background:var(--color-error-bg);color:var(--color-danger);border-color:var(--color-danger)}.role-pill{display:inline-block;padding:2px 10px;background:var(--color-chip-bg);color:var(--color-chip-text);border-radius:12px;font-size:11px;font-weight:500}.node-detail-actions{display:flex;flex-direction:column;gap:8px;margin-top:20px}.node-detail-actions .btn{width:100%}.chips-input{display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1px solid var(--color-input-border);border-radius:8px;min-height:44px;align-items:center;cursor:text;background:var(--color-input-bg);transition:border-color .2s}.chips-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.chips-input input{border:none!important;outline:none;padding:2px 4px!important;font-size:14px;flex:1;min-width:120px;box-shadow:none!important;background:transparent!important;color:var(--color-text)!important}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:var(--color-chip-bg);color:var(--color-chip-text);border-radius:16px;font-size:13px;font-weight:500}.chip-remove{background:none;border:none;font-size:14px;cursor:pointer;color:var(--color-chip-text);line-height:1;padding:0 2px;opacity:.7}.chip-remove:hover{opacity:1}.range-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:3px;outline:none;cursor:pointer}.range-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-bg-card);box-shadow:var(--shadow-sm)}.range-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-bg-card);box-shadow:var(--shadow-sm)}.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--color-text-muted);margin-top:4px}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--color-danger);color:#fff;border-radius:9px;font-size:11px;font-weight:600;margin-left:6px}.share-btn{position:relative}.share-page{min-height:100vh;background:var(--color-bg);color:var(--color-text)}.share-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);padding:0 24px;background:var(--color-bg-card)}.share-tab{padding:12px 24px;border:none;background:none;color:var(--color-text-muted);cursor:pointer;font-size:14px;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.share-tab:hover{color:var(--color-text)}.share-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.share-content{padding:24px;max-width:800px;margin:0 auto}.share-empty{text-align:center;padding:60px 0}.share-list{display:flex;flex-direction:column;gap:12px}.share-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm)}.share-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.share-card-body{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;color:var(--color-text-secondary)}.share-card-actions{display:flex;gap:8px}.share-status{font-size:12px;font-weight:500;padding:3px 10px;border-radius:12px}.share-status-pending{background:#fef3c7;color:#92400e}.share-status-accepted{background:#d1fae5;color:#065f46}.share-status-rejected{background:#fde8e8;color:#991b1b}.dark .share-status-pending{background:#fbbf2426;color:#fbbf24}.dark .share-status-accepted{background:#34d39926;color:#34d399}.dark .share-status-rejected{background:#f8717126;color:#f87171}.share-success{text-align:center;padding:32px 0;color:#065f46;font-weight:500}.dark .share-success{color:#34d399}.modal-large{max-width:700px;width:95%;max-height:85vh;overflow-y:auto}.merge-summary{display:flex;align-items:center;gap:8px;padding:12px 0;font-size:14px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-light);margin-bottom:16px}.merge-dot{width:4px;height:4px;border-radius:50%;background:var(--color-text-muted)}.merge-choose{display:flex;flex-direction:column;gap:12px;padding:16px 0}.merge-option-card{text-align:left;padding:16px;border:1px solid var(--color-border);border-radius:10px;background:var(--color-bg-card);cursor:pointer;transition:all .15s;color:var(--color-text)}.merge-option-card:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.merge-option-card strong{display:block;margin-bottom:6px;font-size:15px}.merge-option-card p{font-size:13px;color:var(--color-text-muted);margin:0}.merge-stats{display:flex;gap:12px;margin-bottom:16px}.merge-stat{font-size:12px;font-weight:500;padding:3px 10px;border-radius:12px}.merge-stat-match{background:#dbeafe;color:#1e40af}.merge-stat-new{background:#d1fae5;color:#065f46}.merge-stat-skip{background:var(--color-secondary-btn);color:var(--color-text-muted)}.dark .merge-stat-match{background:#60a5fa26;color:#60a5fa}.dark .merge-stat-new{background:#34d39926;color:#34d399}.merge-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;max-height:400px;overflow-y:auto}.merge-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-bg);border-radius:8px;font-size:13px}.merge-row-source{flex:1;min-width:0}.merge-row-arrow{color:var(--color-text-muted);flex-shrink:0}.merge-row-target{flex:1.5;min-width:0}.merge-row-target select{width:100%;padding:6px 8px;border:1px solid var(--color-input-border);border-radius:6px;background:var(--color-input-bg);color:var(--color-text);font-size:12px}.merge-label{font-size:12px;padding:3px 10px;border-radius:8px}.merge-label-match{background:#dbeafe;color:#1e40af}.merge-label-new{background:#d1fae5;color:#065f46}.merge-label-skip{background:var(--color-secondary-btn);color:var(--color-text-muted)}.dark .merge-label-match{background:#60a5fa26;color:#60a5fa}.dark .merge-label-new{background:#34d39926;color:#34d399}.landing{min-height:100vh;background:var(--color-bg)}.landing-nav{position:sticky;top:0;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);z-index:20}.landing-nav-inner{max-width:1100px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between}.landing-logo{font-size:24px;font-weight:700;color:var(--color-primary)}.landing-nav-links{display:flex;align-items:center;gap:16px}.landing-nav-link{color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:500}.landing-nav-link:hover{color:var(--color-primary)}.lang-toggle{font-weight:600;font-size:12px;letter-spacing:.5px;padding:4px 10px;border-radius:4px;background:var(--color-primary-light);color:var(--color-primary);border:1px solid var(--color-primary);cursor:pointer;transition:background .2s,color .2s}.lang-toggle:hover{background:var(--color-primary);color:#fff}.landing-cta-nav{width:auto!important}.social-proof-bar{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 24px;background:var(--color-primary-light);font-size:13px;font-weight:500;color:var(--color-primary)}.social-proof-dot{width:8px;height:8px;border-radius:50%;background:#34d399;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.hero{max-width:1100px;margin:0 auto;padding:80px 24px 60px;display:flex;align-items:center;gap:60px}.hero-content{flex:1}.hero-badge{display:inline-block;padding:6px 14px;background:var(--color-primary-light);color:var(--color-primary);border-radius:20px;font-size:13px;font-weight:600;margin-bottom:20px}.hero-title{font-size:46px;font-weight:800;line-height:1.12;color:var(--color-text);margin-bottom:20px;letter-spacing:-.5px}.hero-title-accent{background:linear-gradient(135deg,var(--color-primary),#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:18px;color:var(--color-text-muted);line-height:1.7;margin-bottom:32px;max-width:520px}.hero-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.hero-main-cta{width:auto!important;font-size:16px!important;padding:14px 32px!important;box-shadow:0 4px 14px #667eea66;transition:box-shadow .2s,transform .2s}.hero-main-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px #667eea80}.hero-cta-note{font-size:13px;color:var(--color-text-muted);padding-left:4px}.hero-visual{flex:1;display:flex;justify-content:center}.hero-graph{width:100%;max-width:400px;height:auto}.section-title{text-align:center;font-size:32px;font-weight:700;color:var(--color-text);margin-bottom:16px}.section-subtitle{text-align:center;font-size:16px;color:var(--color-text-muted);margin-bottom:48px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.6}.section-title+.features-grid,.section-title+.use-cases-grid,.section-title+.steps,.section-title+.testimonials-grid{margin-top:48px}.pain-section{background:var(--color-bg-card);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.pain-inner{max-width:900px;margin:0 auto;padding:80px 24px;text-align:center}.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px}.pain-card{padding:24px;border-radius:12px;background:var(--color-bg);border:1px solid var(--color-border)}.pain-icon{font-size:28px;display:block;margin-bottom:12px}.pain-card p{font-size:14px;color:var(--color-text-muted);line-height:1.6;font-style:italic}.pain-resolution{font-size:18px;color:var(--color-text);margin-top:8px}.features{max-width:1100px;margin:0 auto;padding:80px 24px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}.feature-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:28px;transition:box-shadow .2s}.feature-card:hover{box-shadow:var(--shadow-md)}.feature-icon{width:44px;height:44px;background:var(--color-primary-light);color:var(--color-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.feature-icon svg{width:22px;height:22px}.feature-card h3{font-size:17px;font-weight:600;margin-bottom:8px;color:var(--color-text)}.feature-card p{font-size:14px;color:var(--color-text-muted);line-height:1.6}.feature-card-highlight{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 4px 12px #667eea26;position:relative}.feature-new-badge{position:absolute;top:12px;right:12px;padding:3px 10px;border-radius:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--color-primary);color:#fff}.genealogy-showcase{background:var(--color-bg-card);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.genealogy-inner{max-width:1100px;margin:0 auto;padding:80px 24px;display:flex;align-items:center;gap:60px}.genealogy-content{flex:1}.genealogy-label{display:inline-block;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#f472b626;color:#f472b6;margin-bottom:16px}.genealogy-content h2{font-size:32px;font-weight:700;line-height:1.2;color:var(--color-text);margin-bottom:16px}.genealogy-content p{font-size:15px;color:var(--color-text-muted);line-height:1.7;margin-bottom:20px}.genealogy-features{list-style:none;padding:0;margin-bottom:28px}.genealogy-features li{font-size:14px;color:var(--color-text);position:relative;padding:6px 0 6px 24px}.genealogy-features li:before{content:"✓";position:absolute;left:0;color:#34d399;font-weight:700}.genealogy-visual{flex:1;display:flex;justify-content:center}.genealogy-graph{width:100%;max-width:320px;height:auto}.testimonials{max-width:1100px;margin:0 auto;padding:80px 24px}.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.testimonial-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:28px}.testimonial-text{font-size:14px;color:var(--color-text);line-height:1.7;margin-bottom:20px;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:12px}.testimonial-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.testimonial-name{font-size:14px;font-weight:600;color:var(--color-text)}.testimonial-role{font-size:12px;color:var(--color-text-muted)}.how-it-works{max-width:1100px;margin:0 auto;padding:80px 24px}.steps{display:flex;align-items:flex-start;justify-content:center;gap:16px}.step{text-align:center;max-width:260px}.step-number{width:48px;height:48px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;margin:0 auto 14px}.step h3{font-size:17px;font-weight:600;margin-bottom:8px;color:var(--color-text)}.step p{font-size:14px;color:var(--color-text-muted);line-height:1.6}.step-arrow{padding-top:12px;color:var(--color-border)}.step-arrow svg{width:28px;height:28px}.cta-section{text-align:center;padding:80px 24px;background:var(--color-bg-card);border-top:1px solid var(--color-border)}.cta-section h2{font-size:28px;font-weight:700;margin-bottom:12px;color:var(--color-text)}.cta-section p{font-size:16px;color:var(--color-text-muted);margin-bottom:28px}.cta-section .btn-primary{width:auto;display:inline-block}.landing-footer{text-align:center;padding:24px;color:var(--color-text-muted);font-size:13px;border-top:1px solid var(--color-border)}@media(max-width:768px){.hero{flex-direction:column;padding:48px 24px 40px;gap:40px;text-align:center}.hero-title{font-size:30px}.hero-subtitle{max-width:100%}.hero-actions{align-items:center}.pain-grid{grid-template-columns:1fr}.genealogy-inner{flex-direction:column;text-align:center}.genealogy-features{text-align:left;display:inline-block}.testimonials-grid{grid-template-columns:1fr}.steps{flex-direction:column;align-items:center}.step-arrow{transform:rotate(90deg);padding-top:0}}.onboarding-modal{max-width:480px;text-align:center}.onboarding-progress{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:background .3s}.onboarding-dot.active{background:var(--color-primary)}.onboarding-step{display:flex;flex-direction:column;align-items:center;gap:16px}.onboarding-step h2{font-size:22px;font-weight:700}.onboarding-text{font-size:14px;color:var(--color-text-muted);line-height:1.6;max-width:380px}.onboarding-icon{width:64px;height:64px;background:var(--color-primary-light);color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center}.onboarding-icon svg{width:32px;height:32px}.onboarding-step form{width:100%;text-align:left}.onboarding-step .btn-primary{margin-top:8px}.onboarding-contact-row{display:flex;gap:8px;margin-bottom:8px}.onboarding-contact-row .form-group{margin-bottom:0}.onboarding-done{position:relative;overflow:hidden}.confetti-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;top:-10px;width:8px;height:8px;border-radius:2px;animation:confettiFall 3s ease-out forwards}@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(400px) rotate(720deg);opacity:0}}.search-bar-container{position:relative}.search-bar-trigger{display:flex;align-items:center;gap:8px;padding:5px 12px;border:1px solid var(--color-input-border);border-radius:8px;background:var(--color-input-bg);color:var(--color-text-muted);font-size:13px;cursor:pointer;transition:border-color .15s;white-space:nowrap}.search-bar-trigger:hover{border-color:var(--color-primary)}.search-bar-trigger kbd{font-size:11px;padding:1px 5px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text-muted);font-family:inherit}.search-dropdown{position:absolute;top:calc(100% + 4px);right:0;width:340px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;box-shadow:var(--shadow-lg);z-index:50;overflow:hidden}.search-input-wrapper{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);color:var(--color-text-muted)}.search-input-wrapper input{flex:1;border:none;outline:none;font-size:14px;background:transparent;color:var(--color-text)}.search-results{list-style:none;max-height:320px;overflow-y:auto}.search-result-item{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:10px 12px;border:none;background:none;color:var(--color-text);font-size:14px;cursor:pointer;text-align:left;transition:background .1s}.search-result-item:hover{background:var(--color-primary-light)}.search-result-name{font-weight:500}.search-empty{padding:20px;text-align:center;color:var(--color-text-muted);font-size:13px}.group-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;margin-top:4px}.group-badge-sm{display:inline-block;padding:1px 8px;border-radius:10px;font-size:10px;font-weight:600}.group-selector{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.group-chip{padding:4px 12px;border:1.5px solid;border-radius:16px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;background:transparent}.group-chip:hover{opacity:.8}.group-custom-input{flex:1;min-width:80px;padding:4px 8px!important;border:1px solid var(--color-input-border)!important;border-radius:8px!important;font-size:12px!important;background:var(--color-input-bg)!important;color:var(--color-text)!important}.node-detail-interaction{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;background:var(--color-primary-light);border-radius:8px;font-size:13px;color:var(--color-text-secondary);margin-bottom:16px}.interaction-mark-btn{margin-left:auto;font-size:11px!important;padding:3px 10px!important}.reminders-wrapper{position:relative}.reminders-dropdown{position:absolute;top:calc(100% + 4px);right:0;width:320px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;box-shadow:var(--shadow-lg);z-index:50;overflow:hidden}.reminders-header{padding:12px 14px;border-bottom:1px solid var(--color-border-light)}.reminders-header h3{font-size:14px;font-weight:600}.reminders-empty{padding:24px;text-align:center;color:var(--color-text-muted);font-size:13px}.reminders-list{list-style:none;max-height:300px;overflow-y:auto}.reminder-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;border-bottom:1px solid var(--color-border-light)}.reminder-info{display:flex;align-items:center;gap:6px;flex:1;min-width:0;cursor:pointer}.reminder-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reminder-ago{font-size:11px;color:var(--color-text-muted);white-space:nowrap}.reminder-done-btn{flex-shrink:0;width:auto!important;padding:3px 10px!important;font-size:11px!important}.stats-panel{position:absolute;bottom:20px;right:20px;z-index:5}.stats-toggle{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-toolbar-bg);border:1px solid var(--color-border);border-radius:8px;font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s}.stats-toggle:hover{background:var(--color-primary-light)}.stats-toggle-arrow{font-size:10px;color:var(--color-text-muted)}.stats-content{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;padding:16px;margin-top:8px;box-shadow:var(--shadow-md);width:280px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.stat-card{display:flex;flex-direction:column;align-items:center;padding:10px 8px;background:var(--color-bg);border-radius:8px}.stat-value{font-size:20px;font-weight:700;color:var(--color-primary)}.stat-label{font-size:11px;color:var(--color-text-muted);margin-top:2px}.stat-highlight{font-size:12px;color:var(--color-text-secondary);padding:8px 10px;background:var(--color-primary-light);border-radius:6px;margin-bottom:8px}.stat-warning{background:#fbbf241a;color:#b45309}.dark .stat-warning{background:#fbbf241a;color:#fbbf24}.stats-groups{margin-top:8px}.stats-groups h4{font-size:12px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px}.stats-group-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.stats-group-name{font-size:11px;color:var(--color-text-secondary);width:90px;text-align:right;flex-shrink:0}.stats-group-bar-bg{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.stats-group-bar-fill{height:100%;border-radius:3px;transition:width .3s}.stats-group-count{font-size:11px;color:var(--color-text-muted);width:20px;text-align:right}.graph-legend{position:absolute;bottom:70px;left:20px;display:flex;flex-direction:column;gap:4px;background:var(--color-toolbar-bg);border:1px solid var(--color-border);border-radius:8px;padding:8px 12px;box-shadow:var(--shadow-sm);z-index:4}.graph-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-secondary)}.graph-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.filter-panel{display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);font-size:13px;flex-wrap:wrap}.filter-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer;white-space:nowrap}.filter-checkbox input{width:auto}.filter-period{display:flex;align-items:center;gap:8px}.filter-period-label{color:var(--color-text-muted);white-space:nowrap}.filter-period-sep{color:var(--color-text-muted)}.filter-date-input{padding:4px 8px;font-size:12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text)}.deceased-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;background:#94a3b8;color:#fff;margin-top:4px}.node-detail-bio p{margin:2px 0;font-size:13px;color:var(--color-text-muted)}.features-grid-6{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}@media(max-width:768px){.features-grid-6{grid-template-columns:1fr}}.feature-icon-pink{background:#f472b61a;color:#f472b6}.feature-icon-amber{background:#fbbf241a;color:#f59e0b}.feature-icon-green{background:#34d3991a;color:#34d399}.feature-icon-violet{background:#a78bfa1a;color:#a78bfa}.use-cases{max-width:1100px;margin:0 auto;padding:80px 24px}.use-cases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}@media(max-width:768px){.use-cases-grid{grid-template-columns:repeat(2,1fr)}}.use-case-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:24px;text-align:center;transition:box-shadow .2s}.use-case-card:hover{box-shadow:var(--shadow-md)}.use-case-emoji{font-size:32px;display:block;margin-bottom:12px}.use-case-card h3{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--color-text)}.use-case-card p{font-size:13px;color:var(--color-text-muted);line-height:1.5}.pricing-preview{text-align:center;max-width:600px;margin:0 auto;padding:80px 24px}.pricing-text{font-size:16px;color:var(--color-text-muted);line-height:1.7;margin-bottom:28px}.pricing-preview .btn-primary{width:auto;display:inline-block}.import-instructions{font-size:14px;color:var(--color-text-secondary);line-height:1.6;margin-bottom:16px}.import-instructions code{background:var(--color-primary-light);padding:2px 6px;border-radius:4px;font-size:13px}.drop-zone{border:2px dashed var(--color-border);border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color .2s,background .2s;color:var(--color-text-muted)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--color-primary);background:var(--color-primary-light)}.drop-zone-icon{font-size:32px}.drop-zone-hint{font-size:13px;color:var(--color-text-muted)}.import-preview p{margin-bottom:12px;font-size:14px}.import-warning{color:#f59e0b}.import-table-wrapper{max-height:260px;overflow-y:auto;border:1px solid var(--color-border-light);border-radius:8px;margin-bottom:16px}.import-table{width:100%;border-collapse:collapse;font-size:13px}.import-table th{background:var(--color-primary-light);padding:8px 12px;text-align:left;font-weight:600;position:sticky;top:0}.import-table td{padding:8px 12px;border-top:1px solid var(--color-border-light)}.import-table .duplicate-row{opacity:.5;text-decoration:line-through}.import-more{text-align:center;font-size:13px;color:var(--color-text-muted);padding:8px}.import-mapping{background:var(--color-primary-light);border-radius:8px;padding:12px 16px}.import-mapping h4{font-size:13px;margin-bottom:8px}.import-mapping ul{list-style:none;padding:0;margin:0;font-size:13px;color:var(--color-text-secondary)}.import-mapping li{padding:2px 0}.import-progress{text-align:center;padding:20px 0}.progress-bar{width:100%;height:8px;background:var(--color-border-light);border-radius:4px;overflow:hidden;margin:16px 0}.progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s}.import-stats{font-size:14px;color:var(--color-text-secondary)}.import-error-stat{color:var(--color-error-text)}.import-done{text-align:center;padding:20px 0}.import-done-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#d1fae5;color:#059669;font-size:24px;margin-bottom:12px}.import-summary{list-style:none;padding:0;margin:12px 0 0;font-size:14px;color:var(--color-text-secondary)}.import-summary li{padding:4px 0}.linkedin-banner{position:relative;background:linear-gradient(135deg,#0077b5,#005f8d);color:#fff;border-radius:12px;padding:20px 24px;margin:12px;z-index:5;box-shadow:0 4px 16px #0077b54d}.linkedin-banner-close{position:absolute;top:10px;right:14px;background:none;border:none;color:#ffffffb3;font-size:20px;cursor:pointer;padding:0;line-height:1}.linkedin-banner-close:hover{color:#fff}.linkedin-banner-content{display:flex;gap:16px;align-items:flex-start}.linkedin-banner-icon{flex-shrink:0;width:44px;height:44px;background:#ffffff26;border-radius:10px;display:flex;align-items:center;justify-content:center}.linkedin-banner-icon svg{width:24px;height:24px}.linkedin-banner-text h3{margin:0 0 12px;font-size:16px;font-weight:600}.linkedin-banner-steps{display:flex;flex-direction:column;gap:8px}.linkedin-banner-step{display:flex;align-items:flex-start;gap:10px;font-size:13px;line-height:1.5;opacity:.92}.linkedin-banner-step code{background:#fff3;padding:1px 5px;border-radius:3px;font-size:12px}.step-number{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.linkedin-banner-actions{display:flex;align-items:center;gap:12px;margin-top:16px;padding-left:60px}.linkedin-banner-btn{background:#fff!important;color:#0077b5!important;font-weight:600;border:none!important;padding:10px 20px!important}.linkedin-banner-btn:hover{background:#f0f0f0!important}.linkedin-banner-dismiss{background:transparent!important;border:1px solid rgba(255,255,255,.4)!important;color:#fffc!important;font-size:12px}.linkedin-banner-dismiss:hover{background:#ffffff1a!important;color:#fff!important}.beta-tag{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#f59e0b;color:#fff;padding:2px 6px;border-radius:4px;vertical-align:super;margin-left:2px}.admin-badge{background:var(--color-primary);color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;margin-left:8px;text-transform:uppercase;letter-spacing:.5px}.admin-btn{background:var(--color-primary)!important;color:#fff!important}.admin-btn:hover{background:var(--color-primary-hover)!important}.admin-user-select{padding:6px 12px;border:1px solid var(--color-input-border);border-radius:6px;background:var(--color-input-bg);color:var(--color-text);font-size:14px;min-width:280px}.admin-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);font-size:16px}.mobile-menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px;background:none;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;flex-shrink:0}.mobile-menu-btn span{display:block;width:100%;height:2px;background:var(--color-text);border-radius:1px}.mobile-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200}.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:85vw;background:var(--color-bg-card);z-index:201;display:flex;flex-direction:column;box-shadow:-4px 0 20px #00000026;animation:slideInRight .25s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.mobile-drawer-header .user-name{font-weight:600;font-size:15px}.mobile-drawer-body{flex:1;overflow-y:auto;padding:12px 0;display:flex;flex-direction:column}.mobile-drawer-item{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:none;border:none;text-align:left;font-size:15px;color:var(--color-text);cursor:pointer;width:100%;min-height:48px}.mobile-drawer-item:hover{background:var(--color-primary-light)}.mobile-drawer-item.btn-primary{color:var(--color-primary);font-weight:600}.mobile-drawer-item:disabled{opacity:.4;cursor:not-allowed}.mobile-drawer-divider{height:1px;background:var(--color-border);margin:8px 20px}.mobile-drawer-logout{color:var(--color-danger)}@media(max-width:1024px){.detail-sidebar{width:300px}.dashboard-header .header-right .user-name{display:none}.hero-title{font-size:36px}.hero-subtitle{font-size:16px}.onboarding-modal{max-width:90vw}}@media(max-width:640px){.dashboard-header{padding:8px 12px;gap:8px}.dashboard-header .header-right{display:none}.dashboard-header .header-center{flex:1;text-align:center}.dashboard-header .header-center .node-count{font-size:12px}.mobile-menu-btn{display:flex}.dashboard-header h1{font-size:18px}.detail-sidebar{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;z-index:50;border-left:none}.dashboard.detail-open .dashboard-main{display:block}.modal-overlay{padding:0;align-items:stretch}.modal{max-width:100%;width:100%;height:100%;max-height:100%;border-radius:0;padding:16px;margin:0}.modal-large{max-width:100%;width:100%;height:100%;max-height:100%;border-radius:0;padding:16px}.modal-header h2{font-size:18px}.search-dropdown{position:fixed;top:56px;left:12px;right:12px;width:auto;max-height:60vh}.search-bar-trigger{padding:6px 10px}.search-bar-trigger span,.search-bar-trigger kbd{display:none}.reminders-dropdown{position:fixed;top:56px;left:12px;right:12px;width:auto;max-height:70vh;z-index:100}.filter-panel{position:relative;width:100%;height:auto;flex-direction:column;align-items:stretch;padding:8px 12px;gap:8px;border-right:none;border-bottom:1px solid var(--color-border)}.filter-period{flex-wrap:wrap;gap:6px}.filter-date-input{flex:1;min-width:0}.form-row{flex-direction:column;gap:0}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions .btn{width:100%}.group-selector{flex-wrap:wrap}.group-custom-input{width:100%;margin-top:8px}.auth-card{padding:20px;margin:16px;border-radius:12px}.auth-card h1{font-size:22px}.auth-card h2{font-size:18px}.toolbar-floating{left:50%;transform:translate(-50%);bottom:12px}.toolbar-btn{width:38px;height:38px;font-size:16px}.stats-panel{left:0;right:0;width:100%}.stats-panel.open{width:100%}.stats-grid{grid-template-columns:repeat(2,1fr)}.linkedin-banner{margin:8px;padding:12px}.linkedin-banner-content{flex-direction:column}.linkedin-banner-steps{font-size:13px}.linkedin-banner-actions{flex-direction:column;gap:8px}.share-page .dashboard-header{flex-wrap:wrap;gap:8px}.share-page .dashboard-header .header-left,.share-page .dashboard-header .header-right{display:flex}.share-page .dashboard-header .header-left h1{font-size:18px}.share-tabs{gap:0}.share-tab{flex:1;text-align:center;padding:10px 8px;font-size:14px}.share-card{padding:12px}.share-card-header{flex-direction:column;align-items:flex-start;gap:6px}.share-card-actions{flex-direction:column;gap:6px}.share-card-actions .btn{width:100%}.merge-choose{flex-direction:column}.merge-row{flex-direction:column;gap:4px}.merge-row-arrow{transform:rotate(90deg);align-self:center}.merge-stats{flex-wrap:wrap;gap:6px}.onboarding-modal{max-width:100%;border-radius:0}.onboarding-contact-row{flex-direction:column}.landing-nav-inner{padding:0 12px}.landing-logo{font-size:20px}.landing-nav-links{gap:8px}.landing-nav-link{font-size:13px}.landing-cta-nav{font-size:13px;padding:6px 12px}.social-proof-bar{font-size:12px;padding:8px 12px}.hero{padding:40px 16px;flex-direction:column}.hero-content{text-align:center}.hero-title{font-size:28px;line-height:1.2}.hero-subtitle{font-size:15px}.hero-main-cta{width:100%;text-align:center}.hero-visual{max-width:300px;margin:0 auto}.pain-section{padding:40px 16px}.section-title{font-size:22px}.section-subtitle{font-size:14px}.pain-grid{grid-template-columns:1fr;gap:12px}.features{padding:40px 16px}.features-grid,.features-grid-6{grid-template-columns:1fr;gap:12px}.feature-card{padding:20px}.genealogy-showcase{padding:40px 16px}.genealogy-inner{flex-direction:column}.genealogy-content{text-align:center}.genealogy-content h2{font-size:22px}.genealogy-features{text-align:left}.genealogy-content .btn{width:100%}.use-cases{padding:40px 16px}.use-cases-grid{grid-template-columns:1fr;gap:12px}.how-it-works{padding:40px 16px}.steps{flex-direction:column;gap:16px}.step-arrow{transform:rotate(90deg);width:24px;height:24px;align-self:center}.testimonials{padding:40px 16px}.testimonials-grid{grid-template-columns:1fr;gap:12px}.pricing-preview{padding:40px 16px}.pricing-text{font-size:15px}.pricing-preview .btn{width:100%}.cta-section{padding:40px 16px}.cta-section h2{font-size:22px}.cta-section .btn{width:100%}.landing-footer{padding:20px 16px;font-size:13px}.admin-user-select{min-width:0;width:100%;font-size:13px}.btn-sm{min-height:36px;padding:8px 12px}.btn-icon{min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.search-result-item{padding:12px;min-height:44px}.reminder-item,.connection-item{padding:10px 0}.import-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.import-table{font-size:13px}.drop-zone{padding:24px 16px}}
