@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200";.language-switch{display:inline-flex;align-items:center;padding:4px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:inset 0 1px #ffffff0a}.language-switch-btn{min-width:46px;padding:.45rem .8rem;border:none;border-radius:var(--radius-full);background:transparent;color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.08em;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.language-switch-btn:hover{color:var(--color-text-primary)}.language-switch-btn.active{background:linear-gradient(135deg,#d4a85338,#e8c97a24);color:var(--color-text-inverse);box-shadow:inset 0 0 0 1px var(--color-border-accent)}@media(max-width:768px){.language-switch-btn{min-width:42px;padding:.4rem .65rem}}.landing{min-height:100vh;position:relative}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-navbar);background:#0f0f1acc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border)}.landing-nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height)}.landing-nav-actions{display:flex;align-items:center;gap:var(--space-3)}.landing-nav-telegram{border-color:#d4a85347}.landing-logo{display:flex;align-items:center;gap:var(--space-2)}.logo-icon{font-size:1.5rem}.logo-text{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.logo-accent{color:var(--color-accent-primary)}.landing-mobile-language{display:none}.hero{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-20) 0;text-align:center;overflow:hidden}.hero-content{position:relative;z-index:2}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:var(--color-bg-glass);border:1px solid var(--color-border-accent);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-accent-secondary);margin-bottom:var(--space-8)}.hero-badge-icon{color:var(--color-accent-primary)}.hero-title{font-size:var(--font-size-5xl);font-weight:800;line-height:1.1;letter-spacing:-.02em;margin-bottom:var(--space-6)}.text-gradient{background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:540px;margin:0 auto var(--space-10);line-height:1.7;opacity:0}.hero-actions{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-12);opacity:0}.hero-telegram-btn{border-color:#d4a85347}.hero-stats{display:flex;align-items:center;justify-content:center;gap:var(--space-8);opacity:0}.stat-group{display:flex;align-items:center;gap:var(--space-8)}.stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-number{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-accent-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.stat-divider{width:1px;height:40px;background:var(--color-border)}.hero-glow{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,var(--color-accent-glow) 0%,transparent 70%);z-index:1;pointer-events:none}.contributors-section{position:relative;padding:0 0 var(--space-18);overflow:visible}.contributors-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(212,168,83,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(212,168,83,.05) 1px,transparent 1px);background-size:42px 42px,42px 42px;pointer-events:none;z-index:0;opacity:.7}.contributors-shell{position:relative;z-index:1;max-width:1160px;margin:0 auto;overflow:visible}.contributors-header{position:relative;display:flex;justify-content:center;margin-top:var(--space-4);margin-bottom:var(--space-10);overflow:visible}.contributors-header:before{content:"";position:absolute;left:50%;top:-56px;transform:translate(-50%);width:min(560px,calc(100vw - 72px));height:180px;border-radius:999px;background:radial-gradient(ellipse at center,rgba(212,168,83,.22) 0%,rgba(212,168,83,.14) 34%,rgba(212,168,83,.06) 58%,transparent 78%);filter:blur(24px);pointer-events:none;z-index:0}.contributors-title-pill{position:relative;margin:0;display:inline-flex;align-items:center;gap:var(--space-3);min-height:58px;padding:0 var(--space-8);border-radius:999px;background:linear-gradient(180deg,#1a1a2ef5,#0f0f1af0);border:1.5px solid var(--color-border-accent);box-shadow:0 0 36px #d4a85329,0 18px 42px #d4a85314,inset 0 0 24px #d4a85314;font-size:clamp(.95rem,1.4vw,1.3rem);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-secondary);line-height:1.2;z-index:1}.contributors-card{position:relative;max-width:520px;margin:0 auto;border-radius:24px;padding:0;background:var(--color-bg-card);border:1px solid var(--color-border);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-md)}.contributors-card-inner{padding:var(--space-6)}.contributors-total-panel{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);min-height:auto;text-align:left}.contributors-total-copy{display:flex;flex-direction:column;gap:.35rem;min-width:0}.contributors-total-label{margin-bottom:0;font-size:1.9rem;font-weight:800;letter-spacing:.01em;line-height:1.1;color:var(--color-accent-secondary)}.contributors-total-note{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.35}.contributors-total-value-wrap{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0;padding:var(--space-3) var(--space-4);margin-bottom:0;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#ffffff08;color:var(--color-accent-primary);box-shadow:inset 0 1px #ffffff0f}.contributors-total-value{font-size:clamp(1.8rem,4vw,2.6rem);line-height:1;font-weight:800;color:var(--color-text-primary)}.contributors-chip-stage{position:relative;margin-top:var(--space-10)}.contributors-chip-viewport{overflow:hidden;padding:0 var(--space-2)}.contributors-chip-viewport:before,.contributors-chip-viewport:after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}.contributors-chip-viewport:before{left:-18px;background:linear-gradient(90deg,var(--color-bg-primary) 0%,rgba(15,15,26,.96) 24%,rgba(15,15,26,.5) 68%,transparent 100%)}.contributors-chip-viewport:after{right:-18px;background:linear-gradient(270deg,var(--color-bg-primary) 0%,rgba(15,15,26,.96) 24%,rgba(15,15,26,.5) 68%,transparent 100%)}.contributors-chip-row{display:flex;width:max-content;align-items:center;gap:var(--space-3);margin:var(--space-2) 0}.contributors-chip-row-a{animation:contributors-chip-row-a 22s linear infinite}.contributors-chip-row-b{animation:contributors-chip-row-b 28s linear infinite}.contributors-chip{display:inline-flex;min-height:54px;min-width:170px;align-items:center;justify-content:center;padding:0 var(--space-5);border-radius:999px;border:1px solid rgba(212,168,83,.26);background:linear-gradient(180deg,#ffffff0d,#ffffff05),#1e1e37db;color:var(--color-text-primary);font-size:1.08rem;font-weight:500;white-space:nowrap;box-shadow:inset 0 0 16px #ffffff0d,0 0 20px #d4a8531a}.contributors-chip:nth-child(3n),.contributors-chip:nth-child(6n){box-shadow:inset 0 0 16px #ffffff14,0 0 26px #d4a85338}@keyframes contributors-chip-row-a{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes contributors-chip-row-b{0%{transform:translate(-25%)}to{transform:translate(-75%)}}.features{padding:var(--space-20) 0}.section-title{font-size:var(--font-size-3xl);font-weight:700;text-align:center;margin-bottom:var(--space-3)}.section-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-12);font-size:var(--font-size-lg)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.feature-card{padding:var(--space-8);text-align:center}.feature-icon{margin-bottom:var(--space-4);color:var(--color-accent-primary)}.feature-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-3)}.feature-card p{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6}.cta-section{padding:var(--space-16) 0 var(--space-20)}.cta-card{padding:var(--space-16);text-align:center;background:linear-gradient(135deg,#d4a85314,#1e1e37b3)!important;border-color:var(--color-border-accent)!important}.cta-card h2{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--space-4)}.cta-card p{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin-bottom:var(--space-8)}.landing-footer{border-top:1px solid var(--color-border);padding:var(--space-12) 0}.footer-content{text-align:center}.footer-social-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);padding:var(--space-6);margin-bottom:var(--space-8);text-align:left}.footer-social-copy{display:flex;align-items:center;gap:var(--space-4)}.footer-social-icon{width:52px;height:52px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;background:var(--color-accent-glow);color:var(--color-accent-primary);font-size:28px;flex-shrink:0}.footer-social-copy h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-1)}.footer-social-copy p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.footer-social-link{flex-shrink:0}.footer-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-3)}.footer-desc{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.footer-bottom{padding-top:var(--space-6);border-top:1px solid var(--color-border)}.footer-bottom p{color:var(--color-text-muted);font-size:var(--font-size-xs)}@media(max-width:768px){.landing-nav-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--space-3);justify-content:initial}.landing-logo{display:flex;align-items:center;justify-content:flex-start;min-width:0;margin-right:0;overflow:visible}.landing-nav-actions{gap:var(--space-2);margin-left:0;justify-self:end}.landing-nav-actions>:not(.btn-primary){display:none}.landing-nav-actions .btn{min-height:20px;padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs)}.landing-mobile-language{display:block;position:absolute;top:calc(env(safe-area-inset-top,0px) + var(--navbar-height) + 10px);right:0;z-index:calc(var(--z-navbar) - 1);pointer-events:none}.landing-mobile-language-inner{width:max-content}.landing-mobile-language .language-switch{pointer-events:auto;padding:0}.landing-mobile-language .language-switch-btn{min-width:34px;padding:.28rem .5rem;font-size:.68rem}.hero{min-height:auto;padding:calc(var(--navbar-height) + 22px + var(--space-12)) 0 var(--space-12)}.hero-actions{flex-direction:column;gap:var(--space-3);align-items:center}.hero-actions .btn{width:auto;min-width:0;max-width:100%;padding-inline:var(--space-5)}.hero-stats,.stat-group{gap:var(--space-6)}.contributors-section{padding-bottom:var(--space-10)}.contributors-header{margin-top:var(--space-3);margin-bottom:var(--space-6)}.contributors-header:before{top:-42px;width:calc(100vw - 48px);height:140px;filter:blur(20px)}.contributors-title-pill{min-height:48px;padding-inline:var(--space-6);font-size:.86rem;letter-spacing:.06em}.contributors-card{max-width:100%;border-radius:20px}.contributors-card-inner{padding:var(--space-5)}.contributors-total-panel{align-items:center;flex-direction:column-reverse;text-align:center}.contributors-total-copy{gap:var(--space-1);align-items:center}.contributors-total-label{font-size:1.4rem}.contributors-total-value-wrap{padding:var(--space-3) var(--space-4)}.contributors-total-value{font-size:2rem}.contributors-total-note{font-size:var(--font-size-sm)}.contributors-chip-stage{margin-top:var(--space-7)}.contributors-chip{min-height:44px;min-width:138px;padding:0 var(--space-4);font-size:.95rem}.contributors-chip-viewport:before,.contributors-chip-viewport:after{width:56px}.features-grid{grid-template-columns:1fr;gap:var(--space-4)}.feature-card{padding:var(--space-6)}.cta-card{padding:var(--space-8)}.footer-social-card,.footer-social-copy{flex-direction:column;align-items:flex-start}.footer-social-link{width:100%;justify-content:center}}@media(prefers-reduced-motion:reduce){.contributors-chip-row-a,.contributors-chip-row-b{animation:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:calc(var(--navbar-height) + var(--space-8)) var(--space-6) var(--space-6);position:relative;overflow:hidden}.login-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-navbar);background:#0f0f1ad1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border)}.login-header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);height:var(--navbar-height)}.login-glow{position:absolute;top:20%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,var(--color-accent-glow) 0%,transparent 70%);pointer-events:none}.login-container{width:100%;max-width:420px;position:relative;z-index:2}.login-logo{display:flex;align-items:center;gap:var(--space-2);text-decoration:none}.login-card{padding:var(--space-8)}.login-card h1{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-2)}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.error-banner{padding:var(--space-3) var(--space-4);background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-sm);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.input-password-wrapper{position:relative;display:flex;align-items:center}.input-password-wrapper .input{width:100%;padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.1rem;padding:0;line-height:1;opacity:.6;transition:opacity var(--transition-fast)}.password-toggle:hover{opacity:1}.login-btn{width:100%;margin-top:var(--space-2)}.login-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-divider span{color:var(--color-text-muted);font-size:var(--font-size-sm)}.google-btn{width:100%}.google-mark{width:18px;height:18px;flex-shrink:0}@media(max-width:768px){.login-page{padding-inline:var(--space-4)}.login-header-inner{gap:var(--space-3)}}.login-tabs{display:flex;gap:0;margin-bottom:var(--space-5);border-radius:var(--radius-md);overflow:hidden;background:#ffffff0a;border:1px solid var(--color-border)}.login-tab{flex:1;padding:var(--space-2) var(--space-3);background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:500;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.login-tab:hover{background:#ffffff0f;color:var(--color-text-primary)}.login-tab.active{background:linear-gradient(135deg,#d4a8533d,#e8c97a24);color:var(--color-text-primary);font-weight:700;box-shadow:inset 0 0 0 1px var(--color-border-accent)}.person-match-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid #dbe2ea;border-radius:16px;background:#fff;box-shadow:0 10px 24px #0f172a0f}.person-match-card-compact{padding:12px 14px}.person-match-card-selected{border-color:#0f172a;box-shadow:0 14px 28px #0f172a1a}.person-match-avatar{width:48px;height:48px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#f8fafc;color:#475569}.person-match-avatar-alive{box-shadow:0 0 0 4px #22c55e2e,0 0 0 2px #22c55e}.person-match-avatar-deceased{box-shadow:0 0 0 4px #ef44442e,0 0 0 2px #ef4444}.person-match-content{min-width:0;flex:1;display:flex;flex-direction:column;gap:3px}.person-match-name{font-size:.96rem;font-weight:800;color:#0f172a}.person-match-meta,.person-match-gender{color:#64748b;font-size:.82rem}.person-match-select-btn{border:none;border-radius:999px;background:#0f172a;color:#fff;padding:10px 16px;font-family:inherit;font-size:.82rem;font-weight:700;cursor:pointer}@media(max-width:768px){.person-match-card{align-items:flex-start;flex-wrap:wrap}.person-match-select-btn{width:100%;justify-content:center}}.person-search-overlay{z-index:1100}.person-search-shell{width:min(100%,680px);max-height:min(88vh,760px)}.person-search-modal{display:flex;flex-direction:column;gap:16px;min-height:280px;padding:24px;border:1px solid #dbe2ea;border-radius:22px;background:#fff;box-shadow:0 30px 60px #0f172a29}.person-search-modal-embedded{min-height:0;padding:0;border:none;border-radius:0;box-shadow:none;background:transparent}.person-search-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.person-search-header h3{margin:0;font-size:1.15rem;font-weight:800;color:#0f172a}.person-search-close{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #dbe2ea;border-radius:999px;background:#fff;color:#475569;cursor:pointer}.person-search-input-wrap{display:flex;align-items:center;gap:10px;padding:0 14px;border:1px solid #cbd5e1;border-radius:14px;background:#fff;color:#64748b}.person-search-input-wrap:focus-within{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.person-search-input{width:100%;border:none;background:transparent;color:#0f172a;padding:12px 0;font-family:inherit;font-size:.95rem}.person-search-input:focus{outline:none}.person-search-results{display:flex;flex-direction:column;gap:10px;min-height:160px;max-height:420px;overflow-y:auto}.person-search-state{min-height:160px;display:flex;align-items:center;justify-content:center;gap:10px;color:#64748b;font-weight:600}.person-search-empty{border:1px dashed #dbe2ea;border-radius:16px;background:#f8fafc}@media(max-width:768px){.person-search-modal{padding:18px}}.add-person-wizard{width:min(100%,620px);max-height:min(88vh,780px);display:flex;flex-direction:column;gap:18px}.add-person-wizard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.add-person-wizard-header h2{margin:0}.add-person-wizard-close{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #dbe2ea;border-radius:999px;background:#fff;color:#475569;cursor:pointer}.add-person-wizard-methods,.add-person-wizard-step{display:flex;flex-direction:column;gap:16px}.add-person-wizard-choice{padding:18px}.add-person-wizard-form{display:flex;flex-direction:column;gap:0}.add-person-wizard-confirm{display:flex;flex-direction:column;gap:14px}.add-person-wizard-confirm h3{margin:0;font-size:1rem;font-weight:800;color:#0f172a}.add-person-wizard-confirm-label{display:inline-flex;align-items:center;gap:8px;width:fit-content;padding:8px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:.82rem;font-weight:700}.add-person-wizard-confirm-meta{color:#64748b;font-size:.84rem}.add-person-wizard-footer{display:flex;justify-content:space-between;gap:12px;margin-top:4px}.add-person-wizard-error{margin-bottom:0}.add-person-wizard-blocked{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:18px;border:1px solid #fde68a;border-radius:18px;background:#fffbeb}.add-person-wizard-blocked p{margin:0;color:#92400e;line-height:1.5;font-weight:600}.add-person-wizard-blocked-icon{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#fef3c7;color:#b45309}@media(max-width:768px){.add-person-wizard{width:min(100%,100%);padding:20px}.add-person-wizard-footer{flex-direction:column-reverse}.add-person-wizard-footer .btn{width:100%}}.burial-place-shell{display:flex;flex-direction:column;gap:12px}.burial-place-results{margin:-4px 0 4px;border:1px solid #dbe2ea;border-radius:16px;background:#f8fafc;overflow:hidden}.burial-place-state{display:flex;align-items:center;gap:8px;padding:12px 14px;color:#475569;font-size:.85rem}.burial-place-state-error{color:#b91c1c;background:#fef2f2}.burial-place-spinner{width:16px;height:16px;border-width:2px}.burial-place-suggestions{display:flex;flex-direction:column}.burial-place-suggestion{display:flex;flex-direction:column;align-items:flex-start;gap:4px;width:100%;padding:12px 14px;border:none;border-top:1px solid #e2e8f0;background:transparent;text-align:left;cursor:pointer}.burial-place-suggestion:first-child{border-top:none}.burial-place-suggestion:hover{background:#ffffffd1}.burial-place-suggestion-label{color:#0f172a;font-size:.9rem;font-weight:700}.burial-place-suggestion-address{color:#64748b;font-size:.8rem;line-height:1.45}.navbar{position:fixed;top:0;left:0;right:0;z-index:var(--z-navbar);background:#0f0f1ad9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border)}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height)}.navbar-left{display:flex;align-items:center;gap:var(--space-3)}.navbar-right{display:flex;align-items:center;gap:var(--space-4)}.navbar-language-switch{margin-left:var(--space-2)}.nav-link{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--color-text-primary);background:var(--color-bg-glass)}.nav-link.active{color:var(--color-accent-primary)}.navbar-user{display:flex;align-items:center;gap:var(--space-3);padding-left:var(--space-4);border-left:1px solid var(--color-border)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;text-decoration:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast),outline-color var(--transition-fast);outline:2px solid transparent;outline-offset:2px}.user-avatar:hover{transform:translateY(-1px)}.user-avatar:focus-visible{outline-color:var(--color-accent-primary)}.user-avatar-active{box-shadow:0 0 0 2px var(--color-accent-primary)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent-primary);text-transform:uppercase}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.mobile-nav-shell{display:none}@media(max-width:768px){.navbar{border-bottom:none;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.navbar-inner{height:0;min-height:0;padding:0}.navbar-left,.navbar-left .landing-logo,.navbar-right{display:none}.mobile-nav-shell{display:block;position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);left:14px;z-index:calc(var(--z-navbar) + 20)}.mobile-menu-trigger{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:#fffffff0;color:#0f172a;box-shadow:0 12px 28px #0f172a24;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.mobile-menu-trigger .app-icon{font-size:18px}.mobile-menu-trigger-open{background:#0f172a;color:#fff;box-shadow:0 16px 32px #0f172a38}.mobile-menu-panel{position:absolute;top:calc(100% + 10px);left:0;width:168px;display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid rgba(219,226,234,.92);border-radius:18px;background:#fffffffa;box-shadow:0 18px 40px #0f172a29;opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:opacity .18s ease,transform .18s ease}.mobile-menu-panel-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.mobile-menu-language{display:flex;justify-content:center;padding:2px 0 6px}.mobile-menu-item{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:flex-start;gap:10px;padding:10px 12px;border:none;border-radius:12px;background:#f8fafc;color:#0f172a;text-decoration:none;font-size:.84rem;font-weight:700;text-align:left;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.mobile-menu-item:active{transform:scale(.98)}.mobile-menu-item-danger{background:#fff1f2;color:#be123c}.mobile-menu-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.mobile-menu-icon .app-icon{font-size:18px}}.dashboard-page{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif}.canvas-container{--canvas-surface: #f8fafc;--canvas-grid-line: #eef2f7;--canvas-dot: #dbe2ea;--canvas-connection-default: #94a3b8;--canvas-connection-spouse: #64748b;--canvas-connection-generic: #a78bfa;--canvas-connection-related: #64748b;--canvas-connection-active: #0f172a;flex:1;position:relative;width:100%;overflow:hidden;cursor:grab;background-color:var(--canvas-surface);background-image:linear-gradient(var(--canvas-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--canvas-grid-line) 1px,transparent 1px);background-size:28px 28px}.canvas-container:active{cursor:grabbing}.canvas-container-dark{--canvas-surface: #07111f;--canvas-grid-line: rgba(148, 163, 184, .08);--canvas-dot: rgba(148, 163, 184, .22);--canvas-connection-default: #7f8fa6;--canvas-connection-spouse: #cbd5e1;--canvas-connection-generic: #c4b5fd;--canvas-connection-related: #e2e8f0;--canvas-connection-active: #f8fafc}.canvas-content{position:relative}.canvas-scene{position:absolute;top:0;right:0;bottom:0;left:0;overflow:visible}.family-patch-layer,.connection-layer,.connection-label-layer,.node-layer{position:absolute;top:0;right:0;bottom:0;left:0}.family-patch-layer{z-index:0;pointer-events:none}.family-patch{position:absolute;border-radius:56px;background-image:radial-gradient(var(--canvas-dot) 1.15px,transparent 1.15px);background-size:18px 18px;opacity:.42;mask-image:radial-gradient(ellipse at center,black 72%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse at center,black 72%,transparent 100%)}.connection-layer{z-index:1;overflow:visible}.connection-label-layer{z-index:3;pointer-events:none}.node-layer{z-index:2;pointer-events:none}.node-layer .person-node.shadcn-card{pointer-events:auto}.connection-hit-area{fill:none;stroke:transparent;stroke-width:16;cursor:pointer;pointer-events:stroke}.connection-path{fill:none;stroke:var(--canvas-connection-default);stroke-width:2.5;transition:stroke .18s ease,stroke-width .18s ease,opacity .2s ease;pointer-events:none}.connection-exiting{stroke-dasharray:1;stroke-dashoffset:0;animation:connectionPathRetract var(--connection-exit-duration, .22s) cubic-bezier(.4,0,.2,1) forwards;pointer-events:none}.connection-entering{stroke-dasharray:1;stroke-dashoffset:1;animation:connectionPathDraw var(--connection-enter-duration, 1.35s) cubic-bezier(.4,0,.2,1) forwards;pointer-events:none}.connection-entering-segment{stroke-dasharray:1;stroke-dashoffset:1;animation:connectionPathDraw var(--connection-enter-segment-duration, .72s) cubic-bezier(.4,0,.2,1) var(--connection-enter-delay, 0ms) forwards;pointer-events:none}@keyframes connectionPathDraw{0%{stroke-dashoffset:1}to{stroke-dashoffset:0}}@keyframes connectionPathRetract{0%{stroke-dashoffset:0}to{stroke-dashoffset:1}}.connection-spouse{stroke:var(--canvas-connection-spouse)}.connection-parentChild{stroke:var(--canvas-connection-default)}.connection-generic{stroke:var(--canvas-connection-generic);opacity:.82}.connection-related{stroke:var(--canvas-connection-related)}.connection-active{stroke:var(--canvas-connection-active);stroke-width:3.5;opacity:1}.connection-chip-wrap{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:8px;pointer-events:auto;transition:opacity .2s ease}.connection-chip-wrap-entering{opacity:0;animation:connectionChipEnter var(--connection-chip-enter-duration, .14s) ease-out forwards;animation-delay:var(--connection-chip-enter-delay, .11s)}.connection-chip-wrap-exiting{opacity:0}@keyframes connectionChipEnter{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.connection-chip{position:relative;z-index:1;background:#fffffff5;color:#0f172a;border:1px solid #dbe2ea;border-radius:999px;padding:5px 12px;font-family:inherit;font-size:.76rem;font-weight:700;cursor:pointer;box-shadow:0 6px 18px #0f172a14;white-space:nowrap}.connection-chip-active{border-color:#0f172a;box-shadow:0 8px 20px #0f172a29}.connection-delete-btn{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;border-radius:999px;padding:5px 10px;font-family:inherit;font-size:.72rem;font-weight:700;cursor:pointer}.person-node.shadcn-card{--flip-x: 0px;--flip-y: 0px;--node-scale: 1;--node-opacity: 1;position:absolute;width:220px;height:222px;display:flex;flex-direction:column;border:1px solid #e2e8f0;border-radius:16px;background:#fff;box-shadow:0 14px 30px #0f172a14;color:#0f172a;z-index:10;transform:translate(var(--flip-x),var(--flip-y)) scale(var(--node-scale));transform-origin:center center;opacity:var(--node-opacity);transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .3s ease,box-shadow .18s ease,border-color .18s ease;will-change:transform,opacity}.person-node.shadcn-card:hover{box-shadow:0 18px 36px #0f172a1f}.node-selected{border-color:#0f172a!important;box-shadow:0 18px 36px #0f172a29}.node-source{border-color:#2563eb!important;box-shadow:0 0 0 4px #2563eb24,0 18px 36px #0f172a29}.node-targetable{border-color:#bfdbfe!important;animation:targetPulse 1.8s infinite}@keyframes targetPulse{0%{box-shadow:0 0 #3b82f647}70%{box-shadow:0 0 0 14px #3b82f600}to{box-shadow:0 0 #3b82f600}}.branch-toggle-btn{position:absolute;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:1px solid #dbe2ea;border-radius:999px;background:#fffffff5;color:#475569;box-shadow:0 8px 18px #0f172a14;cursor:pointer;z-index:3}.branch-toggle-parent{top:-12px;left:50%;transform:translate(-50%)}.branch-toggle-siblings{top:50%;right:-12px;transform:translateY(-50%)}.branch-toggle-children{bottom:-12px;left:50%;transform:translate(-50%)}.branch-toggle-btn:hover{background:#f8fafc;color:#0f172a}.branch-toggle-btn .app-icon{transition:transform .3s ease-in-out}.branch-toggle-open .app-icon{transform:rotate(180deg)}.node-controls{position:absolute;top:10px;right:10px;display:flex;gap:4px;z-index:2;align-items:center}.icon-btn-shad{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:7px;background:#ffffffb8;color:#64748b;cursor:pointer;transition:background .18s ease,color .18s ease}.icon-btn-shad:hover{background:#f1f5f9;color:#0f172a}.icon-btn-add{background:#eff6ff;color:#1d4ed8}.icon-btn-add:hover,.icon-btn-add-open{background:#1d4ed8;color:#fff}.card-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;padding:34px 16px 12px;text-align:center}.card-focus-trigger{width:100%;cursor:pointer}.node-exiting{pointer-events:none}.avatar-wrapper{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.9)}.node-info{display:flex;flex-direction:column;gap:3px;align-items:center}.node-title{font-size:.72rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.08em}.node-order-badge{display:inline-flex;align-items:center;justify-content:center;min-height:22px;padding:0 10px;border-radius:999px;background:#dcfce7;color:#166534;font-size:.74rem;font-weight:800;letter-spacing:.01em}.node-name{font-size:1.02rem;line-height:1.25;font-weight:700;color:#0f172a}.node-age{font-size:.82rem;color:#64748b}.node-action-menu-btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid transparent;border-radius:10px;font-family:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}.node-action-menu-btn:hover{transform:translateY(-1px)}.node-action-menu{position:absolute;top:calc(100% + 8px);right:0;display:flex;flex-direction:column;gap:6px;width:152px;padding:0;background:transparent;border:none;box-shadow:none;pointer-events:auto}.node-action-submenu{display:flex;flex-direction:column;gap:6px;padding-left:10px;border-left:2px solid rgba(148,163,184,.25)}.node-action-menu-btn{width:100%;justify-content:flex-start;padding:0 12px;box-shadow:0 8px 18px #0f172a14}.node-action-add-toggle{justify-content:space-between;background:#f8fafc;border-color:#dbe2ea;color:#0f172a}.node-action-add-toggle-open{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}.node-action-add-label{display:inline-flex;align-items:center;gap:7px}.node-action-link{background:#f8fafc;border-color:#dbe2ea;color:#0f172a}.node-action-pedigree{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.node-action-spouse{background:#fdf4ff;border-color:#f3d2ff;color:#a21caf}.node-action-child{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.node-action-parent{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.node-action-sibling{background:#f8fafc;border-color:#dbe2ea;color:#334155}.canvas-controls{position:absolute;right:24px;bottom:24px;z-index:120;display:flex;gap:8px;padding:8px;background:#fffffff5;border:1px solid #dbe2ea;border-radius:14px;box-shadow:0 12px 28px #0f172a1f}.canvas-menu-shell{position:relative;z-index:1}.canvas-menu-trigger{box-shadow:none}.canvas-menu-trigger-open{background:#0f172a;color:#fff;border-color:#0f172a}.canvas-menu-trigger:hover{background:#f8fafc}.canvas-menu-trigger-open:hover{background:#0f172a}.canvas-menu-panel{position:absolute;right:0;bottom:calc(100% + 12px);width:232px;padding:12px;border:1px solid rgba(219,226,234,.92);border-radius:18px;background:#fffffffa;box-shadow:0 18px 42px #0f172a2e;opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:opacity .18s ease,transform .18s ease}.canvas-menu-panel-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.canvas-menu-header{margin-bottom:10px;color:#475569;font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.canvas-menu-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 12px 12px 14px;border:1px solid #dbe2ea;border-radius:14px;background:#f8fafc;color:#0f172a;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.canvas-menu-option+.canvas-menu-option{margin-top:8px}.canvas-menu-option:hover,.canvas-menu-option-active{background:#fefce8;border-color:#d4a85357;box-shadow:inset 0 0 0 1px #d4a85324}.canvas-menu-option-copy{display:flex;flex-direction:column;gap:2px;min-width:0}.canvas-menu-option-title{font-size:.88rem;font-weight:700}.canvas-menu-option-hint{color:#64748b;font-size:.75rem}.canvas-menu-switch{width:42px;height:24px;display:inline-flex;align-items:center;padding:2px;border-radius:999px;background:#cbd5e1;transition:background var(--transition-fast);flex-shrink:0}.canvas-menu-switch-on{background:#0f172a}.canvas-menu-switch-handle{width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0f172a38;transition:transform var(--transition-fast)}.canvas-menu-switch-on .canvas-menu-switch-handle{transform:translate(18px)}.canvas-finder-shell{position:absolute;top:calc(var(--navbar-height) + env(safe-area-inset-top,0px) + 12px);left:50%;transform:translate(-50%);z-index:170;width:min(360px,calc(100vw - 48px));display:flex;flex-direction:column;gap:8px}.canvas-finder-bar{display:flex;align-items:center;gap:8px}.canvas-finder-input-wrap{display:flex;align-items:center;gap:10px;flex:1;padding:11px 14px;border:1px solid #dbe2ea;border-radius:16px;background:#fffffff5;box-shadow:0 16px 28px #0f172a1a}.canvas-finder-input{flex:1;border:none;background:transparent;color:#0f172a;font:inherit}.canvas-finder-input:focus{outline:none}.canvas-finder-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:12px;background:#ffffffeb;color:#475569;font-size:.82rem;font-weight:600;box-shadow:0 10px 24px #0f172a14}.canvas-finder-clear{border:none;background:transparent;color:#2563eb;font:inherit;font-weight:700;cursor:pointer}.canvas-finder-close{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #dbe2ea;border-radius:14px;background:#fffffff5;color:#0f172a;cursor:pointer;box-shadow:0 16px 28px #0f172a1a}.btn-global-tambah{position:absolute;left:50%;bottom:24px;transform:translate(-50%);z-index:140;display:inline-flex;align-items:center;gap:var(--space-2);background:#0f172a;color:#fff;border:none;border-radius:999px;padding:13px 24px;font-family:inherit;font-size:.98rem;font-weight:800;cursor:pointer;box-shadow:0 16px 28px #0f172a33}.btn-global-tambah:hover{background:#1e293b}.dashboard-page-dark-canvas .btn-global-tambah{background:#fffffffa;color:#0f172a;box-shadow:0 16px 28px #03071257}.dashboard-page-dark-canvas .btn-global-tambah:hover{background:#fff}.linking-banner{position:absolute;top:24px;left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:14px;max-width:min(92vw,720px);padding:14px 18px;background:#eff6fff5;border:1px solid #bfdbfe;border-radius:16px;box-shadow:0 12px 28px #2563eb29;color:#1d4ed8;font-size:.92rem;font-weight:700}.btn-cancel-link{border:none;border-radius:999px;background:#2563eb;color:#fff;padding:8px 14px;font-family:inherit;font-size:.8rem;font-weight:700;cursor:pointer}.dashboard-loading{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#64748b}.spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#0f172a;border-radius:50%;animation:spin .8s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;background:#ffffffd6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:min(100%,440px);max-height:min(88vh,760px);overflow:auto;background:#fff;color:#0f172a;border:1px solid #dbe2ea;border-radius:22px;padding:24px;box-shadow:0 30px 60px #0f172a29}.modal-compact{width:min(100%,460px)}.modal h2{margin:0 0 8px;font-size:1.45rem;font-weight:800}.modal-subtitle{margin:0 0 20px;color:#64748b;line-height:1.5}.modal-error{margin-bottom:16px;padding:10px 12px;border-radius:12px;background:#fef2f2;color:#b91c1c;font-size:.9rem;font-weight:600}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{font-size:.9rem;font-weight:700}.input-field{width:100%;padding:11px 13px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;color:#0f172a;font-family:inherit;font-size:.95rem}.input-field:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.gelaran-chips{display:flex;flex-wrap:wrap;gap:8px}.gelaran-chips-collapsed{max-height:34px;overflow:hidden}.gelaran-chips-expanded{max-height:none}.chip{border:1px solid #dbe2ea;border-radius:999px;background:#f8fafc;color:#475569;padding:5px 12px;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer}.chip-active{background:#0f172a;border-color:#0f172a;color:#fff}.form-hint{margin:2px 0 0;font-size:.76rem;color:#94a3b8;line-height:1.45}.form-toggle-btn{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;border:1px solid #dbe2ea;border-radius:999px;background:#fff;color:#334155;padding:7px 12px;font-family:inherit;font-size:.82rem;font-weight:700;cursor:pointer}.form-toggle-btn-section{margin:-2px 0 8px}.gender-options{display:flex;gap:16px}.gender-option{display:inline-flex;align-items:center;gap:8px;color:#334155;cursor:pointer}.form-section{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding-top:4px;border-top:1px solid #e2e8f0}.form-section h3{margin:0;color:#0f172a;font-size:1rem;font-weight:700}.form-grid{display:grid;gap:14px}.form-grid-two{grid-template-columns:1fr 1fr}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.btn-secondary,.btn-primary,.btn-danger{border:none;border-radius:12px;padding:10px 16px;font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer}.btn-secondary{background:#e2e8f0;color:#0f172a}.btn-primary{background:#0f172a;color:#fff}.btn-danger{background:#fee2e2;color:#b91c1c}.modal-delete-btn{margin-right:auto}.choice-grid{display:grid;gap:12px}.choice-btn{display:flex;flex-direction:column;gap:6px;align-items:flex-start;padding:16px;border:1px solid #dbe2ea;border-radius:16px;background:#fff;color:#0f172a;text-align:left;font-family:inherit;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.choice-btn:hover{transform:translateY(-1px);border-color:#94a3b8;box-shadow:0 12px 24px #0f172a14}.choice-btn strong{font-size:.95rem}.choice-btn span{color:#64748b;line-height:1.5}.relation-option-list{display:flex;flex-direction:column;gap:10px}.relation-option{display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:start;padding:12px 14px;border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc;cursor:pointer}.relation-option input{margin-top:2px}.relation-option-title{font-size:.92rem;font-weight:700;color:#0f172a}.relation-option-desc{margin-top:4px;font-size:.8rem;color:#64748b;line-height:1.45}@media(max-width:768px){.canvas-menu-shell{display:none}.canvas-finder-shell{top:calc(env(safe-area-inset-top,0px) + 62px);left:50%;transform:translate(-50%);width:calc(100vw - 28px)}.branch-toggle-btn{width:44px;height:44px}.branch-toggle-parent{top:-10px}.branch-toggle-siblings{right:-10px}.branch-toggle-children{bottom:-10px}.node-controls{top:8px;right:8px;gap:5px}.icon-btn-shad{width:24px;height:24px;border-radius:999px;background:#ffffffeb;color:#64748b;box-shadow:0 6px 16px #0f172a14}.icon-btn-add{background:#0f172a;color:#fff}.icon-btn-add:hover,.icon-btn-add-open{background:#1d4ed8;color:#fff}.card-content{gap:7px;padding:30px 12px 12px}.avatar-wrapper{width:56px;height:56px}.node-title{font-size:.68rem}.node-name{font-size:.96rem}.node-age{font-size:.78rem}.node-action-menu-btn{font-size:.74rem;min-height:32px}.node-action-menu{top:calc(100% + 6px);width:138px;gap:5px}.canvas-controls{position:fixed;left:50%;right:auto;bottom:calc(env(safe-area-inset-bottom,0px) + 18px);transform:translate(-50%);z-index:160;display:flex;gap:6px;padding:6px 8px;border-radius:14px;background:#fffffff5;box-shadow:0 10px 28px #0f172a29}.control-btn{min-width:32px;height:32px;border-radius:999px;font-size:.92rem}.control-btn-reset{display:none}.form-grid-two{grid-template-columns:1fr}.btn-global-tambah{top:14px;right:14px;left:auto;bottom:auto;transform:none;padding:8px 12px;font-size:.78rem;font-weight:700;border-radius:999px;box-shadow:0 12px 24px #0f172a2e}.linking-banner{top:calc(env(safe-area-inset-top,0px) + 62px);width:calc(100% - 24px);align-items:flex-start;flex-direction:column}}.person-form-modal{max-width:560px;max-height:85vh;overflow-y:auto}.person-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.person-form textarea.input{resize:vertical;min-height:80px}@media(max-width:768px){.form-row{grid-template-columns:1fr;gap:var(--space-3)}.person-form-modal{max-height:90vh}}.tree-page{min-height:100vh}.tree-main{padding:calc(var(--navbar-height) + var(--space-6)) 0 var(--space-16)}.tree-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-8);gap:var(--space-4)}.tree-header-left{flex:1}.back-btn{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-2);transition:color var(--transition-fast)}.back-btn:hover{color:var(--color-accent-primary)}.tree-header h1{font-size:var(--font-size-2xl);font-weight:700}.tree-header p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.tree-actions{display:flex;gap:var(--space-3);flex-shrink:0}.tree-container{margin-bottom:var(--space-8)}.tree-visual{overflow-x:auto;padding:var(--space-8) var(--space-4);display:flex;justify-content:center;gap:var(--space-8)}.empty-icon{display:inline-flex;color:var(--color-accent-primary);margin-bottom:var(--space-4)}.tree-branch,.tree-node-wrapper{display:flex;flex-direction:column;align-items:center}.tree-couple{display:flex;align-items:center;gap:var(--space-2)}.spouse-connector{display:inline-flex;color:var(--color-accent-primary);opacity:.85}.person-node{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-4) var(--space-5);cursor:pointer;min-width:120px;text-align:center;position:relative;transition:all var(--transition-base)}.person-node[data-gender=male]{border-top:3px solid var(--color-male)}.person-node[data-gender=female]{border-top:3px solid var(--color-female)}.person-node.selected{border-color:var(--color-accent-primary)!important;box-shadow:var(--shadow-glow);background:#d4a8531a}.person-emoji{display:inline-flex;color:inherit}.person-name{font-size:var(--font-size-sm);font-weight:600;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.person-dates{font-size:var(--font-size-xs);color:var(--color-text-muted)}.person-deceased{position:absolute;top:var(--space-2);right:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-muted)}.children-connector{width:2px;height:24px;background:var(--color-border);margin:0 auto}.children-row{display:flex;gap:var(--space-4);position:relative;padding-top:var(--space-4)}.children-row:before{content:"";position:absolute;top:0;left:50px;right:50px;height:2px;background:var(--color-border)}.tree-stats{display:flex;justify-content:center;gap:var(--space-10);padding:var(--space-5) var(--space-8);margin-top:var(--space-6)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-item .stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-accent-primary)}.stat-item .stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.person-detail{padding:var(--space-8);margin-top:var(--space-6)}.person-detail-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.person-avatar{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-primary)}.person-avatar[data-gender=male]{background:#60a5fa26}.person-avatar[data-gender=female]{background:#f472b626}.person-detail h2{font-size:var(--font-size-xl);font-weight:700}.person-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.person-status{display:inline-flex;align-items:center;gap:6px}.person-status-alive{color:var(--color-success)}.person-status-deceased{color:var(--color-text-muted)}.person-bio{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-3)}.person-info{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-2)}.person-links{display:flex;flex-wrap:wrap;gap:var(--space-6);margin:var(--space-6) 0;padding-top:var(--space-4);border-top:1px solid var(--color-border)}.link-section h4{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.link-tag{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);margin-right:var(--space-2);margin-bottom:var(--space-2)}.link-tag:hover{background:var(--color-bg-glass-hover);border-color:var(--color-accent-primary)}.person-detail-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}@media(max-width:768px){.tree-header{flex-direction:column}.tree-actions{width:100%}.tree-actions .btn{flex:1}.tree-visual{justify-content:flex-start;min-width:max-content}.tree-stats{gap:var(--space-6);padding:var(--space-4) var(--space-5)}.person-detail-actions{flex-wrap:wrap}.person-detail-actions .btn{flex:1;min-width:100px}}.profile-page{min-height:100vh}.profile-main{padding:calc(var(--navbar-height) + var(--space-8)) 0 var(--space-16);max-width:640px;margin:0 auto}.profile-header{margin-bottom:var(--space-8)}.profile-header h1{font-size:var(--font-size-3xl);font-weight:700}.profile-header p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.profile-card{padding:var(--space-8);margin-bottom:var(--space-6)}.profile-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-5)}.profile-avatar-section{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}.profile-avatar-large{width:72px;height:72px;border-radius:var(--radius-full);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-avatar-large span{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-accent-primary);text-transform:uppercase}.profile-avatar-section h2{font-size:var(--font-size-xl);font-weight:600}.profile-avatar-section p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.profile-form{display:flex;flex-direction:column;gap:var(--space-4)}.profile-actions{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-2)}.save-success{color:var(--color-success);font-size:var(--font-size-sm);font-weight:500;animation:fadeIn .3s ease}.account-info{display:flex;flex-direction:column;gap:var(--space-4)}.account-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.account-row:last-child{border-bottom:none}.account-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.account-value{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);max-width:200px;overflow:hidden;text-overflow:ellipsis}.profile-social-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-5)}.profile-social-copy{display:flex;align-items:center;gap:var(--space-4)}.profile-social-icon{width:52px;height:52px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;background:var(--color-accent-glow);color:var(--color-accent-primary);font-size:28px;flex-shrink:0}.profile-social-copy h3{margin-bottom:var(--space-1)}.profile-social-copy p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.profile-social-link{flex-shrink:0}@media(max-width:768px){.profile-main{padding-bottom:var(--space-10)}.profile-social-card,.profile-social-copy{flex-direction:column;align-items:flex-start}.profile-social-link{width:100%;justify-content:center}}.pedigree-card{position:relative;width:220px;min-height:156px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px 16px 18px;border:1px solid #dbe2ea;border-radius:18px;background:#fff;color:#0f172a;box-shadow:0 14px 30px #0f172a14;text-align:center;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.pedigree-card:hover{transform:translateY(-2px);box-shadow:0 18px 36px #0f172a1f}.pedigree-card-focus{border-color:#1d4ed8;box-shadow:0 0 0 4px #2563eb1f,0 18px 40px #0f172a24;background:linear-gradient(180deg,#fff,#f8fbff)}.pedigree-focus-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:.72rem;font-weight:800}.pedigree-avatar{width:68px;height:68px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#f8fafc;color:#475569}.pedigree-avatar-alive{box-shadow:0 0 0 4px #22c55e2e,0 0 0 2px #22c55e}.pedigree-avatar-deceased{box-shadow:0 0 0 4px #ef44442e,0 0 0 2px #ef4444}.pedigree-card-name{font-size:1rem;font-weight:800;line-height:1.3}.pedigree-card-meta{color:#64748b;font-size:.82rem;line-height:1.4}.pedigree-card-placeholder{border-style:dashed;background:#f8fafc;color:#475569;box-shadow:none}.pedigree-card-placeholder:hover{border-color:#1d4ed8;background:#eff6ff;box-shadow:0 12px 28px #1d4ed81f}.pedigree-placeholder-icon{width:56px;height:56px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#fff;color:#1d4ed8;box-shadow:inset 0 0 0 1px #bfdbfe}.pedigree-placeholder-label{font-size:.82rem;font-weight:700;line-height:1.4}@media(max-width:768px){.pedigree-card{width:184px;min-height:138px;padding:18px 12px 16px}.pedigree-avatar{width:56px;height:56px}.pedigree-card-name{font-size:.92rem}}.pedigree-page{min-height:100vh;background:#f8fafc}.pedigree-main{min-height:calc(100vh - 64px);padding:24px}.pedigree-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin:0 auto 18px;max-width:1440px}.pedigree-header h1{margin:0;color:#0f172a;font-size:1.8rem;font-weight:800}.pedigree-header-actions{display:flex;align-items:center;gap:12px}.pedigree-tree-btn{white-space:nowrap}.pedigree-canvas-shell{position:relative;height:calc(100vh - 180px);border:1px solid #dbe2ea;border-radius:24px;background:linear-gradient(#eef2f7 1px,transparent 1px),linear-gradient(90deg,#eef2f7 1px,transparent 1px);background-size:28px 28px;overflow:hidden}.pedigree-canvas{width:1600px;min-height:1100px;padding:72px 80px 120px}.pedigree-layout{display:flex;flex-direction:column;gap:90px;align-items:center;transform-origin:top center}.pedigree-row{width:100%;display:flex;justify-content:center;gap:52px}.pedigree-grandparents-row{justify-content:space-between}.pedigree-pair-group{display:flex;justify-content:center;gap:46px}.pedigree-focus-group{gap:56px}.pedigree-children-group{display:flex;justify-content:center;flex-wrap:wrap;gap:30px}.pedigree-card-spacer{width:220px;min-height:156px}.pedigree-zoom-group{display:flex;align-items:center;gap:8px}.control-btn{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid #dbe2ea;border-radius:10px;background:#fff;color:#0f172a;font-size:1rem;font-weight:700;cursor:pointer}.control-btn:hover{background:#f8fafc}.pedigree-loading,.pedigree-empty-state{min-height:calc(100vh - 160px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#64748b}.pedigree-empty-state{color:#475569}.pedigree-mobile-bar{margin-bottom:12px}.pedigree-grandparent-toggle{border-radius:999px}.pedigree-zoom-mobile{position:absolute;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 18px);transform:translate(-50%);z-index:20;padding:6px 8px;border:1px solid #dbe2ea;border-radius:999px;background:#fffffff5;box-shadow:0 10px 28px #0f172a29}.hide-desktop{display:none}@media(max-width:768px){.pedigree-main{padding:16px 12px 24px}.pedigree-header{align-items:flex-start;flex-direction:column;margin-bottom:12px}.pedigree-header-actions{width:100%;justify-content:space-between;flex-wrap:wrap}.pedigree-canvas-shell{height:calc(100vh - 220px);border-radius:20px}.pedigree-canvas{width:1280px;min-height:920px;padding:56px 48px 120px}.pedigree-layout{gap:64px;transform:scale(.85)}.pedigree-grandparents-row{display:none}.pedigree-row-visible-mobile{display:flex}.hide-mobile{display:none}.hide-desktop{display:flex}.pedigree-focus-group{gap:28px}}.person-timeline{display:flex;flex-direction:column;gap:18px}.person-timeline-item{display:grid;grid-template-columns:48px 1fr;gap:16px;align-items:flex-start}.person-timeline-marker{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#fff;border:1px solid #dbe2ea;color:#0f172a;box-shadow:0 10px 24px #0f172a0f;position:relative}.person-timeline-item:not(:last-child) .person-timeline-marker:after{content:"";position:absolute;left:50%;top:calc(100% + 6px);width:1px;height:28px;background:#cbd5e1;transform:translate(-50%)}.person-timeline-content{padding:4px 0 0}.person-timeline-label{font-size:.82rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em}.person-timeline-value{margin-top:4px;font-size:1.06rem;font-weight:800;color:#0f172a}.person-timeline-detail{margin-top:4px;color:#64748b;font-size:.9rem}.memories-tab{display:flex;flex-direction:column;gap:18px}.memories-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.memories-upload-btn{display:inline-flex;align-items:center;gap:8px}.memories-uploading{color:#64748b;font-size:.9rem;font-weight:600}.memories-file-input{display:none}.memories-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.memory-card{border:1px solid #dbe2ea;border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 10px 24px #0f172a0f}.memory-card-image-wrap{aspect-ratio:1 / 1;background:#e2e8f0}.memory-card-image{width:100%;height:100%;object-fit:cover;display:block}.memory-card-caption,.memory-card-caption-input{width:100%;border:none;background:#fff;color:#0f172a;font:inherit;text-align:left;padding:14px 16px;min-height:56px}.memory-card-caption{cursor:text}.memory-card-caption-input{outline:none;border-top:1px solid #e2e8f0}@media(max-width:768px){.memories-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}}.person-page{min-height:100vh;background:radial-gradient(circle at top left,rgba(219,234,254,.7),transparent 34%),radial-gradient(circle at top right,rgba(251,207,232,.48),transparent 34%),#f8fafc}.person-main{min-height:calc(100vh - 64px);padding:24px}.person-shell{max-width:1240px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.person-loading,.person-empty-state{min-height:calc(100vh - 180px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#475569}.person-banner{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:28px 32px;border:1px solid rgba(219,226,234,.9);border-radius:28px;background:#ffffffe0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 24px 48px #0f172a14}.person-avatar{width:108px;height:108px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:linear-gradient(180deg,#f8fafc,#e2e8f0);color:#0f172a}.person-avatar-alive{box-shadow:0 0 0 7px #22c55e2e,0 0 0 3px #22c55e}.person-avatar-deceased{box-shadow:0 0 0 7px #ef44442e,0 0 0 3px #ef4444}.person-banner-copy h1{margin:0;font-size:clamp(2rem,4vw,3rem);line-height:1;color:#0f172a}.person-banner-title{margin-top:8px;color:#334155;font-size:1.08rem;font-weight:700}.person-banner-meta{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}.person-banner-pill{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:999px;background:#f8fafc;border:1px solid #dbe2ea;color:#334155;font-size:.92rem;font-weight:700}.person-banner-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.person-banner-actions .btn{display:inline-flex;align-items:center;gap:8px}.person-tabs-shell{border:1px solid rgba(219,226,234,.92);border-radius:28px;background:#ffffffeb;box-shadow:0 18px 36px #0f172a0f;overflow:hidden}.person-tabs{display:flex;gap:8px;padding:12px;border-bottom:1px solid #e2e8f0;overflow-x:auto}.person-tab-btn{border:none;border-radius:999px;background:transparent;color:#475569;padding:12px 18px;font:inherit;font-weight:700;white-space:nowrap;cursor:pointer}.person-tab-btn-active{background:#0f172a;color:#fff}.person-tab-panel{padding:28px}.person-tab-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:24px}.person-section-card{border:1px solid #e2e8f0;border-radius:24px;background:#fff;padding:22px;box-shadow:0 10px 24px #0f172a0d}.person-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.person-section-header h2,.person-section-header h3{margin:0;color:#0f172a;font-size:1.05rem}.person-inline-edit-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #dbe2ea;border-radius:999px;background:#fff;color:#334155;cursor:pointer}.person-bio-text,.person-bio-empty{color:#334155;line-height:1.65;white-space:pre-wrap}.person-bio-empty,.person-tab-empty{color:#64748b}.person-inline-textarea{width:100%;min-height:160px;resize:vertical}.person-inline-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.person-details-list{display:grid;gap:14px}.person-details-row{display:grid;grid-template-columns:160px 1fr;gap:16px}.person-details-label{color:#64748b;font-weight:700}.person-details-value{color:#0f172a;font-weight:600}.person-family-groups{display:flex;flex-direction:column;gap:24px}.person-family-group h3{margin:0 0 14px;color:#0f172a}.person-family-row{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px}.person-family-card-btn{min-width:min(320px,82vw);border:none;background:transparent;padding:0;text-align:left;cursor:pointer}.person-edit-modal{max-width:680px;max-height:88vh;overflow-y:auto}.person-edit-form{display:flex;flex-direction:column;gap:18px}.person-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.person-edit-toggle-btn{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;border:1px solid #dbe2ea;border-radius:999px;background:#fff;color:#334155;padding:8px 12px;font:inherit;font-size:.82rem;font-weight:700;cursor:pointer}.person-edit-location-block{display:flex;flex-direction:column;gap:12px;padding-top:4px;border-top:1px solid #e2e8f0}.person-edit-location-block h3{margin:0;color:#0f172a;font-size:1rem}@media(max-width:900px){.person-banner{grid-template-columns:1fr;justify-items:flex-start}.person-banner-actions{justify-content:flex-start}.person-tab-grid{grid-template-columns:1fr}}@media(max-width:768px){.person-main{padding:16px 12px 24px}.person-banner,.person-tab-panel{padding:18px}.person-avatar{width:84px;height:84px}.person-edit-grid,.person-details-row{grid-template-columns:1fr;gap:8px}}:root{--color-bg-primary: #0f0f1a;--color-bg-secondary: #1a1a2e;--color-bg-card: rgba(30, 30, 55, .7);--color-bg-glass: rgba(255, 255, 255, .05);--color-bg-glass-hover: rgba(255, 255, 255, .08);--color-bg-input: rgba(255, 255, 255, .06);--color-accent-primary: #d4a853;--color-accent-secondary: #e8c97a;--color-accent-glow: rgba(212, 168, 83, .3);--color-accent-gradient: linear-gradient(135deg, #d4a853, #e8c97a);--color-text-primary: #f0eee6;--color-text-secondary: #a8a5b8;--color-text-muted: #6b6880;--color-text-inverse: #0f0f1a;--color-success: #4ade80;--color-warning: #fbbf24;--color-danger: #f87171;--color-info: #60a5fa;--color-border: rgba(255, 255, 255, .08);--color-border-accent: rgba(212, 168, 83, .3);--color-male: #60a5fa;--color-female: #f472b6;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--color-accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--z-dropdown: 100;--z-modal: 200;--z-toast: 300;--z-navbar: 50;--navbar-height: 64px;--bottom-nav-height: 72px;--max-width: 1200px;--sidebar-width: 280px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23d4a853' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}a{color:var(--color-accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-secondary)}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.glass-card{background:var(--color-bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.glass-card:hover{background:var(--color-bg-glass-hover);border-color:var(--color-border-accent);box-shadow:var(--shadow-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-base);position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:var(--color-accent-gradient);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-bg-glass);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-glass-hover);border-color:var(--color-border-accent)}.btn-danger{background:#f8717126;color:var(--color-danger);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover{background:#f8717140}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full)}.app-icon{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;line-height:1;font-size:1em;letter-spacing:normal;text-transform:none;vertical-align:middle;-webkit-user-select:none;user-select:none;flex-shrink:0;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased;font-feature-settings:"liga";font-variation-settings:"opsz" 24;overflow:hidden}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.input{padding:var(--space-3) var(--space-4);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-fast)}.input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.input::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-slide-up{animation:slideUp .6s ease forwards}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;flex-direction:column;gap:var(--space-4)}.loading-screen p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}@media(max-width:768px){:root{--font-size-5xl: 2.25rem;--font-size-4xl: 1.75rem;--font-size-3xl: 1.5rem}.container{padding:0 var(--space-4)}.hide-mobile{display:none!important}}@media(min-width:769px){.hide-desktop{display:none!important}}
