:root{--bg:#f4f1ea;--paper:#fff;--ink:#111;--muted:#666;--soft:#eee;--grid:#00000038;--line:#111;--mark:#fff2b8;--overlay:#00000057;--shadow:#0000001f}:root[data-theme=dark]{--bg:#151515;--paper:#202020;--ink:#f4f4f4;--muted:#aaa;--soft:#303030;--grid:#fff3;--line:#f3f3f3;--mark:#5b4d1a;--overlay:#000a;--shadow:#0006}html,body,#root{width:100%;height:100%;margin:0;padding:0}#root{max-width:none;text-align:initial}*{box-sizing:border-box}body{background:var(--bg);color:var(--ink);-webkit-user-select:none;user-select:none;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}input,textarea,select{-webkit-user-select:text;user-select:text}button{background:var(--ink);color:var(--paper);cursor:pointer;border:0;border-radius:999px;padding:10px 16px;font-weight:800}button:hover{transform:translateY(-1px)}a{color:inherit}.app{grid-template-rows:auto 1fr;grid-template-columns:310px minmax(0,1fr) 310px;width:100vw;height:100vh;display:grid;overflow:hidden}.toolbar{background:color-mix(in srgb,var(--paper) 88%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid color-mix(in srgb,var(--ink) 8%,transparent);z-index:10;grid-column:1/-1;justify-content:space-between;align-items:center;gap:20px;padding:14px 18px;display:flex}.brand{align-items:center;gap:18px;min-width:0;display:flex}.toolbar h1{white-space:nowrap;color:var(--ink);margin:0;font-size:22px}.network-tabs{gap:8px;max-width:42vw;padding:2px;display:flex;overflow-x:auto}.network-tab{background:var(--soft);color:var(--ink);white-space:nowrap;padding:8px 12px;font-size:13px}.network-tab.active{background:var(--ink);color:var(--paper)}.toolbar-actions{white-space:nowrap;align-items:center;gap:10px;display:flex}.icon-button{place-items:center;width:42px;height:42px;padding:0;font-size:28px;line-height:1;display:grid}.icon-button.small{width:34px;height:34px;font-size:24px}.secondary-button{background:var(--soft);color:var(--ink)}.profile-panel,.legend-panel{background:var(--paper);z-index:5;min-height:0;padding:20px;overflow-y:auto}.profile-panel{border-right:1px solid color-mix(in srgb,var(--ink) 8%,transparent)}.legend-panel{border-left:1px solid color-mix(in srgb,var(--ink) 8%,transparent)}h1,h2,h3{color:var(--ink)}.profile-panel h2,.legend-panel h2{margin:0 0 14px;font-size:22px}.profile-panel h3,.legend-panel h3{margin:24px 0 10px}.profile-panel p,.legend-panel p{color:var(--muted);line-height:1.45}.profile{border-bottom:1px solid var(--soft);padding-bottom:18px}.empty-profile{color:var(--muted)}.profile label,.auth-modal label{color:var(--ink);margin:12px 0;font-size:13px;font-weight:800;display:block}.profile input,.profile textarea,.profile select,.auth-modal input,.direction-select select,.date-grid input,.date-grid select{border:1px solid color-mix(in srgb,var(--ink) 15%,transparent);background:color-mix(in srgb,var(--paper) 90%,var(--soft));width:100%;color:var(--ink);border-radius:14px;outline:none;margin-top:6px;padding:10px 12px;display:block}.profile input:focus,.profile textarea:focus,.profile select:focus,.auth-modal input:focus{border-color:var(--ink);background:var(--paper)}.profile textarea{resize:vertical;min-height:90px}.danger{background:var(--ink);width:100%;margin-top:10px}.marked-box,.history-box{border-bottom:1px solid var(--soft);padding:14px 0 18px}.marked-box p{margin-top:0}.history-controls{gap:8px;display:grid}.history-controls select,.history-controls input{border:1px solid color-mix(in srgb,var(--ink) 15%,transparent);background:var(--paper);color:var(--ink);border-radius:14px;padding:9px}.checkbox-label{color:var(--ink);align-items:center;gap:8px;font-size:13px;display:flex}.history-list{max-height:210px;overflow:auto}.history-list p{background:var(--soft);border-radius:12px;padding:8px;font-size:13px}.network-info{padding-top:14px}.network-info p{color:var(--ink);margin:4px 0 10px;font-weight:800}.network-info span{color:var(--muted);margin:4px 0;font-size:14px;display:block}.reset-data-button{background:var(--soft);width:100%;color:var(--ink);margin-top:14px;font-size:13px}.canvas{touch-action:none;cursor:grab;background:radial-gradient(circle,var(--grid) 1.3px,transparent 1.6px) 0 0/42px 42px,var(--bg);min-width:0;min-height:0;position:relative;overflow:hidden}.canvas.panning{cursor:grabbing}.map-world{transform-origin:0 0;z-index:1;position:absolute;inset:0}.axis-controls{z-index:6;background:color-mix(in srgb,var(--paper) 88%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 8px 24px var(--shadow);border-radius:18px;align-items:end;gap:10px;padding:12px;display:flex;position:absolute;top:14px;left:14px;right:14px}.axis-controls label{color:var(--ink);gap:5px;font-size:12px;font-weight:900;display:grid}.axis-controls select{border:1px solid color-mix(in srgb,var(--ink) 15%,transparent);background:var(--paper);min-width:150px;color:var(--ink);border-radius:999px;outline:none;padding:9px 12px}.axis-controls button{padding:9px 16px}.zoom-label{color:var(--ink);white-space:nowrap;padding:0 6px;font-size:13px;font-weight:900}.fixed-axis-layer{z-index:3;pointer-events:none;position:absolute;inset:0}.fixed-x-axis{background:color-mix(in srgb,var(--ink) 28%,transparent);height:2px;position:absolute;bottom:48px;left:70px;right:70px}.fixed-y-axis{background:color-mix(in srgb,var(--ink) 28%,transparent);width:2px;position:absolute;top:110px;bottom:85px;left:42px}.fixed-x-axis span,.fixed-y-axis span{color:color-mix(in srgb,var(--ink) 72%,transparent);white-space:nowrap;font-size:12px;font-weight:950;position:absolute}.fixed-x-axis span{bottom:18px;left:50%;transform:translate(-50%)}.fixed-y-axis span{transform-origin:0;top:50%;left:-18px;transform:rotate(-90deg)translate(50%)}.fixed-x-axis b,.fixed-y-axis b{color:var(--muted);white-space:nowrap;font-size:11px;font-weight:850;position:absolute}.fixed-x-axis b{top:11px;transform:translate(-50%)}.fixed-y-axis b{left:12px;transform:translateY(-50%)}.relations{z-index:1;pointer-events:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.relation-line{stroke:var(--line);stroke-width:5px;stroke-linecap:round;fill:none;pointer-events:none}.relation-line.past{opacity:.25;stroke-width:3px;stroke-dasharray:10 8}.relation-hitbox{stroke:#0000;stroke-width:28px;stroke-linecap:round;fill:none;pointer-events:stroke;cursor:pointer}.relationship-symbol{pointer-events:none}.relationship-symbol line,.relationship-symbol path,.relationship-symbol circle{stroke:var(--line);stroke-width:6px;stroke-linecap:round;stroke-linejoin:round;fill:none}.interest-symbol path,.conflict-symbol path{fill:var(--line);stroke:var(--line)}.family-symbol circle,.romantic-symbol path,.business-symbol path{stroke-width:5px}.friendship-symbol line{stroke-width:7px}.person{z-index:3;background:var(--paper);border:2px solid var(--ink);min-width:110px;box-shadow:0 10px 25px var(--shadow);cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;text-align:center;color:var(--ink);border-radius:20px;padding:13px 15px;position:absolute;transform:translate(-50%,-50%)}.person *{-webkit-user-select:none;user-select:none}.person:active{cursor:grabbing}.person strong{font-size:17px;display:block}.person.selected{outline:5px solid color-mix(in srgb,var(--ink) 18%,transparent)}.person.marked,.person.connect-start{background:var(--mark);border-width:3px}.dimmed{opacity:.18}.legend{margin:0;padding:0;list-style:none}.legend li{border-bottom:1px solid var(--soft)}.legend-button{width:100%;color:var(--ink);text-align:left;background:0 0;border-radius:0;align-items:center;gap:14px;padding:13px 0;font-weight:600;display:flex}.legend-button:hover{background:var(--soft);transform:none}.legend-button.active-filter{background:var(--ink);color:var(--paper);padding-left:10px}.legend-symbol{width:46px;height:28px;color:var(--ink);place-items:center;display:inline-grid;position:relative}.legend-symbol:before,.legend-symbol:after{content:"";position:absolute}.legend-knows:before{background:currentColor;border-radius:999px;width:28px;height:5px}.legend-friend:before,.legend-good_friend:before,.legend-best_friend:before{background:currentColor;border-radius:999px;width:5px;height:24px}.legend-good_friend:after{background:currentColor;border-radius:999px;width:5px;height:24px;transform:translate(8px);box-shadow:-16px 0}.legend-best_friend:after{background:currentColor;border-radius:999px;width:5px;height:24px;transform:translate(9px);box-shadow:-9px 0,-18px 0}.legend-family:before{border:4px solid;border-radius:50%;width:20px;height:20px}.legend-romantic:before{content:"∞";font-size:34px;font-weight:950;line-height:1}.legend-sexual:before{border-top:5px solid;border-left:5px solid;width:22px;height:22px;transform:rotate(45deg)}.legend-interest:before{background:currentColor;border-radius:999px;width:26px;height:5px}.legend-interest:after{border-top:5px solid;border-right:5px solid;width:13px;height:13px;right:7px;transform:rotate(45deg)}.legend-business:before{content:"∿";font-size:36px;font-weight:900;line-height:1}.legend-conflict:before{content:"ϟ";font-size:32px;font-weight:950;line-height:1}.active-filter-box{background:var(--ink);color:var(--paper);border-radius:16px;gap:10px;margin-top:16px;padding:12px;font-weight:800;display:grid}.active-filter-box button{background:var(--paper);color:var(--ink);width:100%;padding:8px 12px}.legend-help{border-top:1px solid var(--soft);margin-top:20px;padding-top:14px;font-size:14px}.modal-backdrop{z-index:100;background:var(--overlay);place-items:center;padding:24px;display:grid;position:fixed;inset:0}.person-modal,.relation-modal,.auth-modal{background:var(--paper);width:min(540px,100%);max-height:min(720px,90vh);color:var(--ink);box-shadow:0 24px 80px var(--shadow);border-radius:26px;padding:20px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.modal-header h2{color:var(--ink);margin:0}.person-search{border:1px solid color-mix(in srgb,var(--ink) 15%,transparent);width:100%;color:var(--ink);background:var(--paper);border-radius:18px;outline:none;margin:18px 0 12px;padding:13px 14px}.suggestion-list{gap:8px;display:grid}.suggestion-title{color:var(--ink);margin:4px 0;font-size:13px;font-weight:900}.suggestion-item{background:var(--soft);width:100%;color:var(--ink);text-align:left;border-radius:16px;gap:3px;padding:12px 14px;display:grid}.suggestion-item:hover{background:color-mix(in srgb,var(--soft) 70%,var(--ink) 12%);transform:none}.suggestion-item span{color:var(--muted);font-size:13px;font-weight:500}.create-person-button{border-radius:16px;width:100%;margin-top:8px;padding:13px 14px}.relation-modal-subtitle{color:var(--muted);margin:8px 0 18px;font-weight:700}.relationship-editor-list{gap:8px;display:grid}.relationship-editor-row{background:var(--soft);color:var(--ink);border-radius:14px;align-items:center;gap:12px;padding:9px 10px;font-weight:700;display:flex}.relationship-editor-row input{width:18px;height:18px}.direction-select,.date-grid label{color:var(--ink);gap:8px;margin-top:18px;font-weight:800;display:grid}.date-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.relation-modal-actions{gap:10px;margin-top:20px;display:flex}.error-box{color:#7a0000;background:#fdd;border-radius:14px;padding:10px 12px;font-weight:800}.legal-page{max-width:860px;color:var(--ink);background:var(--paper);min-height:100vh;margin:0 auto;padding:40px 24px}.legal-page p{line-height:1.6}.legal-note{background:var(--soft);border-radius:16px;padding:14px 16px}.back-link{margin-bottom:24px;font-weight:900;display:inline-block}@media (width<=1100px){.app{grid-template-columns:260px minmax(0,1fr) 260px}.toolbar{flex-direction:column;align-items:flex-start}.network-tabs{max-width:90vw}.axis-controls{flex-wrap:wrap}}
