*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--bg: oklch(.97 .006 80);--card: oklch(.995 .003 80);--card-dark: oklch(.13 .015 250);--text: oklch(.13 .015 250);--muted: oklch(.5 .01 250);--accent: oklch(.54 .17 198);--accent2: oklch(.54 .17 280);--border: oklch(.88 .008 80);--sidebar-w: 58px;--sidebar-expanded-w: 172px;--r: 18px;--rs: 12px}body{margin:0;font-family:Space Grotesk,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;font-size:15px}#root{flex:1}a{color:inherit}button{font:inherit}canvas{display:block}#bg-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;width:100%;height:100%}.sidebar{position:fixed;left:16px;top:50%;width:var(--sidebar-w);background:#fefdfbe0;border:1px solid oklch(.88 .008 80 / .9);box-shadow:0 8px 32px #04080d12;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;flex-direction:column;padding:8px;border-radius:24px;z-index:100;transform:translateY(-50%);overflow:hidden;transition:width .32s cubic-bezier(.16,1,.3,1),box-shadow .32s ease}.sidebar:hover{width:var(--sidebar-expanded-w);box-shadow:0 12px 48px #04080d1c}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.nav-link{display:flex;align-items:center;gap:11px;height:42px;padding:0 12px;border-radius:16px;font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background .16s ease,color .16s ease}.nav-link:hover{background:#f4f1ed;color:var(--text)}.nav-link.active{background:var(--text);color:#f7f5f1}.nav-link:focus{outline:none}.nav-link:active{opacity:1}.nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-icon i,.nav-link i{display:flex}.nl{font-size:13px;font-weight:500;opacity:0;transition:opacity .18s ease}.sidebar:hover .nl{opacity:1;transition:opacity .22s ease .1s}.lang-toggle-dock{position:fixed;left:16px;bottom:16px;display:flex;flex-direction:column;background:#fefdfbe0;border:1px solid oklch(.88 .008 80 / .9);border-radius:24px;padding:8px;box-shadow:0 8px 32px #04080d12;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:100;gap:2px;width:58px}.ltbtn{width:42px;height:36px;border-radius:16px;font-size:10px;font-weight:600;font-family:DM Mono,monospace;color:var(--muted);cursor:pointer;border:none;background:none;letter-spacing:.07em;transition:background .28s cubic-bezier(.4,0,.2,1),color .28s cubic-bezier(.4,0,.2,1);text-align:center;display:flex;align-items:center;justify-content:center}.ltbtn.active{background:var(--text);color:var(--bg)}.ltbtn:not(.active):hover{background:#f4f1ed;color:var(--text)}.main-content{margin-left:90px;flex:1;padding:24px;position:relative;z-index:1}.bento{max-width:960px;margin:0 auto;display:grid;gap:12px;grid-template-columns:repeat(12,1fr)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:26px;position:relative;overflow:hidden;opacity:0;transform:translateY(14px);animation:fadeUp .5s ease forwards}.hov{transition:transform .28s cubic-bezier(.34,1.56,.64,1),box-shadow .28s ease,border-color .24s ease}.hov:hover{transform:translateY(-3px);box-shadow:0 12px 40px #04080d17;border-color:#c1bdb7}.card:nth-child(1){animation-delay:.04s}.card:nth-child(2){animation-delay:.09s}.card:nth-child(3){animation-delay:.14s}.card:nth-child(4){animation-delay:.19s}.card:nth-child(5){animation-delay:.24s}.card:nth-child(6){animation-delay:.29s}.card:nth-child(7){animation-delay:.34s}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.ctitle{font-size:10px;font-family:DM Mono,monospace;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:14px}.card-hero{grid-column:span 7;background:var(--card-dark);border-color:transparent;color:#f3f1ee;padding:36px;display:flex;flex-direction:column;justify-content:space-between;min-height:340px}.card-hero:before{content:"";position:absolute;top:-80px;right:-80px;width:260px;height:260px;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.18;pointer-events:none}.card-hero:hover{border-color:#1a222b;transform:none;box-shadow:none}.hero-avail{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.14em;color:var(--accent);text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:7px}.dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.hero-name{font-size:clamp(32px,4vw,52px);font-weight:700;line-height:1.05;letter-spacing:-.03em;margin-bottom:8px}.hero-name .aw{color:var(--accent)}.hero-sub{font-family:DM Mono,monospace;font-size:12px;color:#7c8186;margin-bottom:22px}.cursor{display:inline-block;width:2px;height:1em;background:var(--accent);vertical-align:middle;animation:blink 1.1s step-end infinite;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-bio{font-size:14px;line-height:1.75;color:#a1a5a9}.hero-cta{display:flex;gap:9px;margin-top:26px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 17px;border-radius:100px;font-size:12px;font-weight:500;text-decoration:none;cursor:pointer;border:none;font-family:inherit;transition:all .24s cubic-bezier(.4,0,.2,1)}.btn i{display:flex}.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:#006c6f;background:oklch(.48 .17 198);transform:scale(1.03);box-shadow:0 4px 14px #007f8359;box-shadow:0 4px 14px oklch(.54 .17 198 / .35)}.btn-g{background:#11171d;color:#babec3;border:1px solid oklch(.28 .015 250)!important}.btn-g:hover{background:#1f252b}.card-planet{grid-column:span 5;padding:0;overflow:hidden;background:var(--card-dark);border-color:transparent;min-height:340px;position:relative}.card-planet:hover{transform:none;box-shadow:none;border-color:#1a222b}#planet-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.planet-hint{position:absolute;bottom:12px;left:0;right:0;text-align:center;font-family:DM Mono,monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#2f3338;pointer-events:none;transition:opacity .3s}.card-status{grid-column:span 4;display:flex;flex-direction:column;gap:11px}.srow{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted)}.sicon{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}.sicon i{display:flex}.sicon.b{background:#c8ebf7}.sicon.b i{color:#005063;color:oklch(.4 .12 220)}.sicon.p{background:#e4e1fe}.sicon.p i{color:#493883}.sicon.g{background:#c9efd9}.sicon.g i{color:#005636;color:oklch(.4 .12 160)}.srow strong{display:block;color:var(--text);font-size:13px;font-weight:600}.card-about{grid-column:span 4;display:flex;flex-direction:column;justify-content:space-between}.about-q{font-size:17px;font-weight:600;line-height:1.4;letter-spacing:-.02em}.about-q em{font-style:normal;color:var(--accent2)}.about-body{font-size:12px;color:var(--muted);line-height:1.68;margin-top:12px}.about-foot{font-family:DM Mono,monospace;font-size:10px;color:var(--muted);margin-top:16px}.card-contact{grid-column:span 4;display:flex;flex-direction:column;justify-content:space-between;background:#c2f3f4;border-color:#86d8da}.card-contact:hover{border-color:#00b5b9;border-color:oklch(.7 .12 198)}.ctact-title{font-size:17px;font-weight:700;letter-spacing:-.02em;color:#00292a;color:oklch(.25 .1 198);line-height:1.3}.ctact-sub{font-size:12px;color:#005355;color:oklch(.4 .08 198);margin-top:5px}.clinks{display:flex;flex-direction:column;gap:7px;margin-top:16px}.clink{display:flex;align-items:center;gap:9px;padding:9px 12px;background:#fdfcf9b3;border-radius:var(--rs);text-decoration:none;color:var(--text);font-size:12px;font-weight:500;border:1px solid oklch(.83 .08 198 / .4);transition:all .22s cubic-bezier(.4,0,.2,1)}.clink:hover{background:#fdfcf9;transform:translate(4px);transition:all .22s cubic-bezier(.4,0,.2,1)}.clink i{display:flex;flex-shrink:0}.card-skills{grid-column:span 12}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.sg-label{font-size:10px;color:var(--muted);margin-bottom:9px;font-family:DM Mono,monospace;text-transform:uppercase;letter-spacing:.08em}.pills{display:flex;flex-wrap:wrap;gap:6px}.pill{padding:5px 12px;border-radius:100px;font-size:11px;font-weight:500;border:1px solid var(--border);background:var(--bg);transition:all .15s ease;cursor:default}.pill:hover{background:var(--text);color:var(--bg);border-color:transparent;transform:scale(1.05)}.pill.hi{background:#caf1f1;border-color:#90d6d8;color:#004446;color:oklch(.35 .12 198)}.pill.hi:hover{background:var(--accent);color:#fff;border-color:transparent}.proj-section{grid-column:span 12;display:flex;flex-direction:column;gap:12px;opacity:0;transform:translateY(14px);animation:fadeUp .5s ease .32s forwards}.proj-hdr{display:flex;align-items:center;gap:12px}.proj-hdr-lbl{font-family:DM Mono,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.proj-hdr-line{flex:1;height:1px;background:var(--border)}.proj-hdr-count{font-family:DM Mono,monospace;font-size:10px;color:var(--muted)}.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.card-proj{cursor:pointer;text-decoration:none;color:inherit;display:flex;flex-direction:column;padding:0;overflow:hidden;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease,border-color .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:left}.card-proj:hover{transform:translateY(-4px);box-shadow:0 16px 48px #04080d1f}.card-proj:hover .parrow{transform:translate(3px,-3px)}.ppreview{width:100%;aspect-ratio:16 / 9;position:relative;overflow:hidden}.ppreview svg{width:100%;height:100%}.pprev-lbl{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:DM Mono,monospace;font-size:10px;letter-spacing:.06em}.pbody{padding:17px;display:flex;flex-direction:column;gap:8px;flex:1}.ptop{display:flex;align-items:flex-start;justify-content:space-between}.picon{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}.picon i{display:flex}.parrow{color:var(--muted);transition:transform .18s ease;display:flex;align-items:center}.pname{font-size:14px;font-weight:600;letter-spacing:-.02em}.pdesc{font-size:11px;color:var(--muted);line-height:1.62;flex:1}.ptags{display:flex;flex-wrap:wrap;gap:5px}.ptag{font-family:DM Mono,monospace;font-size:10px;padding:3px 8px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--muted)}.pcta{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--accent);font-family:DM Mono,monospace;letter-spacing:.04em}.pcta i{display:flex}.card-ticker{grid-column:span 12;padding:11px 16px;overflow:hidden;display:flex;align-items:center;gap:12px;border-radius:var(--rs)}.ticker-lbl{font-family:DM Mono,monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:5px}.ticker-lbl i{display:flex}.ticker-track{overflow:hidden;flex:1;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 6%,black 94%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 6%,black 94%,transparent 100%)}.ticker-inner{display:flex;gap:34px;white-space:nowrap;animation:ticker 28s linear infinite;width:max-content}.ticker-inner span{font-family:DM Mono,monospace;font-size:11px;color:var(--muted)}.ticker-inner span b{color:var(--text);font-weight:500}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.modal-bd{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#04080db8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .25s ease}.modal-bd.open{opacity:1;pointer-events:all}.modal{background:var(--card);border:1px solid var(--border);border-radius:22px;max-width:660px;width:100%;max-height:88vh;overflow-y:auto;transform:translateY(20px) scale(.97);transition:transform .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 40px 120px #04080d4d}.modal-bd.open .modal{transform:translateY(0) scale(1)}.modal-prev{width:100%;aspect-ratio:16 / 7;position:relative;overflow:hidden;border-radius:22px 22px 0 0}.modal-prev svg{width:100%;height:100%}.modal-prev-lbl{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:DM Mono,monospace;font-size:12px}.mbody{padding:26px}.mtop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.micon-title{display:flex;align-items:center;gap:12px}.micon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center}.micon i{display:flex}.mtitle{font-size:20px;font-weight:700;letter-spacing:-.025em}.mclose{width:32px;height:32px;border-radius:100px;background:var(--bg);border:1px solid var(--border);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:all .15s ease}.mclose:hover{background:var(--text);color:var(--bg)}.mclose i{display:flex}.mdesc{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:20px}.ms-title{font-size:9px;font-family:DM Mono,monospace;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:9px}.mtags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.mtag{font-family:DM Mono,monospace;font-size:10px;padding:4px 10px;border-radius:5px;background:var(--bg);border:1px solid var(--border);color:var(--text)}.mlinks{display:flex;gap:9px;flex-wrap:wrap}.mlink{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:100px;font-size:12px;font-weight:500;text-decoration:none;transition:all .18s ease}.mlink i{display:flex}.mlink.pri{background:var(--accent);color:#fff}.mlink.pri:hover{background:#006c6f;background:oklch(.48 .17 198)}.mlink.sec{background:var(--bg);border:1px solid var(--border);color:var(--text)}.mlink.sec:hover{background:var(--text);color:var(--bg)}.reloc-section{grid-column:span 12;padding:56px 28px 52px;position:relative;overflow:hidden}.globe-inner{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;position:relative;z-index:1}.globe-h2{font-size:clamp(20px,2.4vw,28px);font-weight:700;letter-spacing:-.03em;line-height:1.15;margin-bottom:10px}.globe-sub{font-size:13px;color:var(--muted);line-height:1.72;max-width:380px;margin-bottom:16px}.globe-tags{display:flex;gap:6px;flex-wrap:wrap}.globe-wrap{position:relative;width:256px;height:256px;display:flex;align-items:center;justify-content:center}.globe-whirl{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.globe-whirl svg{width:100%;height:100%;transform-origin:center}.globe-whirl-a svg{animation:globe-spin 3s linear infinite}.globe-whirl-b svg{animation:globe-spin 2s linear infinite reverse}@keyframes globe-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.globe-canvas-round{border-radius:50%;cursor:pointer;display:block;position:relative;z-index:2;filter:drop-shadow(0 2px 16px rgba(0,0,0,.13))}.globe-label{font-family:DM Mono,monospace;font-size:10px;color:var(--accent);text-align:center;margin-top:10px;min-height:16px;letter-spacing:.04em;transition:opacity .3s}.globe-bg-text{position:absolute;top:50%;left:-.02em;transform:translateY(-50%);font-size:clamp(80px,12vw,160px);font-weight:800;letter-spacing:-.045em;color:var(--text);opacity:.05;pointer-events:none;white-space:nowrap;line-height:1;z-index:0;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.sidebar{left:12px;right:12px;top:12px;width:auto!important;height:52px;transform:none;flex-direction:row;align-items:center;padding:6px 10px;bottom:auto;gap:4px;overflow:visible;border-radius:18px}.sidebar-nav{flex-direction:row;gap:2px}.nav-link{height:38px;padding:0 10px;border-radius:12px;gap:0}.nl{display:none}.lang-toggle-dock{left:auto;right:12px;bottom:12px}.main-content{margin-left:0;margin-top:64px;padding:12px}.bento{grid-template-columns:1fr;gap:10px}.card-hero,.card-planet,.card-status,.card-about,.card-contact,.reloc-section,.card-skills,.card-ticker{grid-column:span 1}.globe-inner{grid-template-columns:1fr;gap:1.5rem}.globe-inner canvas{margin:0 auto}.reloc-section{padding:36px 16px 28px}.skills-grid,.proj-grid{grid-template-columns:1fr}.card-planet{min-height:260px}}
