:root{--heritage-50: #fdfbf7;--heritage-100: #f9f6f0;--heritage-200: #f0ebe0;--heritage-300: #e8dcc8;--heritage-400: #dcc9a0;--heritage-500: #d4af37;--heritage-600: #c29f2f;--heritage-700: #b8941f;--heritage-800: #8a6f17;--primary: var(--heritage-500);--primary-dark: var(--heritage-700);--primary-light: var(--heritage-300);--earth-50: #f5f3f0;--earth-100: #e8e3dc;--earth-200: #d1c4b5;--earth-300: #b8a896;--earth-400: #8b7355;--earth-500: #6d5944;--earth-600: #5a4937;--earth-700: #453829;--earth-800: #2d241c;--secondary: var(--earth-400);--accent: var(--earth-300);--forest-400: #6a9776;--forest-500: #4a7a57;--forest-600: #3d6447;--burgundy-400: #b86e7b;--burgundy-500: #a04d5c;--burgundy-600: #84404d;--neutral-50: #fafaf9;--neutral-100: #f5f5f4;--neutral-200: #e7e5e4;--neutral-300: #d6d3d1;--neutral-400: #a8a29e;--neutral-500: #78716c;--neutral-600: #57534e;--neutral-700: #44403c;--neutral-800: #292524;--gray-50: var(--neutral-50);--gray-100: var(--neutral-100);--gray-200: var(--neutral-200);--gray-300: var(--neutral-300);--gray-400: var(--neutral-400);--gray-500: var(--neutral-500);--gray-600: var(--neutral-600);--gray-700: var(--neutral-700);--gray-800: var(--neutral-800);--gray-900: var(--earth-800);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--male: #3b82f6;--female: #ec4899;--gender-other: var(--neutral-500);--font-header: "Playfair Display", Georgia, "Times New Roman", serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-mono: "SF Mono", "Roboto Mono", Consolas, "Courier New", monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--spacing-xs: var(--space-1);--spacing-sm: var(--space-2);--spacing-md: var(--space-3);--spacing-lg: var(--space-4);--spacing-xl: var(--space-6);--spacing-2xl: var(--space-8);--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-xl: .75rem;--radius-2xl: 1rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--surface: #ffffff;--surface-2: var(--heritage-50);--surface-3: var(--heritage-100);--app-bg: var(--heritage-50);--border: var(--gray-200);--text: var(--neutral-800);--text-muted: var(--neutral-500);color-scheme:light}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--app-bg);color:var(--text);line-height:1.6;transition:background-color var(--transition-base),color var(--transition-base);font-size:.9rem;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-header);color:var(--heritage-700);font-weight:700;line-height:1.3}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}.navbar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:1000}.navbar-brand{font-weight:700;font-size:1.5rem;color:var(--heritage-700);text-decoration:none;display:flex;align-items:center;gap:var(--spacing-sm);transition:color var(--transition-base)}.navbar-brand:hover{color:var(--primary-dark)}.navbar-brand i{font-size:1.75rem}.nav-link{color:var(--gray-700);font-weight:500;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-base);text-decoration:none;display:flex;align-items:center;gap:var(--spacing-xs)}.nav-link:hover{background:var(--gray-100);color:var(--primary)}.navbar-text{color:var(--gray-600);font-size:.875rem}.btn{font-weight:500;border-radius:var(--radius-md);padding:.5rem 1rem;font-size:.85rem;transition:all var(--transition-base);border:none;cursor:pointer;display:inline-flex;align-items:center;gap:var(--spacing-xs);text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 2px 4px #0000001a}.btn-secondary{background:var(--gray-200);color:var(--gray-900)}.btn-secondary:hover{background:var(--gray-300)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#dc2626}.btn-outline-primary{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline-primary:hover{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.btn-outline-secondary{background:transparent;color:var(--gray-700);border:1.5px solid var(--gray-400);--bs-btn-hover-color: var(--gray-900);--bs-btn-hover-bg: var(--gray-100);--bs-btn-hover-border-color: var(--gray-400);--bs-btn-active-color: var(--gray-900);--bs-btn-active-bg: var(--gray-200)}.btn-outline-secondary:hover{background:var(--gray-100);border-color:var(--gray-400);color:var(--gray-900)}.btn-sm{padding:.35rem .7rem;font-size:.8rem}.btn-lg{padding:.65rem 1.25rem;font-size:.95rem}.btn-xs{padding:.25rem .5rem;font-size:.75rem}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg)}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-lg);border-top:1px solid var(--gray-200);background:var(--gray-50)}.flash{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500}.flash.success{background:#d1fae5;color:#065f46;border-left:4px solid var(--success)}.flash.error{background:#fee2e2;color:#991b1b;border-left:4px solid var(--error)}.flash.info{background:#dbeafe;color:#1e40af;border-left:4px solid var(--info)}.hero-section{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-2xl);margin-bottom:var(--spacing-2xl);display:grid;grid-template-columns:1fr 300px;gap:var(--spacing-xl);align-items:center;border:1px solid #e8dcc8;box-shadow:var(--shadow-sm)}.hero-content{max-width:600px}.hero-title{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-sm);line-height:1.3}.hero-subtitle{font-size:.95rem;color:var(--gray-600);margin-bottom:var(--spacing-lg);line-height:1.5}.hero-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.hero-illustration{display:flex;align-items:center;justify-content:center;font-size:6rem;color:var(--primary);opacity:.1}.quick-actions-section,.features-section{margin-bottom:var(--spacing-2xl)}.section-title{font-size:1.35rem;font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-lg)}.actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-md)}.action-card{background:var(--surface);border:1px solid #e8dcc8;border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base);text-decoration:none;color:inherit;display:flex;flex-direction:column;position:relative}.action-card:hover{transform:translateY(-1px);box-shadow:0 3px 8px #00000014;border-color:var(--primary-light)}.action-card-disabled{opacity:.6;cursor:not-allowed}.action-card-disabled:hover{transform:none;box-shadow:none;border-color:#e8dcc8}.action-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:var(--spacing-md)}.action-card h3{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.action-card p{font-size:.8rem;color:var(--gray-600);line-height:1.5;margin-bottom:0}.action-card .badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);font-size:.7rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.feature-card{background:var(--surface);border:1px solid #f0ebe0;border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;transition:all var(--transition-base)}.feature-card:hover{border-color:var(--primary-light);box-shadow:0 2px 6px #0000000f}.feature-icon{width:56px;height:56px;border-radius:50%;background:#fdfbf7;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin:0 auto var(--spacing-md);border:2px solid #e8dcc8}.feature-card h3{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.feature-card p{font-size:.85rem;color:var(--gray-600);line-height:1.5;margin-bottom:0}@media (max-width: 768px){.hero-section{grid-template-columns:1fr;padding:var(--spacing-lg)}.hero-illustration{display:none}.hero-title{font-size:1.5rem}.actions-grid,.features-grid{grid-template-columns:1fr}}.page-header{margin-bottom:var(--spacing-2xl)}.page-title{font-size:1.65rem;font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:.9rem;color:var(--gray-600);font-weight:400}.trees-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.tree-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base);position:relative;overflow:hidden;border:1px solid #e8dcc8;display:flex;flex-direction:column}.tree-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);opacity:.6}.tree-card:hover{transform:translateY(-1px);box-shadow:0 4px 10px #00000014;border-color:var(--primary-light)}.tree-card-header{margin-bottom:var(--spacing-md)}.tree-card-title{font-size:1.125rem;font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.tree-card-description{color:var(--gray-600);line-height:1.5;font-size:.85rem}.tree-card-stats{display:flex;gap:var(--spacing-md);margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid #f0ebe0}.tree-stat{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--gray-600);font-size:.8rem}.tree-stat i{color:var(--primary)}.tree-card-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.tree-action-main{width:100%;justify-content:center;font-weight:600}.tree-action-tools{display:flex;gap:.4rem;flex-wrap:wrap}.tree-tool-btn{flex:1 1 0;min-width:40px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--heritage-300);border-radius:var(--radius-md);background:var(--heritage-50);color:var(--heritage-700);font-size:.95rem;text-decoration:none;transition:all var(--transition-fast)}.tree-tool-btn:hover{background:var(--heritage-500);border-color:var(--heritage-600);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-gold)}.tree-tool-danger{color:var(--error);border-color:#f0c2c2;background:#fdf3f3}.tree-tool-danger:hover{background:var(--error);border-color:#dc2626;color:#fff;box-shadow:0 6px 18px #ef444440}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);max-width:600px;margin:var(--spacing-2xl) auto}.empty-state i{font-size:4rem;color:var(--gray-300);margin-bottom:var(--spacing-lg)}.empty-state h3{font-size:1.5rem;color:var(--gray-900);margin-bottom:var(--spacing-sm)}.empty-state p{color:var(--gray-600);margin-bottom:var(--spacing-lg)}.tree-view-header{background:linear-gradient(135deg,#fdfbf7,#fff);border-radius:16px;box-shadow:0 2px 12px #0000000a,0 0 1px #00000014;border:1px solid rgba(212,175,55,.12);padding:var(--space-8) var(--space-8);margin-bottom:var(--space-6);position:relative;overflow:hidden}.tree-view-header:before{content:"";position:absolute;top:0;right:0;width:200px;height:200px;background:radial-gradient(circle,rgba(212,175,55,.04) 0%,transparent 70%);pointer-events:none;z-index:0}.tree-header-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-6);position:relative;z-index:1}.tree-header-row:not(:last-child){margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid rgba(212,175,55,.15)}.tree-header-title-section{flex:1;min-width:0}.tree-header-title{font-size:2rem;font-weight:700;color:var(--heritage-700);margin-bottom:var(--space-2);line-height:1.2;letter-spacing:-.5px;display:flex;align-items:center;gap:var(--space-3)}.tree-header-title i{color:var(--heritage-500);font-size:1.75rem;opacity:.9}.tree-header-description{font-size:.95rem;color:var(--neutral-600);margin:0;font-style:italic;font-weight:400;display:flex;align-items:center;gap:var(--space-2)}.tree-header-description i{color:var(--heritage-400);font-size:.85rem}.tree-header-actions{display:flex;gap:var(--space-4);flex-wrap:wrap;align-items:center}.tree-actions-group{display:flex;gap:var(--space-2);padding:0 var(--space-4);border-right:1px solid rgba(212,175,55,.15)}.tree-actions-group:last-child{border-right:none;padding-right:0}.tree-actions-group:first-child{padding-left:0}.tree-view-toggle-group{background:linear-gradient(135deg,#ffffffe6,#fdfbf7e6);border:1px solid rgba(212,175,55,.2);border-radius:12px;padding:.35rem;display:flex;gap:.35rem;box-shadow:0 1px 3px #0000000d}.tree-view-toggle-group .btn{background:transparent;border:none;color:var(--neutral-600);padding:.6rem 1rem;font-size:.85rem;font-weight:500;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative}.tree-view-toggle-group .btn:hover{background:#fffc;color:var(--heritage-600);transform:translateY(-1px)}.tree-view-toggle-group .btn.active{background:linear-gradient(135deg,var(--heritage-500) 0%,var(--heritage-600) 100%);color:#fff;font-weight:600;box-shadow:0 2px 8px #d4af374d,0 1px 2px #0000001a;transform:translateY(-1px)}.tree-view-toggle-group .btn.active i{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.tree-actions-group .btn-outline-success,.tree-actions-group .btn-outline-primary,.tree-actions-group .btn-outline-secondary{border-width:1.5px;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.tree-actions-group .btn-outline-success:hover,.tree-actions-group .btn-outline-primary:hover,.tree-actions-group .btn-outline-secondary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}@media (max-width: 1200px){.tree-header-row{flex-direction:column;align-items:flex-start}.tree-header-actions{width:100%}.tree-actions-group{flex-wrap:wrap}.tree-view-header{padding:var(--space-6) var(--space-6)}}@media (max-width: 768px){.tree-header-title{font-size:1.5rem}.tree-header-title i{font-size:1.35rem}.tree-actions-group{border-right:none;padding:0;width:100%;margin-bottom:var(--space-2)}.tree-view-toggle-group{width:100%}.tree-view-toggle-group .btn{flex:1;padding:.5rem .6rem;font-size:.8rem}.tree-view-header{padding:var(--space-4) var(--space-4);border-radius:12px}.tree-header-row:not(:last-child){margin-bottom:var(--space-4);padding-bottom:var(--space-4)}}.tree-header-simple{background:var(--surface);border:1px solid #e5e5e5;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.tree-header-info h1{font-size:1.75rem;font-weight:600;color:#2c3e50;margin:0 0 .5rem;line-height:1.3}.tree-header-info .text-muted{font-size:.95rem;color:#6c757d;margin:0;line-height:1.5}.tree-view-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.tree-tab{appearance:none;-webkit-appearance:none;-moz-appearance:none;outline:none;border:1px solid #dee2e6;font-family:inherit;line-height:1.5;text-decoration:none;background:#f8f9fa;border-radius:6px;padding:.6rem 1rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:#495057;cursor:pointer;transition:all .2s ease}.tree-tab:hover{background:#e9ecef;border-color:#ced4da;color:#212529}.tree-tab.active{background:linear-gradient(135deg,#d4af37,#b8860b);border-color:#d4af37;color:#fff;font-weight:600;box-shadow:0 2px 4px #d4af374d}.tree-tab i{font-size:1rem}.tree-header-actions-simple{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.tree-header-actions-simple .btn-group{display:inline-flex;gap:0}.tree-header-actions-simple .btn{font-size:.9rem;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;border-radius:6px;transition:all .2s ease}.tree-header-actions-simple .btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}@media (max-width: 768px){.tree-header-simple{padding:1rem;gap:1rem}.tree-header-info h1{font-size:1.5rem}.tree-view-tabs{gap:.4rem}.tree-tab{padding:.5rem .8rem;font-size:.85rem}.tree-tab span{display:none}.tree-tab i{font-size:1.1rem}.tree-header-actions-simple{gap:.5rem}.tree-header-actions-simple .btn{font-size:.85rem;padding:.45rem .8rem}.tree-header-actions-simple .btn span{display:none}}.tree-view-container{display:grid;grid-template-columns:320px 1fr;gap:var(--spacing-md);min-height:calc(100vh - 200px)}.tree-sidebar{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #e8dcc8;height:fit-content;position:sticky;top:80px;max-height:calc(100vh - 100px);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:var(--spacing-md);border-bottom:1px solid #f0ebe0;display:flex;justify-content:space-between;align-items:center;background:#fdfbf7}.sidebar-header h5{font-weight:600;color:var(--gray-900);font-size:.95rem}.sidebar-stats{padding:var(--spacing-md);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs);border-bottom:1px solid #f0ebe0;background:#fdfbf7}.stat-chip{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-xs);background:var(--surface);border-radius:var(--radius-md);border:1px solid #e8dcc8;font-size:.7rem;gap:.25rem}.stat-chip i{font-size:.9rem;color:var(--primary)}.stat-chip span{font-weight:600;color:var(--gray-700)}.sidebar-search{padding:var(--spacing-md);border-bottom:1px solid #f0ebe0}.search-box{position:relative;margin-bottom:var(--spacing-sm)}.search-box i{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:.8rem}.search-input{width:100%;padding:.5rem .5rem .5rem 2rem;border:1px solid #e8dcc8;border-radius:var(--radius-md);font-size:.8rem;background:var(--surface);transition:all var(--transition-base)}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #d4af371a}.filter-buttons{display:flex;flex-direction:column;gap:.25rem}.filter-btn{padding:.4rem .6rem;border:1px solid #e8dcc8;background:var(--surface);border-radius:var(--radius-md);font-size:.75rem;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all var(--transition-base);text-align:left;display:flex;align-items:center;gap:var(--spacing-xs)}.filter-btn:hover{background:#fdfbf7;border-color:var(--primary-light)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-btn i{font-size:.7rem}.sidebar-add-person{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid #f0ebe0}.w-100{width:100%}.sidebar-body{overflow-y:auto;padding:var(--spacing-xs);flex:1}.generation-group{margin-bottom:var(--spacing-xs)}.generation-group.empty-by-search{display:none}.generation-header{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#fdfbf7;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);border:1px solid transparent}.generation-header:hover{background:#f9f6f0;border-color:#e8dcc8}.generation-toggle{font-size:.7rem;color:var(--gray-500);transition:transform var(--transition-base)}.generation-group.collapsed .generation-toggle{transform:rotate(-90deg)}.generation-title{flex:1;font-weight:600;font-size:.8rem;color:var(--gray-800)}.generation-count{font-size:.7rem;font-weight:700;color:var(--heritage-800);background:var(--heritage-100);padding:.125rem .5rem;border-radius:var(--radius-md);border:1px solid var(--heritage-300)}.generation-persons{padding-left:var(--spacing-sm);padding-top:var(--spacing-xs)}.person-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.person-item{padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:.25rem}.person-item:hover{background:#fdfbf7}.person-item.hidden{display:none}.person-avatar{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.person-avatar.male{background:linear-gradient(135deg,#e8f0fe,#d2e3fc);color:var(--male)}.person-avatar.female{background:linear-gradient(135deg,#fce4ec,#f8bbd0);color:var(--female)}.person-info{flex:1;min-width:0}.person-name{font-weight:600;color:var(--gray-900);margin-bottom:.125rem;font-size:.85rem}.person-name-link{color:var(--gray-900);text-decoration:none;transition:color var(--transition-base)}.person-name-link:hover{color:var(--primary)}.person-dates{font-size:.7rem;color:var(--gray-500)}.person-quick-actions{display:flex;gap:.25rem;margin-top:var(--spacing-xs);flex-wrap:wrap}.person-quick-actions .btn-xs{opacity:.7}.person-quick-actions .btn-xs:hover{opacity:1;transform:scale(1.05)}.person-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-base)}.person-item:hover .person-actions{opacity:1}.locate-in-tree{position:relative}.locate-in-tree:hover{background:var(--primary-light);color:#fff;border-color:var(--primary)}.tree-visualization{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #e8dcc8;padding:var(--spacing-md);display:flex;flex-direction:column}.tree-controls-toolbar{display:flex;gap:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#fff,#f9fafb);border:1px solid var(--gray-200);border-radius:var(--radius-md);margin-bottom:.75rem;flex-wrap:wrap;align-items:center;box-shadow:0 2px 4px #0000000d}.tree-controls-toolbar .control-group{display:flex;gap:.4rem;align-items:center;padding:0 .5rem;border-right:1px solid var(--gray-300)}.tree-controls-toolbar .control-group:last-child{border-right:none}.tree-controls-toolbar .control-label{font-size:.75rem;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;margin:0 .25rem 0 0}.tree-controls-toolbar .control-btn{background:var(--surface);border:1px solid var(--gray-300);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:.9rem;color:var(--gray-700);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.tree-controls-toolbar .control-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--gray-900);transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.tree-controls-toolbar .control-btn:active{transform:translateY(0)}.tree-controls-toolbar .control-btn.active{background:var(--primary);border-color:var(--primary-dark);color:#fff}.tree-controls-toolbar .control-btn.filter-toggle:not(.active){opacity:.5;background:var(--gray-100)}.tree-controls-toolbar .zoom-level-display{font-size:.85rem;font-weight:600;color:var(--primary-dark);padding:0 .5rem;min-width:50px;text-align:center}@media (max-width: 1200px){.tree-controls-toolbar{gap:.5rem;padding:.5rem}.tree-controls-toolbar .control-group{padding:0 .3rem}.tree-controls-toolbar .control-label{display:none}}.family-tree-container{width:100%;height:750px;border-radius:var(--radius-md);overflow:hidden;background:#fdfbf7;position:relative}.family-tree-container svg{display:block}.tree-node{transition:all var(--transition-base)}.tree-node:hover rect{stroke-width:3;filter:drop-shadow(0 8px 16px rgba(0,0,0,.15))}.tree-link{transition:all var(--transition-base)}.tree-link:hover{stroke-width:3;stroke-opacity:1}.families-section{margin-top:var(--spacing-2xl)}.families-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md)}.family-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #e8dcc8;overflow:hidden;transition:all var(--transition-base)}.family-card:hover{box-shadow:0 3px 8px #00000014}.family-card-header{background:var(--primary);color:#fff;padding:var(--spacing-md);display:flex;justify-content:space-between;align-items:center}.family-card-title{font-weight:600;font-size:.95rem}.family-card-body{padding:var(--spacing-md);font-size:.85rem}.family-detail{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--gray-100)}.family-detail:last-child{border-bottom:none}.family-detail strong{color:var(--gray-700);font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-xl)}.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid #e8dcc8;display:flex;align-items:center;gap:var(--spacing-md);transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-1px);box-shadow:0 3px 8px #00000014}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--primary);color:#fff}.stat-content h3{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.125rem}.stat-content p{color:var(--gray-600);font-weight:500;font-size:.8rem}.person-detail-container{max-width:1400px;margin:0 auto}.person-detail-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-xl)}.person-detail-header h1{font-size:2.5rem;font-weight:800;margin-bottom:var(--spacing-sm)}.person-detail-grid{display:grid;grid-template-columns:1fr 380px;gap:var(--spacing-lg)}.info-section{background:var(--surface);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-lg)}.info-section h5{font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-lg);font-size:1.25rem}.info-item{padding:var(--spacing-md) 0;border-bottom:1px solid var(--gray-100);display:flex;align-items:start;gap:var(--spacing-md)}.info-item:last-child{border-bottom:none}.info-item strong{min-width:180px;color:var(--gray-700);font-weight:600}.info-item span{color:var(--gray-900);flex:1}.person-link-item{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:background var(--transition-base)}.person-link-item:hover{background:var(--gray-50)}.person-link-item a{color:var(--primary);text-decoration:none;font-weight:500;transition:color var(--transition-base)}.person-link-item a:hover{color:var(--primary-dark);text-decoration:underline}.family-section{background:var(--gray-50);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.spouse-header h5{font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-sm)}.spouse-header a{color:var(--primary);text-decoration:none}.spouse-header a:hover{color:var(--primary-dark)}.children-list{margin-top:var(--spacing-md)}.children-list h6{color:var(--gray-700);font-weight:600;margin-bottom:var(--spacing-sm)}.quick-actions-sidebar{position:sticky;top:90px}.quick-actions-card{background:var(--surface);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-md)}.quick-actions-card h5{font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-lg)}.quick-actions-card .d-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-container{max-width:700px;margin:0 auto;background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-sm);border:1px solid #e8dcc8}.form-container form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{margin-bottom:0}.form-label,form label{display:block;font-weight:600;color:var(--gray-700);margin-bottom:var(--spacing-sm);font-size:.9rem}.person-form-container{max-width:900px;margin:0 auto}.person-form-section{background:#fdfbf7;border:1px solid #e8dcc8;border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:1.5rem}.person-form-section:last-child{margin-bottom:0}.person-form-section-title{font-size:1.1rem;font-weight:700;color:var(--text-dark);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid #e8dcc8;display:flex;align-items:center;gap:.5rem}.person-form-section-title i{color:var(--primary-color);font-size:1rem}.person-form-row{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-bottom:1.25rem}.person-form-row:last-child{margin-bottom:0}@media (min-width: 768px){.person-form-row.two-cols{grid-template-columns:1fr 1fr}.person-form-row.three-cols{grid-template-columns:1fr 1fr 1fr}}.person-form-field{display:flex;flex-direction:column}.person-form-field label{margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--gray-700)}.person-form-field .form-text{font-size:.8rem;color:var(--gray-500);margin-top:.35rem;font-style:italic}.person-form-field.full-width{grid-column:1 / -1}.person-form-checkbox{display:flex;align-items:center;gap:.5rem;padding:.875rem;background:var(--surface);border:1px solid #e8dcc8;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.person-form-checkbox:hover{border-color:var(--primary-color);background:#fffef9}.person-form-checkbox input[type=checkbox]{width:auto;margin:0;cursor:pointer}.person-form-checkbox label{margin:0;cursor:pointer;font-weight:500;flex:1}.person-form-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:2px solid #e8dcc8;margin-top:2rem}.genealogy-date-picker{background:var(--surface);padding:1.25rem;border:1px solid #e8dcc8;border-radius:var(--radius-md);transition:all var(--transition-base)}.genealogy-date-picker:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #c9a9611a}.genealogy-date-picker .preview-text{display:block;padding:.75rem 1rem;background:linear-gradient(135deg,#fffef9,#f8f9fa);border-left:3px solid var(--primary-color);border-radius:var(--radius-sm);font-size:.85rem;color:var(--gray-700);font-weight:500}.genealogy-date-picker select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.form-control,.form-select,form input[type=text],form input[type=email],form input[type=password],form input[type=date],form input[type=number],form textarea,form select{width:100%;padding:.625rem .875rem;border:1px solid #e8dcc8;border-radius:var(--radius-md);font-size:.9rem;transition:all var(--transition-base);background:var(--surface);font-family:inherit;color:var(--gray-900)}form textarea{min-height:100px;resize:vertical}.form-control:focus,.form-select:focus,form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #d4af371a}.form-check{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.form-check input[type=checkbox],form input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}form button[type=submit],form input[type=submit]{align-self:flex-start;margin-top:var(--spacing-sm)}footer{margin-top:var(--spacing-2xl);padding:var(--spacing-2xl) 0;background:var(--gray-900);color:var(--gray-400);text-align:center}footer p{margin:0}@media (max-width: 1024px){.tree-view-container{grid-template-columns:1fr}.tree-sidebar{position:relative;top:0;max-height:400px}.person-detail-grid{grid-template-columns:1fr}.quick-actions-sidebar{position:relative;top:0}}@media (max-width: 768px){.page-title{font-size:2rem}.trees-grid,.families-grid,.stats-grid{grid-template-columns:1fr}}.container-fluid{padding-left:var(--space-6);padding-right:var(--space-6)}@media (max-width: 768px){.container-fluid{padding-left:var(--space-4);padding-right:var(--space-4)}}@media (min-width: 1400px){.container-fluid{padding-left:var(--space-8);padding-right:var(--space-8)}}.text-muted{color:var(--gray-500)}.text-center{text-align:center}.d-flex{display:flex}.align-items-center{align-items:center}.justify-content-between{justify-content:space-between}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600}.badge.bg-success{background:var(--success);color:#fff}.badge.bg-secondary{background:var(--gray-400);color:#fff}.shadow-sm{box-shadow:var(--shadow-sm)}.sticky-top{position:sticky;top:20px}.sign-in-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f8f6f1,#ebe6dc)}.login-container{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{display:grid;grid-template-columns:1fr 1fr;max-width:1000px;width:100%;background:var(--surface);border-radius:24px;box-shadow:0 20px 60px #2c3e501f;overflow:hidden}@media (max-width: 968px){.login-card{grid-template-columns:1fr;max-width:480px}.brand-side{display:none}}.brand-side{background:linear-gradient(135deg,#1e3a5f,#0d1b2a);padding:3.5rem 3rem;color:#fff;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.brand-side:before{content:"";position:absolute;top:-10%;right:-15%;width:400px;height:400px;background:radial-gradient(circle,rgba(212,175,55,.08) 0%,transparent 65%);border-radius:50%}.brand-side:after{content:"";position:absolute;bottom:-20%;left:-10%;width:350px;height:350px;background:radial-gradient(circle,rgba(212,175,55,.06) 0%,transparent 60%);border-radius:50%}.brand-logo{margin-bottom:3rem;text-align:center;position:relative;z-index:1}.brand-icon{width:100px;height:100px;background:linear-gradient(135deg,#d4af3733,#d4af370d);border:2px solid rgba(212,175,55,.4);border-radius:24px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.75rem;box-shadow:0 8px 24px #d4af3726}.brand-icon i{font-size:3rem;color:var(--primary);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.brand-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:#fff;letter-spacing:-.5px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.brand-subtitle{font-size:1.05rem;opacity:.85;line-height:1.7;color:#e2e8f0;max-width:90%;margin:0 auto}.brand-features{margin-top:3rem;position:relative;z-index:1;display:flex;flex-direction:column;gap:.75rem}.feature-item{display:flex;align-items:center;gap:1.25rem;padding:0;background:transparent;border:none;transition:all .2s ease}.feature-item:hover{transform:translate(5px)}.feature-item:hover .feature-icon{background:linear-gradient(135deg,#d4af374d,#d4af371a);border-color:#d4af3780}.feature-icon{width:50px;height:50px;background:linear-gradient(135deg,#d4af3726,#d4af370d);border:1.5px solid rgba(212,175,55,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;flex:0 0 50px;transition:all .2s ease}.feature-icon i{font-size:1.5rem;color:var(--primary)}.feature-item>div:not(.feature-icon){flex:1 1 auto;min-width:0}.feature-item strong{display:block;margin-bottom:.1rem;font-size:1rem;color:#fff;font-weight:600;line-height:1.25}.feature-item small{display:block;opacity:.75;line-height:1.5;color:#cbd5e1;font-size:.9rem}.form-side{padding:3rem 2.5rem;display:flex;flex-direction:column;justify-content:center;background:var(--surface)}.form-header{margin-bottom:2rem}.form-header h2{font-size:1.875rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;letter-spacing:-.5px}.form-header p{color:#64748b;font-size:1rem;line-height:1.5}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;color:var(--text-dark);font-size:.9rem}.input-icon{position:relative}.input-icon i{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-light);font-size:1rem}.input-icon .form-control{padding-left:2.75rem}.form-control{width:100%;padding:var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:.95rem;transition:all .2s ease}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #d4af371a}.form-check{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.form-check input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary);margin:0;flex-shrink:0}.form-check label{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-dark);cursor:pointer;margin:0;padding:0;line-height:1.2}.form-check label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);margin:0;flex-shrink:0;cursor:pointer}.btn-login{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #d4af3740;letter-spacing:.3px}.btn-login:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d4af3759;background:linear-gradient(135deg,#dab547,#c29f2f)}.btn-login:active{transform:translateY(0);box-shadow:0 2px 8px #d4af374d}.sign-in-footer{background:#2c3e50;border-top:1px solid rgba(212,175,55,.2);padding:2.5rem 0;margin-top:auto}.sign-in-footer h5{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:1rem}.sign-in-footer .text-muted{color:#cbd5e1;font-size:.9rem;line-height:1.6}.sign-in-footer ul{list-style:none;padding:0;margin:0}.sign-in-footer ul li{margin-bottom:.5rem}.sign-in-footer a{color:#cbd5e1;text-decoration:none;font-size:.9rem;transition:color .2s ease}.sign-in-footer a:hover{color:var(--primary)}.sign-in-footer hr{border:none;border-top:1px solid rgba(255,255,255,.1);margin:1.5rem 0}.sign-in-footer .text-center p{color:#94a3b8;font-size:.9rem}.flash{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.9rem}.flash.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.flash.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.flash.info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.error{color:var(--error);font-size:.85rem;margin-top:var(--spacing-xs);display:block}.timeline-container{padding:var(--spacing-lg)}.timeline-list{position:relative;padding-left:3rem}.timeline-list:before{content:"";position:absolute;left:1.25rem;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--primary-light),var(--primary))}.timeline-item{position:relative;margin-bottom:2rem;padding-bottom:1rem}.timeline-item:last-child{margin-bottom:0}.timeline-marker{position:absolute;left:-1.75rem;top:.25rem;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface);border:3px solid var(--primary);box-shadow:var(--shadow-md);z-index:2}.timeline-marker i{font-size:.9rem;color:var(--primary-dark)}.timeline-marker.birth{border-color:#10b981}.timeline-marker.birth i{color:#10b981}.timeline-marker.death{border-color:#6b7280}.timeline-marker.death i{color:#6b7280}.timeline-marker.marriage{border-color:#ec4899}.timeline-marker.marriage i{color:#ec4899}.timeline-marker.event{border-color:var(--info)}.timeline-marker.event i{color:var(--info)}.timeline-content{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition-base)}.timeline-content:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.timeline-date{color:var(--primary-dark);font-weight:700;font-size:.95rem;margin-bottom:var(--spacing-xs)}.timeline-title{color:var(--gray-900);font-weight:600;font-size:1.1rem;margin-bottom:var(--spacing-sm)}.timeline-location{color:var(--gray-600);font-size:.85rem;margin-top:var(--spacing-sm)}.timeline-description{color:var(--gray-700);font-size:.9rem;margin-top:var(--spacing-sm);line-height:1.6}.empty-state{text-align:center;padding:3rem 1rem}.empty-state i{opacity:.5}.empty-state h6{color:var(--gray-700);margin:1rem 0 .5rem}.empty-state p{color:var(--gray-600);font-size:.9rem}.memory-card{transition:all var(--transition-base);border:1px solid var(--gray-200)}.memory-card:hover{box-shadow:var(--shadow-lg)!important;transform:translateY(-4px)}.memory-card-image{position:relative;background:var(--gray-100)}.memory-type-icon{display:flex;align-items:center;justify-content:center;height:200px;color:var(--gray-400)}.memory-type-icon.story{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.memory-type-icon.audio{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.memory-type-icon.document{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#6b21a8}.memory-card .card-title{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-sm)}.memory-card .card-text{color:var(--gray-600);line-height:1.5}.memory-card-wrapper{transition:opacity var(--transition-base)}.upload-area{border:2px dashed var(--gray-300);border-radius:var(--radius-lg);padding:var(--spacing-lg);background:var(--gray-50);transition:all var(--transition-base)}.upload-area:hover{border-color:var(--primary);background:var(--surface)}.source-card{transition:all var(--transition-base);border:1px solid var(--gray-200)}.source-card:hover{box-shadow:var(--shadow-lg)!important;transform:translateY(-2px)}.source-card .card-title{font-size:1.1rem;font-weight:600;color:var(--gray-900)}.source-card .badge{font-size:.7rem;font-weight:500}.person-modal-content{padding:.5rem}.person-modal-content .info-section{padding:1rem;margin-bottom:1rem;background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.person-modal-content .section-title{font-size:.95rem;font-weight:600;color:var(--primary-dark);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-light)}.person-modal-content strong{color:var(--gray-700);font-size:.85rem;text-transform:uppercase;letter-spacing:.3px}.person-modal-content .badge{font-size:.8rem;padding:.4rem .7rem;font-weight:500}#personModal .modal-header{background:linear-gradient(135deg,var(--primary-light),var(--primary));color:var(--gray-900);border-bottom:3px solid var(--primary-dark)}#personModal .modal-title{font-weight:600;color:var(--gray-900)}#personModal .modal-footer{background:var(--gray-50);border-top:1px solid var(--gray-200);padding:1rem 1.5rem}#personModal .modal-footer .btn-group{gap:0}#personModal .modal-footer .btn-group .btn{font-size:.85rem;padding:.5rem .9rem;font-weight:500;transition:all .2s ease;border:1px solid var(--gray-300)}#personModal .modal-footer .btn-group .btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;z-index:1}#personModal .modal-footer .btn-outline-primary:hover{background:var(--info);border-color:var(--info);color:#fff}#personModal .modal-footer .btn-outline-warning:hover{background:var(--warning);border-color:var(--warning);color:#fff}#personModal .modal-footer .btn-outline-success:hover{background:var(--success);border-color:var(--success);color:#fff}#personModal .modal-footer .btn-outline-info:hover{background:#ec4899;border-color:#ec4899;color:#fff}#personModal .modal-footer .btn-outline-secondary:hover{background:var(--secondary);border-color:var(--secondary);color:#fff}#personModal .modal-footer .btn i{font-size:.9rem}#personModal .btn-close{filter:brightness(.8)}@media (max-width: 992px){#personModal .modal-footer{flex-direction:column;gap:.75rem}#personModal .modal-footer .btn-group{width:100%;flex-wrap:wrap}#personModal .modal-footer .btn-group .btn{flex:1 1 auto;min-width:120px}}#family-tree-container g.filtered-node,#family-tree-container g.tree-node.filtered-node,#family-tree-container g.pedigree-node.filtered-node,#family-tree-container g.descendant-node.filtered-node{opacity:.15!important;pointer-events:none!important}#family-tree-container g.filtered-node rect,#family-tree-container g.filtered-node text,#family-tree-container g.filtered-node circle,#family-tree-container g.filtered-node path{opacity:.15!important}.person-card{background:var(--surface);border:1px solid var(--heritage-200);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.person-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--heritage-400)}.person-card-header{border-bottom:2px solid var(--heritage-200);padding-bottom:var(--space-4);margin-bottom:var(--space-4)}.tree-node text{fill:var(--neutral-800);font-family:var(--font-body);font-weight:500}.tree-link{stroke:var(--heritage-500);stroke-width:2px;fill:none;transition:all var(--transition-base)}.tree-link:hover{stroke:var(--heritage-600);stroke-width:3px}.badge-free{background-color:var(--neutral-400);color:#fff;font-weight:600}.badge-basic{background-color:var(--success);color:#fff;font-weight:600}.badge-premium{background:linear-gradient(135deg,var(--heritage-500),var(--heritage-700));color:#fff;font-weight:600;box-shadow:0 2px 8px #d4af374d}.badge-enterprise{background:linear-gradient(135deg,var(--burgundy-500),var(--burgundy-600));color:#fff;font-weight:600;box-shadow:0 2px 8px #a04d5c4d}.btn-forest{background-color:var(--forest-500);color:#fff;border:none}.btn-forest:hover{background-color:var(--forest-600);transform:translateY(-1px)}.btn-burgundy{background-color:var(--burgundy-500);color:#fff;border:none}.btn-burgundy:hover{background-color:var(--burgundy-600);transform:translateY(-1px)}.heritage-paper{background:linear-gradient(to bottom,var(--heritage-50) 0%,var(--heritage-100) 100%);border:1px solid var(--heritage-300);box-shadow:var(--shadow-md)}.heritage-paper-subtle{background:var(--heritage-50);border:1px solid var(--heritage-200)}.stat-card-heritage{background:var(--surface);border-left:4px solid var(--heritage-500);padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.stat-card-heritage:hover{box-shadow:var(--shadow-md);border-left-width:6px}.heritage-link{color:var(--heritage-600);text-decoration:none;font-weight:500;transition:all var(--transition-base);border-bottom:2px solid transparent}.heritage-link:hover{color:var(--heritage-700);border-bottom-color:var(--heritage-400)}@media print{nav,.navbar,.sidebar,.tree-sidebar,footer,button,.btn,.controls,.tree-controls-toolbar,.person-actions,.quick-actions,.action-card{display:none!important}*{cursor:default!important;pointer-events:none!important}body{background:#fff!important;color:#000!important}.tree-node rect,.person-card,.card,.info-section{border:1pt solid black!important;background:#fff!important;box-shadow:none!important}h1,h2,h3,h4,h5,h6{color:#000!important;page-break-after:avoid}.tree-node,.person-card,.card,.info-section,.family-card{page-break-inside:avoid}body{font-size:11pt;line-height:1.4}h1{font-size:18pt}h2{font-size:16pt}h3{font-size:14pt}h4{font-size:12pt}h5{font-size:11pt}h6{font-size:10pt}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#666}.page-header,.section-title{margin-top:12pt;margin-bottom:8pt}svg{max-width:100%;height:auto}.tree-node text{font-size:10pt!important;fill:#000!important}.tree-link{stroke:#000!important;stroke-width:1pt!important}}.account-sidebar{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--heritage-200);overflow:hidden}.account-sidebar-header{background:linear-gradient(135deg,var(--heritage-400),var(--heritage-500));padding:var(--space-6);border-bottom:2px solid var(--heritage-600)}.account-sidebar-header h5{color:#fff;font-weight:600;font-size:1.1rem;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.1)}.account-sidebar-header i{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.account-nav-item{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--heritage-100);display:flex;align-items:center;gap:var(--space-4);color:var(--neutral-700);text-decoration:none;transition:all var(--transition-base);font-weight:500}.account-nav-item:hover{background:var(--heritage-50);color:var(--heritage-700);padding-left:calc(var(--space-6) + .25rem)}.account-nav-item.active{background:linear-gradient(90deg,var(--heritage-100),var(--heritage-50));color:var(--heritage-700);border-left:4px solid var(--heritage-500);font-weight:600}.account-nav-item i{font-size:1rem;width:1.25rem;text-align:center}.account-nav-item.danger{color:var(--error)}.account-nav-item.danger:hover{background:#fef2f2;color:#dc2626}.account-nav-item.danger.active{background:linear-gradient(90deg,#fee2e2,#fef2f2);color:#dc2626;border-left-color:var(--error)}.account-user-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--heritage-200);padding:var(--space-6);text-align:center}.account-user-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--heritage-100),var(--heritage-200));display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4);border:3px solid var(--heritage-300)}.account-user-avatar i{font-size:2.5rem;color:var(--heritage-500)}.account-user-card h5{color:var(--neutral-800);font-weight:600;margin-bottom:var(--space-2)}.account-user-card .text-muted{font-size:.9rem;color:var(--neutral-500)}.account-user-card .badge{margin-top:var(--space-3)}a:focus,button:focus,.btn:focus,select:focus,textarea:focus{outline:none}a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--heritage-500);outline-offset:2px;box-shadow:none}.skip-to-content{position:absolute;left:-9999px;z-index:999;padding:var(--space-4);background:var(--heritage-500);color:#fff;text-decoration:none;font-weight:600}.skip-to-content:focus{left:var(--space-4);top:var(--space-4)}@media (prefers-contrast: high){.tree-node rect{stroke-width:3px}.heritage-link{border-bottom:2px solid currentColor}button,.btn{border:2px solid currentColor}}g.tree-node.filtered-out,g.pedigree-node.filtered-out,g.descendant-node.filtered-out,g.person-box-group.filtered-out{opacity:.15;pointer-events:none;transition:opacity .3s ease}g.tree-node.filtered-out+path,g.pedigree-node.filtered-out+path,g.descendant-node.filtered-out+path{opacity:.3}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.admin-tabs{display:flex;flex-wrap:wrap;gap:.5rem;border-bottom:2px solid #ece4d2;padding-bottom:.5rem}.admin-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:8px 8px 0 0;color:#6b6258;text-decoration:none;font-weight:600;transition:all .15s ease}.admin-tab:hover{background:#f5efe1;color:#8a6d1f}.admin-tab.active{background:#c9a961;color:#fff}.admin-stat-card{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid #ece4d2;border-radius:12px;padding:1.1rem 1.25rem;height:100%;box-shadow:0 1px 3px #281e0a0d}.admin-stat-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.admin-stat-value{font-size:1.6rem;font-weight:700;line-height:1.1;color:#2b2b2b}.admin-stat-label{font-size:.85rem;color:#7a7166}:root{--text-dark: var(--neutral-800);--text-light: var(--neutral-400);--border-color: var(--heritage-300);--primary-color: var(--heritage-500);--heritage-900: #5e4c0f}.alert-heritage{background:linear-gradient(135deg,var(--heritage-50),var(--heritage-100));border:1px solid var(--heritage-300);border-left:4px solid var(--heritage-500);color:var(--earth-700)}.alert-heritage strong{color:var(--heritage-800)}.alert-heritage i{color:var(--heritage-600)}.card-header-heritage{background:linear-gradient(135deg,var(--heritage-400),var(--heritage-600));border-bottom:2px solid var(--heritage-700);color:#fff}.card-header-heritage h3,.card-header-heritage h4,.card-header-heritage h5{color:#fff;margin:0}.tariff-header-free{background:var(--heritage-100);border-bottom:2px solid var(--heritage-300)}.tariff-header-free h3{color:var(--heritage-800)}.tariff-header-basic{background:linear-gradient(135deg,var(--heritage-400),var(--heritage-600));border-bottom:2px solid var(--heritage-700)}.tariff-header-basic h3{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.15)}.tariff-header-premium{background:linear-gradient(135deg,var(--earth-500),var(--earth-700));border-bottom:2px solid var(--earth-800)}.tariff-header-premium h3{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.badge-current{background:var(--surface);color:var(--heritage-800);border:1.5px solid var(--heritage-500);font-size:.7rem;font-weight:700;letter-spacing:.3px;vertical-align:middle}.tariff-header-basic .badge-current,.tariff-header-premium .badge-current{background:#ffffff2e;color:#fff;border-color:#fff9}.tariff-card .card-body{display:flex;flex-direction:column}.tariff-card .card-body ul.list-unstyled{flex:1 1 auto}.progress-heritage{height:.85rem;background:var(--heritage-100);border-radius:var(--radius-md);overflow:hidden}.progress-heritage .progress-bar{background:linear-gradient(90deg,var(--heritage-400),var(--heritage-600));transition:width .6s ease;font-size:.68rem;font-weight:600}.progress-heritage .progress-bar.bg-warning{background:linear-gradient(90deg,#e8a838,#c8841a)!important}.text-heritage-gold{color:var(--heritage-700)!important;font-weight:700}.border-heritage-active{border:2px solid var(--heritage-500)!important;box-shadow:0 0 0 3px #d4af371f}.tree-header-info h1{color:var(--heritage-700);font-family:var(--font-header)}.tree-header-simple{border:1px solid var(--heritage-300)!important;background:linear-gradient(180deg,#ffffff 0%,var(--heritage-50) 100%)}.stat-chip span{font-weight:700;font-size:.82rem;color:var(--heritage-700);line-height:1.1}.stat-chip i{font-size:1rem}.display-option-label{font-size:.8rem;cursor:pointer;display:flex;align-items:center;white-space:nowrap;gap:.35rem;color:var(--gray-700);font-weight:500}.display-option-label input[type=checkbox]{width:14px;height:14px;flex-shrink:0;margin:0}#root-person-selector{min-width:200px;max-width:260px}.admin-stat-icon--gold{background:#fbf3df;color:var(--heritage-600)}.admin-stat-icon--crown{background:#f7eccb;color:var(--heritage-800)}.admin-stat-icon--green{background:#e7f0e9;color:var(--forest-500)}.admin-stat-icon--earth{background:#efe8dd;color:var(--earth-400)}.admin-stat-label{margin-top:.15rem}.admin-tabs{padding-bottom:0;gap:.25rem}.admin-tab.active{margin-bottom:-2px;border-bottom:2px solid var(--heritage-500)}.admin-header h1.page-title{border-left:4px solid var(--heritage-500);padding-left:.75rem}.admin-count-badge{background:var(--heritage-100);color:var(--heritage-800);border:1px solid var(--heritage-300);font-weight:700}.admin-vs-code{font-family:var(--font-mono);font-size:.8rem;color:var(--earth-500);background:var(--heritage-50);padding:.1rem .4rem;border-radius:var(--radius-sm);border:1px solid var(--heritage-200)}.tree-controls-display{margin-top:.5rem}.control-group-wrap{flex-wrap:wrap;gap:.5rem}.filter-buttons{display:flex;flex-direction:row;gap:.25rem;flex-wrap:wrap}.filter-buttons .filter-btn{flex:1 1 auto;justify-content:center;min-width:0;text-align:center}.family-tree-container{height:clamp(520px,66vh,880px)}.tree-card-actions .btn-outline-danger{flex:0 0 auto;flex-basis:auto}.navbar-brand{display:inline-flex;align-items:center;gap:.5rem}.navbar-brand i{font-size:1.15rem}:root{--shadow-soft: 0 1px 2px rgba(58, 46, 22, .04), 0 2px 8px rgba(58, 46, 22, .05);--shadow-float: 0 4px 12px rgba(58, 46, 22, .07), 0 12px 28px rgba(58, 46, 22, .08);--shadow-gold: 0 6px 18px rgba(212, 175, 55, .28);--ring-gold: 0 0 0 3px rgba(212, 175, 55, .28)}::selection{background:#d4af3740;color:var(--earth-800)}*{scrollbar-width:thin;scrollbar-color:var(--heritage-400) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--heritage-300);border-radius:10px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--heritage-400);background-clip:padding-box}.btn{font-weight:600;letter-spacing:.2px;position:relative;will-change:transform}.btn-primary{background:linear-gradient(135deg,var(--heritage-500) 0%,var(--heritage-700) 100%);box-shadow:0 2px 8px #d4af3740}.btn-primary:hover{background:linear-gradient(135deg,#e0bd4d 0%,var(--heritage-600) 100%);box-shadow:var(--shadow-gold);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 6px #d4af374d}.btn-success{background:linear-gradient(135deg,#14b87a,#0d8a5b);box-shadow:0 2px 8px #10b98138}.btn-success:hover{background:linear-gradient(135deg,#18c184,#0c7d53);transform:translateY(-2px);box-shadow:0 6px 18px #10b9814d}.btn-danger{background:linear-gradient(135deg,#f25555,#d83a3a);box-shadow:0 2px 8px #ef444433}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 18px #ef44444d}.btn-outline-primary{transition:all var(--transition-base)}.btn-outline-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-gold)}.btn-secondary,.btn-outline-secondary{transition:all var(--transition-base)}.btn-secondary:hover,.btn-outline-secondary:hover{transform:translateY(-1px)}.card{box-shadow:var(--shadow-soft);border:1px solid var(--heritage-200)}.card:hover{box-shadow:var(--shadow-float)}.tariff-card,.admin-stat-card,.tree-card,.feature-card,.action-card{transition:transform var(--transition-base),box-shadow var(--transition-base)}.tariff-card:hover,.admin-stat-card:hover,.tree-card:hover,.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-float)}.form-control{border-radius:var(--radius-md);background:var(--surface)}.form-control:hover:not(:focus){border-color:var(--heritage-400)}.form-control:focus{box-shadow:var(--ring-gold)}.form-select:focus{box-shadow:var(--ring-gold);border-color:var(--heritage-500)}.navbar{background:var(--surface);border-bottom:1px solid var(--heritage-200);box-shadow:0 1px 12px #3a2e160d}.navbar .nav-link{border-radius:var(--radius-md);transition:all var(--transition-fast);padding:.45rem .8rem}.navbar .nav-link:hover{background:var(--heritage-100);color:var(--heritage-800)}.navbar .dropdown-menu{box-shadow:var(--shadow-float);border:1px solid var(--heritage-200);border-radius:var(--radius-md)}.admin-stat-icon{box-shadow:inset 0 0 0 1px #d4af371f}.admin-stat-card{border:1px solid var(--heritage-200)}.tree-controls-toolbar .control-btn{border-radius:10px;box-shadow:var(--shadow-soft)}.tree-controls-toolbar .control-btn.active{background:linear-gradient(135deg,var(--heritage-500),var(--heritage-700));box-shadow:var(--shadow-gold)}.brand-side{background:linear-gradient(150deg,#213a5c,#122236 55%,#0b1622)}.brand-side:before{width:480px;height:480px;background:radial-gradient(circle,rgba(212,175,55,.16) 0%,transparent 66%);animation:brandGlow 7s ease-in-out infinite alternate}@keyframes brandGlow{0%{opacity:.7;transform:scale(1)}to{opacity:1;transform:scale(1.12)}}.brand-icon{box-shadow:0 10px 30px #d4af3747,inset 0 1px #ffffff26}.brand-title{font-family:var(--font-header);letter-spacing:.5px}.feature-item{padding:.5rem .6rem;border-radius:12px}.feature-item:hover{background:#ffffff0a;transform:translate(6px)}.login-card{box-shadow:0 30px 80px #141e3038}.btn-login{font-family:var(--font-body)}body{background:linear-gradient(180deg,#fdfbf7,#faf6ee);background-attachment:fixed}.page-title,.section-title,h1,h2{letter-spacing:-.01em}.btn-link{color:var(--heritage-700);text-decoration:none}.btn-link:hover{color:var(--heritage-800);text-decoration:underline}.btn-outline-primary{--bs-btn-hover-bg: var(--primary);--bs-btn-hover-border-color: var(--primary-dark);--bs-btn-active-bg: var(--primary-dark);--bs-btn-active-border-color: var(--primary-dark);--bs-btn-focus-shadow-rgb: 212, 175, 55}.btn{--bs-btn-focus-shadow-rgb: 212, 175, 55}.btn-outline-primary:active,.btn-outline-primary.active{border-color:var(--primary-dark)!important}.dropdown-item:active,.dropdown-item.active{background-color:var(--heritage-500)}.dropdown-item:focus{background-color:var(--heritage-100)}.form-check-input:checked{background-color:var(--heritage-500);border-color:var(--heritage-600)}.form-check-input:focus{border-color:var(--heritage-400);box-shadow:var(--ring-gold)}.page-link{color:var(--heritage-700)}.page-link:hover{color:var(--heritage-800);background-color:var(--heritage-100)}.page-item.active .page-link{background-color:var(--heritage-500);border-color:var(--heritage-600)}.page-link:focus{box-shadow:var(--ring-gold);color:var(--heritage-800)}.nav-pills .nav-link.active{background-color:var(--heritage-500)}.text-primary,.link-primary{color:var(--heritage-700)!important}.link-primary:hover{color:var(--heritage-800)!important}.bg-primary{background-color:var(--heritage-500)!important}.text-bg-primary{background-color:var(--heritage-500)!important;color:#fff!important}.card-header.bg-primary,.card-header.text-bg-primary{background:linear-gradient(135deg,var(--heritage-400),var(--heritage-600))!important;color:#fff!important}.bg-info{background-color:var(--heritage-100)!important}.text-bg-info{background-color:var(--heritage-100)!important;color:var(--earth-800)!important}.border-primary{border-color:var(--heritage-500)!important}.border-info{border-color:var(--heritage-300)!important}.text-info{color:var(--heritage-600)!important}.badge.bg-primary,.badge.text-bg-primary{background-color:var(--heritage-500)!important;color:#fff!important}.badge.bg-info,.badge.text-bg-info{background-color:var(--heritage-200)!important;color:var(--earth-800)!important}.alert-primary,.alert-info{background-color:var(--heritage-50)!important;border-color:var(--heritage-300)!important;color:var(--earth-700)!important;border-left:4px solid var(--heritage-500)!important}.alert-primary .alert-link,.alert-info .alert-link{color:var(--heritage-800)!important}.btn-info{background-color:var(--heritage-400)!important;border-color:var(--heritage-500)!important;color:#fff!important}.btn-info:hover{background-color:var(--heritage-500)!important}.spinner-border.text-primary,.spinner-grow.text-primary{color:var(--heritage-500)!important}.progress-bar{background-color:var(--heritage-500)}.btn-outline-info{color:var(--burgundy-500);border:1.5px solid var(--burgundy-400);background:transparent}.btn-outline-info:hover{background:var(--burgundy-500);border-color:var(--burgundy-600);color:#fff}.btn-outline-success{color:var(--forest-500);border:1.5px solid var(--forest-400);background:transparent}.btn-outline-success:hover{background:var(--forest-500);border-color:var(--forest-600);color:#fff}.btn-outline-warning{color:#a8780c;border:1.5px solid #e0c068;background:transparent}.btn-outline-warning:hover{background:#d4a017;border-color:#b8860b;color:#fff}.btn-outline-danger{color:var(--error);border:1.5px solid #f0c2c2;background:transparent}.btn-outline-danger:hover{background:var(--error);border-color:#dc2626;color:#fff}.card-header.bg-primary h1,.card-header.bg-primary h2,.card-header.bg-primary h3,.card-header.bg-primary h4,.card-header.bg-primary h5,.card-header.bg-primary h6,.card-header.text-bg-primary h1,.card-header.text-bg-primary h2,.card-header.text-bg-primary h3,.card-header.text-bg-primary h4,.card-header.text-bg-primary h5,.card-header.text-bg-primary h6,.card-header-heritage h1,.card-header-heritage h2,.card-header-heritage h3,.card-header-heritage h4,.card-header-heritage h5,.card-header-heritage h6,.tariff-header-basic h1,.tariff-header-basic h2,.tariff-header-basic h3,.tariff-header-premium h1,.tariff-header-premium h2,.tariff-header-premium h3{color:#fff!important}.stat-bar-row{display:grid;grid-template-columns:130px 1fr 36px;align-items:center;gap:.6rem;margin-bottom:.55rem}.stat-bar-label{font-size:.82rem;color:var(--earth-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.35rem}.stat-bar{height:12px;background:var(--heritage-100);border-radius:6px;overflow:hidden}.stat-bar-fill{height:100%;background:linear-gradient(90deg,var(--heritage-400),var(--heritage-600));border-radius:6px;transition:width .6s ease;min-width:2px}.stat-bar-male{background:linear-gradient(90deg,#6ea2e0,#3b82f6)}.stat-bar-female{background:linear-gradient(90deg,#e89ac0,#e0518a)}.stat-bar-other{background:linear-gradient(90deg,#b7b1a6,#8a8378)}.stat-bar-place{background:linear-gradient(90deg,var(--forest-400),var(--forest-600))}.stat-bar-num{font-size:.8rem;font-weight:700;color:var(--earth-700);text-align:right}.issue-list{display:flex;flex-direction:column;gap:.4rem}.issue-row{display:grid;grid-template-columns:24px minmax(120px,200px) 1fr;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:var(--radius-md);border-left:4px solid var(--neutral-300);background:var(--neutral-50);font-size:.88rem}.issue-row .issue-person a{font-weight:600;color:var(--heritage-700);text-decoration:none}.issue-row .issue-person a:hover{text-decoration:underline}.issue-msg{color:var(--earth-600)}.issue-error{border-left-color:var(--error);background:#fdf3f3}.issue-error .issue-icon{color:var(--error)}.issue-warning{border-left-color:var(--warning);background:#fdf8ee}.issue-warning .issue-icon{color:#c8841a}.issue-info{border-left-color:var(--heritage-400);background:var(--heritage-50)}.issue-info .issue-icon{color:var(--heritage-600)}.person-view-photo{text-align:center;margin-bottom:1.5rem}.person-view-photo-img{max-width:200px;max-height:240px;border-radius:var(--radius-lg);border:3px solid var(--heritage-300);box-shadow:var(--shadow-float);object-fit:cover}.person-photo-current{margin-bottom:.75rem}.person-photo-thumb{max-width:120px;max-height:140px;border-radius:var(--radius-md);border:2px solid var(--heritage-300);object-fit:cover;display:block;margin-bottom:.4rem}.tree-style-select{width:auto;min-width:130px;display:inline-block}.btn-heritage{background:linear-gradient(135deg,var(--heritage-500) 0%,var(--heritage-600) 100%);border:1px solid var(--heritage-600);color:#fff;font-weight:600}.btn-heritage:hover{background:linear-gradient(135deg,var(--heritage-600) 0%,var(--heritage-700) 100%);border-color:var(--heritage-700);color:#fff}.btn-outline-heritage{background:transparent;border:1px solid var(--heritage-600);color:var(--heritage-700);font-weight:600}.btn-outline-heritage:hover{background:var(--heritage-100);border-color:var(--heritage-700);color:var(--heritage-800)}.export-controls{position:sticky;top:1rem;border:1px solid var(--heritage-200);box-shadow:0 4px 18px #3c2d1414}.export-controls-title{color:var(--heritage-800);font-family:var(--font-header);margin-bottom:1.25rem}.export-controls .form-label{font-weight:600;font-size:.85rem;color:var(--earth-600);margin-bottom:.25rem}.export-poster{background:var(--surface);border:1px solid var(--heritage-200);border-radius:8px;box-shadow:0 10px 36px #3c2d1424;padding:28px 32px 18px;display:flex;flex-direction:column;margin:0 auto;width:100%;aspect-ratio:297 / 210}.export-poster[data-orientation=portrait]{aspect-ratio:210 / 297;max-width:720px}.export-poster-header{text-align:center;border-bottom:2px solid var(--heritage-300);padding-bottom:12px;margin-bottom:10px}.export-poster-title{font-family:var(--font-header);font-size:clamp(1.6rem,2.6vw,2.4rem);font-weight:700;color:var(--earth-700);margin:0;letter-spacing:.3px}.export-poster-subtitle{font-family:var(--font-header);font-size:.95rem;color:var(--heritage-700);letter-spacing:3px;text-transform:uppercase;margin-top:4px}.export-tree-container{flex:1 1 auto;min-height:320px;overflow:hidden}.export-poster-footer{text-align:center;border-top:1px solid var(--heritage-200);padding-top:8px;margin-top:6px;font-family:var(--font-header);font-size:.8rem;color:var(--earth-500);letter-spacing:1px}.export-poster-footer-sep{margin:0 8px;color:var(--heritage-500)}@media print{body *{visibility:hidden}.export-poster,.export-poster *{visibility:visible}.export-poster{position:absolute;top:0;left:0;width:100%;box-shadow:none;border:none;border-radius:0}@page{size:landscape;margin:10mm}}.export-advanced{border-top:1px dashed var(--heritage-300);margin-top:.5rem;padding-top:1rem}.export-advanced-title{font-family:var(--font-header);font-size:.95rem;color:var(--heritage-800);margin-bottom:.85rem}.export-toggle{font-weight:500;font-size:.78rem;color:var(--earth-500);cursor:pointer;margin:0}.export-toggle input{margin-right:4px;vertical-align:middle}.export-range-val{font-weight:600;color:var(--heritage-700);font-size:.8rem}.export-advanced .form-control-color{width:100%;height:38px;cursor:pointer}.export-label-fields{display:flex;flex-wrap:wrap;gap:.35rem .85rem}.export-label-fields .export-toggle{white-space:nowrap}.export-presets{background:var(--heritage-50);border:1px solid var(--heritage-200);border-radius:8px;padding:.75rem}.export-tabs{gap:.25rem}.export-tabs .nav-link{color:var(--earth-600);font-weight:600;font-size:.82rem;padding:.4rem .5rem;border-radius:7px}.export-tabs .nav-link:hover{background:var(--heritage-100);color:var(--heritage-800)}.export-tabs .nav-link.active{background:linear-gradient(135deg,var(--heritage-500) 0%,var(--heritage-600) 100%);color:#fff}.theme-toggle{background:transparent;border:0;cursor:pointer;color:var(--earth-600);font-size:1.05rem;line-height:1;padding:.45rem .7rem;border-radius:var(--radius-md);transition:background-color var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background:var(--heritage-100);color:var(--heritage-700)}.theme-toggle:focus-visible{outline:2px solid var(--heritage-500);outline-offset:2px}.theme-toggle-floating{position:fixed;top:1rem;right:1rem;z-index:1050;width:2.6rem;height:2.6rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--surface);color:var(--earth-600);box-shadow:var(--shadow-md)}.theme-toggle-floating:hover{color:var(--heritage-700)}html[data-bs-theme=dark]{color-scheme:dark;--surface: #241e17;--surface-2: #2c261d;--surface-3: #352e23;--app-bg: #17130d;--border: #3a3126;--text: #ece6da;--text-muted: #b4aa99;--heritage-50: #1c160f;--heritage-100: #241d15;--heritage-200: #2e261c;--heritage-300: #3c3225;--heritage-400: #c2a04a;--heritage-700: #e8c869;--heritage-800: #f0d98a;--earth-600: #cdbfa9;--earth-700: #ddd0bd;--earth-800: #ece6da;--neutral-50: #1e1811;--neutral-100: #251e16;--neutral-200: #322a20;--neutral-300: #41382b;--neutral-400: #8a8170;--neutral-500: #a99e8b;--neutral-600: #c5baa7;--neutral-700: #ddd3c3;--neutral-800: #ece6da;--gray-900: #f3eee5;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .55);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6)}html[data-bs-theme=dark] body{background-image:linear-gradient(180deg,#17130d,#1d1812)}html[data-bs-theme=dark] .navbar{background:var(--surface)}html[data-bs-theme=dark] footer.bg-light,html[data-bs-theme=dark] .bg-light{background:var(--surface-2)!important;color:var(--text)}html[data-bs-theme=dark] .theme-toggle,html[data-bs-theme=dark] .theme-toggle-floating{color:var(--heritage-400)}html[data-bs-theme=dark] .theme-toggle:hover,html[data-bs-theme=dark] .theme-toggle-floating:hover{color:var(--heritage-700);background:var(--surface-3)}html[data-bs-theme=dark] .form-control,html[data-bs-theme=dark] .form-select,html[data-bs-theme=dark] textarea{background:var(--surface-2);color:var(--text);border-color:var(--border)}html[data-bs-theme=dark] .form-control::placeholder{color:var(--text-muted)}html[data-bs-theme=dark] .table{color:var(--text);--bs-table-color: var(--text)}html[data-bs-theme=dark] .table-light,html[data-bs-theme=dark] .table-light>th,html[data-bs-theme=dark] .table-light>td,html[data-bs-theme=dark] .table>thead th{--bs-table-bg: var(--surface-3);--bs-table-color: var(--text);background-color:var(--surface-3);color:var(--text);border-color:var(--border)}html[data-bs-theme=dark] .dropdown-menu{background:var(--surface);border-color:var(--border)}html[data-bs-theme=dark] .dropdown-item{color:var(--text)}html[data-bs-theme=dark] .dropdown-item:hover{background:var(--surface-3);color:var(--heritage-700)}html[data-bs-theme=dark] .modal-content{background:var(--surface);color:var(--text)}html[data-bs-theme=dark] .sign-in-page{background:linear-gradient(135deg,#14110c,#1d1812)}html[data-bs-theme=dark] .form-header h2{color:var(--heritage-700)}html[data-bs-theme=dark] .form-header p{color:var(--text-muted)}html[data-bs-theme=dark] .tree-view-header{background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);border-color:#d4af3738}html[data-bs-theme=dark] .genealogy-date-picker .preview-text{background:var(--surface-2);color:var(--text)}
