:root{--white:#fff;--accent:#e44040;--gray-50:#f5f5f3;--gray-50-alt:#f5f5f3;--gray-100:#efefed;--gray-200:#e5e5e3;--gray-300:#d4d4ce;--gray-400:#9b9b95;--gray-500:#6b6b66;--gray-600:#545450;--gray-700:#3b3b38;--gray-800:#262624;--gray-900:#1a1a18;--gray-meta:#9b9b95;--slate-50:#f7f7f5;--slate-100:#f0f0ee;--slate-200:#e5e5e3;--slate-300:#d4d4ce;--slate-400:#9b9b95;--slate-500:#74746f;--slate-600:#545450;--slate-700:#3b3b38;--slate-800:#262624;--slate-900:#1a1a18;--slate-warm-50:#f7f7f5;--blue-50:#fef4ee;--blue-100:#fde2cc;--blue-200:#fac09a;--blue-300:#f49462;--blue-400:#e87848;--blue-500:#e44040;--blue-600:#c0613f;--blue-700:#a64d2d;--blue-800:#8a3c20;--blue-900:#6d2c12;--indigo-500:#c0613f;--violet-50:#f5f3ff;--violet-100:#ede9fe;--violet-200:#ddd6fe;--violet-400:#a78bfa;--violet-500:#8b5cf6;--violet-600:#7c3aed;--violet-700:#6d28d9;--violet-800:#5b21b6;--violet-900:#4c1d95;--purple-50:#faf5ff;--sky-600:#0284c7;--sky-700:#0369a1;--sky-800:#075985;--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-500:#22c55e;--green-600:#16a34a;--green-800:#166534;--emerald-50:#ecfdf5;--emerald-100:#d1fae5;--emerald-400:#34d399;--emerald-500:#10b981;--emerald-600:#059669;--emerald-700:#047857;--amber-50:#fffbeb;--amber-100:#fef3c7;--amber-200:#fde68a;--amber-300:#fcd34d;--amber-500:#f59e0b;--amber-600:#d97706;--amber-700:#b45309;--amber-800:#92400e;--amber-900:#78350f;--orange-50:#fff7ed;--orange-200:#fcd9b6;--orange-400:#fb923c;--orange-500:#f97316;--orange-600:#ea580c;--red-50:#fef2f2;--red-100:#fee2e2;--red-200:#fecaca;--red-300:#fca5a5;--red-500:#ef4444;--red-600:#dc2626;--red-700:#b91c1c;--red-800:#991b1b}[data-theme=dark]{--white:#252523;--bg:#0a0a0b;--text:#f0eeeb;--accent:#e44040;--muted:#6a7c8a;--gray-50:#1e1e1c;--gray-50-alt:#1e1e1c;--gray-100:#2a2a27;--gray-200:#38382f;--gray-300:#4a4a42;--gray-400:#6b6860;--gray-500:#9a9690;--gray-600:#b0aca2;--gray-700:#cec9be;--gray-800:#e0dbd2;--gray-900:#f5f2ec;--gray-meta:#6b6860;--slate-50:#1c1c1a;--slate-100:#222220;--slate-200:#38382f;--slate-300:#4a4a42;--slate-400:#6b6860;--slate-500:#9a9690;--slate-600:#b0aca2;--slate-700:#cec9be;--slate-800:#e0dbd2;--slate-900:#f5f2ec;--slate-warm-50:#222220;--blue-50:#2a1608;--blue-100:#3d2010;--blue-200:#6b3820;--blue-300:#96562e;--blue-400:#c07245;--blue-500:#e44040;--blue-600:#d97757;--blue-700:#c0613f;--blue-800:#f4a882;--blue-900:#fad5bd;--indigo-500:#c96845;--violet-50:#1a1040;--violet-100:#231555;--violet-200:#2e1a6e;--violet-800:#c4b5fd;--violet-900:#ddd6fe;--purple-50:#1a1040;--green-50:#052210;--green-100:#0d3320;--green-200:#166534;--green-800:#4ade80;--emerald-50:#022c22;--emerald-100:#064e3b;--amber-50:#1c1200;--amber-100:#2a1c00;--amber-200:#3d2800;--amber-300:#5e3f00;--amber-500:#d9940f;--amber-600:#bf8009;--amber-700:#c89620;--amber-800:#fde68a;--amber-900:#fef3c7;--orange-50:#1c0d00;--red-50:#1c0505;--red-100:#2e0909;--red-200:#450e0e;--red-800:#fca5a5}:root{--bg:#080b14;--accent:var(--blue-500);--text:var(--gray-900);--muted:var(--gray-500);--panel-bg:#0d1322f0;--panel-bg-soft:#111a2dd6;--border:color-mix(in srgb, var(--blue-500) 16%, transparent);--border-strong:color-mix(in srgb, var(--blue-500) 28%, transparent);--accent-soft:color-mix(in srgb, var(--blue-500) 10%, transparent);--accent-glow:color-mix(in srgb, var(--blue-500) 44%, transparent);--surface-soft:#1723386b;--surface-track:color-mix(in srgb, var(--gray-900) 12%, transparent);--font:"Space Grotesk", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);width:100%;height:100%;min-height:100dvh;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;overflow:hidden}html{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.sphere-canvas{z-index:0;cursor:grab;touch-action:none;display:block;position:fixed;inset:0}.sphere-canvas.dragging{cursor:grabbing}.sphere-canvas.hovering{cursor:pointer}.welcome-block{z-index:10;pointer-events:none;max-width:400px;position:fixed;top:50%;left:48px;transform:translateY(-50%)}.welcome-greeting{letter-spacing:.22em;text-transform:uppercase;color:var(--accent);opacity:.9;margin-bottom:14px;font-size:1.6rem;font-weight:500}.welcome-name{letter-spacing:.02em;color:var(--text);margin-bottom:10px;font-size:3.5rem;font-weight:700;line-height:1.1}.welcome-role{color:var(--muted);letter-spacing:.04em;margin-bottom:20px;font-size:1.2rem;font-weight:300}.welcome-hint{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;opacity:.45;border-top:1px solid var(--border);margin-bottom:20px;padding-top:14px;font-size:1rem}.welcome-cv{pointer-events:auto}.controls{z-index:10;align-items:center;gap:10px;display:flex;position:fixed;top:22px;right:28px}.ctrl-btn{border:1px solid var(--border);color:var(--muted);font-family:var(--font);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:40px;align-items:center;min-height:48px;padding:15px 30px;font-size:1rem;font-weight:500;text-decoration:none;transition:border-color .2s,color .2s;display:inline-flex}.ctrl-btn:hover{border-color:var(--accent);color:var(--accent)}.hs-label{pointer-events:auto;cursor:pointer;z-index:5;background:0 0;border:none;min-width:44px;min-height:44px;padding:17px;transition:opacity .3s;display:block;position:fixed;overflow:visible;transform:translate(-50%,-50%)}.hs-dot{background:var(--accent);width:9px;height:9px;box-shadow:0 0 6px var(--accent), 0 0 18px var(--accent-glow);border-radius:50%;margin:0 auto;transition:box-shadow .2s;display:block;position:relative}.hs-dot:after{content:"";border:1px solid var(--border-strong);animation:2.4s ease-in-out infinite hs-pulse;animation-delay:var(--delay,0s);border-radius:50%;position:absolute;inset:-5px}@keyframes hs-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:0;transform:scale(2.4)}}.hs-text{letter-spacing:.12em;text-transform:uppercase;color:var(--text);white-space:nowrap;background:color-mix(in srgb, var(--panel-bg-soft) 72%, transparent);-webkit-backdrop-filter:blur(4px);border-radius:10px;padding:3px 9px;font-size:.66rem;font-weight:500;transition:color .2s;position:absolute;top:32px;left:50%;transform:translate(-50%)}.hs-label:hover .hs-text{color:var(--accent)}.hs-label:hover .hs-dot{box-shadow:0 0 10px var(--accent), 0 0 28px color-mix(in srgb, var(--blue-400) 55%, transparent)}.drag-hint{z-index:10;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;opacity:.7;pointer-events:none;align-items:center;gap:7px;font-size:.68rem;transition:opacity .8s;display:flex;position:fixed;bottom:30px;left:50%;transform:translate(-50%)}.drag-hint.hidden{opacity:0}.connector-svg{pointer-events:none;z-index:25;width:100%;height:100%;position:fixed;inset:0;overflow:visible}.popup-card{background:var(--panel-bg);border:1px solid var(--border-strong);z-index:30;scrollbar-width:thin;scrollbar-color:var(--border) transparent;border-radius:14px;width:min(500px,100vw - 96px);max-height:68vh;animation:.38s cubic-bezier(.22,1,.36,1) both popup-in;position:fixed;top:50%;right:48px;overflow-y:auto;transform:translateY(-50%)}@keyframes popup-in{0%{opacity:0;transform:translateY(calc(16px - 50%))scale(.97)}to{opacity:1;transform:translateY(-50%)scale(1)}}.popup-card::-webkit-scrollbar{width:3px}.popup-card::-webkit-scrollbar-track{background:0 0}.popup-card::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.popup-header{z-index:1;background:var(--panel-bg);border-radius:14px 14px 0 0;justify-content:flex-end;padding:16px 16px 0;display:flex;position:sticky;top:0}.panel-close{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:border-color .2s,color .2s;display:flex}.panel-close:hover{border-color:var(--accent);color:var(--accent)}.panel-body{padding:20px 38px 60px}.panel-eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;font-size:.65rem;font-weight:500}.panel-heading{color:var(--text);margin-bottom:28px;font-size:1.9rem;font-weight:600;line-height:1.2}.pill{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);border-radius:20px;align-items:center;padding:6px 14px;font-size:.7rem;font-weight:500;text-decoration:none;transition:color .2s,border-color .2s;display:inline-flex}.pill:hover{color:var(--accent);border-color:var(--border-strong)}.about-photo{object-fit:cover;border:2px solid var(--border);border-radius:50%;width:76px;height:76px;margin-bottom:24px;display:block}.about-body p{color:var(--muted);margin-bottom:14px;font-size:.875rem;line-height:1.8}.about-social{flex-wrap:wrap;gap:8px;margin-top:24px;display:flex}.skill-row{margin-bottom:22px}.skill-row-header{justify-content:space-between;align-items:baseline;margin-bottom:9px;display:flex}.skill-name{color:var(--text);font-size:.85rem;font-weight:500}.skill-pct{color:var(--muted);font-size:.75rem;font-weight:300}.skill-track{background:var(--surface-track);border-radius:1px;height:1px;position:relative}.skill-fill{background:var(--accent);height:100%;box-shadow:0 0 8px var(--accent-glow);border-radius:1px;transition:width 1.1s cubic-bezier(.22,1,.36,1);position:absolute;top:0;left:0}.project-card{border:1px solid var(--border);color:inherit;border-radius:8px;margin-bottom:14px;text-decoration:none;transition:border-color .2s,transform .2s;display:block;overflow:hidden}.project-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.project-img{object-fit:cover;filter:brightness(.8)saturate(.7);width:100%;height:148px;display:block}.project-body{padding:14px 16px 16px}.project-title{color:var(--text);margin-bottom:5px;font-size:.9rem;font-weight:600}.project-desc{color:var(--muted);margin-bottom:10px;font-size:.78rem;line-height:1.65}.project-tags{flex-wrap:wrap;gap:6px;display:flex}.tag{letter-spacing:.07em;text-transform:uppercase;color:var(--accent);border:1px solid var(--border);border-radius:10px;padding:2px 8px;font-size:.62rem}.view-all{color:var(--accent);letter-spacing:.06em;opacity:.8;margin-top:10px;font-size:.78rem;text-decoration:none;transition:opacity .2s;display:inline-block}.view-all:hover{opacity:1}.exp-item{border-bottom:1px solid var(--border);padding:18px 0}.exp-item:first-child{padding-top:0}.exp-item:last-child{border-bottom:none}.exp-title{color:var(--text);margin-bottom:7px;font-size:.9rem;font-weight:600}.exp-desc{color:var(--muted);font-size:.8rem;line-height:1.75}.email-copy{background:var(--surface-soft);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:6px;width:100%;margin-bottom:4px;padding:16px 20px;transition:border-color .2s,background .2s;display:flex}.email-copy:hover{border-color:var(--border-strong);background:var(--accent-soft)}.email-address{font-family:var(--font);color:var(--text);letter-spacing:.01em;font-size:.92rem}.email-copy-label{font-family:var(--font);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-size:.7rem;font-weight:500}.contact-links{flex-wrap:wrap;gap:8px;margin-top:24px;display:flex}@media (prefers-reduced-motion:reduce){.hs-dot:after,.popup-card{animation:none}.skill-fill{transition:none}}@media (width<=760px){.welcome-block{top:max(72px, env(safe-area-inset-top));max-width:none;left:20px;right:20px;transform:none}.welcome-greeting{letter-spacing:.13em;margin-bottom:6px;font-size:clamp(.82rem,3.8vw,1.05rem)}.welcome-name-furigana{letter-spacing:.1em;font-size:.68rem}.welcome-name{white-space:normal;max-width:12ch;margin-bottom:6px;font-size:clamp(1.72rem,8.8vw,2.35rem);line-height:1}.welcome-role{max-width:22rem;margin-bottom:10px;font-size:.78rem;line-height:1.4}.welcome-hint{max-width:19rem;margin-bottom:10px;padding-top:8px;font-size:.62rem;line-height:1.5}.welcome-cv{min-height:40px;padding:0 15px;font-size:.64rem}.controls{top:max(14px, env(safe-area-inset-top));z-index:50;right:14px}.controls .ctrl-btn{min-height:42px;padding:0 15px;font-size:.74rem}.hs-label{z-index:8}.hs-text{text-overflow:ellipsis;letter-spacing:.08em;max-width:108px;padding:4px 8px;font-size:.58rem;overflow:hidden}.drag-hint{justify-content:center;width:calc(100vw - 40px);font-size:.62rem;bottom:78px}.connector-svg{display:none}.popup-card{top:auto;left:18px;right:18px;bottom:calc(70px + env(safe-area-inset-bottom));overscroll-behavior:contain;border-radius:14px;width:auto;max-height:min(46dvh,360px);transform:none}@keyframes popup-in{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.popup-header{padding:8px 8px 0}.panel-body{padding:4px 18px 22px}.panel-eyebrow{letter-spacing:.14em;font-size:.6rem}.panel-heading{margin-bottom:16px;font-size:clamp(1.25rem,5.8vw,1.55rem)}.about-photo{width:56px;height:56px;margin-bottom:14px}.about-body p,.exp-desc{font-size:.82rem;line-height:1.65}.pill{align-items:center;min-height:38px}.project-img{height:104px}.project-body{padding:11px 12px 13px}.email-copy{padding:13px 14px}.email-address{overflow-wrap:anywhere;font-size:.86rem}}@media (width<=390px){.welcome-block{top:max(64px, env(safe-area-inset-top))}.welcome-hint{display:none}.popup-card{max-height:min(44dvh,330px);left:14px;right:14px}.panel-body{padding-inline:16px}}@media (height<=640px) and (width<=760px){.welcome-block{top:max(58px, env(safe-area-inset-top))}.welcome-role,.welcome-hint{display:none}.popup-card{max-height:min(42dvh,300px)}}
