*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff;color:#2c3e50}#app{width:100%;min-height:100vh}.toast[data-v-e2ccbdb0]{display:flex;align-items:center;gap:.75rem;min-width:300px;max-width:500px;padding:1rem 1.25rem;margin-bottom:.5rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;opacity:0;transform:translateY(-20px);transition:all .3s ease}.toast-visible[data-v-e2ccbdb0]{opacity:1;transform:translateY(0)}.toast-icon[data-v-e2ccbdb0]{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1rem;font-weight:700}.toast-message[data-v-e2ccbdb0]{flex:1;color:#2c3e50;font-size:.95rem;line-height:1.4}.toast-close[data-v-e2ccbdb0]{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:1.5rem;color:#95a5a6;cursor:pointer;transition:color .2s}.toast-close[data-v-e2ccbdb0]:hover{color:#2c3e50}.toast-success[data-v-e2ccbdb0]{border-left:4px solid #27ae60}.toast-success .toast-icon[data-v-e2ccbdb0]{background-color:#d4edda;color:#27ae60}.toast-error[data-v-e2ccbdb0]{border-left:4px solid #e74c3c}.toast-error .toast-icon[data-v-e2ccbdb0]{background-color:#f8d7da;color:#e74c3c}.toast-warning[data-v-e2ccbdb0]{border-left:4px solid #f39c12}.toast-warning .toast-icon[data-v-e2ccbdb0]{background-color:#fff3cd;color:#f39c12}.toast-info[data-v-e2ccbdb0]{border-left:4px solid #3498db}.toast-info .toast-icon[data-v-e2ccbdb0]{background-color:#d1ecf1;color:#3498db}.toast-container[data-v-ed449975]{position:fixed;top:1rem;right:1rem;z-index:9999;pointer-events:none}.toast-container[data-v-ed449975]>*{pointer-events:auto}@media(max-width:768px){.toast-container[data-v-ed449975]{left:1rem;right:1rem}}#app[data-v-33939e98]{width:100%;min-height:100vh}.graph-visualization[data-v-2ffab203]{display:flex;flex-direction:column;align-items:center;width:100%}.graph-container-wrapper[data-v-2ffab203]{position:relative;width:100%;max-width:800px;margin-bottom:1.5rem}.graph-container[data-v-2ffab203]{width:100%;height:600px;border:2px solid #e0e0e0;border-radius:8px;background-color:#fafafa;display:flex;justify-content:center;align-items:center}.legend-overlay[data-v-2ffab203]{position:absolute;top:20px;right:20px;background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #00000026;border:1px solid #e0e0e0;z-index:10}.legend-title[data-v-2ffab203]{font-size:.9rem;font-weight:600;color:#2c3e50;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.legend-items[data-v-2ffab203]{display:flex;flex-direction:column;gap:.5rem}.legend-item[data-v-2ffab203]{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#555}.legend-line[data-v-2ffab203]{width:30px;height:3px;border-radius:2px}.friend-line[data-v-2ffab203]{background-color:#999}.couple-line[data-v-2ffab203]{background-color:#e74c3c}.fun-line[data-v-2ffab203]{background-color:#f39c12}@media(max-width:1024px){.graph-container-wrapper[data-v-2ffab203]{max-width:100%}.graph-container[data-v-2ffab203]{height:500px}.legend-overlay[data-v-2ffab203]{top:10px;right:10px;padding:.75rem}.legend-title[data-v-2ffab203]{font-size:.8rem;margin-bottom:.5rem}.legend-item[data-v-2ffab203]{font-size:.8rem}.legend-line[data-v-2ffab203]{width:25px}}@media(max-width:768px){.graph-container[data-v-2ffab203]{height:400px;border-radius:6px}.legend-overlay[data-v-2ffab203]{padding:.5rem}.legend-title[data-v-2ffab203]{font-size:.75rem;margin-bottom:.4rem}.legend-items[data-v-2ffab203]{gap:.4rem}.legend-item[data-v-2ffab203]{font-size:.75rem}.legend-line[data-v-2ffab203]{width:20px;height:2px}}.actions-menu[data-v-6bdb9fe5]{width:280px;padding:2rem;background-color:#f5f5f5;border-left:1px solid #e0e0e0}.sidebar-title[data-v-6bdb9fe5]{font-size:1.3rem;color:#2c3e50;margin-bottom:1.5rem;font-weight:600}.auth-required-message[data-v-6bdb9fe5]{background-color:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;padding:2rem 1.5rem;text-align:center}.message-icon[data-v-6bdb9fe5]{font-size:3rem;margin:0 0 1rem}.message-text[data-v-6bdb9fe5]{color:#7f8c8d;font-size:.95rem;line-height:1.5;margin:0}.action-button[data-v-6bdb9fe5]{width:100%;padding:1rem;background-color:#fff;color:#4a90e2;border:2px solid #4a90e2;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:left}.action-button[data-v-6bdb9fe5]:hover{background-color:#4a90e2;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #4a90e24d}.add-friend-card[data-v-6bdb9fe5]{background:#fff;padding:1.5rem;border-radius:8px;border:2px solid #4a90e2;animation:slideDown-6bdb9fe5 .2s ease-out}@keyframes slideDown-6bdb9fe5{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.add-friend-card h4[data-v-6bdb9fe5]{font-size:1.1rem;color:#2c3e50;margin-bottom:1rem;font-weight:600}.add-friend-card form[data-v-6bdb9fe5]{display:flex;flex-direction:column;gap:.75rem}.friend-input[data-v-6bdb9fe5]{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.friend-input[data-v-6bdb9fe5]:focus{outline:none;border-color:#4a90e2}.friend-input[data-v-6bdb9fe5]:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-actions[data-v-6bdb9fe5]{display:flex;gap:.5rem}.submit-button[data-v-6bdb9fe5]{flex:1;padding:.75rem;background-color:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s}.submit-button[data-v-6bdb9fe5]:hover:not(:disabled){background-color:#357abd}.submit-button[data-v-6bdb9fe5]:disabled{background-color:#95a5a6;cursor:not-allowed}.cancel-button[data-v-6bdb9fe5]{padding:.75rem 1rem;background-color:transparent;color:#7f8c8d;border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.cancel-button[data-v-6bdb9fe5]:hover:not(:disabled){border-color:#7f8c8d;color:#2c3e50}.cancel-button[data-v-6bdb9fe5]:disabled{cursor:not-allowed;opacity:.5}.action-section[data-v-6bdb9fe5]{margin-top:1rem}.add-relation-card[data-v-6bdb9fe5]{background:#fff;padding:1.5rem;border-radius:8px;border:2px solid #9b59b6;animation:slideDown-6bdb9fe5 .2s ease-out}.add-relation-card h4[data-v-6bdb9fe5]{font-size:1.1rem;color:#2c3e50;margin-bottom:1rem;font-weight:600}.instruction-text[data-v-6bdb9fe5]{color:#7f8c8d;font-size:.95rem;margin-bottom:1rem;line-height:1.5}.full-width[data-v-6bdb9fe5]{width:100%}.relationship-type-selector[data-v-6bdb9fe5]{margin-bottom:1rem;padding:.75rem;background-color:#f9f9f9;border-radius:6px}.type-label[data-v-6bdb9fe5]{display:block;font-size:.9rem;font-weight:600;color:#2c3e50;margin-bottom:.5rem}.radio-group[data-v-6bdb9fe5]{display:flex;gap:1rem}.radio-option[data-v-6bdb9fe5]{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.95rem;color:#555}.radio-option input[type=radio][data-v-6bdb9fe5]{cursor:pointer;width:16px;height:16px}.radio-option input[type=radio][data-v-6bdb9fe5]:disabled{cursor:not-allowed}.radio-option:has(input[type=radio]:checked) span[data-v-6bdb9fe5]{font-weight:600;color:#2c3e50}@media(max-width:1024px){.actions-menu[data-v-6bdb9fe5]{width:100%;border-left:none;border-top:1px solid #e0e0e0;padding:1.5rem}.sidebar-title[data-v-6bdb9fe5]{font-size:1.2rem}}@media(max-width:768px){.actions-menu[data-v-6bdb9fe5]{padding:1rem}.sidebar-title[data-v-6bdb9fe5]{font-size:1.1rem;margin-bottom:1rem}.action-button[data-v-6bdb9fe5]{padding:.875rem;font-size:.95rem}}.delete-action[data-v-6bdb9fe5]{border-color:#e74c3c;color:#e74c3c}.delete-action[data-v-6bdb9fe5]:hover{background-color:#e74c3c;color:#fff}.delete-friend-card[data-v-6bdb9fe5]{background:#fff;padding:1.5rem;border-radius:8px;border:2px solid #e74c3c;animation:slideDown-6bdb9fe5 .2s ease-out}.delete-friend-card h4[data-v-6bdb9fe5]{font-size:1.1rem;color:#2c3e50;margin-bottom:1rem;font-weight:600}.delete-friend-card form[data-v-6bdb9fe5]{display:flex;flex-direction:column;gap:.75rem}.friend-select[data-v-6bdb9fe5]{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s;background-color:#fff;cursor:pointer}.friend-select[data-v-6bdb9fe5]:focus{outline:none;border-color:#e74c3c}.friend-select[data-v-6bdb9fe5]:disabled{background-color:#f5f5f5;cursor:not-allowed}.delete-button[data-v-6bdb9fe5]{flex:1;padding:.75rem;background-color:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s}.delete-button[data-v-6bdb9fe5]:hover:not(:disabled){background-color:#c0392b}.delete-button[data-v-6bdb9fe5]:disabled{background-color:#95a5a6;cursor:not-allowed}.user-menu[data-v-ef285cc5]{width:280px;background-color:#fff;border-left:2px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}.menu-header[data-v-ef285cc5]{padding:1.5rem;border-bottom:2px solid #e0e0e0;background-color:#f8f9fa}.menu-header h3[data-v-ef285cc5]{margin:0;font-size:1.25rem;color:#2c3e50;font-weight:600}.menu-content[data-v-ef285cc5]{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.auth-section[data-v-ef285cc5]{display:flex;flex-direction:column;gap:1rem}.user-info[data-v-ef285cc5]{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background-color:#f8f9fa;border-radius:8px}.user-icon[data-v-ef285cc5]{font-size:3rem}.user-status[data-v-ef285cc5]{margin:0;color:#27ae60;font-weight:500;font-size:.9rem}.admin-badge[data-v-ef285cc5]{margin:.25rem 0 0;color:#e67e22;font-weight:600;font-size:.85rem;background-color:#fef5e7;padding:.25rem .75rem;border-radius:12px;display:inline-block}.auth-message[data-v-ef285cc5]{text-align:center;color:#7f8c8d;font-size:.9rem;margin:0;padding:1rem;background-color:#f8f9fa;border-radius:8px}.menu-button[data-v-ef285cc5]{width:100%;padding:.75rem 1rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:center;text-decoration:none;display:block}.login-button[data-v-ef285cc5]{background-color:#4a90e2;color:#fff}.login-button[data-v-ef285cc5]:hover{background-color:#357abd}.register-button[data-v-ef285cc5]{background-color:#27ae60;color:#fff}.register-button[data-v-ef285cc5]:hover{background-color:#229954}.logout-button[data-v-ef285cc5]{background-color:#e74c3c;color:#fff}.logout-button[data-v-ef285cc5]:hover{background-color:#c0392b}.profile-button[data-v-ef285cc5]{background-color:#95a5a6;color:#fff}.profile-button[data-v-ef285cc5]:hover{background-color:#7f8c8d}.suggestions-button[data-v-ef285cc5]{background-color:#3498db;color:#fff}.suggestions-button[data-v-ef285cc5]:hover{background-color:#2980b9}.admin-button[data-v-ef285cc5]{background-color:#e67e22;color:#fff}.admin-button[data-v-ef285cc5]:hover{background-color:#d35400}.users-button[data-v-ef285cc5]{background-color:#9b59b6;color:#fff}.users-button[data-v-ef285cc5]:hover{background-color:#8e44ad}.friends-button[data-v-ef285cc5]{background-color:#e74c3c;color:#fff}.friends-button[data-v-ef285cc5]:hover{background-color:#c0392b}.feedback-button[data-v-ef285cc5]{background-color:#16a085;color:#fff}.feedback-button[data-v-ef285cc5]:hover{background-color:#138d75}@media(max-width:1024px){.user-menu[data-v-ef285cc5]{width:100%;border-left:none;border-top:2px solid #e0e0e0}.menu-header[data-v-ef285cc5],.menu-content[data-v-ef285cc5]{padding:1rem}}@media(max-width:768px){.menu-header h3[data-v-ef285cc5]{font-size:1.1rem}.menu-button[data-v-ef285cc5]{font-size:.9rem;padding:.65rem .85rem}}.modal-overlay[data-v-0e5e09b7]{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-container[data-v-0e5e09b7]{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header[data-v-0e5e09b7]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2[data-v-0e5e09b7]{margin:0;font-size:1.5rem;color:#2c3e50}.close-button[data-v-0e5e09b7]{background:none;border:none;font-size:1.5rem;color:#7f8c8d;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button[data-v-0e5e09b7]:hover:not(:disabled){background-color:#f5f5f5;color:#2c3e50}.close-button[data-v-0e5e09b7]:disabled{opacity:.5;cursor:not-allowed}.modal-body[data-v-0e5e09b7]{padding:1.5rem;overflow-y:auto}.modal-description[data-v-0e5e09b7]{margin:0 0 1.5rem;color:#7f8c8d;line-height:1.5}.feedback-textarea[data-v-0e5e09b7]{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .2s;min-height:120px}.feedback-textarea[data-v-0e5e09b7]:focus{outline:none;border-color:#4a90e2}.feedback-textarea[data-v-0e5e09b7]:disabled{background-color:#f5f5f5;cursor:not-allowed}.modal-actions[data-v-0e5e09b7]{display:flex;gap:.75rem;margin-top:1.5rem}.submit-button[data-v-0e5e09b7],.cancel-button[data-v-0e5e09b7]{flex:1;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.submit-button[data-v-0e5e09b7]{background-color:#4a90e2;color:#fff}.submit-button[data-v-0e5e09b7]:hover:not(:disabled){background-color:#357abd}.submit-button[data-v-0e5e09b7]:disabled{background-color:#b0b0b0;cursor:not-allowed}.cancel-button[data-v-0e5e09b7]{background-color:#f5f5f5;color:#2c3e50;border:2px solid #e0e0e0}.cancel-button[data-v-0e5e09b7]:hover:not(:disabled){background-color:#e0e0e0}.cancel-button[data-v-0e5e09b7]:disabled{opacity:.5;cursor:not-allowed}.modal-enter-active[data-v-0e5e09b7],.modal-leave-active[data-v-0e5e09b7]{transition:opacity .3s ease}.modal-enter-from[data-v-0e5e09b7],.modal-leave-to[data-v-0e5e09b7]{opacity:0}.modal-enter-active .modal-container[data-v-0e5e09b7],.modal-leave-active .modal-container[data-v-0e5e09b7]{transition:transform .3s ease}.modal-enter-from .modal-container[data-v-0e5e09b7],.modal-leave-to .modal-container[data-v-0e5e09b7]{transform:scale(.9)}@media(max-width:768px){.modal-container[data-v-0e5e09b7]{max-width:100%;margin:0 1rem}.modal-actions[data-v-0e5e09b7]{flex-direction:column}.submit-button[data-v-0e5e09b7],.cancel-button[data-v-0e5e09b7]{width:100%}}.home-page[data-v-dd70f80f]{display:flex;min-height:100vh}.main-content[data-v-dd70f80f]{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem}h1[data-v-dd70f80f]{font-size:2.5rem;color:#2c3e50;font-weight:600;margin-bottom:.5rem}.subtitle[data-v-dd70f80f]{font-size:1.1rem;color:#7f8c8d;margin-bottom:2rem}.status-message[data-v-dd70f80f]{text-align:center;padding:3rem;font-size:1.2rem;color:#7f8c8d}.status-message.error[data-v-dd70f80f]{color:#e74c3c}.retry-button[data-v-dd70f80f]{margin-top:1rem;padding:.75rem 1.5rem;background-color:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.retry-button[data-v-dd70f80f]:hover{background-color:#357abd}@media(max-width:1024px){.home-page[data-v-dd70f80f]{flex-direction:column}.main-content[data-v-dd70f80f]{padding:1.5rem 1rem;order:2}h1[data-v-dd70f80f]{font-size:2rem}.subtitle[data-v-dd70f80f]{font-size:1rem}}@media(max-width:768px){.main-content[data-v-dd70f80f]{padding:1rem}h1[data-v-dd70f80f]{font-size:1.75rem}.subtitle[data-v-dd70f80f]{font-size:.95rem}.status-message[data-v-dd70f80f]{padding:2rem 1rem;font-size:1rem}}.floating-feedback-button[data-v-dd70f80f]{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;border-radius:50%;background-color:#4a90e2;color:#fff;border:none;font-size:1.75rem;cursor:pointer;box-shadow:0 4px 12px #4a90e266;transition:all .3s ease;z-index:100;display:flex;align-items:center;justify-content:center}.floating-feedback-button[data-v-dd70f80f]:hover{transform:scale(1.1);background-color:#357abd;box-shadow:0 6px 20px #4a90e280}.floating-feedback-button[data-v-dd70f80f]:active{transform:scale(.95)}@media(max-width:768px){.floating-feedback-button[data-v-dd70f80f]{bottom:1rem;right:1rem;width:50px;height:50px;font-size:1.5rem}}
