.family-map-button{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background-color:var(--wp-admin-theme-color,#2271b1);color:#fff;text-decoration:none;border-radius:4px;cursor:pointer;transition:background-color 0.3s ease}.family-map-button svg,.family-map-button svg path,.family-map-button svg g{width:32px;height:32px;fill:#ffffff!important;stroke:#ffffff!important;stroke-width:2}.family-map-button:hover{background-color:var(--wp-admin-theme-color-darker-10,#135e96)}.family-map-modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:80vw;max-width:800px;max-height:80vh;background-color:#fff;z-index:1001;border-radius:8px;box-shadow:0 4px 20px rgb(0 0 0 / .2);overflow:hidden}.family-map-modal.active{display:block}.family-map-modal-content{position:relative;width:100%;padding-bottom:75%;height:0;overflow:hidden}.family-map-visualization{position:absolute;top:0;left:0;width:100%;height:100%;overflow:auto}.family-map-container{position:relative;width:100%;max-width:800px;height:600px;margin:0 auto;background:#f5f5f5;border-radius:4px;overflow:hidden}@media (max-width:800px){.family-map-container{height:75vw}}.family-map-controls{position:absolute;top:10px;right:10px;z-index:1000}.family-map-controls button{background:#fff;border:1px solid #ddd;border-radius:4px;padding:5px 10px;margin-left:5px;cursor:pointer}.family-map-controls button:hover{background:#f0f0f0}.family-map-content{position:relative;width:100%;height:100%}.family-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding:20px;transform-origin:top left;transition:transform 0.3s ease}.person{background:#fff0;border:none;padding:10px;text-align:center;min-width:150px;min-height:150px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;position:relative}.person img{width:80px;height:80px;object-fit:cover;border-radius:50%;margin-bottom:10px;border:2px solid #f0f0f0;box-shadow:0 2px 4px rgb(0 0 0 / .1)}.person .name-container{margin-bottom:8px;width:100%;text-align:center}.person .name{font-weight:700;margin-bottom:2px;font-size:.95em;color:#333}.person .first-surname{font-weight:500;margin-bottom:2px;font-size:.9em;color:#555}.person .second-surname{font-weight:500;font-size:.9em;color:#555}.person .dates-container{width:100%;text-align:center}.person .dates{font-size:.85em;color:#666;display:flex;flex-direction:column;gap:3px;width:100%}.person .dates .birth-date,.person .dates .death-date{display:flex;align-items:center;justify-content:center;gap:5px;line-height:1.2}.person .dates i{font-size:.9em;opacity:.7}.person .dates .birth-date i{color:#4CAF50}.person .dates .death-date i{color:#757575}.marriage{background:#f8f8f8;border:1px dashed #ddd;border-radius:4px;padding:5px;text-align:center}.parent-child{border:1px solid #ddd;border-radius:4px;padding:5px}.family-map-modal-close{position:absolute;top:10px;right:10px;width:30px;height:30px;background-color:rgb(0 0 0 / .5);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1002;font-size:18px;transition:background-color 0.3s}.family-map-modal-close:hover{background-color:rgb(0 0 0 / .7)}.family-map-modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgb(0 0 0 / .5);z-index:1000}.family-map-modal-overlay.active{display:block}.family-map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:1002}.family-map-loading::after{content:'';display:block;width:40px;height:40px;margin:10px auto;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.zoom-controls{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:1002}.zoom-button{width:40px;height:40px;background-color:rgb(255 255 255 / .8);border:1px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:background-color 0.3s}.zoom-button:hover{background-color:rgb(255 255 255)}@media (max-width:768px){.family-map-modal{width:95vw;max-height:90vh}.zoom-controls{bottom:10px;right:10px}.zoom-button{width:36px;height:36px;font-size:16px}}.family-map-json-url{background-color:#f8f9fa;padding:15px;margin-bottom:20px;border:1px solid #ddd;border-radius:4px}.family-map-json-url p{margin:0;word-break:break-all}.family-map-json-url a{color:#2271b1;text-decoration:none}.family-map-json-url a:hover{color:#135e96;text-decoration:underline}.family-map-modal .zoom-controls{position:fixed;top:20px;left:20px;z-index:1000000;background:#fff;padding:10px;border-radius:4px;box-shadow:0 2px 4px rgb(0 0 0 / .1)}.family-map-modal .zoom-controls button{padding:5px 10px;margin:0 5px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer}.family-map-modal .zoom-controls button:hover{background:#f0f0f0}.family-map-modal .zoom-container{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;background:#fff}.family-map-modal .container{position:absolute;top:0;left:0;width:100%;height:100%;display:grid;grid-template-columns:repeat(100,1fr);grid-template-rows:repeat(25,1fr);gap:10px;padding:20px;background:#fff;overflow:auto}.family-map-modal .family-grid{position:relative;width:100%;height:100%;display:grid;grid-template-columns:repeat(100,1fr);grid-template-rows:repeat(25,1fr);gap:10px;background:#fff}.family-map-modal .person{position:relative;background:#fff;border:1px solid #ddd;border-radius:4px;padding:10px;text-align:center;box-shadow:0 2px 4px rgb(0 0 0 / .1)}.family-map-modal .person img{width:100px;height:100px;border-radius:50%;object-fit:cover;margin-bottom:10px}.family-map-modal .person .name{font-weight:700;margin-bottom:5px}.family-map-modal .person .dates{font-size:.9em;color:#666}.family-map-modal .marriage{position:relative;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;padding:5px;text-align:center}.family-map-modal .marriage .dates{font-size:.9em;color:#666}.family-map-modal .parent-child{position:relative;border:1px solid #ddd;border-radius:4px}.json-content{margin:20px;padding:20px;background-color:#f8f9fa;border:1px solid #ddd;border-radius:4px;font-family:monospace;white-space:pre-wrap;word-wrap:break-word;max-height:calc(100vh - 200px);overflow:auto;font-size:14px;line-height:1.5;color:#333}