@import"https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Inter:wght@400;500;600;700&display=swap";.app-container{display:flex;flex-direction:column;height:100vh;width:100vw}.app-header{height:64px;background-color:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;z-index:100}.app-header h1{font-size:1.25rem;margin:0;color:var(--text-main);font-weight:600}.app-main{flex:1;position:relative;overflow:hidden;display:flex;background-color:var(--bg-dark)}.sidebar{width:320px;background-color:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:50;box-shadow:var(--shadow-sm);transition:width .3s cubic-bezier(.4,0,.2,1);position:relative}.sidebar.collapsed{width:60px}.toggle-sidebar{position:absolute;right:-12px;top:20px;width:24px;height:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:60;color:var(--text-muted);box-shadow:var(--shadow-sm)}.toggle-sidebar:hover{color:var(--primary-color);background:var(--bg-dark)}.sidebar-header{padding:1.25rem;border-bottom:1px solid var(--border)}.search-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;color:var(--text-muted)}.search-container input{width:100%;background:var(--bg-dark);border:1px solid var(--border);border-radius:.5rem;padding:.6rem .75rem .6rem 2.25rem;color:var(--text-main);outline:none;font-size:.9rem;transition:all .2s}.search-container input:focus{border-color:var(--primary-color);background:var(--bg-card);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary-color) 10%,transparent)}.filter-toggle{margin-left:.5rem;background:transparent;border:1px solid var(--border);border-radius:.5rem;padding:.6rem;color:var(--text-muted);cursor:pointer;transition:all .2s}.filter-toggle:hover,.filter-toggle.active{background:var(--bg-dark);color:var(--primary-color);border-color:var(--primary-color)}.filters-panel{margin-top:1rem;padding:1rem;background:var(--bg-dark);border-radius:.75rem;border:1px solid var(--border);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-group{margin-bottom:.75rem}.filter-group:last-child{margin-bottom:0}.filter-group label{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem}.filter-group select,.range-inputs input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:.4rem;padding:.4rem;color:var(--text-main);font-size:.85rem}.range-inputs{display:flex;align-items:center;gap:.5rem}.range-inputs span{color:var(--text-muted)}.person-list{flex:1;overflow-y:auto;padding:.75rem}.person-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;margin-bottom:.25rem;animation:fadeIn .3s ease-out forwards;border:1px solid transparent}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.person-item:hover{background:var(--bg-dark)}.person-item.active{background:color-mix(in srgb,var(--primary-color) 5%,transparent);border-color:color-mix(in srgb,var(--primary-color) 20%,transparent)}.item-info{display:flex;flex-direction:column}.item-name{font-size:.9rem;font-weight:500;color:var(--text-main)}.item-id{font-size:.75rem;color:var(--text-muted)}.collapsed-icons{display:flex;flex-direction:column;align-items:center;padding:1rem 0;gap:1.5rem}.collapsed-icon{color:var(--text-muted);cursor:pointer;transition:all .2s}.collapsed-icon:hover{color:var(--primary-color);transform:scale(1.1)}.empty-state{padding:2rem;text-align:center;color:var(--text-muted);font-size:.85rem}.viewport{flex:1;position:relative;overflow:hidden}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;height:100%;overflow-y:auto;padding:2rem 1rem;box-sizing:border-box}.profile-panel{position:absolute;top:0;right:0;width:420px;height:100%;background-color:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;box-shadow:var(--shadow-md);animation:slideIn .3s cubic-bezier(.16,1,.3,1);z-index:200}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.profile-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.profile-title{display:flex;align-items:center;gap:1rem}.avatar{width:48px;height:48px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--bg-card);box-shadow:var(--shadow-md)}.title-text{display:flex;flex-direction:column}.person-id{font-size:.75rem;color:var(--text-muted);font-family:monospace}.profile-title h2{margin:0;font-size:1.15rem;font-weight:600}.profile-content{flex:1;overflow-y:auto;padding:1.5rem}.profile-section{background:var(--bg-dark);padding:1.25rem;border-radius:var(--radius-xl, 1rem);margin-bottom:1.5rem;border:1px solid var(--border)}.profile-section h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1.25rem;margin-top:0;display:flex;align-items:center;gap:.6rem}.event-item{background:var(--bg-card);padding:1rem;border-radius:var(--radius-lg, .75rem);margin-bottom:.75rem;display:flex;gap:1rem;border:1px solid var(--border)}.event-tag{background:var(--primary-color);padding:.3rem .6rem;border-radius:var(--radius-sm, .4rem);font-size:.7rem;font-weight:700;height:fit-content;box-shadow:var(--shadow-sm)}.event-details{display:flex;flex-direction:column;gap:.35rem}.event-date{font-weight:600;font-size:.95rem}.event-place{font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.rel-group{margin-bottom:1.5rem}.rel-type{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem;margin-top:0}.relationship-card{display:flex;align-items:center;gap:1rem;padding:.85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg, .75rem);margin-bottom:.6rem;cursor:pointer;transition:all .2s}.relationship-card:hover{background:var(--bg-dark);border-color:var(--border-dark);transform:translate(5px)}.rel-role{font-size:.75rem;color:var(--accent);font-weight:600;min-width:60px}.rel-name{font-size:.9rem;font-weight:500}.ml-auto{margin-left:auto}.btn-icon{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.6rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon:hover{background:var(--bg-dark);color:var(--primary-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.import-modal{background:var(--bg-card);width:90%;max-width:600px;border-radius:1.5rem;padding:2.5rem;border:1px solid var(--border);box-shadow:var(--shadow-xl)}.import-modal h2{margin-top:0;margin-bottom:.5rem;font-size:1.75rem}.tier-selection{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem}.tier-card{background:var(--bg-dark);border:2px solid var(--border);border-radius:1rem;padding:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:1rem;position:relative;overflow:hidden}.tier-card:hover{transform:translateY(-4px);border-color:var(--primary-color);background:color-mix(in srgb,var(--primary-color) 5%,var(--bg-dark))}.tier-card.active{border-color:var(--primary-color);background:color-mix(in srgb,var(--primary-color) 10%,var(--bg-dark));box-shadow:var(--shadow-lg)}.tier-icon{width:48px;height:48px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg, .75rem);display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.tier-card h3{margin:0;font-size:1.1rem}.tier-card p{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.5}.tier-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.tier-features li{font-size:.8rem;color:var(--text-main);display:flex;align-items:center;gap:.5rem}.tier-features li:before{content:"✓";color:var(--primary-color);font-weight:700}.modal-footer{margin-top:2.5rem;display:flex;justify-content:flex-end;gap:1rem}[data-theme=classic] .search-container input{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset)}[data-theme=classic] .search-container input:focus{background:var(--bg-card);border-color:var(--border-ornate);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .filters-panel{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .filter-group select,[data-theme=classic] .range-inputs input{background:var(--bg-dark);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset)}[data-theme=classic] .filter-group select:focus,[data-theme=classic] .range-inputs input:focus{border-color:var(--border-ornate);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .filter-group label{color:var(--text-secondary);font-family:var(--font-family-ui)}[data-theme=classic] .person-item{border:1px solid transparent}[data-theme=classic] .person-item:hover{background:var(--bg-dark);border-color:var(--border)}[data-theme=classic] .person-item.active{background:color-mix(in srgb,var(--primary-color) 8%,var(--bg-card));border-color:var(--border-ornate);box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .profile-section{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .profile-section h3{color:var(--text-secondary);font-family:var(--font-family-ui);letter-spacing:.08em}[data-theme=classic] .event-item,[data-theme=classic] .relationship-card{background:var(--bg-dark);border:1px solid var(--border);box-shadow:var(--shadow-sm)}[data-theme=classic] .relationship-card:hover{background:var(--bg-card);border-color:var(--border-ornate);box-shadow:var(--shadow-md)}[data-theme=classic] .sidebar{background:var(--bg-card);border-right:2px solid var(--border-dark);box-shadow:var(--shadow-md)}[data-theme=classic] .sidebar-header{border-bottom:2px solid var(--border-dark);background:linear-gradient(to bottom,var(--bg-card),var(--bg-dark))}[data-theme=classic] .app-header{background:var(--bg-card);border-bottom:2px solid var(--border-dark);box-shadow:var(--shadow-sm)}[data-theme=classic] .toggle-sidebar{background:var(--bg-card);border:2px solid var(--border-dark);box-shadow:var(--shadow-sm)}[data-theme=classic] .toggle-sidebar:hover{border-color:var(--border-ornate);background:var(--bg-dark)}[data-theme=classic] .profile-panel{background:var(--bg-card);border-left:2px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .profile-header{border-bottom:2px solid var(--border-dark);background:linear-gradient(to bottom,var(--bg-card),var(--bg-dark))}[data-theme=classic] .avatar{background:linear-gradient(135deg,var(--primary-color),var(--accent));border:2px solid var(--border-ornate);box-shadow:var(--shadow-md),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .import-modal{background:var(--bg-card);border:2px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .tier-card{background:var(--bg-dark);border:2px solid var(--border);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .tier-card:hover{border-color:var(--border-ornate);background:var(--bg-card)}[data-theme=classic] .tier-card.active{border-color:var(--border-ornate);background:color-mix(in srgb,var(--primary-color) 10%,var(--bg-card));box-shadow:var(--shadow-md),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .tier-icon{background:linear-gradient(135deg,var(--bg-card),var(--bg-dark));border:1px solid var(--border-ornate)}[data-theme=classic] small,[data-theme=classic] .text-muted{color:var(--text-muted);font-family:var(--font-family-ui)}[data-theme=classic] .filter-toggle{border:1px solid var(--border-dark);background:var(--bg-card)}[data-theme=classic] .filter-toggle:hover,[data-theme=classic] .filter-toggle.active{background:var(--bg-dark);border-color:var(--border-ornate)}[data-theme=classic] .btn-icon{transition:all .2s ease}[data-theme=classic] .btn-icon:hover{background:color-mix(in srgb,var(--primary-color) 10%,transparent);color:var(--primary-color)}.tree-container{width:100%;height:100%;position:relative;background:var(--bg-card);cursor:grab}[data-theme=classic] .tree-container{background:radial-gradient(ellipse at center,var(--bg-card) 0%,var(--bg-dark) 100%);position:relative}[data-theme=classic] .tree-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 30%,rgba(133,77,14,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(133,77,14,.02) 0%,transparent 50%);pointer-events:none;opacity:.6}.tree-container:active{cursor:grabbing}.node circle{cursor:pointer;stroke:var(--accent);stroke-width:2px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:all .3s cubic-bezier(.4,0,.2,1)}.node:hover circle{fill:var(--accent);transform:scale(1.1);filter:drop-shadow(0 4px 8px rgba(14,165,233,.3))}.node.female circle{stroke:var(--gender-female, #ec4899)}.node.male circle{stroke:var(--gender-male, #0ea5e9)}.node.focal circle{fill:var(--primary-color);stroke:#fff;stroke-width:3px;filter:drop-shadow(0 4px 10px rgba(37,99,235,.3))}.link{transition:all .5s ease;opacity:.4;stroke:var(--border-dark, #cbd5e1)}[data-theme=classic] .link{stroke:var(--text-muted);opacity:.3;stroke-width:1.5px}.node text{font-weight:600;text-shadow:none;letter-spacing:.01em;fill:var(--text-main);background:#fffc;padding:2px 4px;border-radius:4px}.zoom-container{transition:transform .1s ease-out}[data-theme=classic] .node circle{filter:drop-shadow(0 2px 6px var(--emboss-shadow))}[data-theme=classic] .node:hover circle{filter:drop-shadow(0 3px 8px var(--emboss-shadow))}[data-theme=classic] .node.focal circle{fill:var(--primary-color);stroke:var(--bg-card);stroke-width:3px;filter:drop-shadow(0 4px 12px var(--emboss-shadow)) drop-shadow(0 0 8px var(--primary-light))}[data-theme=classic] .node text{fill:var(--text-main);text-shadow:0 1px 2px var(--bg-card);font-weight:600}.edit-input-title{background:var(--bg-dark);border:1px solid var(--border);color:var(--text-main);font-size:1.1rem;padding:.25rem .5rem;border-radius:.25rem;width:100%}.edit-input-title:focus{border-color:var(--primary-color);outline:2px solid color-mix(in srgb,var(--primary-color) 10%,transparent)}.header-actions{display:flex;gap:.5rem}.btn-icon.primary{color:var(--primary-color);background:color-mix(in srgb,var(--primary-color) 10%,transparent)}.btn-icon.primary:hover{background:color-mix(in srgb,var(--primary-color) 20%,transparent)}.actions-bar{margin-bottom:1.5rem;display:flex;justify-content:center}.btn-action{background:var(--bg-card);border:1px solid var(--border);color:var(--text-main);padding:.6rem 1.2rem;border-radius:.5rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.9rem;transition:all .2s;box-shadow:var(--shadow-sm)}.btn-action:hover{background:var(--bg-dark);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px);box-shadow:var(--shadow-md)}.add-menu{display:flex;gap:.5rem;flex-wrap:wrap;background:var(--bg-card);padding:1rem;border-radius:.75rem;border:1px solid var(--border);box-shadow:var(--shadow-md)}.add-menu button{background:var(--primary-color);border:none;color:#fff;padding:.4rem .8rem;border-radius:.4rem;cursor:pointer;font-size:.8rem;transition:background .2s}.add-menu button:hover{background:var(--primary-hover)}.add-menu button.cancel{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.add-menu button.cancel:hover{background:var(--bg-dark);color:var(--text-main)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.btn-add-event{background:var(--bg-card);border:1px solid var(--border);color:var(--primary-color);padding:.3rem .6rem;border-radius:.4rem;font-size:.75rem;cursor:pointer;display:flex;align-items:center;gap:.3rem;transition:all .2s}.btn-add-event:hover{border-color:var(--primary-color);background:color-mix(in srgb,var(--primary-color) 5%,transparent)}.event-editor-card{background:var(--bg-card);border:1px solid var(--border);padding:1rem;border-radius:.5rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-sm)}.event-editor-card select,.event-editor-card input{background:var(--bg-dark);border:1px solid var(--border);color:var(--text-main);padding:.5rem;border-radius:.3rem;font-size:.85rem}.editor-actions{display:flex;justify-content:flex-end;gap:.5rem}.btn-save-event,.btn-cancel-event{background:var(--primary-color);border:none;color:#fff;padding:.4rem .6rem;border-radius:.3rem;cursor:pointer}.btn-save-event:hover{background:var(--primary-hover)}.btn-cancel-event{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.btn-cancel-event:hover{background:var(--bg-dark);color:var(--text-main)}.event-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-radius:.4rem;transition:background .2s}.event-row:hover{background:var(--bg-dark)}.event-row.hidden{display:none}.event-info{display:flex;flex-direction:column;gap:.1rem}.event-tag{font-size:.75rem;text-transform:uppercase;color:var(--primary-color);font-weight:700}.event-date{font-size:.9rem;font-weight:600;color:var(--text-main)}.event-place{font-size:.8rem;color:var(--text-muted);font-style:italic}.row-actions{display:flex;gap:.4rem}.btn-row{background:transparent;border:1px solid transparent;color:var(--text-muted);cursor:pointer;padding:.2rem;border-radius:.2rem;display:flex;align-items:center;justify-content:center}.btn-row:hover{color:var(--primary-color);background:color-mix(in srgb,var(--primary-color) 10%,transparent)}.btn-row.danger:hover{color:var(--accent-burgundy, #ef4444);background:color-mix(in srgb,var(--accent-burgundy, #ef4444) 10%,transparent)}.attributes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;padding:.5rem 0}.attribute-item{background:var(--bg-dark);padding:.5rem;border-radius:.4rem;border:1px solid var(--border);transition:transform .2s,border-color .2s;cursor:help}.attribute-item:hover{transform:translateY(-2px);border-color:var(--primary-color)}.attr-label{display:block;font-size:.7rem;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin-bottom:.2rem}.attr-value{font-size:.85rem;font-weight:600;color:var(--text-main);word-break:break-word}.timeline-note-inline{display:flex;align-items:center;gap:.3rem;font-size:.7rem;color:var(--text-muted);margin-top:.3rem;background:var(--bg-dark);padding:.2rem .4rem;border-radius:var(--radius-sm, .2rem);width:fit-content}[data-theme=classic] .edit-input-title{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset);font-family:var(--font-family-ui)}[data-theme=classic] .edit-input-title:focus{border-color:var(--border-ornate);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .event-editor-card select,[data-theme=classic] .event-editor-card input{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset);font-family:var(--font-family-ui)}[data-theme=classic] .event-editor-card select:focus,[data-theme=classic] .event-editor-card input:focus{border-color:var(--border-ornate);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .event-editor-card{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .add-menu{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-md)}[data-theme=classic] .btn-action{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-sm)}[data-theme=classic] .btn-action:hover{background:var(--bg-dark);border-color:var(--border-ornate)}[data-theme=classic] .attribute-item{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm)}[data-theme=classic] .attribute-item:hover{border-color:var(--border-ornate);box-shadow:var(--shadow-md)}[data-theme=classic] .timeline-note-inline{background:color-mix(in srgb,var(--text-main) 5%,var(--bg-dark));border:1px solid var(--border)}.rel-info{display:flex;flex-direction:column;gap:.2rem;flex:1}.rel-lifespan{font-size:.75rem;color:var(--text-muted);font-style:italic;margin-top:.2rem}.notes-container{display:flex;flex-direction:column;gap:.75rem}.note-card{background:var(--bg-dark);padding:.75rem;border-radius:.4rem;border:1px solid var(--border);border-left:3px solid var(--primary-color)}.note-card p{margin:0;font-size:.9rem;line-height:1.5;color:var(--text-main);white-space:pre-wrap;word-break:break-word}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.media-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:.4rem;cursor:pointer;transition:all .2s}.media-item:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.media-placeholder{font-size:2rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--primary-color) 10%,transparent);border-radius:.3rem}.media-title{font-size:.75rem;text-align:center;color:var(--text-muted);margin:0;word-break:break-word}[data-theme=classic] .note-card,[data-theme=classic] .media-item{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-sm)}[data-theme=classic] .media-item:hover{border-color:var(--border-ornate);box-shadow:var(--shadow-md)}.avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.3rem;box-shadow:0 2px 8px #00000026;flex-shrink:0;border:2px solid rgba(255,255,255,.2);transition:transform .2s,box-shadow .2s}.avatar:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.profile-section h3{display:flex;align-items:center;gap:.5rem;padding:.75rem 0;margin:0 0 1rem;border-bottom:2px solid var(--border);font-size:1.05rem;color:var(--text-main);transition:all .2s}.profile-section h3 svg{color:var(--primary-color);flex-shrink:0}.profile-section h4.rel-type{margin:.75rem 0 .5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.empty-state{text-align:center;padding:2rem 1rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:.75rem;opacity:.5}.empty-state-text{font-size:.9rem;font-style:italic}@media(max-width:768px){.profile-panel{width:100%;max-width:100%;right:0;border-radius:.75rem .75rem 0 0}.profile-header,.profile-content{padding:1rem}.avatar{width:48px;height:48px;font-size:1.1rem}.relationship-card{padding:.75rem}.attributes-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.media-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}@media(max-width:480px){.avatar{width:40px;height:40px;font-size:.95rem}.profile-panel{max-height:95vh}.profile-header,.profile-content{padding:.75rem}.add-menu{flex-direction:column}.add-menu button{width:100%}}button{transition:all .2s ease}button:focus{outline:2px solid var(--primary-color);outline-offset:2px}button:focus:not(:focus-visible){outline:none}button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.btn-icon:focus-visible,.btn-action:focus-visible,.relationship-card:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.relationship-card:focus{outline:2px solid var(--primary-color);outline-offset:2px}@media(prefers-contrast:more){.relationship-card,button{border-width:2px}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.avatar:hover,.media-item:hover{transform:none}}.timeline-container{position:relative;padding:.5rem 0;margin-left:.75rem;border-left:2px solid var(--border)}.timeline-item{position:relative;margin-bottom:1.25rem;padding-left:1.5rem;transition:all .2s ease}.timeline-item.is-editing{opacity:.5;transform:scale(.98)}.timeline-dot{position:absolute;left:-.42rem;top:.35rem;width:.75rem;height:.75rem;background:var(--bg-card);border:2px solid var(--primary-color);border-radius:50%;z-index:1;box-shadow:0 0 0 2px var(--bg-card)}.timeline-content{display:flex;flex-direction:column;background:var(--bg-card);padding:.75rem 1rem;border-radius:var(--radius-md, .6rem);border:1px solid var(--border);transition:all .2s;box-shadow:var(--shadow-sm)}.timeline-container.editable .timeline-item:hover .timeline-content{background:var(--bg-dark);border-color:var(--primary-color);transform:translate(2px);box-shadow:var(--shadow-md)}.timeline-header{display:flex;justify-content:space-between;align-items:center}.timeline-date{font-weight:600;color:var(--text-main);font-size:.85rem}.timeline-tag{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--accent);margin:.15rem 0}.timeline-place{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.timeline-actions{display:flex;gap:.4rem;opacity:0;transition:opacity .2s}.timeline-item:hover .timeline-actions{opacity:1}.btn-tiny{background:transparent;border:1px solid transparent;color:var(--text-muted);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;transition:all .2s}.btn-tiny:hover{background:color-mix(in srgb,var(--primary-color) 10%,transparent);color:var(--primary-color)}.btn-tiny.danger:hover{background:color-mix(in srgb,var(--accent-burgundy, #ef4444) 10%,transparent);color:var(--accent-burgundy, #ef4444)}.timeline-empty{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic;font-size:.9rem}[data-theme=classic] .timeline-container{border-left-color:var(--border-ornate);border-left-width:2.5px}[data-theme=classic] .timeline-dot{background:radial-gradient(circle,var(--primary-light) 0%,var(--primary-color) 100%);border-color:var(--border-ornate);border-width:2.5px;box-shadow:0 0 0 3px var(--bg-card),var(--shadow-sm)}[data-theme=classic] .timeline-content{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .timeline-date{color:var(--text-main);font-variant-numeric:oldstyle-nums}[data-theme=classic] .timeline-tag{color:var(--primary-color);letter-spacing:.05em}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out;max-width:500px;width:90%}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border);background:var(--bg-dark)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--text-main)}.modal-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:.25rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--text-main);background:color-mix(in srgb,var(--text-main) 10%,transparent)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid var(--border);background:var(--bg-dark);justify-content:flex-end}.form-section{display:flex;flex-direction:column;gap:1rem}.form-section label:not(.radio-label){font-size:.85rem;font-weight:600;color:var(--text-main);text-transform:uppercase;letter-spacing:.5px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row.full{grid-template-columns:1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-input{background:var(--bg-dark);border:1px solid var(--border);color:var(--text-main);padding:.75rem;border-radius:.4rem;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent)}.form-input-small{font-size:.85rem}.radio-group{display:flex;gap:2rem}.radio-label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-main);cursor:pointer;text-transform:none;font-weight:400;letter-spacing:normal}.radio-label input[type=radio]{cursor:pointer;width:18px;height:18px}.collapsible{border:1px solid var(--border);border-radius:.4rem;padding:0}.collapsible-header{width:100%;display:flex;justify-content:space-between;align-items:center;background:transparent;border:none;padding:1rem;cursor:pointer;color:var(--text-main);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;transition:background .2s}.collapsible-header:hover{background:var(--bg-dark)}.collapse-icon{font-size:.7rem;transition:transform .2s}.collapse-icon.expanded{transform:rotate(180deg)}.collapsible-content{padding:1rem;border-top:1px solid var(--border);background:var(--bg-dark);display:flex;flex-direction:column;gap:1rem}.error-message{display:flex;align-items:center;gap:.5rem;color:var(--accent-burgundy, #ef4444);font-size:.8rem;padding:.5rem;background:color-mix(in srgb,var(--accent-burgundy, #ef4444) 10%,transparent);border-radius:.3rem;border-left:3px solid var(--accent-burgundy, #ef4444)}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:.4rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-main)}.btn-secondary:hover{background:var(--bg-dark);border-color:var(--primary-color);color:var(--primary-color)}[data-theme=classic] .modal-content{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .modal-header{background:var(--bg-dark);border-bottom-color:var(--border-dark)}[data-theme=classic] .modal-footer{background:var(--bg-dark);border-top-color:var(--border-dark)}[data-theme=classic] .form-input{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset);font-family:var(--font-family-ui)}[data-theme=classic] .form-input:focus{border-color:var(--border-ornate);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .collapsible{border-color:var(--border-dark)}[data-theme=classic] .collapsible-header{border-bottom-color:var(--border-dark)}[data-theme=classic] .collapsible-header:hover{background:var(--bg-dark)}[data-theme=classic] .collapsible-content{background:var(--bg-dark);border-top-color:var(--border-dark)}@media(max-width:640px){.modal-content{max-width:95%;max-height:95vh}.form-row{grid-template-columns:1fr}.radio-group{gap:1rem;flex-wrap:wrap}.modal-body,.modal-header,.modal-footer{padding:1rem}}.form-input:focus,.radio-label input:focus{outline:none}.collapsible-header:focus-visible{outline:2px solid var(--primary-color);outline-offset:-2px}.modal-close:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.btn-primary:focus-visible,.btn-secondary:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media(prefers-reduced-motion:reduce){.modal-content,.modal-overlay{animation:none}}.theme-switcher{position:relative}.theme-switcher .btn-icon.active{background:var(--bg-dark);color:var(--primary-color)}.theme-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:.5rem;min-width:220px;box-shadow:var(--shadow-md);z-index:1000;animation:fadeIn .2s ease-out}.theme-menu-title{padding:.5rem .75rem;font-size:.75rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:.05em;border-bottom:1px solid var(--border);margin-bottom:.25rem}.theme-option{display:flex;align-items:center;width:100%;padding:.6rem .75rem;background:transparent;border:none;color:var(--text-main);cursor:pointer;border-radius:.5rem;gap:.75rem;font-size:.9rem;transition:background .1s;text-align:left}.theme-option:hover{background:var(--bg-dark)}.theme-option.active{background:color-mix(in srgb,var(--primary-color) 5%,transparent);color:var(--primary-color);font-weight:500}.theme-color-preview{width:16px;height:16px;border-radius:50%;border:1px solid var(--border);flex-shrink:0}[data-theme-preview=modern]{background:#2563eb}[data-theme-preview=classic]{background:#854d0e}[data-theme-preview=organic]{background:#15803d}[data-theme-preview=slate]{background:#94a3b8}[data-theme-preview=tokyo]{background:#6366f1}[data-theme=classic] .theme-menu{background:var(--bg-card);border:2px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .theme-menu-title{border-bottom:1px solid var(--border-dark);color:var(--text-secondary);font-family:var(--font-family-ui)}[data-theme=classic] .theme-option{border-radius:var(--radius-md)}[data-theme=classic] .theme-option:hover{background:var(--bg-dark)}[data-theme=classic] .theme-option.active{background:color-mix(in srgb,var(--primary-color) 10%,var(--bg-card));box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .theme-color-preview{border:2px solid var(--border-ornate);box-shadow:var(--shadow-sm)}.language-selector{position:relative}.language-selector .btn-icon.active{background:var(--bg-dark);color:var(--primary-color)}.language-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:.5rem;min-width:160px;box-shadow:var(--shadow-md);z-index:1000;animation:fadeIn .2s ease-out}.language-menu-title{padding:.5rem .75rem;font-size:.75rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:.05em;border-bottom:1px solid var(--border);margin-bottom:.25rem}.language-option{display:flex;align-items:center;width:100%;padding:.6rem .75rem;background:transparent;border:none;color:var(--text-main);cursor:pointer;border-radius:.5rem;gap:.75rem;font-size:.9rem;transition:background .1s;text-align:left}.language-option:hover{background:var(--bg-dark)}.language-option.active{background:color-mix(in srgb,var(--primary-color) 5%,transparent);color:var(--primary-color);font-weight:500}.language-label{flex:1}.check-icon{margin-left:auto;color:var(--primary-color)}[data-theme=classic] .language-menu{background:var(--bg-card);border:2px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .language-menu-title{border-bottom:1px solid var(--border-dark);color:var(--text-secondary);font-family:var(--font-family-ui)}[data-theme=classic] .language-option{border-radius:var(--radius-md)}[data-theme=classic] .language-option:hover{background:var(--bg-dark)}[data-theme=classic] .language-option.active{background:color-mix(in srgb,var(--primary-color) 10%,var(--bg-card));box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight)}.stats-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.stats-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:1rem;box-shadow:var(--shadow-md);width:90%;max-width:800px;max-height:90vh;overflow-y:auto;padding:2rem;position:relative;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-bottom:1px solid var(--border);padding-bottom:1rem}.stats-header h2{margin:0;display:flex;align-items:center;gap:.75rem;color:var(--text-main);font-size:1.5rem}.header-icon{color:var(--primary-color)}.btn-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s}.btn-close:hover{background:var(--bg-dark);color:var(--text-main)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-dark);border:1px solid var(--border);padding:1.25rem;border-radius:.75rem;display:flex;align-items:center;gap:1rem;transition:transform .2s}.stat-card:hover{transform:translateY(-2px);border-color:var(--primary-color)}.stat-icon-wrapper{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-card)}.stat-card.blue .stat-icon-wrapper{background:color-mix(in srgb,var(--primary-color) 15%,var(--bg-card));color:var(--primary-color)}.stat-card.indigo .stat-icon-wrapper{background:color-mix(in srgb,var(--accent) 15%,var(--bg-card));color:var(--accent)}.stat-card.green .stat-icon-wrapper{background:color-mix(in srgb,var(--accent-forest, #22c55e) 15%,var(--bg-card));color:var(--accent-forest, #22c55e)}.stat-card.purple .stat-icon-wrapper{background:color-mix(in srgb,var(--accent-burgundy, #a855f7) 15%,var(--bg-card));color:var(--accent-burgundy, #a855f7)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;margin:0;line-height:1.1;color:var(--text-main)}.stat-title{font-size:.85rem;color:var(--text-muted);font-weight:500}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:700px){.stats-row{grid-template-columns:1fr}}.stats-section h3{margin-top:0;margin-bottom:1rem;font-size:1.1rem;color:var(--text-main);display:flex;align-items:center;gap:.5rem}.fact-list{display:flex;flex-direction:column;gap:.75rem}.fact-item{background:var(--bg-dark);padding:.85rem;border-radius:.5rem;border:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem}.fact-label{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:.05em}.fact-value{font-size:1rem;font-weight:500;color:var(--text-main)}.highlight{color:var(--primary-color);font-weight:700}.gender-bar-container{margin-top:1rem}.gender-labels{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;font-weight:500}.gender-bar{display:flex;height:12px;border-radius:6px;overflow:hidden;background:var(--bg-dark)}.bar-segment{height:100%;transition:flex .5s ease-out}.bar-segment.male{background:var(--gender-male, #3b82f6)}.bar-segment.female{background:var(--gender-female, #ec4899)}.tags-cloud{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.surname-tag{background:var(--bg-card);border:1px solid var(--border);padding:.3rem .6rem;border-radius:1rem;font-size:.8rem;font-weight:500;color:var(--text-main);box-shadow:var(--shadow-sm)}.mt-4{margin-top:1.5rem}[data-theme=classic] .stats-modal{background:var(--bg-card);border:2px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .stat-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .stat-card:hover{border-color:var(--border-ornate);box-shadow:var(--shadow-md)}[data-theme=classic] .stat-value{font-variant-numeric:oldstyle-nums}[data-theme=classic] .gender-bar{border:1px solid var(--border)}.dynasty-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:color-mix(in srgb,var(--text-main) 85%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.dynasty-modal{background:var(--bg-card);width:100%;max-width:1100px;height:85vh;border-radius:1.5rem;border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000080;animation:zoomIn .3s cubic-bezier(.16,1,.3,1)}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dynasty-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--bg-dark)}.dynasty-header h2{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.5rem}.dynasty-content{flex:1;display:grid;grid-template-columns:300px 1fr;overflow:hidden}.cluster-sidebar{border-right:1px solid var(--border);padding:1.5rem;overflow-y:auto;background:var(--bg-dark)}.cluster-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.cluster-item{padding:1rem;border-radius:var(--radius-lg, .75rem);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all .2s}.cluster-item:hover{background:var(--bg-card);border-color:var(--border-dark);box-shadow:var(--shadow-sm)}.cluster-item.active{background:color-mix(in srgb,var(--primary-color) 10%,var(--bg-card));border-color:var(--primary-color)}.cluster-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.cluster-name{font-weight:600;font-size:.95rem}.cluster-badge{padding:.2rem .5rem;border-radius:2rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.cluster-details{padding:2rem;overflow-y:auto;display:flex;flex-direction:column;gap:2rem}.cluster-info-card{background:var(--bg-card);padding:2rem;border-radius:var(--radius-xl, 1.25rem);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.cluster-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:1.5rem}.meta-item{display:flex;flex-direction:column;gap:.4rem}.meta-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;font-weight:600}.meta-value{font-size:1.1rem;font-weight:500}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.member-card{background:var(--bg-dark);padding:1rem;border-radius:var(--radius-lg, .75rem);display:flex;align-items:center;gap:1rem;border:1px solid var(--border)}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-dark);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.member-info{display:flex;flex-direction:column}.member-name{font-weight:600;font-size:.9rem}.member-type{font-size:.7rem;color:var(--text-muted)}.btn-create-cluster{width:100%;padding:.75rem;background:var(--primary-color);border:none;border-radius:.75rem;color:#fff;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem;transition:all .2s}.btn-create-cluster:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:var(--primary-hover)}.cluster-form{display:flex;flex-direction:column;gap:1.25rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-size:.85rem;font-weight:600}.form-field input,.form-field select,.form-field textarea{background:var(--bg-dark);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;color:var(--text-main)}.tags-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.surname-tag{background:var(--primary-color);color:var(--bg-card);padding:.35rem .75rem;border-radius:2rem;font-size:.8rem;font-weight:600;box-shadow:var(--shadow-sm)}[data-theme=classic] .dynasty-overlay{background:color-mix(in srgb,var(--bg-dark) 90%,var(--text-main));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=classic] .dynasty-modal{border:2px solid var(--border-dark);box-shadow:var(--shadow-lg)}[data-theme=classic] .dynasty-header{background:linear-gradient(to bottom,var(--bg-card),var(--bg-dark));border-bottom:2px solid var(--border-dark)}[data-theme=classic] .cluster-sidebar{background:var(--bg-dark);border-right:2px solid var(--border-dark)}[data-theme=classic] .cluster-item{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm),var(--shadow-inset)}[data-theme=classic] .cluster-item:hover{border-color:var(--border-ornate);box-shadow:var(--shadow-md);transform:translate(2px)}[data-theme=classic] .cluster-item.active{background:color-mix(in srgb,var(--primary-color) 12%,var(--bg-card));border-color:var(--border-ornate);box-shadow:var(--shadow-md),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .cluster-badge{background:linear-gradient(135deg,var(--primary-color),var(--accent));border:1px solid var(--border-ornate)}[data-theme=classic] .btn-create-cluster{background:linear-gradient(to bottom,var(--primary-color),var(--primary-hover));border:1px solid var(--border-ornate);box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .btn-create-cluster:hover{background:linear-gradient(to bottom,var(--primary-hover),var(--accent-secondary))}[data-theme=classic] .form-field input,[data-theme=classic] .form-field select,[data-theme=classic] .form-field textarea{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset);font-family:var(--font-family-ui)}[data-theme=classic] .form-field input:focus,[data-theme=classic] .form-field select:focus,[data-theme=classic] .form-field textarea:focus{border-color:var(--border-ornate);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .form-field label{color:var(--text-secondary);font-family:var(--font-family-ui)}[data-theme=classic] .dynasty-rules-grid{background:var(--bg-dark)!important;border:1px solid var(--border);box-shadow:var(--shadow-inset)}[data-theme=classic] .profile-section{background:color-mix(in srgb,var(--primary-color) 3%,var(--bg-dark))!important;border:1px solid var(--border)}[data-theme=classic] .cluster-form{font-family:var(--font-family-ui)}[data-theme=classic] .cluster-form h3{font-family:var(--font-family-headings);color:var(--text-main)}*{box-sizing:border-box}body,html,#root{height:100%;width:100%;overflow:hidden}.btn-primary{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-weight:500;transition:background-color .2s,box-shadow .2s;box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md)}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--bg-dark: #f8fafc;--bg-card: #ffffff;--text-main: #0f172a;--text-muted: #64748b;--accent: #0ea5e9;--border: #e2e8f0;--glass: rgba(255, 255, 255, .8);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--border-radius: .5rem}[data-theme=modern]{--primary-color: #2563eb;--primary-hover: #1d4ed8;--bg-dark: #f8fafc;--bg-card: #ffffff;--text-main: #0f172a;--text-muted: #64748b;--accent: #0ea5e9;--border: #e2e8f0;--glass: rgba(255, 255, 255, .8)}[data-theme=classic]{--primary-color: #854d0e;--primary-hover: #713f12;--primary-light: #a16207;--bg-dark: #f5ebe0;--bg-card: #fdf8f3;--bg-overlay: rgba(245, 235, 224, .95);--text-main: #3e2723;--text-secondary: #4e342e;--text-muted: #8d6e63;--text-light: #a1887f;--accent: #b45309;--accent-secondary: #92400e;--accent-burgundy: #7c2d12;--accent-forest: #3f6212;--gender-female: #be6464;--gender-male: #5a7c8c;--border: #d4c5b9;--border-dark: #a89080;--border-ornate: #8b6f47;--shadow-sm: 0 2px 4px rgba(62, 39, 35, .08);--shadow-md: 0 4px 12px rgba(62, 39, 35, .12);--shadow-lg: 0 8px 24px rgba(62, 39, 35, .16);--shadow-inset: inset 0 2px 4px rgba(62, 39, 35, .06);--emboss-highlight: rgba(255, 255, 255, .4);--emboss-shadow: rgba(62, 39, 35, .15);--ink-spread: 0 0 3px rgba(62, 39, 35, .2);--glass: rgba(253, 248, 243, .92);--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--radius-sm: .35rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--font-family-primary: "Crimson Text", "Georgia", serif;--font-family-headings: "Libre Baskerville", "Georgia", serif;--font-family-ui: "Inter", -apple-system, sans-serif}[data-theme=classic] body,[data-theme=classic] #root{font-family:var(--font-family-primary);letter-spacing:.01em;line-height:1.6}[data-theme=classic] h1,[data-theme=classic] h2,[data-theme=classic] h3,[data-theme=classic] h4,[data-theme=classic] h5,[data-theme=classic] h6{font-family:var(--font-family-headings);font-weight:700;letter-spacing:-.01em}[data-theme=classic] button,[data-theme=classic] input,[data-theme=classic] select,[data-theme=classic] .ui-element{font-family:var(--font-family-ui)}[data-theme=classic] body,[data-theme=classic] #root{background:var(--bg-dark);position:relative}[data-theme=classic] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(62,39,35,.015) 2px,rgba(62,39,35,.015) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(62,39,35,.015) 2px,rgba(62,39,35,.015) 4px);pointer-events:none;opacity:.4;z-index:1}[data-theme=classic] body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 15% 20%,rgba(133,77,14,.04) 0%,transparent 25%),radial-gradient(circle at 85% 15%,rgba(133,77,14,.03) 0%,transparent 20%),radial-gradient(circle at 50% 85%,rgba(133,77,14,.03) 0%,transparent 30%),radial-gradient(circle at 10% 70%,rgba(133,77,14,.02) 0%,transparent 15%);pointer-events:none;opacity:.6;z-index:1}[data-theme=classic] #root>*{position:relative;z-index:2}[data-theme=classic] .stat-card,[data-theme=classic] .event-editor-card,[data-theme=classic] .cluster-info-card,[data-theme=classic] .profile-card{box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight),inset 0 -1px 0 var(--emboss-shadow)}[data-theme=classic] .dynasty-modal,[data-theme=classic] .stats-modal{border:2px solid var(--border-dark);position:relative}[data-theme=classic] .dynasty-modal:before,[data-theme=classic] .dynasty-modal:after,[data-theme=classic] .stats-modal:before,[data-theme=classic] .stats-modal:after{content:"";position:absolute;width:20px;height:20px;border-color:var(--border-ornate)}[data-theme=classic] .dynasty-modal:before,[data-theme=classic] .stats-modal:before{top:-2px;left:-2px;border-top:3px solid var(--border-ornate);border-left:3px solid var(--border-ornate)}[data-theme=classic] .dynasty-modal:after,[data-theme=classic] .stats-modal:after{top:-2px;right:-2px;border-top:3px solid var(--border-ornate);border-right:3px solid var(--border-ornate)}[data-theme=classic] .btn-primary{background:linear-gradient(to bottom,var(--primary-color),var(--primary-hover));border:1px solid var(--border-ornate);box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight);text-shadow:0 1px 2px rgba(0,0,0,.2)}[data-theme=classic] .btn-primary:hover{background:linear-gradient(to bottom,var(--primary-hover),var(--accent-secondary));box-shadow:var(--shadow-md),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] button:active,[data-theme=classic] .btn-action:active{box-shadow:var(--ink-spread),var(--shadow-inset);transform:translateY(1px)}[data-theme=classic] input,[data-theme=classic] select,[data-theme=classic] textarea{background:var(--bg-card);border:1px solid var(--border-dark);box-shadow:var(--shadow-inset)}[data-theme=classic] input:focus,[data-theme=classic] select:focus,[data-theme=classic] textarea:focus{border-color:var(--border-ornate);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 10%,transparent)}[data-theme=classic] .stat-card:hover,[data-theme=classic] .attribute-item:hover,[data-theme=classic] .member-card:hover{transform:translateY(-2px) rotate(.2deg);box-shadow:var(--shadow-md),inset 0 1px 0 var(--emboss-highlight)}@keyframes heritage-pulse{0%,to{filter:drop-shadow(0 4px 12px var(--emboss-shadow)) drop-shadow(0 0 8px var(--primary-light))}50%{filter:drop-shadow(0 4px 16px var(--emboss-shadow)) drop-shadow(0 0 12px var(--primary-light))}}[data-theme=classic] .node.focal circle{animation:heritage-pulse 3s ease-in-out infinite}@keyframes quill-write{0%{border-bottom-color:var(--text-main)}to{border-bottom-color:var(--primary-color)}}[data-theme=classic] input:focus,[data-theme=classic] textarea:focus{animation:quill-write .5s ease-in-out}@keyframes parchment-fade-in{0%{opacity:0;transform:scale(.98) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}[data-theme=classic] .dynasty-modal,[data-theme=classic] .stats-modal{animation:parchment-fade-in .4s cubic-bezier(.16,1,.3,1)}@keyframes ink-spread-load{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.1);opacity:1}to{transform:scale(.8);opacity:.5}}[data-theme=classic] ::-webkit-scrollbar{width:12px;height:12px}[data-theme=classic] ::-webkit-scrollbar-track{background:var(--bg-dark);border:1px solid var(--border)}[data-theme=classic] ::-webkit-scrollbar-thumb{background:linear-gradient(to bottom,var(--border-dark),var(--border-ornate));border:1px solid var(--border-ornate);border-radius:6px}[data-theme=classic] ::-webkit-scrollbar-thumb:hover{background:linear-gradient(to bottom,var(--border-ornate),var(--primary-color))}[data-theme=classic] [title]:hover:after{background:var(--bg-card);border:1px solid var(--border-ornate);box-shadow:var(--shadow-md);font-family:var(--font-family-primary);font-style:italic;color:var(--text-muted)}[data-theme=classic] .cluster-badge,[data-theme=classic] .event-tag,[data-theme=classic] .timeline-tag{background:linear-gradient(135deg,var(--primary-color),var(--accent));color:var(--bg-card);text-shadow:0 1px 1px rgba(0,0,0,.2);border:1px solid var(--border-ornate);box-shadow:var(--shadow-sm),inset 0 1px 0 var(--emboss-highlight)}[data-theme=classic] .cluster-info-card{border:2px solid var(--border);outline:1px solid var(--border-dark);outline-offset:3px}[data-theme=classic] a{color:var(--primary-color);text-decoration:none;border-bottom:1px solid transparent;transition:border-bottom-color .2s}[data-theme=classic] a:hover{border-bottom-color:var(--primary-color);color:var(--accent)}[data-theme=classic] .surname-tag{background:linear-gradient(135deg,var(--primary-color),var(--accent));border:1px solid var(--border-ornate);box-shadow:var(--shadow-sm),inset 0 -1px 1px #0000001a;text-shadow:0 1px 1px rgba(0,0,0,.15)}[data-theme=organic]{--primary-color: #15803d;--primary-hover: #166534;--bg-dark: #f0fdf4;--bg-card: #ffffff;--text-main: #14532d;--text-muted: #6b7280;--accent: #a16207;--border: #bbf7d0;--glass: rgba(255, 255, 255, .8)}[data-theme=slate]{--primary-color: #94a3b8;--primary-hover: #cbd5e1;--bg-dark: #0f172a;--bg-card: #1e293b;--text-main: #f1f5f9;--text-muted: #94a3b8;--accent: #38bdf8;--border: #334155;--glass: rgba(30, 41, 59, .8);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4)}[data-theme=tokyo]{--primary-color: #6366f1;--primary-hover: #4f46e5;--bg-dark: #000000;--bg-card: #111111;--text-main: #f8fafc;--text-muted: #a1a1aa;--accent: #d946ef;--border: #27272a;--glass: rgba(17, 17, 17, .8);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .5);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .8)}
