:root{--frm-blue-950:#06122b;--frm-blue-900:#0b1f4d;--frm-blue-850:#102b63;--frm-blue-800:#12306f;--frm-blue-700:#1f55b5;--frm-blue-300:#9fc2ff;--frm-blue-150:#d9e8ff;--frm-white:#fff;--frm-text:#f7fbff;--frm-muted:#9fb5d8;--frm-border:#9fc2ff38;--frm-card:#0c224deb;--frm-card-hover:#102b63f5;--frm-shadow:0 12px 28px #00000047;--wolf-gray:#9a9a9a;--wolf-gray-soft:#9a9a9a73;--wolf-gray-faint:#9a9a9a38;--app-header-height:68px;--app-footer-height:64px;--app-shell-max-width:760px;--app-shell-padding:1rem;--app-shell-width:min(calc(100% - (var(--app-shell-padding) * 2)), var(--app-shell-max-width));color:var(--frm-text);background:radial-gradient(circle at top left, #4f8cff33, transparent 34rem), linear-gradient(180deg, var(--frm-blue-950), var(--frm-blue-900));font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font:16px/1.5 system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--frm-blue-950);min-height:100%}body{background:radial-gradient(circle at top left, #4f8cff33, transparent 34rem), linear-gradient(180deg, var(--frm-blue-950), var(--frm-blue-900));min-width:320px;min-height:100dvh;margin:0}button,input{font:inherit}#root{min-height:100dvh}.login-main{box-sizing:border-box;place-items:center;min-height:100dvh;padding:1rem;display:grid}.login-panel{border:1px solid var(--frm-border);background:var(--frm-card);width:min(100%,390px);box-shadow:var(--frm-shadow);border-radius:16px;padding:.75rem;overflow:hidden}.login-panel h1{color:var(--frm-white);text-align:center;margin:0 0 .85rem;font-size:1.3rem;line-height:1.15}.login-hero{aspect-ratio:16/23;border:1px solid var(--frm-border);background:var(--frm-blue-950);border-radius:12px;position:relative;overflow:hidden}.login-photo{object-fit:contain;object-position:center top;width:100%;height:100%;display:block}.login-form{background:linear-gradient(#0000,#06122beb 42%,#06122bfa);gap:.6rem;padding:3rem .85rem .85rem;display:grid;position:absolute;bottom:0;left:0;right:0}.login-field{gap:.45rem;display:grid}.login-field span{color:var(--frm-blue-150);font-size:.88rem;font-weight:700}.login-field input{box-sizing:border-box;border:1px solid var(--frm-border);height:42px;color:var(--frm-white);background:#ffffff1a;border-radius:10px;outline:none;padding:0 .75rem;font-size:1rem}.login-field input:disabled{opacity:1;cursor:not-allowed}.login-field input:focus-visible{outline:2px solid var(--frm-blue-300);outline-offset:2px}.login-error{color:var(--frm-white);margin:0;font-size:.9rem;font-weight:700}.login-button{height:42px;color:var(--frm-white);background:var(--frm-blue-700);cursor:pointer;border:1px solid #9fc2ff4d;border-radius:10px;font-size:1rem;font-weight:800}.login-button:disabled{cursor:not-allowed;opacity:.72}.login-button:focus-visible{outline:2px solid var(--frm-blue-300);outline-offset:2px}.login-status,.access-ready{color:var(--frm-white);text-align:center;gap:1rem;display:grid}.access-ready p{color:var(--frm-blue-150);margin:0}@media (width>=720px){.login-panel{width:min(100%,420px)}}.app-header{height:calc(var(--app-header-height) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);z-index:30;border-bottom:1px solid var(--frm-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#06122bf5;position:fixed;top:0;left:0;right:0}.app-brand{width:var(--app-shell-width);height:var(--app-header-height);align-items:center;gap:.75rem;margin:0 auto;display:flex}.app-logo{width:42px;height:42px;color:var(--frm-white);background:#ffffff14;border:2px solid #ffffffdb;border-radius:999px;flex:none;place-items:center;font-size:1.45rem;line-height:1;display:grid}.app-brand h1{min-width:0;color:var(--frm-white);letter-spacing:-.04em;margin:0;font-size:1.35rem;font-weight:850;line-height:1.05}.app-main{width:var(--app-shell-width);padding:calc(var(--app-header-height) + env(safe-area-inset-top) + 1rem) 0 calc(var(--app-footer-height) + env(safe-area-inset-bottom) + 1.2rem);margin:0 auto}.app-main-compact{--compact-shell-bottom-space:8rem;padding:calc(env(safe-area-inset-top,0px) + .85rem) 0 calc(env(safe-area-inset-bottom,0px) + var(--compact-shell-bottom-space));scroll-padding-bottom:calc(env(safe-area-inset-bottom,0px) + var(--compact-shell-bottom-space))}.compact-mode-label{color:var(--frm-muted);letter-spacing:0;margin:0 0 .55rem;font-size:.86rem;font-weight:750;line-height:1.2}.directory-count{color:var(--frm-muted);margin:0 0 .8rem;font-size:.92rem}.person-card{border:1px solid var(--frm-border);background:var(--frm-card);box-shadow:var(--frm-shadow);border-radius:18px;margin-bottom:.8rem;padding:1rem}.view-title{color:var(--frm-blue-150);margin:0 0 1.55rem;font-size:1.08rem;font-weight:650;line-height:1.2}.birthdays-view{max-width:760px;margin:0 auto}.birthday-group{gap:.72rem;display:grid}.birthday-month{color:var(--wolf-gray);margin:.15rem 0 .2rem;font-size:1.12rem;font-weight:800;line-height:1.2}.birthday-card{width:100%;color:inherit;background:var(--frm-card);box-shadow:var(--frm-shadow);text-align:left;cursor:pointer;border:1px solid #6495ed5c;border-radius:18px;gap:.52rem;margin:0 0 .95rem;padding:1.15rem 1.35rem;display:grid}.birthday-date-line{color:var(--frm-white);font-size:1.04rem;font-weight:850;line-height:1.25}.birthday-name{color:var(--frm-white);letter-spacing:-.025em;font-size:1.42rem;font-weight:900;line-height:1.1}.birthday-age{color:var(--wolf-gray);font-size:1.02rem;font-weight:800;line-height:1.15}.birthday-contact{color:var(--frm-blue-300);overflow-wrap:anywhere;font-size:1.08rem;line-height:1.25}.relationship-card{min-height:min(680px,100vh - 11rem);padding:1.35rem 1.45rem 1.55rem}.relationship-header{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:1rem;margin-bottom:2.1rem;display:grid}.relationship-title{color:var(--frm-white);letter-spacing:-.025em;font-size:1.75rem;font-weight:900;line-height:1.08}.relationship-map{grid-template-rows:auto auto auto;grid-template-columns:minmax(0,.92fr) minmax(0,1fr) minmax(0,.92fr);align-items:center;gap:1.25rem;display:grid}.relationship-group-card{min-width:0;color:var(--frm-white);background:#ffffff0d;border:1px solid #9fc2ff33;border-radius:14px;padding:1rem 1.1rem}.relationship-group-card h3{color:var(--wolf-gray);margin:0 0 .72rem;font-size:.98rem;font-weight:850;line-height:1.2}.relationship-parents{grid-area:2/1}.relationship-older{grid-area:1/2}.relationship-selected{text-align:center;grid-area:2/2}.relationship-children{grid-area:2/3}.relationship-younger{grid-area:3/2}.relationship-name-list{gap:.45rem;display:grid}.person-name-link{min-width:0;color:inherit;font:inherit;line-height:inherit;text-align:inherit;overflow-wrap:anywhere;cursor:pointer;background:0 0;border:0;padding:0}.person-name-link:hover{text-underline-offset:.18em;text-decoration:underline}.relationship-other-list{border-top:1px solid var(--wolf-gray-faint);margin-top:.85rem;padding-top:.72rem}.relationship-sub-label{color:var(--wolf-gray);font-size:.84rem;font-weight:750}.relationship-person-button,.relationship-selected-button{min-width:0;color:var(--frm-white);font:inherit;text-align:left;overflow-wrap:anywhere;cursor:pointer;background:0 0;border:0;padding:0;font-weight:850;line-height:1.2}.relationship-person-button:hover,.relationship-selected-button:hover{color:var(--frm-blue-150);text-underline-offset:.18em;text-decoration:underline}.relationship-selected-button{text-align:center;width:100%;font-size:1.22rem}.relationship-empty{color:var(--wolf-gray);margin:0;font-size:1rem;font-weight:650}.edit-card{overflow-wrap:anywhere}.add-card{width:100%;padding:1rem;position:relative}.person-edit-form{min-height:inherit;flex-direction:column;display:flex}.person-edit-header,.add-person-header{margin-bottom:.45rem}.add-person-header .person-name{margin-bottom:0;font-size:1.28rem}.person-card-header{grid-template-rows:auto auto;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:.75rem;display:grid}.person-summary{min-width:0;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-row:1/span 2;gap:.25rem;padding:0;display:grid}.person-name{color:var(--frm-white);letter-spacing:-.025em;margin-bottom:.3rem;font-size:1.22rem;font-weight:850;line-height:1.1}.person-line{color:var(--frm-blue-300);overflow-wrap:anywhere;font-size:1rem;line-height:1.25}.person-meta{color:var(--frm-blue-150);margin-top:.25rem;font-size:.95rem;font-weight:750}.card-icon-button{border:1px solid var(--wolf-gray-soft);width:36px;height:36px;color:var(--frm-white);cursor:pointer;background:#ffffff14;border-radius:999px;flex:none;place-items:center;font-size:1.2rem;font-weight:900;line-height:1;display:grid}.relationship-icon-button{color:var(--frm-white);grid-area:2/2;align-self:end}.detail-relationship-button{grid-area:auto;align-self:auto}.relationship-icon-button svg{fill:none;stroke:currentColor;stroke-width:1.9px;stroke-linecap:round;stroke-linejoin:round;width:1.25rem;height:1.25rem}.app-footer{height:calc(var(--app-footer-height) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);z-index:30;border-top:1px solid var(--frm-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#06122bfa;grid-template-columns:repeat(6,minmax(0,1fr));align-items:center;display:grid;position:fixed;bottom:0;left:0;right:0}.find-bar{right:auto;bottom:calc(var(--app-footer-height) + env(safe-area-inset-bottom) + .5rem);width:var(--app-shell-width);z-index:28;border:1px solid var(--frm-border);box-shadow:var(--frm-shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0c234efa;border-radius:18px;grid-template-columns:auto minmax(9rem,.7fr) minmax(0,1fr) 48px;align-items:center;gap:.65rem;padding:.85rem;display:grid;position:fixed;left:50%;transform:translate(-50%)}.find-label{color:var(--frm-white);font-size:1.08rem;font-weight:850}.find-select,.find-input{box-sizing:border-box;border:1px solid var(--frm-border);width:100%;min-width:0;height:42px;color:var(--frm-white);font:inherit;background:#ffffff1a;border-radius:12px;outline:none;padding:0 .85rem;font-size:1rem}.find-select option{color:var(--frm-white);background:var(--frm-blue-850)}.find-input::placeholder{color:var(--frm-muted);opacity:1}.find-submit{width:48px;height:42px;color:var(--frm-white);background:var(--frm-blue-700);cursor:pointer;border:1px solid #9fc2ff4d;border-radius:12px;place-items:center;font-size:1.35rem;font-weight:900;line-height:1;display:grid}.footer-icon{width:48px;height:48px;color:var(--frm-white);cursor:pointer;background:#ffffff14;border:0;border-radius:999px;justify-self:center;place-items:center;font-size:1.55rem;line-height:1;display:grid}.footer-icon svg{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;width:25px;height:25px}.footer-icon-disabled{cursor:default;opacity:1}.footer-icon-active{color:var(--frm-white);background:#2f69ca70;box-shadow:inset 0 0 0 1px #9fc2ff3d}.footer-icon-export{color:#141821eb}.footer-icon-logout{color:var(--wolf-gray)}.footer-icon:disabled{color:#ffffffc7}.person-summary:focus-visible,.person-name-link:focus-visible,.birthday-card:focus-visible,.relationship-person-button:focus-visible,.relationship-selected-button:focus-visible,.card-icon-button:focus-visible,.find-select:focus-visible,.find-input:focus-visible,.find-submit:focus-visible,.footer-icon:focus-visible{outline:2px solid var(--frm-blue-300);outline-offset:2px}.error{color:var(--frm-white);background:#b0002040;border:1px solid #ffa0a073;border-radius:12px;padding:1rem;font-weight:700}.directory-empty{color:var(--frm-muted);margin:0;font-size:1rem;font-weight:700}.edit-error{color:var(--frm-white);background:#b0002038;border:1px solid #ffa0a066;border-radius:10px;margin:.15rem 0 .7rem;padding:.55rem .65rem;font-size:.9rem;font-weight:700}.edit-notice{color:var(--frm-white);background:#2f69ca47;border:1px solid #9fc2ff52;border-radius:10px;margin:.15rem 0 .7rem;padding:.55rem .65rem;font-size:.9rem;font-weight:700}.edit-form-body{flex:auto;padding-top:.15rem}.edit-form-footer{justify-content:flex-end;gap:.45rem;padding-top:.7rem;display:flex}.edit-profile-section{border-top:1px solid var(--wolf-gray-faint);min-width:0;padding:.78rem 0}.edit-profile-section:first-child{border-top:0;padding-top:.35rem}.edit-contact-stack{gap:.55rem;display:grid}.edit-field-grid,.add-field-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem;display:grid}.add-name-grid .edit-field:last-child{grid-column:span 1}.add-two-field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;display:grid}.add-personal-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.add-contact-section{gap:.55rem;display:grid}.add-contact-row{grid-template-columns:1.65rem minmax(0,1fr);align-items:end;gap:.5rem;display:grid}.add-contact-indicator{border:1px solid var(--wolf-gray-soft);background:#ffffff0a;border-radius:999px;justify-self:center;width:1.05rem;height:1.05rem;margin-bottom:.78rem}.edit-field{gap:.28rem;min-width:0;display:grid}.edit-field-label{color:var(--frm-blue-150);font-size:.82rem;font-weight:600;line-height:1.15}.edit-field input,.edit-field select,.edit-field textarea{box-sizing:border-box;border:1px solid var(--frm-border);width:100%;min-width:0;max-width:100%;color:var(--frm-white);background:#ffffff1a;border-radius:9px;outline:none;font-size:.9rem}.edit-field input,.edit-field select{height:36px;padding:0 .55rem}.add-card .edit-field input,.add-card .edit-field select{border-radius:9px;height:36px;padding:0 .55rem;font-size:.9rem}.edit-field textarea{resize:vertical;min-height:72px;padding:.48rem .55rem;font-family:inherit;line-height:1.3}.edit-address-control{grid-template-columns:minmax(0,1fr) 36px;align-items:center;gap:.45rem;display:grid}.edit-address-add-button{width:36px;height:36px;color:var(--frm-white);border-color:var(--wolf-gray-soft);background:#ffffff14;font-size:1.2rem}.add-card .edit-field textarea{border-radius:9px;min-height:72px;font-size:.9rem}.add-tags-placeholder{gap:.4rem;display:grid}.add-tags-empty{border:1px dashed var(--wolf-gray-soft);min-height:42px;color:var(--frm-muted);background:#ffffff0d;border-radius:9px;align-items:center;padding:.65rem .7rem;font-size:.9rem;display:flex}.edit-field select option{color:var(--frm-white);background:var(--frm-blue-850)}.edit-field input:focus-visible,.edit-field select:focus-visible,.edit-field textarea:focus-visible{outline:2px solid var(--frm-blue-300);outline-offset:2px}.profile-save-button{color:var(--wolf-gray);border-color:var(--wolf-gray-soft);background:#ffffff14}.profile-save-button.is-dirty{color:var(--frm-white);background:var(--frm-blue-700);border-color:#9fc2ff4d}.profile-save-button:disabled{cursor:default;opacity:.74}.profile-save-button:disabled:not(.is-dirty){opacity:1}.add-form-footer{justify-content:flex-end;align-items:center;gap:.45rem}.add-person-submit.is-ready{color:var(--frm-white);background:var(--frm-blue-700);border-color:#9fc2ff4d}.add-person-submit:disabled{cursor:default;opacity:.74}.details-card{overflow-wrap:anywhere;max-height:calc(100vh - var(--app-header-height) - var(--app-footer-height) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 2.2rem);overflow-y:auto}.profile-header{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:.75rem;display:grid}.profile-actions{align-items:center;gap:.45rem;display:flex}.edit-person-button svg{fill:currentColor;width:1.15rem;height:1.15rem;display:block}.edit-person-button:disabled{cursor:default;opacity:1}.profile-name{color:var(--frm-white);letter-spacing:-.025em;font-size:1.65rem;font-weight:900;line-height:1.08}.profile-time{color:var(--wolf-gray);margin-top:.35rem;font-size:.98rem;font-weight:750}.profile-body{padding-top:1rem}.profile-divider{background:var(--wolf-gray-faint);width:95%;height:1px;margin:.95rem auto}.profile-contact{gap:.45rem;margin-bottom:1rem;display:grid}.profile-verified-line{align-items:center;gap:.65rem;min-width:0;display:flex}.verified-mark{width:1.05rem;height:1.05rem;color:var(--frm-blue-950);background:var(--frm-blue-150);border-radius:999px;flex:none;place-items:center;font-size:.74rem;font-weight:950;line-height:1;display:inline-grid}.address-verified-mark{width:.9rem;height:.9rem;font-size:.62rem}.profile-contact-line{width:fit-content;max-width:100%;color:var(--frm-white);overflow-wrap:anywhere;font-size:1.08rem;font-weight:500;line-height:1.25;text-decoration:none}.profile-contact-line:hover{color:var(--frm-white)}.profile-personal{color:var(--frm-white);margin:.9rem 0;font-size:.98rem;font-weight:500;line-height:1.35}.profile-addresses{gap:.75rem;margin:1rem 0;display:grid}.address-block{border-left:3px solid var(--wolf-gray-soft);color:var(--frm-white);padding:.1rem 0 .1rem .75rem;font-size:.98rem;font-weight:400;line-height:1.4}.address-label{color:var(--wolf-gray);align-items:center;gap:.4rem;margin-bottom:.18rem;font-size:.84rem;font-weight:600;display:flex}.profile-family{color:var(--frm-white);gap:.4rem;margin:1rem 0;font-size:.98rem;font-weight:400;line-height:1.4;display:grid}.family-line span{color:var(--wolf-gray);font-weight:600}.profile-notes{color:var(--frm-white);margin-top:1rem;font-size:.96rem;font-weight:400;line-height:1.45}@media (width<=520px){.app-main-compact{--compact-shell-bottom-space:11rem}.app-brand h1{font-size:1.08rem}.find-bar{grid-template-columns:auto minmax(0,1fr) 44px;gap:.55rem;padding:.7rem}.find-label{font-size:1rem}.find-select{min-width:0}.find-input{grid-column:1/span 2}.find-submit{width:44px}.relationship-card{min-height:0;padding:1rem}.relationship-header{margin-bottom:1rem}.relationship-title{font-size:1.4rem}.relationship-map{grid-template-columns:1fr;gap:.8rem}.relationship-selected,.relationship-parents,.relationship-older,.relationship-younger,.relationship-children{grid-area:auto/1}.relationship-selected{order:1}.relationship-parents{order:2}.relationship-older{order:3}.relationship-younger{order:4}.relationship-children{order:5}.add-card{padding:1rem}.edit-field-grid{grid-template-columns:1fr;gap:.55rem}.add-field-grid,.add-two-field-grid{grid-template-columns:1fr}.edit-profile-section{padding:.7rem 0}}
