:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;color:#333;line-height:1.5;display:block!important;place-items:unset!important}#root{height:100%;width:100%}.app{min-height:100vh;background:#fff;display:flex;flex-direction:column}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.app-header h1{margin:0;font-size:1.5rem;font-weight:600;color:#333}.header-controls{display:flex;gap:1rem;align-items:center}.refresh-btn,.edit-sheet-btn{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#333;text-decoration:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.refresh-btn:hover,.edit-sheet-btn:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.refresh-btn:active,.edit-sheet-btn:active{transform:translateY(0)}.main-content{padding:0;width:100%;flex:1;overflow:hidden;min-height:0}.form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.form-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 10px 40px #0000001a;max-width:400px;width:90%;border:1px solid #f0f0f0}.family-member-form h3{margin-top:0;margin-bottom:1.5rem;color:#333;font-weight:600;font-size:1.1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555;font-size:.9rem}.form-group label .optional{font-weight:400;color:#999;font-size:.8rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #e0e0e0;border-radius:6px;background:#fff;font-size:.9rem;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .2s ease;resize:vertical}.form-group input:focus,.form-group textarea:focus{border-color:#666;background:#fff;outline:none;box-shadow:0 0 0 3px #6666661a}.about-textarea{min-height:100px}.form-buttons{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem}.save-btn{background-color:#333;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:500;font-size:.9rem;transition:background-color .2s ease}.save-btn:hover{background-color:#555}.cancel-btn{background-color:transparent;color:#666;border:1px solid #e0e0e0;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.cancel-btn:hover{background-color:#f5f5f5;border-color:#ccc}.node-based-tree{width:100%;height:100%;background:#fff;position:relative}.tree-svg{width:100%;height:100%;cursor:move}.empty-node-circle{fill:#f8f8f8;stroke:#ddd;stroke-width:2;stroke-dasharray:8,4;cursor:pointer;transition:all .2s ease}.empty-node-circle:hover{fill:#f0f0f0;stroke:#999}.empty-node-text{fill:#999;font-size:.8rem;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.node-circle{fill:#fff;stroke:#333;stroke-width:2;cursor:pointer;transition:all .2s ease}.node-circle:hover{fill:#f8f8f8;stroke:#555;stroke-width:2.5}.node-name{fill:#333;font-size:.85rem;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;text-anchor:middle;dominant-baseline:central}.edge-line{stroke:#ccc;stroke-width:1.5;cursor:pointer;transition:all .2s ease}.edge-line:hover{stroke:#666;stroke-width:2.5}.edge-endpoint{fill:#999;cursor:pointer;transition:all .2s ease}.edge-endpoint:hover{fill:#333}.hover-info-panel{position:absolute;top:20px;right:20px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 4px 12px #00000026;max-width:300px;z-index:100}.info-header h3{margin:0 0 1rem;color:#333;font-size:1.1rem;font-weight:600;border-bottom:1px solid #f0f0f0;padding-bottom:.5rem}.info-content{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;align-items:flex-start;gap:.5rem}.info-label{font-weight:500;color:#666;font-size:.85rem;min-width:70px;flex-shrink:0}.info-value{color:#333;font-size:.85rem;line-height:1.4}.info-about{display:flex;flex-direction:column;gap:.5rem}.about-text{margin:0;color:#333;font-size:.85rem;line-height:1.4;background:#f8f8f8;padding:.75rem;border-radius:4px;border-left:3px solid #ddd}.info-metadata{margin-top:1rem;padding-top:.75rem;border-top:1px solid #f0f0f0}.info-metadata .info-label{color:#999;font-size:.75rem}.info-metadata .info-value{color:#666;font-size:.75rem}.connection-line{stroke:#ddd;stroke-width:1}.connection-line:hover{stroke:#999}.dev-indicator{position:fixed;bottom:10px;right:10px;background:#000000b3;color:#fff;padding:.5rem .75rem;border-radius:4px;font-size:.75rem;z-index:1000}.auth-container{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:#fff;padding:2rem;position:fixed;top:0;left:0;right:0;bottom:0}.auth-signin{text-align:center;max-width:400px;width:100%;display:flex;flex-direction:column;align-items:center}.auth-signin h1{margin:0 0 1rem;color:#333;font-size:2rem;font-weight:600}.auth-signin p{margin:0 0 2rem;color:#666;font-size:1rem;line-height:1.5}.google-signin-button{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:6px;background:#4285f4;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;min-width:200px;margin:1.5rem 0}.google-signin-button:hover{background:#3367d6;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.google-signin-button:active{transform:translateY(0);background:#2d5aa0}.auth-note{margin-top:2rem;color:#999;font-size:.8rem}#g_id_signin{display:flex;justify-content:center;margin:1.5rem 0;width:100%}.auth-loading,.auth-error{text-align:center;max-width:400px;width:100%}.auth-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1.5rem}.auth-error h2{margin:0 0 1rem;color:#dc2626;font-size:1.2rem;font-weight:600}.auth-error p{margin:0 0 1rem;color:#b91c1c;font-size:.9rem}.auth-help{background:#f3f4f6;border-radius:4px;padding:.75rem;font-size:.8rem;color:#374151;font-family:monospace}.auth-user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:32px;height:32px;border-radius:50%;border:2px solid #e5e7eb}.user-name{color:#333;font-weight:500;font-size:.9rem}.signout-button{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#666;font-size:.8rem;cursor:pointer;transition:all .2s ease}.signout-button:hover{background:#f9fafb;border-color:#d1d5db;color:#333}.sheet-error-container{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem}.sheet-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:2rem;max-width:500px;text-align:center}.sheet-error h2{margin:0 0 1rem;color:#dc2626;font-size:1.2rem;font-weight:600}.sheet-error p{margin:0 0 1.5rem;color:#b91c1c;font-size:.9rem;line-height:1.5}.error-actions{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap}@media (max-width: 768px){.app-header{padding:1rem;flex-direction:column;gap:1rem;align-items:center}.app-header h1{font-size:1.25rem;text-align:center}.header-controls{justify-content:center;flex-wrap:wrap;gap:.75rem}.refresh-btn,.edit-sheet-btn{font-size:.8rem;padding:.4rem .8rem}.form-container{width:95%;padding:1.5rem}.tree-svg{cursor:default;touch-action:manipulation}.node-circle{stroke-width:3}.node-circle:hover{stroke-width:4}.node-name{font-size:.9rem;font-weight:600}.dev-indicator{bottom:5px;right:5px;font-size:.7rem;padding:.4rem .6rem}.auth-container{padding:1rem}.auth-signin{max-width:350px;padding:0 1rem}.auth-signin h1{font-size:1.75rem;margin-bottom:1.5rem}.auth-signin p{font-size:.95rem;margin-bottom:2.5rem}#g_id_signin{margin:2rem 0}.google-signin-button{width:100%;max-width:280px}.auth-user-info{flex-direction:column;gap:.75rem;align-items:center}.user-name{font-size:.85rem;text-align:center}.signout-button{font-size:.75rem;padding:.4rem .8rem}.hover-info-panel{position:fixed;top:auto;bottom:20px;right:10px;left:10px;max-width:none;margin:0 auto;max-height:40vh;overflow-y:auto}.sheet-error{padding:1.5rem;margin:0 1rem}.error-actions{flex-direction:column;gap:.75rem}}@media (max-width: 480px){.app-header{padding:.75rem}.app-header h1{font-size:1.1rem}.auth-signin h1{font-size:1.5rem}.auth-signin{max-width:300px}.refresh-btn,.edit-sheet-btn{font-size:.75rem;padding:.35rem .7rem}}
