.app-shell{height:100vh;display:grid;grid-template-columns:260px 1fr;background-color:var(--bg);overflow:hidden;padding:0;gap:0}.app-shell--mobile{grid-template-columns:1fr}.sidebar{width:260px;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 0;z-index:10}.sidebar__logos{display:flex;flex-direction:column;align-items:center;gap:12px;padding:0 20px;margin-bottom:24px}.sidebar__logo-main{width:80%;height:auto;object-fit:contain}.sidebar__logo-sub{width:50%;height:auto;object-fit:contain;opacity:.8}.sidebar__nav{display:flex;flex-direction:column;gap:4px;padding:0 12px}.sidebar__nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s ease;background:transparent;border:none;width:100%;text-align:left}.sidebar__nav-item:hover:not(.sidebar__nav-item--disabled){background-color:var(--bg);color:var(--primary)}.sidebar__nav-item--active{background-color:#7c5cfc14;color:var(--primary)}.sidebar__nav-item--disabled{opacity:.5;cursor:not-allowed}.sidebar__divider{height:1px;background:var(--border);margin:16px 12px;opacity:.6}.sidebar__section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:0 16px 8px}.main-area{min-width:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.topbar{height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:var(--card);border-bottom:1px solid var(--border);flex-shrink:0}@media(max-width:768px){.topbar{height:auto;flex-direction:column;padding:8px 16px;gap:12px;align-items:stretch}}.topbar__nav{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:12px;width:100%;max-width:1200px;margin:0 auto}@media(max-width:768px){.topbar__nav{overflow-x:auto;justify-content:flex-start;padding-bottom:4px;scrollbar-width:none}.topbar__nav::-webkit-scrollbar{display:none}}@media(min-width:640px){.topbar__nav{justify-content:flex-end}}.topbar__nav-link{text-decoration:none;display:inline-flex;align-items:center;border-radius:9999px;border:1px solid var(--border);background:var(--card);padding:8px 20px;font-size:13px;font-weight:600;color:var(--muted);box-shadow:0 1px 2px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1)}.topbar__nav-link:hover{color:var(--primary);background-color:var(--male-soft);border-color:#7c5cfc33;transform:translateY(-2px);box-shadow:0 4px 12px #7c5cfc26}.topbar__actions{display:flex;align-items:center;gap:8px}@media(max-width:768px){.topbar__actions{overflow-x:auto;justify-content:flex-start;padding-bottom:4px;scrollbar-width:none}.topbar__actions::-webkit-scrollbar{display:none}}.topbar__divider{width:1px;height:24px;background:var(--border);margin:0 8px}.topbar__button{border-radius:10px;border:1px solid var(--border);background:var(--card);padding:8px 14px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s ease}.topbar__button:hover{border-color:var(--primary);color:var(--primary)}.topbar__button--primary{background:var(--primary);border-color:var(--primary);color:#fff}.topbar__button--primary:hover{background:var(--primary-2);border-color:var(--primary-2);color:#fff}.topbar__button--danger{color:#ef4444}.topbar__button--danger:hover{background:#ef44440d;border-color:#ef4444}.topbar__file{display:none}.main-content{flex:1;min-height:0;padding:24px 32px;background-color:var(--bg);display:flex;flex-direction:column;overflow:auto}.app-shell--mobile .main-content{padding:0}.mobile-view-container{height:100%;display:flex;flex-direction:column}.panel{flex:1;display:flex;flex-direction:column;min-height:0}.topbar__toggle{display:flex;gap:6px}.topbar__toggle .topbar__button{padding:8px 12px}.cards-view{display:flex;flex-direction:column;gap:32px}.mobile-shell{position:fixed;inset:0;display:flex;flex-direction:column;background-color:var(--card);overflow:hidden;z-index:100}.mobile-content{flex:1;position:relative;overflow:hidden}.mobile-scroll-area{position:absolute;inset:0;overflow-y:auto;padding-bottom:20px}.mobile-nav{height:64px;background:#fff;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:64px;background:none;border:none;cursor:pointer;transition:colors .2s}.mobile-nav-item--active .mobile-nav-icon,.mobile-nav-item--active .mobile-nav-label{color:var(--primary)}.mobile-nav-icon{width:24px;height:24px;color:var(--muted)}.mobile-nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.fab{position:fixed;bottom:100px;right:24px;width:64px;height:64px;border-radius:9999px;background-color:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;border:none;box-shadow:0 8px 24px #7c5cfc66;z-index:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;touch-action:manipulation}.fab:active{transform:scale(.85);box-shadow:0 4px 12px #7c5cfc4d}.fab-icon{width:32px;height:32px;pointer-events:none}.cards-section__header{display:flex;align-items:center;justify-content:space-between;gap:16px}.cards-actions{display:flex;gap:8px;flex-wrap:wrap}.cards-section__title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.cards-card .ui-card__content{display:flex;flex-direction:column;gap:12px}.sex-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;background:#f4f2ff;padding:6px;border-radius:14px}.sex-toggle__option{border:1px solid transparent;border-radius:12px;padding:10px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;background:transparent;color:var(--muted)}.sex-toggle__option--male.sex-toggle__option--active{background:var(--male-soft);color:#3b2d7a;border-color:#8f7cf84d;box-shadow:0 8px 16px #8f7cf833}.sex-toggle__option--female.sex-toggle__option--active{background:var(--female-soft);color:#4a2466;border-color:#a56dff4d;box-shadow:0 8px 16px #a56dff33}.sex-toggle__option:hover{color:var(--text);border-color:#7c5cfc33}.cards-empty{padding:16px;border-radius:12px;background:#7c5cfc0d;border:1px dashed var(--border);color:var(--muted);font-size:14px}.cards-alert{border-radius:16px;border:1px solid rgba(239,68,68,.25);background:#ef44440f;padding:16px 18px;color:#b91c1c;display:flex;flex-direction:column;gap:8px}.cards-alert__title{font-weight:700;font-size:14px}.cards-alert__list{margin:0;padding-left:18px;font-size:13px;line-height:1.5}.legend{margin-top:auto;padding:20px 24px;display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--border)}.legend__title{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}.legend__items{display:flex;flex-direction:column;gap:10px}.legend__item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text)}.legend__item--muted{color:var(--muted)}.tree{display:flex;flex-direction:column;min-height:0;gap:12px}.tree__header{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.tree__stage{flex:1;border-radius:16px;background:#f6f7fb;min-height:0;overflow:auto;position:relative;display:flex;align-items:center;justify-content:center;padding:24px}.tree__paper{width:1200px;height:900px;background:#fff;border-radius:16px;box-shadow:0 24px 60px #0f172a1f;position:relative;overflow:hidden}.tree__svg{width:100%;height:100%;display:block}.genogram__label{font-size:12px;fill:#111827;font-weight:600}.genogram__meta{font-size:11px;fill:#6b7280}@media(max-width:1023px){.genogram__label{font-size:9px}.genogram__meta{font-size:8px}}.genogram__section{font-size:12px;fill:#9ca3af;font-weight:700;letter-spacing:.1em}.sidebar__section{margin-top:28px;padding:0 20px;display:flex;flex-direction:column;gap:12px}.sidebar__section-title{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}.sidebar__section-empty{font-size:13px;line-height:1.4;color:var(--muted);padding:10px 12px;border-radius:10px;background:#7c5cfc0f;border:1px dashed var(--border)}.toolbox{display:flex;flex-direction:column;gap:12px}.toolbox__button{border-radius:12px;border:1px solid var(--border);background:var(--card);padding:12px 16px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s ease;text-align:left}.toolbox__button:hover{border-color:var(--primary);box-shadow:0 4px 12px #7c5cfc1a;transform:translateY(-1px)}.toolbox__button:active{transform:translateY(0)}.toolbox__button--active{border-color:var(--primary);background-color:#7c5cfc0a;color:var(--primary)}.toolbox__group{margin-top:8px;padding-top:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.toolbox__group-title{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.inspector{display:flex;flex-direction:column;gap:20px}.inspector__field{display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--text)}.inspector__label{font-weight:600}.inspector__input{border-radius:10px;border:1px solid var(--border);padding:10px 12px;font-size:14px;background:var(--card);color:var(--text)}.inspector__textarea{resize:vertical;min-height:100px}.inspector__toggle{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text);cursor:pointer}.inspector__toggle input{width:18px;height:18px;accent-color:var(--primary)}.inspector__danger{margin-top:8px;border-radius:10px;border:1px solid rgba(239,68,68,.2);background:#ef44440d;padding:10px 16px;font-size:13px;font-weight:600;color:#ef4444;cursor:pointer;transition:all .2s ease;text-align:center}.inspector__danger:hover{background:#ef44441a;border-color:#ef4444}.canvas{display:flex;flex-direction:column;min-height:0}.canvas__header{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px}.canvas__stage{flex:1;border-radius:16px;background:#f6f7fb;min-height:0;overflow:auto;position:relative;display:flex;align-items:center;justify-content:center;padding:24px}.canvas__paper{width:1100px;height:750px;background:#fff;border-radius:16px;box-shadow:0 24px 60px #0f172a1f;position:relative;overflow:hidden}@media(max-width:1400px){.app-shell{grid-template-columns:240px 1fr 320px}}@media(max-width:1100px){.sidebar{width:220px}.app-shell{grid-template-columns:1fr}.inspector-area{padding:0 24px 24px}}.sheet-overlay{position:fixed;inset:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.sheet-overlay--open{opacity:1;pointer-events:auto}.sheet-panel{position:fixed;bottom:0;left:0;right:0;max-height:90vh;background-color:#fff;border-radius:24px 24px 0 0;box-shadow:0 -10px 25px #0000001a;z-index:1001;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.sheet-panel--open{transform:translateY(0)}.sheet-handle{display:flex;justify-content:center;padding:12px;cursor:pointer}.sheet-handle-bar{width:48px;height:6px;background-color:var(--border);border-radius:9999px}.sheet-header{padding:0 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sheet-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.sheet-close{background:none;border:none;padding:8px;color:var(--muted);cursor:pointer}.sheet-icon{width:24px;height:24px}.sheet-body{flex:1;overflow-y:auto;padding:24px}.sheet-footer{padding:24px;border-top:1px solid var(--border);background-color:var(--male-soft)}.fab-actions-grid{display:grid;gap:12px}.fab-action-button{display:flex;align-items:center;gap:16px;width:100%;padding:16px;border-radius:16px;background-color:#fff;border:1px solid var(--border);transition:all .2s ease;cursor:pointer;text-align:left}.fab-action-button:active{background-color:var(--male-soft);border-color:var(--primary);transform:scale(.98)}.fab-action-button:disabled{opacity:.4;cursor:not-allowed;background-color:#f9f9f9}.fab-action-icon-wrapper{flex-shrink:0;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background-color:var(--primary);color:#fff;box-shadow:0 4px 8px #7c5cfc33}.fab-action-button:disabled .fab-action-icon-wrapper{background-color:#e0e0e0;color:#999;box-shadow:none}.fab-action-icon{width:20px;height:20px}.fab-action-label{font-size:16px;font-weight:600;color:var(--text-primary)}.fab-action-button:disabled .fab-action-label{color:#999}.about-view{background-color:#fff;min-height:100%;width:100%;overflow-y:auto}.about-container{max-width:900px;margin:0 auto;padding:48px 32px;display:flex;flex-direction:column;gap:40px}@media(max-width:768px){.about-container{padding:24px;gap:32px}}.about-header{display:flex;gap:40px;align-items:flex-start}@media(max-width:768px){.about-header{flex-direction:column;align-items:center;text-align:center;gap:24px}}.about-image-wrapper{flex-shrink:0;width:100%;max-width:320px}.about-image{width:100%;height:auto;aspect-ratio:3/4;object-fit:cover;border-radius:16px;box-shadow:0 12px 30px #00000014}.about-info{flex:1;display:flex;flex-direction:column;gap:16px}.about-title{font-size:24px;font-weight:600;color:#111;letter-spacing:-.025em;margin:0}@media(max-width:768px){.about-title{font-size:20px}}.about-subtitle{font-size:18px;line-height:1.5;color:var(--muted);margin:0}.about-section{display:flex;flex-direction:column;gap:12px}.about-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary)}.about-text{font-size:16px;line-height:1.7;color:#333;margin:0;white-space:pre-wrap}.about-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px}@media(max-width:768px){.about-links{flex-direction:column}}.about-link-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:1px solid #ddd;border-radius:12px;font-size:14px;font-weight:600;color:#111;text-decoration:none;background-color:#fff;transition:all .2s ease}.about-link-button:hover{background-color:#f8f8f8;border-color:#bbb;transform:translateY(-1px)}.about-link-button:active{transform:translateY(0)}:root{--bg: #f6f7fb;--card: #ffffff;--border: #e5e9f2;--text: #2c3140;--muted: #7b8396;--primary: #7c5cfc;--primary-2: #5836e2;--shadow: 0 12px 28px rgba(124, 92, 252, .12);--radius: 16px;--focus-ring: 0 0 0 3px rgba(124, 92, 252, .2);--male-soft: #efe9ff;--female-soft: #f5eaff;--male-accent: #8f7cf8;--female-accent: #a56dff}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .2s ease;white-space:nowrap;gap:8px}.btn--full-width{width:100%}.btn--primary{background-color:var(--primary);color:#fff}.btn--primary:hover{background-color:var(--primary-2);transform:translateY(-1px);box-shadow:0 4px 12px #7c5cfc33}.btn--secondary{background-color:#7c5cfc0d;border-color:#7c5cfc1a;color:var(--primary)}.btn--secondary:hover{background-color:#7c5cfc1a;border-color:var(--primary)}.btn--ghost{background:transparent;color:var(--muted)}.btn--ghost:hover{background-color:var(--bg);color:var(--text)}.btn--danger{color:#ef4444;background:#ef44440d;border-color:#ef44441a}.btn--danger:hover{background-color:#ef4444;color:#fff;border-color:#ef4444}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.ui-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.ui-card__header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.ui-card__title{margin:0;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.ui-card__subtitle{margin:0;font-size:13px;color:var(--muted);font-weight:400}.ui-card__content{padding:24px;flex:1}.ui-field{display:flex;flex-direction:column;gap:8px;width:100%}.ui-field__label{font-size:12px;font-weight:600;color:var(--muted)}.react-flow__controls{box-shadow:var(--shadow)!important;border-radius:8px!important;overflow:hidden;border:1px solid var(--border)!important}.react-flow__controls-button{background:#fff!important;border-bottom:1px solid var(--border)!important;width:28px!important;height:28px!important;display:flex!important;align-items:center!important;justify-content:center!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__controls-button svg{max-width:14px!important;max-height:14px!important;fill:var(--text)!important}.react-flow__controls-button:hover{background:var(--bg)!important}.ui-input,.ui-select{width:100%;border-radius:12px;border:1px solid var(--border);padding:10px 14px;font-size:14px;background:var(--card);color:var(--text);transition:all .2s ease}.ui-input:focus,.ui-select:focus{outline:none;border-color:var(--primary);box-shadow:var(--focus-ring)}.ui-textarea{resize:vertical;min-height:100px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--muted);background:#7c5cfc05;border:1px dashed var(--border);border-radius:12px;height:100%}.empty-state__icon{margin-bottom:16px;color:var(--primary);opacity:.5}.empty-state__text{font-size:14px;font-weight:500;line-height:1.5}:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background-color:var(--bg)}*{box-sizing:border-box}body{margin:0;background:var(--bg)}#root{height:100vh}button,input,textarea,select{font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}button:focus-visible,input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:var(--focus-ring)}
