@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap";.lp-root{min-height:100vh;display:flex;background:#fff}.lp-left{width:45%;max-width:480px;min-width:320px;display:flex;flex-direction:column;justify-content:center;padding:40px;background:#fff;position:relative;z-index:2}.lp-right{flex:1;position:relative;overflow:hidden;display:flex}.lp-right img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.lp-right-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#d4af3726,#0000001a)}.lp-logo{display:flex;align-items:center;gap:12px;margin-bottom:40px}.lp-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,#d4af37,#a08520);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:800;font-family:Playfair Display,serif;box-shadow:0 4px 16px #d4af374d}.lp-logo-text{font-family:Playfair Display,serif;font-size:22px;font-weight:700;color:#111827;line-height:1.2}.lp-logo-sub{font-family:Inter,sans-serif;font-size:12px;color:#9ca3af;font-weight:400}.lp-form{display:flex;flex-direction:column;gap:20px}.lp-field{display:flex;flex-direction:column;gap:6px}.lp-label{font-size:13px;font-weight:500;color:#6b7280}.lp-label .req{color:#ef4444;margin-right:4px}.lp-input-wrap{position:relative}.lp-input{width:100%;padding:12px 16px;border:1.5px solid #E5E7EB;border-radius:8px;font-size:14px;color:#111827;background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;font-family:Inter,sans-serif}.lp-input::-moz-placeholder{color:#c0c4cc}.lp-input::placeholder{color:#c0c4cc}.lp-input:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af3714}.lp-input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#b0b4bc;display:flex;pointer-events:none}.lp-input.has-icon{padding-left:42px}.lp-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#b0b4bc;padding:4px;display:flex;transition:color .15s}.lp-eye:hover{color:#6b7280}.lp-input-hint{font-size:11px;color:#9ca3af;margin-top:4px}.lp-btn-primary{width:100%;padding:14px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;font-family:Inter,sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#d4af37,#c4981e);color:#fff;transition:all .2s;margin-top:4px;box-shadow:0 4px 16px #d4af3740}.lp-btn-primary:hover{box-shadow:0 6px 24px #d4af3759;transform:translateY(-1px)}.lp-btn-primary:active{transform:scale(.98) translateY(0)}.lp-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.lp-forgot-link{background:none;border:none;color:#d4af37;cursor:pointer;font-size:13px;font-weight:500;padding:0;font-family:Inter,sans-serif;transition:color .15s}.lp-forgot-link:hover{color:#a08520}.lp-or{display:flex;align-items:center;gap:12px;color:#c0c4cc;font-size:12px;font-weight:500;letter-spacing:.05em;margin:4px 0;width:100%}.lp-or:before,.lp-or:after{content:"";flex:1;height:1px;background:#e5e7eb}.lp-btn-outline{width:100%;padding:13px;background:transparent;color:#374151;border:1.5px solid #E5E7EB;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;font-family:Inter,sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s}.lp-btn-outline:hover{background:#f9fafb;border-color:#d1d5db}.lp-footer{display:flex;gap:24px;justify-content:center;font-size:12px;color:#9ca3af;margin-top:28px;flex-wrap:wrap}.lp-footer a{color:#6b7280;text-decoration:none;transition:color .15s}.lp-footer a:hover{color:#d4af37}.lp-copyright{font-size:11px;color:#c0c4cc;text-align:center;margin-top:12px}.lp-error{width:100%;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px}.lp-forgot-panel{width:100%;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:10px}.lp-forgot-panel p{font-size:13px;color:#6b7280;margin:0}.lp-forgot-msg{font-size:13px;color:#059669;background:#ecfdf5;border-radius:8px;padding:8px 12px}@media (max-width: 900px){.lp-right{display:none}.lp-left{width:100%;max-width:100%;padding:32px 24px;min-width:auto}.lp-root{justify-content:center;align-items:center;background:#f9fafb}.lp-left{border-radius:16px;box-shadow:0 10px 40px #0000000d}}.login-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;background:var(--bg-primary);overflow-y:auto;z-index:1000}.login-left{flex:0 0 50%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px;background:var(--bg-secondary)}.login-right{flex:0 0 50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);position:relative;overflow:hidden}.login-right-content{position:relative;z-index:2;padding:60px;color:#fff}.login-right-text h2{font-family:var(--font-heading);font-size:28px;margin-bottom:12px;color:var(--gold)}.login-right-text p{font-size:15px;color:#ffffffbf;margin-bottom:32px;line-height:1.6}.login-features{display:grid;grid-template-columns:1fr 1fr;gap:12px}.login-feature{padding:12px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:13px;color:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-decoration{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.deco-circle{position:absolute;border-radius:50%;border:1px solid rgba(212,175,55,.15)}.deco-circle.c1{width:300px;height:300px;top:-80px;right:-60px;animation:float 12s ease-in-out infinite}.deco-circle.c2{width:200px;height:200px;bottom:20%;left:-40px;animation:float 8s ease-in-out infinite reverse}.deco-circle.c3{width:150px;height:150px;bottom:-30px;right:30%;animation:float 10s ease-in-out infinite 2s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.login-card{width:380px;max-width:100%;text-align:center}.login-logo{display:flex;justify-content:center;margin-bottom:16px}.login-title{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--gold);margin-bottom:4px}.login-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:32px;letter-spacing:2px;text-transform:uppercase}.login-error{background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:16px;color:var(--accent-error);font-size:13px;text-align:left;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-card .form-group{text-align:left}.login-card .form-input{background:#ffffffe6;border-color:#d0d5dd;color:#1a1a2e}.login-card .form-input::-moz-placeholder{color:#9ca3af}.login-card .form-input::placeholder{color:#9ca3af}.login-card .form-input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #3b6fcf1f}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon .form-input{padding-left:36px;padding-right:36px}.input-icon{position:absolute;left:10px;font-size:14px;pointer-events:none;z-index:1}.input-toggle{position:absolute;right:4px;background:none;border:none;cursor:pointer;font-size:14px;padding:6px;opacity:.5}.input-toggle:hover{opacity:1}.login-btn{width:100%;padding:14px;font-size:15px;margin-top:12px;border-radius:12px}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:28px;font-size:12px;color:var(--text-muted)}.login-hint code{background:#d4af371a;padding:2px 8px;border-radius:4px;color:var(--gold);font-family:monospace}.login-footer{margin-top:40px;font-size:11px;color:var(--text-muted)}@media (max-width: 768px){.login-page{flex-direction:column}.login-left{flex:1;padding:32px 20px}.login-right{flex:0;min-height:180px}.login-right-content{padding:24px}.login-features{grid-template-columns:1fr}}.toolbar{min-height:var(--toolbar-height);display:flex;align-items:center;justify-content:space-between;padding:4px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-shrink:0;flex-wrap:wrap;gap:4px;z-index:50}.toolbar-group{display:flex;align-items:center;gap:4px}.toolbar .btn{padding:6px 12px;font-size:12px;border-radius:6px}.toolbar .btn-icon{width:32px;height:32px;padding:0}.divider{width:1px;height:24px;background:var(--border-subtle);margin:0 8px}.canvas-container{flex:1;position:relative;overflow:hidden}.tree-canvas{display:block;cursor:grab}.tree-canvas:active{cursor:grabbing}.detail-panel{position:fixed;top:0;right:0;width:360px;height:100vh;background:var(--bg-card);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-left:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);z-index:300;transform:translate(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto}.detail-panel.open{transform:translate(0)}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border-subtle)}.detail-header h3{font-family:var(--font-heading);font-size:14px;color:var(--gold);letter-spacing:1px;text-transform:uppercase}.detail-close{width:32px;height:32px;border:1px solid var(--border-subtle);border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s}.detail-close:hover{border-color:var(--border-glow);color:var(--gold)}.detail-content{padding:24px;flex:1}.detail-name{font-family:var(--font-heading);font-size:24px;font-weight:700;margin-bottom:8px}.detail-gender{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:0;font-size:13px;font-weight:500;margin-bottom:4px}.detail-gender.male{background:#4682e626;color:var(--accent-male);border:1px solid rgba(70,130,230,.2)}.detail-gender.female{background:#e6648a26;color:var(--accent-female);border:1px solid rgba(230,100,138,.2)}.detail-years{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.detail-section{margin-bottom:20px}.detail-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.detail-field{padding:10px 0;border-bottom:1px solid var(--border-subtle)}.detail-field-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}.detail-field-value{font-size:14px;color:var(--text-primary)}.detail-actions{display:flex;flex-wrap:wrap;gap:8px;padding:20px 24px;border-top:1px solid var(--border-subtle)}.detail-actions .btn{flex:1;min-width:calc(50% - 4px);justify-content:center}.photo-cropper-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .2s ease}.photo-cropper-modal{background:var(--bg-secondary, #1a1a2e);border-radius:0;border:1px solid var(--border-subtle);padding:20px;width:400px;max-width:95vw;box-shadow:0 16px 64px #00000080}.photo-cropper-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.photo-cropper-header h3{font-family:var(--font-heading);font-size:16px;color:var(--gold);margin:0}.photo-cropper-hint{text-align:center;font-size:12px;color:var(--text-muted);margin-bottom:10px}.photo-cropper-zoom{display:flex;align-items:center;gap:8px;padding:10px 0}.photo-cropper-zoom input[type=range]{accent-color:var(--gold);height:4px}.photo-cropper-zoom span{color:var(--text-secondary)}.photo-cropper-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}html.light .photo-cropper-modal{background:#fff}.nf-reaction-container{position:relative;display:inline-flex;align-items:center;flex:1;justify-content:center}.nf-reaction-picker{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:50px;padding:6px 10px;display:flex;gap:8px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px) scale(.9);transition:all .2s cubic-bezier(.175,.885,.32,1.275);z-index:100}.nf-reaction-container:hover .nf-reaction-picker,.nf-reaction-picker:hover{opacity:1;visibility:visible;transform:translateY(0) scale(1);transition-delay:.3s}.nf-reaction-picker-btn{background:transparent;border:none;font-size:28px;cursor:pointer;transition:transform .15s ease-out;padding:0 4px;line-height:1;position:relative;transform-origin:bottom center}.nf-reaction-picker-btn:hover{transform:scale(1.3) translateY(-4px);z-index:2}.nf-reaction-picker-btn:after{content:attr(data-label);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-4px);background:#000000bf;color:#fff;font-size:11px;padding:2px 6px;border-radius:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s .1s;pointer-events:none}html.dark .nf-reaction-picker-btn:after{background:#ffffffe6;color:#000}.nf-reaction-picker-btn:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.nf-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;background:transparent;border:none;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:var(--radius-sm);transition:background .15s}.nf-action-btn:hover{background:var(--border-subtle)}.nf-action-btn.reacted-❤️{color:#e0245e}.nf-action-btn.reacted-👍{color:#2563eb}.nf-action-btn.reacted-😂,.nf-action-btn.reacted-😮,.nf-action-btn.reacted-😢{color:#f59e0b}.nf-action-btn.reacted-😡{color:#dc2626}.nf-reaction-summary{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-muted);margin:8px 0;padding-bottom:8px;border-bottom:1px solid var(--border-subtle)}.nf-summary-icon{font-size:18px;margin-right:-6px;position:relative;border:2px solid var(--bg-card);border-radius:50%;display:inline-flex;background:var(--bg-card);line-height:1}.nf-summary-icon:nth-child(1){z-index:3}.nf-summary-icon:nth-child(2){z-index:2}.nf-summary-icon:nth-child(3){z-index:1}.nf-actions-bar{display:flex;gap:4px;padding:0}.nf-dashboard-header{margin-bottom:24px}.nf-welcome-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.nf-welcome-greeting{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 4px;font-family:var(--font-body)}.nf-welcome-sub{font-size:13px;color:var(--text-muted);margin:0}.nf-stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}@media (max-width: 900px){.nf-stat-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.nf-stat-cards{grid-template-columns:1fr 1fr}}.nf-stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px 18px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.nf-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.nf-stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.nf-stat-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1}.nf-stat-label{font-size:12px;color:var(--text-muted);margin-top:2px}.nf-body-grid{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}@media (max-width: 960px){.nf-body-grid{grid-template-columns:1fr}}.nf-right-panel{display:flex;flex-direction:column;gap:16px}.nf-panel-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow-sm)}.nf-panel-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}.nf-quick-actions{display:flex;flex-direction:column;gap:8px}.nf-quick-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-primary);font-family:var(--font-body);text-align:left;transition:background .15s,border-color .15s}.nf-quick-btn:hover{background:var(--primary-glow);border-color:var(--border-glow);color:var(--primary)}.nf-quick-btn-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.nf-event-list{display:flex;flex-direction:column;gap:10px}.nf-event-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-subtle)}.nf-event-item:last-child{border-bottom:none;padding-bottom:0}.nf-event-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0}.nf-event-name{font-size:13px;font-weight:500;color:var(--text-primary)}.nf-event-date{font-size:11px;color:var(--text-muted)}.nf-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid var(--border-subtle);padding-bottom:0}.nf-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s,transform .15s;position:relative;overflow:hidden}.nf-tab:hover{color:var(--text-primary)}.nf-tab:active{transform:scale(.95);transition-duration:80ms}.nf-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600;animation:tabActivate .25s cubic-bezier(.34,1.56,.64,1)}@keyframes tabActivate{0%{transform:scaleX(.85);opacity:.6}60%{transform:scaleX(1.05)}to{transform:scaleX(1);opacity:1}}.nf-create-post{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:0;padding:20px;margin-bottom:24px;box-shadow:0 2px 8px #0000000f;transition:box-shadow .2s}.nf-create-post:focus-within{box-shadow:0 4px 16px #3b6fcf1f;border-color:#3b6fcf4d}.nf-create-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.nf-author-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#3b6fcf,#60a5fa);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:0 2px 8px #3b6fcf40}.nf-author-name{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.nf-post-input{width:100%;padding:14px 16px;border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-size:14px;resize:vertical;min-height:70px;outline:none;transition:border-color .2s,box-shadow .2s;line-height:1.6}.nf-post-input:focus{border-color:#3b6fcf80;box-shadow:0 0 0 3px #3b6fcf14}.nf-post-input::-moz-placeholder{color:var(--text-muted)}.nf-post-input::placeholder{color:var(--text-muted)}.nf-create-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.nf-char-count{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.nf-posts-list{display:flex;flex-direction:column;gap:16px}.nf-post-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:0;padding:20px;transition:box-shadow .25s,transform .25s;box-shadow:0 1px 4px #0000000a}.nf-post-card:hover{box-shadow:0 4px 20px #00000014;transform:translateY(-1px)}.nf-post-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.nf-post-author{display:flex;align-items:center;gap:12px}.nf-post-time{font-size:12px;color:var(--text-muted);margin-top:2px}.nf-post-delete{border:none;background:transparent;cursor:pointer;font-size:14px;padding:6px;opacity:.4;transition:all .2s;border-radius:8px}.nf-post-delete:hover{opacity:1;background:#ef44441a}.nf-post-content{font-size:15px;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.nf-reactions-bar{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border-subtle);gap:8px}.nf-reactions-emojis{display:flex;gap:6px;flex-wrap:wrap}.nf-reaction-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border:1.5px solid transparent;border-radius:24px;background:#64748b0f;cursor:pointer;font-size:15px;transition:all .18s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;overflow:hidden}.nf-reaction-btn:hover{background:#3b6fcf1a;transform:scale(1.15);border-color:#3b6fcf26}.nf-reaction-btn:active{transform:scale(.9);transition-duration:80ms}.nf-reaction-btn.active{background:#3b6fcf26;border-color:#3b6fcf59;box-shadow:0 2px 8px #3b6fcf26;animation:reactionPop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes reactionPop{0%{transform:scale(.7)}60%{transform:scale(1.2)}to{transform:scale(1)}}.nf-reaction-count{font-size:12px;font-weight:700;color:var(--text-secondary);min-width:12px;text-align:center}.nf-comment-toggle{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font-body);font-weight:500;padding:6px 12px;border-radius:20px;transition:all .18s;white-space:nowrap}.nf-comment-toggle:hover{background:#64748b1a;color:var(--primary)}.nf-comments-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.nf-comment{padding:10px 0;transition:background .15s}.nf-comment+.nf-comment{border-top:1px solid rgba(100,116,139,.06)}.nf-comment-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.nf-comment-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#3b6fcf,#93c5fd);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;box-shadow:0 1px 4px #3b6fcf33}.nf-comment-author{font-size:13px;font-weight:700;color:var(--text-primary)}.nf-comment-time{font-size:11px;color:var(--text-muted);flex:1}.nf-comment-del{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:11px;padding:3px 6px;border-radius:6px;opacity:0;transition:all .15s}.nf-comment:hover .nf-comment-del{opacity:.6}.nf-comment-del:hover{opacity:1!important;background:#ef44441f;color:#ef4444}.nf-comment-text{font-size:13px;color:var(--text-secondary);line-height:1.5;padding-left:36px;word-break:break-word}.nf-comment-input-wrap{display:flex;gap:8px;margin-top:12px;align-items:center}.nf-comment-input{flex:1;padding:10px 16px;border:1.5px solid var(--border-subtle);border-radius:24px;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-size:13px;outline:none;transition:border-color .2s,box-shadow .2s}.nf-comment-input:focus{border-color:#3b6fcf66;box-shadow:0 0 0 3px #3b6fcf0f}.nf-comment-input::-moz-placeholder{color:var(--text-muted)}.nf-comment-input::placeholder{color:var(--text-muted)}.nf-comment-send{width:34px;height:34px;border-radius:50%;border:none;background:linear-gradient(135deg,#3b6fcf,#60a5fa);color:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;box-shadow:0 2px 8px #3b6fcf4d}.nf-comment-send:hover:not(:disabled){transform:scale(1.08);box-shadow:0 4px 12px #3b6fcf66}.nf-comment-send:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.nf-contacts-grid{display:flex;flex-direction:column;gap:12px;max-width:480px}.nf-contact-card{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:box-shadow .2s,transform .2s}.nf-contact-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.nf-contact-icon-wrap{flex-shrink:0}.nf-contact-info{flex:1;min-width:0}.nf-contact-type{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.nf-contact-name{font-size:16px;font-weight:600;color:var(--text-primary)}.nf-contact-url{font-size:13px;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px}.nf-contact-actions{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap}.nf-contact-form-card{background:var(--bg-secondary);border:1px solid var(--border-glow);border-radius:var(--radius-md);padding:20px;margin-bottom:16px}.nf-contact-form-card h4{margin:0 0 14px;color:var(--primary);font-family:var(--font-heading)}.nf-form-group{margin-bottom:10px}.nf-form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.calendar-page .page-header{margin-bottom:16px}.calendar-layout{display:flex;gap:20px;height:calc(100vh - 160px);overflow:hidden}.calendar-main{flex:1;min-width:0;overflow-y:auto}.calendar-sidebar{width:380px;min-width:340px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px}.calendar-card{background:var(--bg-card);border-radius:0;border:1px solid var(--border-subtle);box-shadow:0 2px 8px #0000000a;padding:24px;overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-nav{display:flex;align-items:center;gap:8px;margin-bottom:20px}.cal-nav-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-subtle);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cal-nav-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.cal-nav-title{font-size:20px;font-weight:800;color:var(--text-primary);margin:0 12px;letter-spacing:-.3px}.cal-today-btn{margin-left:auto;padding:7px 16px;border-radius:10px;border:1px solid var(--primary);background:transparent;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.cal-today-btn:hover{background:var(--primary);color:#fff}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border-radius:12px;overflow:hidden;border:1.5px solid var(--border-subtle, #e0e0e0);background:var(--border-subtle, #e0e0e0);min-width:480px}.cal-weekday{text-align:center;font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;padding:10px 0;letter-spacing:.5px;background:#2e7d32;border:none;border-radius:0}.cal-weekday-sun{color:#ffcdd2;background:#c62828}.cal-day{display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;position:relative;gap:2px;padding:8px 4px;min-height:60px;background:var(--bg-card, #fff);border:.5px solid var(--border-subtle, #eee);border-radius:0}.cal-day:hover:not(.cal-day-empty){background:#2e7d320f;transform:none;box-shadow:inset 0 0 0 2px #2e7d324d}.cal-day-empty{cursor:default;background:var(--bg-primary, #fafafa)}.cal-day-sun .cal-day-num{color:#c62828;font-weight:700}.cal-day-today{background:#e8f5e9!important;box-shadow:inset 0 0 0 2.5px #2e7d32}.cal-day-today .cal-day-num{color:#1b5e20!important;font-weight:900}.cal-day-today .cal-day-lunar{color:#c62828;font-weight:600;opacity:1}.cal-day-today .cal-dot{border:1.5px solid #2e7d32}.cal-day-selected{background:#2e7d3214;box-shadow:inset 0 0 0 2.5px var(--primary, #3B6FCF)}.cal-day-selected.cal-day-today{box-shadow:inset 0 0 0 2.5px #1b5e20}.cal-day-event{background:#ff98000f}.cal-day-num{font-size:22px;font-weight:600;color:var(--text-primary, #333);line-height:1}.cal-day-lunar{font-size:11px;color:#bf360c;line-height:1;opacity:.85;font-weight:500;white-space:nowrap}.cal-day-sun .cal-day-lunar{color:#d32f2f;opacity:.6}.cal-day-dots{display:flex;gap:3px;margin-top:1px}.cal-dot{width:5px;height:5px;border-radius:50%;display:inline-block}.cal-dot-birthday{background:#f59e0b;box-shadow:0 0 4px #f59e0b66}.cal-dot-anniversary{background:#8b5cf6;box-shadow:0 0 4px #8b5cf666}.calendar-legend{display:flex;gap:24px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border-subtle)}.cal-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary);font-weight:600}.cal-day-detail{margin-top:18px;padding:16px;background:linear-gradient(135deg,#3b6fcf0a,#3b6fcf03);border-radius:14px;border:1px solid rgba(59,111,207,.1)}.cal-day-detail h4{font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.cal-no-event{font-size:13px;color:var(--text-tertiary);margin:0;text-align:center;padding:8px 0}.cal-event-list{display:flex;flex-direction:column;gap:8px}.cal-event-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border-subtle)}.cal-event-birthday{border-left:4px solid #f59e0b}.cal-event-anniversary{border-left:4px solid #8b5cf6}.cal-event-icon{font-size:22px}.cal-event-info{display:flex;flex-direction:column;gap:2px}.cal-event-name{font-size:14px;font-weight:700;color:var(--text-primary)}.cal-event-sub{font-size:12px;color:var(--text-tertiary)}.cal-member-photo{border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-subtle);flex-shrink:0}.cal-member-emoji{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.cal-upcoming-card{background:var(--bg-card);border-radius:0;border:1px solid var(--border-subtle);box-shadow:0 2px 8px #0000000a;overflow:hidden}.cal-upcoming-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.cal-upcoming-birthday .cal-upcoming-header{background:linear-gradient(135deg,#f59e0b14,#f59e0b05)}.cal-upcoming-anniversary .cal-upcoming-header{background:linear-gradient(135deg,#8b5cf614,#8b5cf605)}.cal-upcoming-icon{font-size:22px}.cal-upcoming-header h3{font-size:15px;font-weight:800;color:var(--text-primary);margin:0;flex:1}.cal-upcoming-count{min-width:26px;height:26px;border-radius:50%;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;color:#fff}.cal-upcoming-birthday .cal-upcoming-count{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 6px #f59e0b4d}.cal-upcoming-anniversary .cal-upcoming-count{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 6px #8b5cf64d}.cal-upcoming-body{padding:8px 14px 14px;max-height:360px;overflow-y:auto}.cal-upcoming-item{display:flex;align-items:center;gap:12px;padding:12px 10px;border-radius:12px;transition:background .15s;border-bottom:1px solid rgba(0,0,0,.03)}.cal-upcoming-item:last-child{border-bottom:none}.cal-upcoming-item:hover{background:#3b6fcf0a}.cal-upcoming-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cal-upcoming-name{font-size:14px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-upcoming-date{font-size:11px;color:var(--text-tertiary);line-height:1.3}.cal-upcoming-gen{font-size:11px;color:var(--text-tertiary);font-weight:500}.cal-upcoming-lunar{font-size:11px;color:#7c3aed;font-weight:600}.cal-upcoming-lunar em{font-weight:400;opacity:.7}.cal-upcoming-badge{flex-shrink:0}.cal-badge{display:inline-block;padding:4px 10px;border-radius:10px;font-size:11px;font-weight:700;white-space:nowrap}.cal-badge-today{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;box-shadow:0 1px 4px #f59e0b33}.cal-badge-days{background:#3b6fcf14;color:var(--primary)}.cal-badge-memorial{background:#8b5cf614;color:#7c3aed}.cal-item-today{background:linear-gradient(135deg,#f59e0b14,#f59e0b08)!important;border:1.5px solid rgba(245,158,11,.25);border-radius:14px!important;box-shadow:0 2px 10px #f59e0b1f;animation:todayPulse 2s ease-in-out infinite}.cal-item-today .cal-upcoming-name{color:#92400e}.cal-item-today .cal-badge-today{transform:scale(1.05)}@keyframes todayPulse{0%,to{box-shadow:0 2px 10px #f59e0b1f}50%{box-shadow:0 3px 16px #f59e0b38}}.side-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:flex;justify-content:flex-end;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease}.theme-toggle-float{position:fixed;bottom:20px;right:20px;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-subtle);background:var(--bg-card);box-shadow:var(--shadow-md);font-size:20px;cursor:pointer;z-index:450;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.theme-toggle-float:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}.side-panel{width:440px;max-width:100vw;height:100vh;background:var(--bg-secondary, #1a1a2e);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000004d;animation:slideInRight .25s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.side-panel-header h3{font-family:var(--font-heading);font-size:16px;color:var(--gold);margin:0;display:flex;align-items:center;gap:8px}.side-panel-body{flex:1;overflow-y:auto;padding:16px}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#f44336;color:#fff;font-size:11px;font-weight:700;margin-left:6px;position:relative;top:-1px;animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{box-shadow:0 0 #f4433666}50%{box-shadow:0 0 0 6px #f4433600}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:8px;color:var(--text-muted);font-size:14px}.history-timeline{display:flex;flex-direction:column;gap:8px}.history-entry{border:1px solid var(--border-subtle);border-radius:10px;overflow:hidden;background:#ffffff05;transition:border-color .2s}.history-entry:hover{border-color:#d4af374d}.history-entry-header{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.history-entry-icon{font-size:18px;flex-shrink:0}.history-entry-info{flex:1;min-width:0}.history-entry-title{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-entry-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.history-entry-expand{font-size:10px;color:var(--text-muted)}.history-entry-details{padding:10px 14px 12px;border-top:1px solid var(--border-subtle);margin-top:0}.diff-view{display:flex;flex-direction:column;gap:4px;font-size:12px}.diff-row{display:flex;align-items:flex-start;gap:8px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.03)}.diff-label{font-size:11px;color:var(--text-muted);min-width:80px;flex-shrink:0;padding-top:1px}.diff-values{flex:1;display:flex;align-items:center;flex-wrap:wrap}.diff-old{color:#f44336;text-decoration:line-through;opacity:.7}.diff-new{color:#4caf50;font-weight:500}.request-filters{display:flex;gap:4px;padding:10px 16px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.filter-btn{padding:5px 10px;font-size:11px;border:1px solid var(--border-subtle);border-radius:0;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--gold);color:var(--gold)}.filter-btn.active{background:#d4af3726;border-color:var(--gold);color:var(--gold);font-weight:600}.requests-list{display:flex;flex-direction:column;gap:10px}.request-card{border:1px solid var(--border-subtle);border-radius:10px;padding:12px 14px;background:#ffffff05;transition:border-color .2s}.request-card.pending{border-left:3px solid #FF9800}.request-card.approved{border-left:3px solid #4CAF50;opacity:.7}.request-card.rejected{border-left:3px solid #f44336;opacity:.7}.request-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.request-card-status{font-size:12px;font-weight:600}.request-card-time{font-size:11px;color:var(--text-muted)}.request-card-title{font-size:14px;color:var(--text-primary);margin-bottom:4px}.request-card-meta{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.request-card-note{font-size:12px;color:var(--text-muted);font-style:italic;margin-bottom:8px}.request-card-actions{display:flex;gap:6px;margin-top:10px}.request-card-reason{font-size:12px;color:#f44336;margin-top:6px;padding:6px 10px;background:#f4433614;border-radius:6px}.request-card-reviewed{font-size:11px;color:var(--text-muted);margin-top:6px}.btn-sm{padding:4px 10px!important;font-size:12px!important}html.light .side-panel{background:#fff;box-shadow:-8px 0 32px #0000001a}html.light .history-entry,html.light .request-card{background:#fafafa}html.light .diff-row{border-bottom-color:#0000000d}html.light .filter-btn{color:#555}html.light .filter-btn.active{background:#8b69141a;color:#8b6914}.chat-layout{display:flex;height:100%;background:var(--bg-primary);overflow:hidden}.chat-inbox{width:340px;min-width:340px;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;background:var(--bg-secondary);height:100%}.chat-inbox-header{padding:12px 16px 0;flex-shrink:0}.chat-inbox-header h2{font-family:var(--font-body);font-size:24px;font-weight:800;color:var(--text-primary);margin:0 0 12px;display:flex;align-items:center;justify-content:space-between}.chat-inbox-header h2 .chat-new-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-primary);border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s;color:var(--text-primary)}.chat-inbox-header h2 .chat-new-btn:hover{background:var(--bg-hover)}.chat-search{position:relative;margin-bottom:8px}.chat-search input{width:100%;padding:8px 12px 8px 36px;border-radius:20px;border:none;background:var(--bg-primary);font-size:14px;color:var(--text-primary);outline:none;font-family:var(--font-body)}.chat-search input::-moz-placeholder{color:var(--text-muted)}.chat-search input::placeholder{color:var(--text-muted)}.chat-search input:focus{background:var(--bg-secondary);box-shadow:0 0 0 2px var(--primary)}.chat-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex}.chat-tabs{display:flex;gap:4px;padding:4px 0 8px}.chat-tab{padding:6px 12px;border-radius:16px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .15s}.chat-tab:hover{background:var(--bg-hover)}.chat-tab.active{background:var(--primary-glow);color:var(--primary)}.chat-room-list{flex:1;overflow-y:auto;padding:4px 8px}.chat-room-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;cursor:pointer;transition:background .12s;position:relative}.chat-room-item:hover{background:var(--bg-hover)}.chat-room-item.active{background:var(--primary-glow)}.chat-room-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;overflow:hidden}.chat-room-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-room-avatar .online-dot{position:absolute;bottom:1px;right:1px;width:12px;height:12px;border-radius:50%;background:#31a24c;border:2px solid var(--bg-secondary)}.chat-room-info{flex:1;min-width:0}.chat-room-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-room-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}.chat-room-time{font-size:12px;color:var(--text-secondary);flex-shrink:0;white-space:nowrap}.chat-messages-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);min-width:0}.chat-msg-header{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0}.chat-msg-header-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.chat-msg-header-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-msg-header-info{flex:1;min-width:0}.chat-msg-header-name{font-size:16px;font-weight:700;color:var(--text-primary)}.chat-msg-header-status{font-size:12px;color:var(--text-secondary)}.chat-msg-header-actions{display:flex;gap:4px;margin-left:auto}.chat-header-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:20px;transition:background .15s}.chat-header-btn:hover{background:var(--bg-hover)}.chat-msg-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:2px}.chat-msg-row{display:flex;align-items:flex-end;gap:8px;max-width:65%}.chat-msg-row.me{align-self:flex-end;flex-direction:row-reverse}.chat-msg-row.them{align-self:flex-start}.chat-msg-sender-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}.chat-msg-sender-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-msg-bubble{padding:8px 12px;border-radius:18px;font-size:15px;line-height:1.35;word-break:break-word;max-width:100%}.chat-msg-row.me .chat-msg-bubble{background:#0084ff;color:#fff;border-bottom-right-radius:4px}.chat-msg-row.them .chat-msg-bubble{background:#e4e6eb;color:#050505;border-bottom-left-radius:4px}.chat-msg-sender-label{font-size:11px;color:#65676b;margin-bottom:2px;margin-left:36px}.chat-msg-time{font-size:11px;color:#65676b;margin-top:2px;text-align:center;padding:4px 0}.chat-input-bar{padding:8px 16px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:8px;background:var(--bg-primary);flex-shrink:0}.chat-input-bar input{flex:1;padding:10px 16px;border-radius:20px;border:none;background:var(--bg-secondary);font-size:15px;color:var(--text-primary);outline:none;font-family:var(--font-body)}.chat-input-bar input::-moz-placeholder{color:var(--text-muted)}.chat-input-bar input::placeholder{color:var(--text-muted)}.chat-input-bar input:focus{box-shadow:none}.chat-send-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:22px;transition:all .15s}.chat-send-btn:disabled{color:var(--text-muted);cursor:default}.chat-send-btn:not(:disabled):hover{background:var(--bg-hover)}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:15px;gap:12px}.chat-empty-icon{font-size:64px;opacity:.4}@media (max-width: 768px){.chat-inbox{width:100%;min-width:100%}.chat-layout.room-active .chat-inbox{display:none}.chat-layout:not(.room-active) .chat-messages-panel{display:none}.chat-back-btn{display:flex!important}}@media (min-width: 769px){.chat-back-btn{display:none!important}}.chat-back-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;font-size:20px;color:var(--primary);display:flex;align-items:center;justify-content:center;transition:background .15s}.chat-back-btn:hover{background:var(--bg-hover)}/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-blue-500:oklch(62.3% .214 259.815);--color-indigo-500:oklch(58.5% .233 277.117);--color-slate-900:oklch(20.8% .042 265.755);--color-gray-500:oklch(55.1% .027 264.364);--color-white:#fff;--spacing:.25rem;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-medium:500;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--drop-shadow-md:0 3px 3px #0000001f;--animate-spin:spin 1s linear infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.z-50{z-index:50}.m-4{margin:calc(var(--spacing) * 4)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.table{display:table}.h-8{height:calc(var(--spacing) * 8)}.h-12{height:calc(var(--spacing) * 12)}.h-screen{height:100vh}.min-h-\[200px\]{min-height:200px}.w-8{width:calc(var(--spacing) * 8)}.w-12{width:calc(var(--spacing) * 12)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e38px}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-4{border-style:var(--tw-border-style);border-width:4px}.border-blue-500{border-color:var(--color-blue-500)}.border-indigo-500{border-color:var(--color-indigo-500)}.border-t-transparent{border-top-color:#0000}.bg-slate-900\/40{background-color:#0f172b66}@supports (color:color-mix(in lab,red,red)){.bg-slate-900\/40{background-color:color-mix(in oklab,var(--color-slate-900) 40%,transparent)}}.p-4{padding:calc(var(--spacing) * 4)}.p-12{padding:calc(var(--spacing) * 12)}.pt-16{padding-top:calc(var(--spacing) * 16)}.pb-24{padding-bottom:calc(var(--spacing) * 24)}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.break-all{word-break:break-all}.text-gray-500{color:var(--color-gray-500)}.text-white{color:var(--color-white)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.drop-shadow-md{--tw-drop-shadow-size:drop-shadow(0 3px 3px var(--tw-drop-shadow-color,#0000001f));--tw-drop-shadow:drop-shadow(var(--drop-shadow-md));filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (min-width:40rem){.sm\:pt-0{padding-top:calc(var(--spacing) * 0)}}@media (min-width:48rem){.md\:p-6{padding:calc(var(--spacing) * 6)}}}.app-layout{background:var(--bg-primary);width:100vw;height:100vh;padding:0;display:flex;overflow:hidden}.main-content{background:var(--bg-secondary);z-index:1;border-radius:0;flex-direction:column;flex:1;min-width:0;height:100%;display:flex;overflow:auto;box-shadow:-4px 0 20px #00000014}.tree-page{flex-direction:column;height:100%;display:flex}.sidebar{background:var(--sidebar-bg);z-index:100;border-right:none;border-radius:0;flex-direction:column;width:240px;min-width:240px;height:100%;transition:width .25s,min-width .25s;display:flex;overflow:hidden;box-shadow:4px 0 24px #0000002e}.sidebar.collapsed{width:60px;min-width:60px}.sidebar-header{border-bottom:1px solid #ffffff1f;justify-content:space-between;align-items:center;min-height:64px;padding:16px;display:flex}.sidebar-logo{white-space:nowrap;align-items:center;gap:10px;display:flex;overflow:hidden}.sidebar-logo-icon{flex-shrink:0;font-size:24px}.sidebar-logo-title{font-family:var(--font-heading);color:#fff;font-size:16px;font-weight:700;line-height:1.2;display:block}.sidebar-logo-sub{color:#fff9;font-size:10px;display:block}.sidebar-toggle{color:#fffc;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;transition:all .2s;display:flex}.sidebar-toggle:hover{color:#fff;background:#fff3;border-color:#fff6}.sidebar.collapsed .sidebar-header{justify-content:center;padding:16px 10px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex;overflow-y:auto}.sidebar-item{color:var(--sidebar-text);cursor:pointer;font-size:14px;font-family:var(--font-body);text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:10px 14px;transition:all .2s;display:flex;position:relative}.sidebar-item:hover{background:var(--sidebar-hover-bg);color:#fff}.sidebar-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:700;box-shadow:0 2px 8px #ffd05340}.sidebar-item-icon{text-align:center;flex-shrink:0;width:24px;font-size:18px}.sidebar-item-label{text-overflow:ellipsis;overflow:hidden}.sidebar-badge{color:#fff;background:#f44336;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:10px;font-weight:700;animation:2s infinite badgePulse;display:inline-flex}.sidebar-divider{background:#ffffff1f;height:1px;margin:8px 12px}.sidebar.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-badge{margin:0;position:absolute;top:4px;right:4px}.sidebar-footer{border-top:1px solid #ffffff1f;padding:12px}.sidebar-user{background:#ffffff1a;border-radius:8px;align-items:center;gap:10px;padding:8px;display:flex}.sidebar-user-avatar{background:#ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;display:flex}.sidebar-user-info{flex:1;min-width:0;overflow:hidden}.sidebar-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;display:block;overflow:hidden}.sidebar-user-role{color:#ffffff80;font-size:10px;display:block}.sidebar-logout{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;transition:background .2s;display:flex}.sidebar-logout:hover{background:#f8717126}.sidebar.collapsed .sidebar-user{justify-content:center;padding:8px 4px}.sidebar-user-expand{color:#ffffff80;margin-left:auto;font-size:10px}.sidebar-footer{margin-top:auto;position:relative}.sidebar-user-menu{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:500;min-width:200px;animation:.2s slideUpFade;position:absolute;bottom:calc(100% + 8px);left:8px;right:8px;overflow:hidden}@keyframes slideUpFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar-user-menu-header{align-items:center;gap:10px;padding:14px 16px;display:flex}.sidebar-user-menu-avatar{background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.sidebar-user-menu-name{color:var(--text-primary);font-size:14px;font-weight:600}.sidebar-user-menu-role{color:var(--text-muted);font-size:11px}.sidebar-user-menu-divider{background:var(--border-subtle);height:1px;margin:0}.sidebar-user-menu-item{width:100%;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;font-size:13px;transition:background .15s;display:flex}.sidebar-user-menu-item:hover{background:var(--primary-glow)}.sidebar-user-menu-item.logout{color:var(--accent-error);font-weight:600}.sidebar-user-menu-item.logout:hover{background:#e8545414}.sidebar.collapsed .sidebar-user-menu{min-width:220px;bottom:0;left:calc(100% + 8px);right:auto}.page-container{flex-direction:column;height:100%;padding:24px 32px;display:flex;overflow-y:auto}.page-header{margin-bottom:24px}.page-header h2{font-family:var(--font-heading);color:var(--primary);margin-bottom:4px;font-size:22px}.page-subtitle{color:var(--text-muted);font-size:13px}.page-body{flex:1}.header{min-height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);z-index:100;box-shadow:var(--shadow-sm);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 20px;display:flex}.header-left{flex:1;align-items:center;gap:16px;min-width:0;display:flex}.logo{align-items:center;gap:12px;display:flex}.logo-icon{background:linear-gradient(135deg,var(--gold),var(--gold-dark));border-radius:var(--radius-sm);width:40px;height:40px;box-shadow:var(--shadow-glow);justify-content:center;align-items:center;font-size:20px;display:flex}.logo-text{flex-direction:column;display:flex}.logo-title{font-family:var(--font-heading);color:var(--gold);letter-spacing:.5px;font-size:20px;font-weight:700;line-height:1.2}.logo-subtitle{color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;font-size:11px}.header-center{align-items:center;gap:12px;display:flex}.stat-badge{background:var(--gold-glow);border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;display:flex}.stat-badge .stat-value{color:var(--gold);font-weight:600}.header-right{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.header-dropdown{display:inline-flex;position:relative}.header-dropdown-menu{background:var(--bg-card,#1e293b);border:1px solid var(--border-subtle);z-index:100;border-radius:10px;min-width:160px;animation:.15s ease-out dropIn;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000040}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.header-dropdown-item{width:100%;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;font-size:13px;transition:background .15s;display:flex}.header-dropdown-item:hover{background:#3b6fcf1a}.header-dropdown-item:not(:last-child){border-bottom:1px solid var(--border-subtle)}@keyframes ripple{0%{opacity:.5;transform:scale(0)}to{opacity:0;transform:scale(4)}}.ripple-host{position:relative;overflow:hidden}.ripple-circle{opacity:.3;pointer-events:none;transform-origin:50%;background:currentColor;border-radius:50%;width:60px;height:60px;margin-top:-30px;margin-left:-30px;animation:.55s ease-out forwards ripple;position:absolute}.btn{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex;position:relative;overflow:hidden}.btn:hover{background:var(--primary-glow);border-color:var(--border-glow);color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn:active{transition-duration:80ms;transform:scale(.95)translateY(0)!important}.btn-icon{width:36px;height:36px;padding:8px}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.btn-primary:hover{background:var(--primary-dark);color:#fff;box-shadow:0 4px 14px #f59e0b59}.btn-danger{color:var(--accent-error);border-color:#e854544d}.btn-danger:hover{border-color:var(--accent-error);background:#e8545414}.search-container{flex-shrink:1;width:320px;min-width:0;max-width:100%;position:relative}.search-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;font-size:14px;position:absolute;left:12px}.search-input{background:var(--bg-primary);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);font-family:var(--font-body);border-radius:20px;outline:none;padding:8px 36px;font-size:13px;transition:all .2s}.search-input::-moz-placeholder{color:var(--text-muted)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--primary);background:var(--bg-secondary);box-shadow:0 0 8px #3b6fcf1f}.btn-clear-search{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;right:4px}.btn-clear-search:hover{color:var(--text-primary);background:#ffffff1a}.search-results{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);min-width:280px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;z-index:600;max-height:300px;margin-top:8px;transition:all .25s;position:absolute;top:100%;left:0;overflow-y:auto;transform:translateY(-8px)}.search-results.open{opacity:1;visibility:visible;transform:translateY(0)}.search-item{cursor:pointer;align-items:center;gap:12px;padding:10px 16px;transition:background .15s;display:flex}.search-item:hover{background:var(--gold-glow)}.search-item-icon{font-size:18px}.search-item-name{color:var(--text-primary);font-size:13px;font-weight:500}.search-item-info{color:var(--text-muted);font-size:11px}.search-empty{text-align:center;color:var(--text-muted);padding:16px;font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;opacity:0;visibility:hidden;background:#0009;justify-content:center;align-items:center;transition:all .25s;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-overlay.open{opacity:1;visibility:visible}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:480px;max-width:90vw;max-height:85vh;box-shadow:var(--shadow-lg);transition:transform .4s cubic-bezier(.4,0,.2,1);overflow-y:auto;transform:scale(.9)translateY(20px)}.modal-overlay.open .modal{transform:scale(1)translateY(0)}.modal-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-family:var(--font-heading);color:var(--gold);font-size:20px;font-weight:600}.modal-body{padding:24px}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);width:100%;color:var(--input-color);font-family:var(--font-body);outline:none;padding:10px 14px;font-size:14px;transition:all .25s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-shadow)}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--input-placeholder)}.form-input::placeholder,.form-textarea::placeholder{color:var(--input-placeholder)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-section-title{color:var(--gold);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border-subtle);margin-bottom:12px;padding-bottom:6px;font-size:12px;font-weight:600}.modal-footer{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.toast-container{z-index:999999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-md);color:var(--text-primary);opacity:0;align-items:center;gap:10px;padding:12px 20px;font-size:14px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;transform:translate(100%)}.toast.show{opacity:1;transform:translate(0)}.toast-icon{font-size:16px;font-weight:700}.toast-success{border-color:#4ade804d}.toast-success .toast-icon{color:var(--accent-success)}.toast-error{border-color:#f871714d}.toast-error .toast-icon{color:var(--accent-error)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d4af3733;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#d4af3766}.user-info{align-items:center;gap:6px;display:flex}.user-badge{background:var(--gold-glow);border:1px solid var(--border-subtle);color:var(--gold);white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.theme-select-wrapper{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:20px;align-items:center;gap:4px;padding:2px 6px 2px 10px;display:flex;position:relative}.theme-select-icon{pointer-events:none;font-size:14px}.theme-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:var(--text-primary);font-size:12px;font-family:var(--font-primary);cursor:pointer;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23999'/%3E%3C/svg%3E") right 4px center no-repeat;border:none;outline:none;padding:5px 20px 5px 4px}.theme-select option{background:var(--bg-secondary);color:var(--text-primary)}.photo-upload{flex-direction:column;align-items:center;display:flex}.photo-placeholder{border:2px dashed var(--border-subtle);cursor:pointer;background:#d4af3708;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:80px;height:80px;transition:all .2s;display:flex}.photo-placeholder:hover{border-color:var(--gold);background:#d4af3714}.photo-preview{width:80px;height:80px;position:relative}.photo-preview img{-o-object-fit:cover;object-fit:cover;border:2px solid var(--gold);width:80px;height:80px;box-shadow:var(--shadow-glow);border-radius:50%}.photo-remove{background:var(--accent-error);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:flex;position:absolute;top:-4px;right:-4px}.contact-link{color:var(--gold);text-decoration:none;transition:color .2s}.contact-link:hover{color:var(--gold-light);text-decoration:underline}@media (max-width:768px){.header{flex-direction:column;align-items:flex-start;height:auto;padding:12px 16px}.header-center{display:none}.header-right{justify-content:flex-start;width:100%;margin-top:8px;overflow-x:auto}.chat-layout{flex-direction:column}.chat-inbox-panel{border-right:none;border-bottom:1px solid var(--border-subtle);width:100%;height:40vh}.chat-messages-panel{height:60vh}.detail-panel{width:100%!important;max-width:100%!important}.modal{max-height:90vh;margin:10px;width:95%!important}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid var(--border-subtle);border-top:3px solid var(--primary);border-radius:50%;width:24px;height:24px;animation:1s linear infinite spin;display:inline-block}.spinner-lg{border-width:4px;width:36px;height:36px}.spinner-sm{border-width:2px;width:16px;height:16px}.spinner-center{width:100%;height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--bg-glass:#ffffffd9;--bg-hover:#f1f5f9;--gold:#d4af37;--gold-light:#f0d060;--gold-dark:#a08520;--gold-glow:#d4af371a;--primary:#4f46e5;--primary-light:#6366f1;--primary-dark:#4338ca;--primary-glow:#4f46e526;--sidebar-bg:#fff;--sidebar-active-bg:#eef2ff;--sidebar-active-text:#4f46e5;--sidebar-hover-bg:#f8fafc;--sidebar-text:#64748b;--sidebar-text-active:#1e293b;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent-male:#3b82f6;--accent-female:#ec4899;--accent-success:#10b981;--accent-error:#ef4444;--accent-info:#3b82f6;--border-subtle:#e2e8f0;--border-glow:#4f46e533;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-glow:0 0 15px #4f46e51a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--font-heading:"Outfit", sans-serif;--font-body:"Inter", -apple-system, sans-serif;--header-height:64px;--toolbar-height:48px;--input-bg:#fff;--input-color:#0f172a;--input-border:#cbd5e1;--input-placeholder:#94a3b8;--input-focus-border:#4f46e5;--input-focus-shadow:#4f46e526;--tree-bg:#f8fafc;--tree-grid:#0f172a0d;--tree-node-bg:#fff;--tree-node-border:#e2e8f0;--tree-node-border-active:#4f46e5;--tree-node-shadow:0 4px 6px -1px #0000001a;--tree-node-shadow-active:0 0 0 3px #4f46e533;--tree-line-parent:#47556966;--tree-line-spouse:#ec489966;--tree-badge-bg:#4f46e51a;--tree-badge-border:#4f46e533;--tree-badge-text:#4f46e5}html.dark{color-scheme:dark;--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-card:#1e293b;--bg-glass:#1e293bd9;--bg-hover:#ffffff0d;--primary:#6366f1;--primary-light:#818cf8;--primary-dark:#4f46e5;--primary-glow:#6366f140;--sidebar-bg:#0f172a;--sidebar-active-bg:#6366f126;--sidebar-active-text:#818cf8;--sidebar-hover-bg:#ffffff0d;--sidebar-text:#94a3b8;--sidebar-text-active:#f8fafc;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--border-subtle:#334155;--border-glow:#6366f133;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 12px #0009;--shadow-lg:0 8px 24px #000000b3;--shadow-glow:0 0 20px #6366f126;--input-bg:#0f172a;--input-color:#f8fafc;--input-border:#334155;--input-placeholder:#64748b;--input-focus-border:#818cf8;--input-focus-shadow:#6366f133;--tree-bg:#0f172a;--tree-grid:#ffffff08;--tree-node-bg:#1e293b;--tree-node-border:#334155;--tree-node-border-active:#818cf8;--tree-node-shadow:0 4px 12px #00000080;--tree-node-shadow-active:0 0 0 3px #6366f14d;--tree-line-parent:#94a3b84d;--tree-line-spouse:#ec489959;--tree-badge-bg:#6366f126;--tree-badge-border:#6366f14d;--tree-badge-text:#818cf8}input,select,textarea{background-color:var(--input-bg);color:var(--input-color);border:1px solid var(--input-border);border-radius:var(--radius-sm);padding:8px 12px}input:focus,select:focus,textarea:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-shadow);outline:none}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow:hidden}::-moz-selection{color:#1a2138;background:#3b6fcf33}::selection{color:#1a2138;background:#3b6fcf33}.app{flex-direction:column;width:100vw;height:100vh;display:flex}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
