*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:Cairo,sans-serif;background:#fff;direction:rtl;color:#1a1a1a}.canvas-wrap{position:absolute;top:52px;left:0;right:0;bottom:0;overflow:hidden;cursor:grab;touch-action:none}.canvas-wrap.dragging{cursor:grabbing}.canvas-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,#e0e0e0 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0}.canvas-inner{position:absolute;top:0;left:0;transform-origin:0 0}.tree-node{position:absolute;background:#fff;border-radius:12px;border:1.5px solid #a07428;box-shadow:0 2px 8px #0000000f;font-family:Cairo,sans-serif;direction:rtl;-webkit-user-select:none;user-select:none;transition:opacity .2s,box-shadow .2s,border-color .2s,background .2s}.tree-node:hover{box-shadow:0 4px 16px #0000001a;border-color:#8b1a1a}.tree-node.deceased{border-color:#a0742859;background:#fefefe;opacity:.75}.tree-node.selected{border-color:#8b1a1a!important;background:#fff5f5!important;box-shadow:0 0 0 3px #8b1a1a2e,0 4px 16px #0000001a!important}.tree-node.ancestor{border-color:#8b1a1a8c!important;background:#fff8f8!important}.node-actions{position:absolute;top:-38px;right:0;display:flex;flex-direction:row-reverse;gap:4px;background:#fff;border:1.5px solid rgba(160,116,40,.4);border-radius:10px;padding:4px 6px;box-shadow:0 4px 12px #0000001a;z-index:20;white-space:nowrap}.action-btn{background:none;border:none;cursor:pointer;font-size:13px;padding:4px 6px;border-radius:6px;font-family:Cairo,sans-serif;color:#8b4a1a;display:inline-flex;align-items:center;gap:4px;transition:background .1s}.action-btn:hover{background:#fdf5e8}.action-btn.danger{color:#b83232}.action-btn .label{font-size:12px}.collapse-badge{margin-top:8px;padding:4px 10px;background:#fdf8f0;border:1.5px dashed rgba(160,116,40,.4);border-radius:7px;font-size:13px;color:#a07840;cursor:pointer;text-align:center}.collapse-badge:hover{background:#fdf0dc;color:#8b5e2a}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:400}.drawer-right{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:92vw;background:#fff;border-left:1.5px solid rgba(200,150,54,.27);box-shadow:-4px 0 32px #0000001a;z-index:500;display:flex;flex-direction:column;font-family:Cairo,sans-serif;direction:rtl;animation:slideRight .22s ease}@keyframes slideRight{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{padding:18px 22px 14px;border-bottom:1.5px solid #f0e8d8;display:flex;justify-content:space-between;align-items:center;color:#8b4a1a;font-weight:700}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:14px}.drawer-footer{padding:12px 22px;border-top:1.5px solid #f0e8d8;display:flex;gap:10px;justify-content:flex-start}.field-label{font-size:13px;color:#888;margin-bottom:5px;display:block}.field-input,.field-textarea{width:100%;padding:9px 12px;border:1.5px solid #e0d0b8;border-radius:9px;font-family:Cairo,sans-serif;font-size:15px;background:#fdfaf6;color:#2a1a0a;outline:none;direction:rtl;text-align:right;transition:border-color .15s}.field-input:focus,.field-textarea:focus{border-color:#c89636;background:#fff}.field-textarea{resize:vertical;min-height:80px}.photo-block{display:flex;gap:14px;align-items:center;padding-bottom:14px;border-bottom:1px solid #f0e8d8}.photo-preview{position:relative;width:96px;height:96px;flex:0 0 96px}.photo-preview .avatar{width:96px;height:96px}.photo-preview.busy:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff8c;border-radius:50%}.photo-spinner{position:absolute;top:50%;left:50%;width:28px;height:28px;margin-left:-14px;margin-top:-14px;border:3px solid rgba(160,116,40,.25);border-top-color:#a07428;border-radius:50%;animation:photo-spin .7s linear infinite;z-index:2}@keyframes photo-spin{to{transform:rotate(360deg)}}.photo-actions{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.photo-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;padding:7px 12px;justify-content:center}.photo-hint{font-size:12px;color:#999;line-height:1.4}.photo-err{color:#8b1a1a;font-size:12px}.avatar-clickable{transition:filter .18s ease}.avatar-clickable img{cursor:inherit}.avatar-clickable:hover{filter:brightness(.82)}.avatar-clickable:active{filter:brightness(.72)}.lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:800;display:flex;align-items:center;justify-content:center;padding:40px;cursor:zoom-out;animation:lightbox-fade .15s ease-out}@keyframes lightbox-fade{0%{opacity:0}to{opacity:1}}.lightbox-image{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 10px 40px #00000080;cursor:default;-webkit-user-select:none;user-select:none}.lightbox-close{position:fixed;top:20px;left:20px;width:40px;height:40px;border-radius:50%;background:#ffffff26;border:1.5px solid rgba(255,255,255,.35);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.lightbox-close:hover{background:#ffffff47}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:600;display:flex;align-items:center;justify-content:center}.modal-box{background:#fff;border-radius:18px;border:1.5px solid rgba(200,150,54,.33);padding:28px;width:420px;max-width:92vw;font-family:Cairo,sans-serif;direction:rtl;color:#2a1a0a;box-shadow:0 10px 40px #00000021}.btn{padding:9px 18px;border:1.5px solid rgba(200,150,54,.4);border-radius:9px;cursor:pointer;font-family:Cairo,sans-serif;font-size:15px;background:#fff;color:#8b4a1a;transition:background .15s,border-color .15s}.btn:hover{background:#fdf5e8;border-color:#c89636}.btn-primary{background:#a07428;color:#fff;border-color:#a07428;font-weight:700}.btn-primary:hover{background:#8b5e1f;border-color:#8b5e1f}.btn-danger{background:#8b1a1a;color:#fff;border-color:#8b1a1a}.btn-danger:hover{background:#6e1414;border-color:#6e1414}.lock-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;padding:6px 12px;font-weight:600}.lock-btn-locked{background:#fff5f5;color:#8b1a1a;border-color:#8b1a1a66}.lock-btn-locked:hover{background:#ffeaea;border-color:#8b1a1a}.lock-btn-unlocked{background:#f6fbf6;color:#2d6b3a;border-color:#2d6b3a66}.lock-btn-unlocked:hover{background:#e8f5ec;border-color:#2d6b3a}.zoom-btn{width:34px;height:34px;border:1.5px solid rgba(200,150,54,.4);border-radius:8px;background:#fff;color:#8b4a1a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.zoom-btn:hover{background:#fdf5e8;border-color:#c89636}.header{position:fixed;top:0;left:0;right:0;height:52px;background:#fffcf8f7;border-bottom:1px solid rgba(224,207,168,.53);display:flex;align-items:center;padding:0 18px;gap:14px;z-index:300;direction:rtl;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-actions{display:flex;gap:8px;align-items:center;order:3}.header-title-group{display:flex;align-items:center;gap:14px;order:1}.header-basmala{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:Cairo,Amiri,serif;font-size:22px;color:#8b4a1a;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;text-shadow:0 1px 0 rgba(255,255,255,.6)}.header>.header-actions{margin-right:auto}.search-wrap{position:relative;flex:0 0 280px}.search-input{width:100%;padding:7px 14px;border:1.5px solid #a07428;border-radius:9px;font-family:Cairo,sans-serif;font-size:14px;background:#fff;color:#1a1a1a;outline:none;direction:rtl;transition:border-color .15s}.search-input:focus{border-color:#8b1a1a}.search-dropdown{position:absolute;top:calc(100% + 6px);right:0;left:0;background:#fff;border:1.5px solid rgba(160,116,40,.27);border-radius:10px;box-shadow:0 8px 24px #0000001a;z-index:999;overflow:hidden}.search-result{padding:10px 14px;cursor:pointer;direction:rtl;border-bottom:1px solid #f0ece4;transition:background .1s}.search-result:last-child{border-bottom:none}.search-result:hover{background:#fff8f0}.search-empty{padding:12px 14px;color:#999;font-size:14px;direction:rtl}.bottom-left-stack{position:fixed;bottom:20px;left:20px;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:10px}.minimap{background:#fffcf8f2;border:1.5px solid rgba(200,150,54,.27);border-radius:12px;padding:8px;box-shadow:0 4px 16px #00000014;transform-origin:bottom left;animation:bl-expand .2s cubic-bezier(.2,.8,.2,1)}.minimap-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;padding:0 2px}.minimap-label{font-size:11px;color:#b08040;font-family:Cairo,sans-serif}.minimap-close{background:none;border:none;cursor:pointer;color:#a07428;padding:2px 4px;border-radius:4px;display:inline-flex;align-items:center}.minimap-close:hover{background:#c8963626}.minimap-toggle,.stats-toggle{background:#fffcf8f2;border:1.5px solid rgba(200,150,54,.4);border-radius:9px;padding:7px 12px;font-family:Cairo,sans-serif;font-size:13px;color:#8b4a1a;cursor:pointer;display:inline-flex;align-items:center;gap:6px;box-shadow:0 4px 12px #0000000f;transition:background .15s,border-color .15s;animation:bl-fade .16s ease-out}@keyframes bl-expand{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bl-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.minimap-toggle:hover,.stats-toggle:hover{background:#fdf5e8;border-color:#c89636}.stats-panel{background:#fffcf8f2;border:1.5px solid rgba(200,150,54,.27);border-radius:12px;padding:10px 14px 8px;box-shadow:0 4px 16px #00000014;font-family:Cairo,sans-serif;direction:rtl;min-width:200px;transform-origin:bottom left;animation:bl-expand .2s cubic-bezier(.2,.8,.2,1)}.stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.stats-title{font-size:13px;font-weight:700;color:#8b4a1a}.stats-close{background:none;border:none;cursor:pointer;color:#a07428;padding:2px 4px;border-radius:4px;display:inline-flex;align-items:center}.stats-close:hover{background:#c8963626}.stats-row{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0;font-size:13px}.stats-row-label{color:#6a4a20}.stats-row-value{font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}.pw-inline{display:flex;gap:6px;align-items:center}.pw-inline input{flex:1;padding:8px 10px;border:1.5px solid #e0d0b8;border-radius:8px;font-size:14px;font-family:Cairo,sans-serif;outline:none;text-align:right;direction:rtl}.pw-inline input:focus{border-color:#8b1a1a}.pw-inline .err{color:#8b1a1a;font-size:12px;margin-top:4px}.toast{position:fixed;top:64px;left:50%;transform:translate(-50%);background:#1a1a1a;color:#fff;padding:8px 16px;border-radius:9px;font-size:14px;z-index:1000;font-family:Cairo,sans-serif}.loading-screen{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:Cairo,sans-serif;color:#8b4a1a;font-size:16px}.mobile-title{display:none}.header-title{font-size:20px;font-weight:700;color:#1a1a1a;white-space:nowrap}.zoom-pct{font-size:13px;color:#888;min-width:42px;text-align:center}.fit-btn{font-size:13px;padding:5px 12px;display:inline-flex;align-items:center;gap:6px}@media (max-width: 600px){.mobile-title{display:flex;align-items:center;justify-content:center;position:fixed;top:0;left:0;right:0;height:36px;background:#fffcf8f7;border-bottom:1px solid rgba(224,207,168,.53);font-family:Cairo,sans-serif;font-size:15px;font-weight:700;color:#1a1a1a;z-index:301;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header{top:36px;height:auto;min-height:52px;flex-wrap:wrap;padding:6px 10px;gap:4px 6px}.header-title{display:none}.header-title-group{flex:1 1 auto;gap:0;flex-direction:column;align-items:flex-start}.search-wrap{flex:1 1 100%;order:10;min-width:0}.lock-label,.fit-label,.zoom-pct{display:none}.zoom-btn{width:40px;height:40px}.fit-btn{width:40px;height:40px;padding:0;justify-content:center}.lock-btn{padding:8px 10px}.header-basmala{display:none}.canvas-wrap{top:88px}.bottom-left-stack{bottom:12px;left:10px;gap:8px}.minimap{padding:6px}.node-actions{flex-wrap:wrap;max-width:200px;top:-46px}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.drawer-right{width:100%;max-width:100%;border-radius:16px 16px 0 0;top:auto;bottom:0;max-height:80vh;overflow-y:auto;animation:slideUp .22s ease}.toast{top:100px}}@media (min-width: 601px) and (max-width: 1100px){.header-basmala,.lock-label,.fit-label{display:none}.fit-btn{width:38px;height:38px;padding:0;justify-content:center}.search-wrap{flex:0 0 200px}}
