*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color:#6366f1;--secondary-color:#8b5cf6;--success-color:#10b981;--danger-color:#ef4444;--dark:#1f2937;--light:#f9fafb;--border:#e5e7eb;--shadow:rgba(0, 0, 0, 0.1)}body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#1e1e2e 0,#2d2d44 100%);min-height:100vh;padding:0;margin:0;color:var(--dark);overflow-x:hidden;width:100vw;overflow:visible}body::before{content:'';background:radial-gradient(circle at 20% 80%,rgba(120,119,198,.3) 0,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,119,198,.2) 0,transparent 50%),radial-gradient(circle at 40% 40%,rgba(120,200,255,.15) 0,transparent 40%);pointer-events:none;z-index:0}.container{display:flex;min-height:100vh;width:100%;margin:0;overflow-x:hidden}.sidebar{width:70px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:15px;position:fixed;top:0;height:100vh;display:flex;flex-direction:column}.sidebar.expanded{width:280px;overflow-y:hidden}.sidebar-toggle-btn{width:40px;height:40px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);border-radius:10px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:.3s;font-size:1.2rem}.sidebar-toggle-btn:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.sidebar-header{margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid rgba(255,255,255,.3);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.sidebar.expanded .sidebar-header{opacity:1;visibility:visible}.sidebar-header h1,.sidebar-header h2{color:#fff;font-size:1.5rem;margin:0;font-weight:700;white-space:nowrap;display:flex;align-items:center;gap:10px}.sidebar-header h1 i,.sidebar-header h2 i{font-size:1.3rem}.sidebar-subtitle{color:rgba(255,255,255,.8);font-size:.85rem;margin-top:8px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.sidebar.expanded .sidebar-subtitle{opacity:1;visibility:visible}.sidebar-toggle{display:flex;flex-direction:column;gap:8px;margin-bottom:25px;transition:.3s}.sidebar:not(.expanded) .sidebar-toggle{flex-direction:column}.sidebar.expanded .sidebar-toggle{flex-direction:row}.btn-sidebar-toggle,a.btn-sidebar-toggle{flex:1;padding:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.9rem;font-weight:500;text-decoration:none}.sidebar:not(.expanded) .btn-sidebar-toggle{width:100%;height:48px;padding:14px;border-radius:16px;font-size:1.2rem}.sidebar:not(.expanded) .btn-sidebar-toggle span{display:none}.btn-sidebar-toggle:hover,a.btn-sidebar-toggle:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);transform:translateY(-2px)}.btn-sidebar-toggle:active{transform:translateY(0)}.btn-sidebar-toggle.active,a.btn-sidebar-toggle.active{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.4);color:#fff;font-weight:600}.sidebar h2{color:#fff;font-size:1.1rem;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.2);font-weight:600;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;white-space:nowrap}.sidebar.expanded h2{opacity:1;visibility:visible}.family-members-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;max-height:calc(100vh - 200px);overflow-y:auto}.sidebar:not(.expanded) .family-members-list{gap:15px}.sidebar:not(.expanded) .btn-primary{width:40px;height:40px;padding:0;border-radius:10px;display:flex;align-items:center;justify-content:center}.sidebar:not(.expanded) .btn-primary span{display:none}.main-content{margin-left:70px;flex:1;padding:20px;transition:margin-left .3s;box-sizing:border-box;overflow-x:hidden;min-width:0}.sidebar.expanded~.main-content{margin-left:280px}.header{display:none;text-align:center;color:#fff;margin-bottom:40px;animation:.6s fadeInDown}.header h1{font-size:3rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2);display:inline-flex;align-items:center;justify-content:center;gap:15px}.header h1 i{font-size:2.5rem}.subtitle{font-size:1.2rem;opacity:.9;margin-bottom:20px}.view-toggle{display:flex;gap:15px;justify-content:center;margin-top:20px}.btn-toggle{padding:12px 30px;background:rgba(255,255,255,.2);color:#fff;border:2px solid rgba(255,255,255,.3);backdrop-filter:blur(10px)}.btn-toggle:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.5)}.btn-toggle.active{background:#fff;color:var(--primary-color);border-color:#fff}select.btn-toggle{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='white' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:35px}a.btn-toggle{display:inline-flex;align-items:center;gap:8px}a.btn-toggle:hover{transform:translateY(-2px)}select.btn-sidebar-toggle{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath fill='white' d='M10 14L4 8h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px 16px;padding-right:40px;font-size:16px}.view-container{animation:.4s fadeIn;width:100%;max-width:100%;overflow:hidden}.family-nav{background:#fff;border-radius:15px;padding:25px;margin-bottom:30px;box-shadow:0 10px 30px var(--shadow);animation:.6s .2s both fadeIn}.family-nav h2{margin-bottom:20px;color:var(--primary-color)}.family-members{display:flex;gap:15px;flex-wrap:wrap;margin-bottom:20px}.family-member{display:flex;align-items:center;gap:12px;padding:12px;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);border-radius:12px;cursor:pointer;transition:.3s;color:#fff}.family-member:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.4);transform:translateX(5px)}.family-member.active{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.5);box-shadow:0 4px 15px rgba(0,0,0,.2)}.family-member img{width:45px;height:45px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.5)}.family-member span{font-weight:600;font-size:.95rem;transition:opacity .3s,visibility .3s}.sidebar:not(.expanded) .family-member{width:40px;height:40px;padding:0;justify-content:center;border-radius:50%}.sidebar:not(.expanded) .family-member span{display:none}.sidebar:not(.expanded) .family-member img{width:35px;height:35px;margin:0}.current-person{background:#fff;border-radius:15px;padding:25px;margin-bottom:30px;box-shadow:0 10px 30px var(--shadow);animation:.6s .3s both fadeIn}.person-card{display:flex;gap:25px;align-items:center}.person-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--primary-color)}.person-info h2{color:var(--primary-color);margin-bottom:10px}.person-info p{color:#6b7280;margin-bottom:15px}.person-relations{display:flex;gap:10px;flex-wrap:wrap}.relation-tag{padding:5px 15px;background:var(--light);border-radius:15px;font-size:.9rem;color:var(--dark)}.timeline-controls{text-align:center;margin-bottom:30px;animation:.6s .4s both fadeIn}.timeline{position:relative;padding:40px 0}.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:4px;background:linear-gradient(to bottom,var(--primary-color),var(--secondary-color));transform:translateX(-50%)}.timeline-item{position:relative;margin-bottom:50px;animation:.6s both fadeInUp}.timeline-item:nth-child(odd){padding-right:calc(50% + 40px)}.timeline-item:nth-child(2n){padding-left:calc(50% + 40px)}.timeline-year{position:absolute;top:15px;font-size:.75rem;font-weight:600;color:rgba(99,102,241,.8);background:#fff;width:50px;height:50px;border-radius:50%;border:2px solid rgba(99,102,241,.4);display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,.1)}.timeline-year::before{content:'';position:absolute;width:40px;height:2px;background:rgba(99,102,241,.3);top:50%;transform:translateY(-50%)}.timeline-item:nth-child(odd) .timeline-year{left:calc(50% + 50px)}.timeline-item:nth-child(odd) .timeline-year::before{right:50px}.timeline-item:nth-child(2n) .timeline-year{right:calc(50% + 50px)}.timeline-item:nth-child(2n) .timeline-year::before{left:50px}.timeline-content{background:#fff;border-radius:15px;padding:25px;box-shadow:0 5px 20px var(--shadow);cursor:pointer;transition:.3s;position:relative}.timeline-content:hover{transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow)}.timeline-delete-btn{position:absolute;top:10px;right:10px;width:32px;height:32px;border:none;border-radius:50%;background:rgba(239,68,68,.9);color:#fff;font-size:14px;cursor:pointer;opacity:0;transform:scale(.8);transition:.2s;display:flex;align-items:center;justify-content:center;z-index:10}.timeline-delete-btn:hover{background:#ef4444;transform:scale(1.1)}.timeline-content:hover .timeline-delete-btn{opacity:1;transform:scale(1)}.timeline-content::before{content:'';position:absolute;top:30px;width:30px;height:2px;background:var(--primary-color)}.timeline-item:nth-child(odd) .timeline-content::before{right:-30px}.timeline-item:nth-child(2n) .timeline-content::before{left:-30px}.timeline-marker{position:absolute;left:50%;top:20px;width:20px;height:20px;background:var(--primary-color);border:4px solid #fff;border-radius:50%;transform:translateX(-50%);box-shadow:0 0 0 4px var(--primary-color);z-index:1}.timeline-date{color:var(--primary-color);font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}.timeline-title{font-size:1.5rem;margin-bottom:10px;color:var(--dark)}.timeline-description{color:#6b7280;margin-bottom:10px;line-height:1.6}.timeline-story-snippet{color:#8b5cf6;font-style:italic;font-size:14px;margin-bottom:15px;padding:10px;background:rgba(139,92,246,.05);border-left:3px solid #8b5cf6;border-radius:5px}.timeline-participants{display:inline-flex;align-items:center;gap:.5rem;margin:.75rem 0;padding:.375rem .75rem;background:#e0f2fe;border-radius:20px;font-size:.875rem;color:#0c4a6e}.timeline-participants i{font-size:.875rem;color:#0284c7}.participants-label{display:flex;align-items:center}.participant-avatar:hover{transform:scale(1.1);transform:translateY(-2px);z-index:10}.event-participants-modal{display:flex;align-items:center;gap:.75rem;margin:1rem 0;padding:.75rem;background:#f0f9ff;border-radius:12px;border:1px solid #bae6fd}.event-participants-modal .participants-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#0369a1;font-weight:600}.event-participants-modal .participants-avatars{display:flex;gap:-10px}.event-participants-modal .participant-avatar{width:36px;height:36px;display:inline-block;border-radius:50%;overflow:hidden;border:3px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.1)}.participants-label{display:flex;align-items:center;gap:.375rem;color:#0c4a6e;font-weight:500}.participants-label i{font-size:.875rem;color:#0284c7}.participants-avatars{display:flex;gap:-8px;align-items:center}.participant-avatar{box-shadow:0 2px 4px rgba(0,0,0,.1);z-index:1;display:inline-block;width:30px;height:30px;border-radius:50%;border:2px solid #fff;overflow:hidden;position:relative;margin-left:-8px;transition:transform .2s}.participant-avatar:first-child{margin-left:0}.participant-avatar img{width:100%;height:100%;object-fit:cover}.timeline-image{width:100%;height:250px;object-fit:cover;border-radius:10px;margin-top:15px}.timeline-actions{display:flex;gap:10px;margin-top:15px}.btn{padding:12px 24px;border:none;border-radius:12px;font-size:.95rem;cursor:pointer;transition:.3s;display:inline-flex;align-items:center;gap:8px;font-weight:600;box-shadow:0 2px 8px rgba(0,0,0,.1)}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.btn-primary{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#5568d3 0,#6441a5 100%)}.btn-success{background:linear-gradient(135deg,#10b981 0,#059669 100%);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#059669 0,#047857 100%)}.btn-danger{background:linear-gradient(135deg,#ef4444 0,#dc2626 100%);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#dc2626 0,#b91c1c 100%)}.btn-secondary{background:linear-gradient(135deg,#764ba2 0,#667eea 100%);color:#fff}.btn-secondary:hover{background:linear-gradient(135deg,#6441a5 0,#5568d3 100%)}.btn-block{width:100%;justify-content:center}.add-member-btn{margin-top:15px;padding:14px 20px!important;font-size:1rem;font-weight:600;border-radius:16px;box-shadow:0 8px 20px rgba(99,102,241,.3);transition:.3s cubic-bezier(.4, 0, .2, 1);display:flex;align-items:center;gap:10px}.add-member-btn i{font-size:1.1rem}.add-member-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(99,102,241,.4)}.add-member-btn:active{transform:translateY(0)}.timeline-share-btn:hover{background:#10b981!important;transform:scale(1.1)}.timeline-item-private{position:relative}.timeline-item-private .timeline-content{position:relative;cursor:pointer}.private-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:15px;backdrop-filter:blur(6px)}.private-overlay i{font-size:80px;color:#6366f1;text-shadow:0 4px 12px rgba(99,102,241,.3)}.private-overlay h3,.private-overlay p{display:none}.private-badge{position:absolute;top:10px;right:160px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:5;box-shadow:0 2px 8px rgba(99,102,241,.3);display:flex;align-items:center;gap:5px}.modal{display:none;position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.7);animation:.3s fadeIn}body.modal-open{overflow:hidden!important}.modal-content{background:linear-gradient(180deg,#fff 0,#fafafa 100%);margin:30px auto;padding:0;border-radius:20px;max-width:600px;max-height:90vh;overflow:hidden;position:relative;animation:.3s slideUp;box-shadow:0 25px 80px rgba(0,0,0,.3)}.modal-content h2{margin:0;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;font-size:1.15rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.modal-content h2 i{font-size:1.1rem}.modal-content .close{position:absolute;top:1rem;right:1rem;color:#fff;font-size:1.5rem;opacity:.8;z-index:10}.modal-content .close:hover{opacity:1}.modal-body,.modal-content>.event-form,.modal-content>form{padding:1.5rem;max-height:calc(90vh - 80px);overflow-y:auto}.modal-large{max-width:700px}.modal-large #entityFormContainer,.modal-large .modal-body{max-height:calc(90vh - 160px);overflow-y:auto;overflow-x:hidden}.modal-image{max-width:90%;padding:20px;background:0 0}.modal-image img{width:100%;height:auto;border-radius:10px}.close{position:absolute;right:20px;top:20px;font-size:2rem;color:#6b7280;cursor:pointer;transition:color .3s}.close:hover{color:var(--danger-color)}.modal-compact{padding:0!important;max-width:360px!important;min-width:320px;border-radius:12px!important;overflow:visible!important;margin:10% auto!important;max-height:fit-content!important;height:auto!important;background:#fff!important}#addRelationModal .modal-content{max-height:fit-content!important;overflow:visible!important}.modal-header-compact{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:12px 12px 0 0}.modal-header-compact h3{margin:0;color:#fff;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:5px}.modal-header-compact h3 i{font-size:.85rem}.close-btn-compact{background:0 0;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s;line-height:1}.close-btn-compact:hover{background:rgba(255,255,255,.2)}.form-compact{padding:10px 12px}.form-row-compact{display:flex;align-items:center;gap:6px;margin-bottom:10px}.select-compact{flex:1;padding:6px 8px;border:1.5px solid #e5e7eb;border-radius:6px;font-size:.83rem;background:#fff;transition:.2s;outline:0;color:#374151;min-width:0;height:32px}.select-compact:focus{border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,.1)}.relation-arrow{color:#9ca3af;font-weight:700;font-size:1rem;flex-shrink:0}.btn-compact{width:100%;padding:7px 12px;font-size:.85rem;border-radius:6px;border:none;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;font-weight:600;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:5px}.btn-compact:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(102,126,234,.3)}.btn-compact:active{transform:translateY(0)}.btn-compact i{font-size:.8rem}.event-modal-wrapper{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:12px}.event-modal-header{position:relative;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #e5e7eb}.event-badge-wrapper{flex:1}.event-type-badge{padding:5px 10px;background:#f3f4f6;border:none;border-radius:6px;color:#6b7280;font-size:.8rem;font-weight:500;display:inline-flex;align-items:center;gap:5px}.event-type-badge i{font-size:.8rem;color:#9ca3af}.event-close-btn{background:0 0;border:none;color:#9ca3af;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;font-size:1.2rem}.event-close-btn:hover{background:#f3f4f6;color:#4b5563}.event-modal-body{padding:24px 32px;overflow-y:auto;flex:1}.event-title-section{margin-bottom:20px}.event-title{margin:0 0 8px;font-size:1.5rem;font-weight:600;color:#111827;line-height:1.3}.event-date-location{display:flex;gap:16px;flex-wrap:wrap;font-size:.9rem;color:#6b7280}.event-date-location span{display:flex;align-items:center;gap:5px}.event-date-location i{color:#9ca3af;font-size:.85rem}.event-description-section{background:#f9fafb;padding:16px;border-radius:8px;margin-bottom:20px}.event-description-section p{margin:0;line-height:1.6;color:#4b5563;font-size:.95rem}.event-story-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:0;margin-bottom:20px;overflow:hidden;transition:.2s;position:relative}.event-story-card:hover{border-color:#d1d5db}.story-card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#fafafa;border-bottom:1px solid #e5e7eb}.story-card-header h3{margin:0;font-size:.95rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:6px}.story-card-header h3 i{color:#6b7280;font-size:.9rem}.story-actions{display:flex;gap:6px;opacity:0;visibility:hidden;transition:.2s ease-in-out}.event-story-card:hover .story-actions{opacity:1;visibility:visible}.btn-story-action{padding:4px 8px;background:#fff;border:1px solid #e5e7eb;border-radius:5px;color:#6b7280;font-size:.78rem;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:4px}.btn-story-action:hover{background:#f9fafb;border-color:#c6c9cf;color:#374151}.btn-story-action i{font-size:.75rem}.btn-story-ai{padding:4px 8px;background:linear-gradient(135deg,#a855f7 0,#ec4899 100%);border:none;border-radius:5px;color:#fff;font-size:.78rem;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:4px}.btn-story-ai:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(168,85,247,.25)}.btn-story-ai i{font-size:.75rem}.story-content{white-space:pre-wrap;font-size:.95rem}.story-content.empty{text-align:center;display:flex;align-items:center;justify-content:center;font-size:.9rem}.story-textarea{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem;line-height:1.6;resize:vertical;font-family:inherit;min-height:120px}.story-textarea:focus{outline:0;border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.1)}.story-editor-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px;padding:0 15px 15px}.event-image-section{margin-top:20px;border-radius:8px;border:1px solid #e5e7eb;padding:16px}.image-source-tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid #e5e7eb;padding-bottom:12px}.img-tab{padding:8px 16px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;font-size:.85rem;color:#6b7280;transition:.2s;display:flex;align-items:center;gap:6px}.img-tab:hover{border-color:#c6c9cf;color:#374151}.img-tab.active{background:#6366f1;border-color:#6366f1;color:#fff}.image-tab-content{transition:opacity .2s}.image-tab-content.hidden{display:none}.url-image-section{display:flex;flex-direction:column;gap:20px}.url-input-group{display:flex;flex-direction:column;gap:8px}.url-input-row{display:flex;gap:8px}.url-input-row input{flex:1}.url-preview{min-height:60px;border-radius:8px;overflow:hidden}.url-preview img{max-width:100%;max-height:200px;border-radius:8px;object-fit:cover}.url-preview .url-error{color:#ef4444;font-size:.85rem;padding:10px;background:#fef2f2;border-radius:6px;display:block}.album-url-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.album-url-item{position:relative;width:70px;height:70px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.album-url-item img{width:100%;height:100%;object-fit:cover}.album-url-item .remove-url-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(239,68,68,.9);border:none;color:#fff;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.album-url-item:hover .remove-url-btn{opacity:1}.url-sources-hint{font-size:.8rem;color:#9ca3af;padding:10px;background:#f9fafb;border-radius:8px;display:flex;align-items:center;gap:8px}.url-sources-hint i{color:#0ea5e9}.event-main-img{width:100%;height:auto;max-height:380px;object-fit:cover;cursor:pointer;transition:opacity .2s;display:block}.event-main-img:hover{opacity:.95}.event-album-section{margin-top:20px;padding:15px;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.album-title{margin:0 0 10px;font-size:.85rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:6px}.album-title i{color:#9ca3af;font-size:.8rem}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;max-width:100%}.album-thumbnail{aspect-ratio:1;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.1)}.album-thumbnail:hover{transform:scale(1.1);z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.2)}.main-image-thumb{position:relative;border:2px solid #fbbf24}.main-badge{position:absolute;top:4px;right:4px;background:#fbbf24;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,.3)}.main-badge i{font-size:10px}#eventModal .modal-content{max-width:800px;width:90%;padding:0;max-height:92vh;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 20px 40px rgba(0,0,0,.15)}#eventModal .event-modal-body::-webkit-scrollbar{width:8px}#eventModal .event-modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}#eventModal .event-modal-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:10px}#eventModal .event-modal-body::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.event-modal-modern{background:#fff;border-radius:16px;overflow:hidden}.event-modal-modern .event-modal-header{background:linear-gradient(135deg,var(--type-color,#6366f1) 0,color-mix(in srgb,var(--type-color,#6366f1) 70%,#000) 100%);padding:24px 28px;flex-direction:column;align-items:flex-start;border-bottom:none;position:relative}.event-modal-modern .event-close-btn{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.2);color:#fff;backdrop-filter:blur(8px)}.event-modal-modern .event-close-btn:hover{background:rgba(255,255,255,.3);color:#fff}.event-modal-modern .event-type-badge{padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:600;color:#fff;margin-bottom:12px;box-shadow:0 2px 8px rgba(0,0,0,.2)}.event-modal-modern .event-title{color:#fff;font-size:1.6rem;font-weight:700;margin:0 0 10px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.event-modal-modern .event-meta{display:flex;gap:20px;flex-wrap:wrap;font-size:.9rem;color:rgba(255,255,255,.9)}.event-modal-modern .event-meta span{display:flex;align-items:center;gap:6px}.event-modal-modern .event-meta i{opacity:.8}.event-modal-modern .event-modal-body{padding:24px 28px;background:#fafafa}.event-modal-modern .event-participants-section{display:flex;justify-content:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.event-modal-modern .participants-avatars{display:flex;gap:8px}.event-modal-modern .participant-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.1);transition:transform .2s}.event-modal-modern .participant-avatar:hover{transform:scale(1.1)}.event-modal-modern .participant-avatar img{width:100%;height:100%;object-fit:cover}.event-modal-modern .event-section{background:#fff;border-radius:12px;padding:18px 20px;margin-bottom:16px;border:1px solid #e5e7eb}.event-modal-modern .event-section h4{margin:0 0 12px;font-size:.9rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:8px}.event-modal-modern .event-section h4 i{color:#9ca3af;font-size:.85rem}.event-modal-modern .event-description{margin:0;color:#4b5563;line-height:1.7;font-size:.95rem}.event-modal-modern .event-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.event-modal-modern .detail-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:#f9fafb;border-radius:8px}.event-modal-modern .detail-item.detail-item-full{grid-column:1/-1;align-items:center}.event-modal-modern .detail-item-full .detail-value{margin-top:8px}.event-modal-modern .detail-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.event-modal-modern .detail-value{font-size:.9rem;color:#1f2937;font-weight:500}.event-modal-modern .event-story-section{background:#fff}.event-modal-modern .event-story-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.event-modal-modern .event-story-section .section-header h4{margin:0}.event-modal-modern .story-actions{display:flex;gap:6px;opacity:0;transition:opacity .2s}.event-modal-modern .event-story-section:hover .story-actions{opacity:1}.event-modal-modern .btn-icon{width:32px;height:32px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}.event-modal-modern .btn-icon:hover{background:#f3f4f6;color:#374151}.event-modal-modern .btn-icon.btn-ai{background:linear-gradient(135deg,#a855f7,#ec4899);border:none;color:#fff}.event-modal-modern .btn-icon.btn-ai:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(168,85,247,.3)}.event-modal-modern .story-content{padding:0;min-height:60px;font-size:.95rem;line-height:1.8}.event-modal-modern .story-content.empty{padding:16px;background:#f9fafb;border-radius:8px;min-height:auto}.event-modal-modern .story-textarea{border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem}.event-modal-modern .story-editor-actions{padding:12px 0 0}.event-modal-modern .event-images-section h4{margin-bottom:14px}.event-modal-modern .event-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}.event-modal-modern .event-image-thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;position:relative;box-shadow:0 2px 6px rgba(0,0,0,.08);transition:.2s}.event-modal-modern .event-image-thumb:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(0,0,0,.15)}.event-modal-modern .event-image-thumb img{width:100%;height:100%;object-fit:cover}.event-modal-modern .event-image-thumb.main{border:2px solid #fbbf24}.event-modal-modern .event-image-thumb .main-badge{position:absolute;top:6px;right:6px;background:#fbbf24;color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px}@media (max-width:600px){.event-modal-modern .event-modal-header{padding:20px}.event-modal-modern .event-title{font-size:1.3rem}.event-modal-modern .event-modal-body{padding:16px}.event-modal-modern .event-details-grid{grid-template-columns:1fr 1fr}.event-modal-modern .event-images-grid{grid-template-columns:repeat(3,1fr)}}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--dark)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--primary-color)}.event-detail h2{color:var(--primary-color);margin-bottom:10px}.event-date{color:#6b7280;margin-bottom:30px;display:flex;align-items:center;gap:8px}.event-story{margin-bottom:30px}.event-story h3{color:var(--dark);margin-bottom:15px}.story-content{background:var(--light);padding:20px;border-radius:10px;line-height:1.8;color:#374151;margin-bottom:15px;min-height:100px;white-space:pre-wrap;word-wrap:break-word}.story-content.empty{color:#9ca3af;font-style:italic}.story-edit-btn{position:absolute;top:10px;right:10px;width:32px;height:32px;border:none;border-radius:50%;background:rgba(99,102,241,.9);color:#fff;font-size:14px;cursor:pointer;opacity:0;transform:scale(.8);transition:.2s;display:flex;align-items:center;justify-content:center;z-index:10}.story-content:hover+.story-edit-btn,.story-edit-btn:hover{opacity:1;transform:scale(1)}.story-edit-btn:hover{background:#6366f1;transform:scale(1.1)}div:has(> .story-content):hover .story-edit-btn{opacity:1;transform:scale(1)}.story-actions{display:flex;gap:10px}.story-editor{margin-top:15px}.story-editor textarea{width:100%;padding:15px;border:2px solid var(--border);border-radius:8px;font-size:1rem;line-height:1.6;margin-bottom:10px}.event-album h3{color:var(--dark);margin-bottom:15px}.album-thumbnail{position:relative;cursor:pointer;border-radius:8px;overflow:hidden;aspect-ratio:1;background:#f3f4f6;width:80px;height:80px}.album-thumbnail img{object-fit:cover;width:100%;height:100%;object-fit:cover;transition:transform .3s}.album-thumbnail:hover img{transform:scale(1.1)}.thumbnail-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.album-thumbnail:hover .thumbnail-overlay{opacity:1}.thumbnail-overlay i{color:#fff;font-size:32px;text-shadow:0 2px 8px rgba(0,0,0,.3)}.lightbox{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:10000;align-items:center;justify-content:center;animation:.3s fadeIn}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.5)}.lightbox-close{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.2);border:none;color:#fff;width:50px;height:50px;border-radius:50%;font-size:24px;cursor:pointer;transition:.3s;backdrop-filter:blur(10px);z-index:10001}.lightbox-close:hover{background:rgba(255,255,255,.3);transform:rotate(90deg)}.lightbox-next,.lightbox-prev{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.2);border:none;color:#fff;width:60px;height:60px;border-radius:50%;font-size:24px;cursor:pointer;transition:.3s;backdrop-filter:blur(10px);z-index:10001}.lightbox-prev{left:30px}.lightbox-next{right:30px}.lightbox-next:hover,.lightbox-prev:hover{background:rgba(255,255,255,.3);transform:translateY(-50%) scale(1.1)}.lightbox-counter{color:#fff;font-size:18px;font-weight:600;margin-top:20px;padding:10px 20px;background:rgba(0,0,0,.5);border-radius:20px;backdrop-filter:blur(10px)}.lightbox::after{content:'Nhấn ESC để đóng, ← → để chuyển ảnh';position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:14px;pointer-events:none}.image-nav{display:flex;justify-content:center;gap:20px;margin-top:20px}.btn-nav{background:#fff;border:none;width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:1.2rem;color:var(--primary-color);transition:.3s}.btn-nav:hover{background:var(--primary-color);color:#fff;transform:scale(1.1)}@keyframes fadeInDown{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:768px){.header h1{font-size:2rem}.timeline::before{left:30px}.timeline-item:nth-child(2n),.timeline-item:nth-child(odd){padding-left:70px;padding-right:0}.timeline-marker{left:30px}.timeline-content::before,.timeline-year{display:none}.person-card{flex-direction:column;text-align:center}.album-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px}.album-thumbnail{width:70px;height:70px}.modal-content{margin:20px;max-width:calc(100% - 40px)}}.loading{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:1s ease-in-out infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px;color:#fff}.empty-state i{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:1.5rem;margin-bottom:10px}.empty-state p{opacity:.8}.tree-container{background:linear-gradient(135deg,#fff 0,#f8f9ff 100%);border-radius:20px;padding:40px;box-shadow:0 20px 60px rgba(99,102,241,.15);min-height:600px;border:1px solid rgba(99,102,241,.1)}.tree-header{text-align:center;margin-bottom:40px;position:relative}.tree-header h2{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.5rem;margin-bottom:15px;font-weight:700}.tree-header p{color:#6b7280;font-size:1.1rem}.tree-controls{display:flex;gap:15px;justify-content:center;margin-bottom:35px;flex-wrap:wrap}.tree-controls .btn{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border:none;color:#fff;padding:12px 28px;font-weight:600;box-shadow:0 4px 15px rgba(102,126,234,.4)}.tree-controls .btn:hover{box-shadow:0 6px 20px rgba(102,126,234,.6);transform:translateY(-3px)}.tree-canvas-wrapper{overflow:hidden;border:none;border-radius:15px;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.1);height:calc(100vh - 200px);position:relative;margin-top:20px;width:100%}.tree-canvas-wrapper::-webkit-scrollbar{width:12px;height:12px}.tree-canvas-wrapper::-webkit-scrollbar-track{background:rgba(99,102,241,.05);border-radius:10px}.tree-canvas-wrapper::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:10px;border:2px solid #e8ecff}.tree-canvas-wrapper::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--secondary-color),var(--primary-color))}.tree-canvas{width:100%;height:100%;position:absolute;top:0;left:0}.tree-node{position:absolute;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:.3s cubic-bezier(.4, 0, .2, 1);animation:.6s ease-out backwards nodeAppear;z-index:10}@keyframes nodeAppear{from{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.tree-node:hover{transform:scale(1.1) translateY(-5px);z-index:20}.tree-node-card{background:linear-gradient(135deg,#fff 0,#f8f9ff 100%);border:none;border-radius:16px;padding:15px;text-align:center;box-shadow:0 6px 20px rgba(99,102,241,.15),0 0 0 1px rgba(99,102,241,.1);min-width:130px;transition:.4s cubic-bezier(.4, 0, .2, 1);position:relative;overflow:hidden}.tree-node-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));opacity:0;transition:opacity .3s}.tree-node:hover .tree-node-card::before{opacity:1}.tree-node:hover .tree-node-card{box-shadow:0 15px 40px rgba(99,102,241,.3),0 0 0 2px var(--primary-color);background:linear-gradient(135deg,#fff 0,#f0f4ff 100%)}.tree-node-avatar{width:70px;height:70px;border-radius:50%;object-fit:cover;margin-bottom:10px;border:3px solid #fff;transition:.3s;box-shadow:0 3px 12px rgba(99,102,241,.2)}.tree-node:hover .tree-node-avatar{transform:scale(1.05);box-shadow:0 6px 20px rgba(99,102,241,.4)}.tree-node-name{font-weight:700;color:var(--dark);margin-bottom:5px;font-size:.95rem;letter-spacing:-.02em}.tree-node-info{font-size:.8rem;color:#6b7280;display:flex;align-items:center;justify-content:center;gap:4px}.tree-node-info::before{content:'🎂';font-size:.85rem}.tree-node-relations{margin-top:10px;font-size:.8rem;color:var(--primary-color);background:rgba(99,102,241,.1);padding:4px 12px;border-radius:12px;font-weight:600}.tree-connection{position:absolute;pointer-events:none;z-index:1}.tree-line{stroke:var(--primary-color);stroke-width:3;fill:none;opacity:.7;transition:.3s;filter:drop-shadow(0 2px 4px rgba(99, 102, 241, .2))}.tree-line-spouse{stroke:#ec4899;stroke-width:4;stroke-dasharray:8,6;opacity:.8;filter:drop-shadow(0 2px 4px rgba(236, 72, 153, .3))}.tree-line-child{stroke:var(--success-color);stroke-width:3;opacity:.8;filter:drop-shadow(0 2px 4px rgba(16, 185, 129, .3))}.tree-line-sibling{stroke:#f59e0b;stroke-width:3;stroke-dasharray:6,4;opacity:.7;filter:drop-shadow(0 2px 4px rgba(245, 158, 11, .3))}.relation-label{position:absolute;background:linear-gradient(135deg,#fff 0,#f8f9ff 100%);padding:5px 12px;border-radius:15px;font-size:.75rem;color:var(--primary-color);border:2px solid var(--primary-color);pointer-events:none;z-index:5;white-space:nowrap;font-weight:600;box-shadow:0 4px 12px rgba(99,102,241,.2);animation:2s ease-in-out infinite labelPulse}@keyframes labelPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes drawLine{to{stroke-dashoffset:0}}.tree-legend{position:absolute;top:20px;right:20px;background:linear-gradient(135deg,#fff 0,#f8f9ff 100%);padding:20px;border-radius:15px;box-shadow:0 10px 30px rgba(99,102,241,.2);z-index:100;border:1px solid rgba(99,102,241,.1);backdrop-filter:blur(10px)}.tree-legend h4{margin-bottom:15px;color:var(--dark);font-size:1rem;font-weight:700;display:flex;align-items:center;gap:8px}.tree-legend h4::before{content:'📊';font-size:1.2rem}.legend-item{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-size:.9rem;padding:6px;border-radius:8px;transition:.2s}.legend-item:hover{background:rgba(99,102,241,.05);transform:translateX(3px)}.legend-line{width:35px;height:3px;border-radius:2px}.legend-line-spouse{background:#ec4899;border-top:3px dashed #ec4899;box-shadow:0 2px 4px rgba(236,72,153,.3)}.legend-line-child{background:var(--success-color);box-shadow:0 2px 4px rgba(16,185,129,.3)}.legend-line-sibling{background:#f59e0b;border-top:3px dashed #f59e0b;box-shadow:0 2px 4px rgba(245,158,11,.3)}.tree-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:#9ca3af;animation:.6s fadeIn}.tree-empty i{font-size:5rem;margin-bottom:25px;opacity:.5;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tree-empty h3{margin-bottom:12px;font-size:1.5rem;color:var(--dark)}.tree-empty p{font-size:1.1rem}@keyframes slideIn{from{transform:translateX(400px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(400px);opacity:0}}@media (max-width:768px){.tree-canvas{padding:30px}.tree-node-card{min-width:120px;padding:10px}.tree-node-avatar{width:60px;height:60px}.tree-node-name{font-size:.9rem}.tree-legend{position:relative;top:auto;right:auto;margin-bottom:20px}}.custom-alert-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10000;animation:.2s fadeIn}.custom-alert-dialog{background:#fff;border-radius:12px;padding:0;max-width:400px;width:90%;box-shadow:0 10px 40px rgba(0,0,0,.3);animation:.3s slideIn}.custom-alert-header{padding:20px 20px 15px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #e5e7eb}.custom-alert-icon{font-size:24px}.custom-alert-title{margin:0;font-size:1.25rem;color:#1f2937}.custom-alert-message{padding:20px;color:#4b5563;line-height:1.6;white-space:pre-wrap}.custom-alert-buttons{padding:15px 20px 20px;display:flex;justify-content:flex-end;gap:10px}.custom-alert-btn{padding:10px 24px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:.2s}.custom-alert-btn-primary{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff}.custom-alert-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(102,126,234,.4)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.minimalist-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;transition:opacity .2s}.minimalist-confirm-overlay.show{opacity:1}.minimalist-confirm-box{background:#fff;border-radius:8px;padding:20px;width:280px;text-align:center;transform:scale(.95);transition:transform .2s;box-shadow:0 4px 12px rgba(0,0,0,.15)}.minimalist-confirm-overlay.show .minimalist-confirm-box{transform:scale(1)}.minimalist-confirm-icon{width:40px;height:40px;margin:0 auto 12px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center}.minimalist-confirm-icon i{color:#ef4444;font-size:18px}.minimalist-confirm-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#111827}.minimalist-confirm-text{margin:0 0 16px;font-size:14px;color:#6b7280;line-height:1.4}.minimalist-confirm-actions{display:flex;gap:8px}.minimalist-btn-cancel,.minimalist-btn-delete{flex:1;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:.15s}.minimalist-btn-cancel{background:#f3f4f6;color:#4b5563}.minimalist-btn-cancel:hover{background:#e5e7eb}.minimalist-btn-delete{background:#ef4444;color:#fff}.minimalist-btn-delete:hover{background:#dc2626}@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}100%{transform:translateX(100%) translateY(100%) rotate(45deg)}}.password-modal{position:fixed!important;top:0!important;left:0!important;width:100%!important;height:100%!important;align-items:center!important;justify-content:center!important;z-index:9999!important;background:rgba(0,0,0,.5)!important;backdrop-filter:blur(2px)}.password-modal.show{display:flex!important}.password-modal .modal-content{padding:0!important;background:#fff!important;border-radius:12px!important;overflow:visible!important;box-shadow:0 10px 25px rgba(0,0,0,.15)!important;width:320px!important;max-width:320px!important;min-width:300px!important;height:auto!important;max-height:auto!important;min-height:auto!important;position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;margin:0!important;animation:.3s fadeInScale!important}.password-modal-header{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:8px 14px!important;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;height:auto!important;min-height:unset!important}.password-modal-header i{margin-right:8px}.password-modal-header .modal-close-btn{background:0 0;border:none;color:#fff;font-size:18px;cursor:pointer;padding:4px;opacity:.8;transition:opacity .2s}.password-modal-header .modal-close-btn:hover{opacity:1}.password-modal-container{background:#fff;padding:12px 20px!important;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:unset!important;height:auto!important}.password-modal-content{max-width:100%!important;margin:0 auto}.password-modal-desc{color:#718096;font-size:13px!important;margin:0 0 10px!important;line-height:1.2!important}.password-input-group{margin-bottom:10px!important;margin-top:0!important}.password-input-wrapper{position:relative;background:#f7fafc;border-radius:8px;border:1.5px solid #e2e8f0;transition:.3s;display:flex;align-items:center;padding:0 10px!important;height:34px!important}.password-input-wrapper:focus-within{border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.password-input-wrapper i.fa-key{color:#a0aec0;margin-right:10px;font-size:14px!important}.password-input{flex:1;border:none;background:0 0;padding:8px 0!important;font-size:14px!important;color:#2d3748;outline:0}.password-input::placeholder{color:#a0aec0}.toggle-password{background:0 0;border:none;color:#a0aec0;cursor:pointer;padding:6px!important;transition:color .2s}.toggle-password i{font-size:14px!important}.toggle-password:hover{color:#667eea}.password-modal-actions{display:flex;gap:8px!important;justify-content:center;margin-top:12px!important;margin-bottom:0!important}.password-btn{padding:7px 20px!important;border-radius:6px;font-size:13px!important;font-weight:500;border:none;cursor:pointer;transition:.3s;display:inline-flex;align-items:center;gap:5px!important}.password-btn i{font-size:13px!important}.password-btn-cancel{background:#e2e8f0;color:#4a5568}.password-btn-cancel:hover{background:#cbd5e0;transform:translateY(-2px)}.password-btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px rgba(102,126,234,.3)}.password-btn-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,.4)}@keyframes bounceIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}@keyframes shake{0%,100%{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}.password-error{background:#fee2e2;color:#dc2626;padding:8px 12px;border-radius:6px;margin-bottom:12px;margin-top:8px;font-size:13px!important;display:flex;align-items:center;gap:6px;animation:.3s slideDown;transition:opacity .3s}.password-error i{font-size:12px!important}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}#passwordModal .modal-content{height:fit-content!important;max-height:fit-content!important;min-height:unset!important}@keyframes fadeInScale{from{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media (max-width:768px){.password-modal .modal-content{max-width:280px!important;min-width:260px!important}.password-modal-container{padding:12px 20px!important}.lock-circle{width:40px!important;height:40px!important}.lock-circle i{font-size:18px!important}.password-modal-title{font-size:16px!important}.password-modal-desc{font-size:13px!important}.password-btn{padding:7px 18px!important;font-size:13px!important}.password-input-wrapper{height:34px!important}.password-input{font-size:13px!important}}.timeline-loading{text-align:center;padding:30px;color:#6b7280}.timeline-loading .loading-spinner{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;background:#f9fafb;border-radius:50px;font-size:14px}.timeline-loading .fa-spinner{font-size:18px;color:#6366f1}#timeline-sentinel{height:1px;visibility:hidden}