:root{--tab-1: linear-gradient(135deg, #E8272C 0%, #a31b1f 100%);--tab-2: linear-gradient(135deg, #F5A623 0%, #d48a0d 100%);--tab-3: linear-gradient(135deg, #A2D633 0%, #7da822 100%);--tab-4: linear-gradient(135deg, #8B5CF6 0%, #5B21B6 100%);--tab-5: linear-gradient(135deg, #3344DD 0%, #222ea3 100%);--bg: #0a0a0a;--fg: #fff;--muted: #666;--dim: #444;--accent: #8B5CF6;--mono: "Space Mono", monospace;--sans: "Outfit", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--fg);font-family:var(--sans);min-height:100vh;overflow-x:hidden}body.locked{overflow:hidden}.page-content{position:relative;min-height:100vh;padding:2rem;transition:opacity .4s ease}body.any-expanded .page-content{opacity:.15;pointer-events:none}.info-area{position:fixed;top:2.5rem;right:2.5rem;max-width:360px;z-index:5;font-family:var(--mono)}.info-content{transition:opacity .2s ease}.info-content h1{font-family:var(--mono);font-size:1.35rem;font-weight:700;color:#fff;margin-bottom:.75rem;letter-spacing:-.01em}.info-content p{font-family:var(--mono);color:#888;font-size:.82rem;line-height:1.9}.boot-line{font-family:var(--mono);color:#888;font-size:.82rem;line-height:1.9;opacity:0;animation:bootIn .25s ease forwards}.boot-line.bright{color:#fff;font-weight:700}.boot-line .ok{color:#10b981}.boot-line .warn{color:#f59e0b}@keyframes bootIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.cursor{display:inline-block;animation:blink 1s steps(2,end) infinite}@keyframes blink{50%{opacity:0}}.tabs-container{position:fixed;inset:0;pointer-events:none;z-index:10}.tab{position:absolute;inset:0;pointer-events:auto;cursor:pointer;overflow:hidden;will-change:clip-path;transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;box-shadow:inset 10px 0 20px #00000026}.tab:focus-visible{outline:3px solid rgba(255,255,255,.6);outline-offset:-3px}.tab-inner{position:absolute;top:30%;bottom:0;left:0;width:55%;padding:3rem;opacity:0;transition:opacity .3s ease .25s;overflow-y:auto;scrollbar-width:none;will-change:transform;pointer-events:none}.tab-inner::-webkit-scrollbar{display:none}.tab-inner:focus{outline:none}.tab.expanded .tab-inner{opacity:1;pointer-events:auto}@media(min-width:769px){.tab-4 .tab-inner{width:80%;max-width:1100px}}.tab-label{position:absolute;font-family:var(--mono);font-size:.875rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#ffffffe6;text-shadow:0 1px 3px rgba(0,0,0,.25);transform-origin:left center;transition:opacity .3s ease;pointer-events:none;white-space:nowrap;will-change:transform}.tab-inner h2{font-size:2.4rem;font-weight:700;margin-bottom:.5rem;color:#fff;letter-spacing:-.02em;opacity:0;transform:translateY(30px);transition:opacity .4s ease,transform .4s ease}.tab-inner .subtitle{font-family:var(--mono);font-size:.78rem;color:#fff9;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.5rem;opacity:0;transform:translateY(30px);transition:opacity .4s ease,transform .4s ease}.tab-inner p{font-size:1rem;line-height:1.7;color:#ffffffd9;max-width:480px;opacity:0;transform:translateY(30px);transition:opacity .4s ease,transform .4s ease}.tab-inner .body-block{opacity:0;transform:translateY(30px);transition:opacity .4s ease,transform .4s ease}.tab.expanded .tab-inner h2{opacity:1;transform:translateY(0);transition-delay:.3s}.tab.expanded .tab-inner .subtitle{opacity:1;transform:translateY(0);transition-delay:.38s}.tab.expanded .tab-inner p{opacity:1;transform:translateY(0);transition-delay:.45s}.tab.expanded .tab-inner .body-block{opacity:1;transform:translateY(0);transition-delay:.55s}.tab.closing .tab-inner h2,.tab.closing .tab-inner .subtitle,.tab.closing .tab-inner p,.tab.closing .tab-inner .body-block{opacity:1;transform:translateY(0);transition:none}.tab.closing .project-card{background:transparent;border-color:transparent;transition:background .2s ease,border-color .2s ease}.tab.closing .project-card .thumb-wrap{opacity:0;transition:opacity .2s ease}.tab.closing .tab-inner{transition:opacity .5s ease;pointer-events:none}.tab-dissolve-canvas{position:absolute;left:0;top:0;pointer-events:none;z-index:2;display:none}.tab.closing .tab-dissolve-canvas{display:block}.close-btn{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border:2px solid rgba(0,0,0,.35);border-radius:50%;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease .3s,background .2s;pointer-events:none;z-index:50}@media(hover:hover){.close-btn:hover{background:#00000026}}.close-btn:before,.close-btn:after{content:"";position:absolute;width:18px;height:2px;background:#000000b3}.close-btn:before{transform:rotate(45deg)}.close-btn:after{transform:rotate(-45deg)}.tab.expanded .close-btn{opacity:1;pointer-events:auto}.tab-1{background:var(--tab-1);z-index:15}.tab-2{background:var(--tab-2);z-index:14}.tab-3{background:var(--tab-3);z-index:13}.tab-4{background:var(--tab-4);z-index:12}.tab-5{background:var(--tab-5);z-index:11}.hint{position:fixed;bottom:1.5rem;right:2rem;font-size:.72rem;color:#555;letter-spacing:.08em;font-family:var(--mono);z-index:5;display:flex;gap:1rem;align-items:center}.hint .key{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);padding:2px 6px;border-radius:3px;color:#999;font-weight:700}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:1.25rem;max-width:480px}.stat-cell{background:#00000026;padding:.75rem 1rem;border-left:2px solid rgba(255,255,255,.25);border-radius:0 4px 4px 0}.stat-cell .label{font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:#fff9;margin-bottom:2px}.stat-cell .value{font-family:var(--mono);font-size:.95rem;font-weight:700;color:#fff}.skills{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;max-width:480px}.skill-tag{font-family:var(--mono);font-size:.72rem;font-weight:700;padding:4px 10px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);border-radius:3px;color:#fff;letter-spacing:.05em}.service-list{margin-top:1.25rem;max-width:480px}.service-item{display:flex;align-items:flex-start;gap:1rem;padding:.9rem 0;border-bottom:1px solid rgba(0,0,0,.15)}.service-item:last-child{border-bottom:none}.service-item .num{font-family:var(--mono);font-size:.7rem;font-weight:700;color:#ffffff80;padding-top:3px;min-width:28px}.service-item .body h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:2px}.service-item .body span{font-family:var(--mono);font-size:.78rem;color:#ffffffb3;line-height:1.55}.project-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}@media(min-width:900px){.project-grid{grid-template-columns:repeat(3,1fr)}}.project-card{background:#0003;padding:.75rem .75rem 1.75rem;border-radius:6px;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:transform .2s ease,border-color .2s ease,background .2s ease;position:relative}@media(hover:hover){.project-card:hover{background:#00000052;border-color:#ffffff38;transform:translateY(-2px)}.project-card:hover:after{opacity:1}}.project-card:after{content:"// click to expand ›";position:absolute;bottom:.6rem;right:.75rem;font-family:var(--mono);font-size:.62rem;color:#ffffff73;opacity:0;transition:opacity .2s ease;letter-spacing:.05em;pointer-events:none}.project-card .thumb-wrap{width:100%;aspect-ratio:400/180;background:#000;border-radius:4px;overflow:hidden;margin-bottom:.75rem;display:block}.project-card svg.project-thumb{width:100%;height:100%;display:block}.project-card h3{font-family:var(--mono);font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;margin-bottom:.4rem}.project-card p{font-size:.85rem;line-height:1.55;color:#fffc;max-width:none}.contact-link{display:flex;align-items:center;padding:1rem 1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;text-decoration:none;font-weight:600;transition:all .2s ease;margin-bottom:.75rem;max-width:480px}@media(hover:hover){.contact-link:hover{background:#fff3;transform:translate(8px)}}.contact-link .num{font-family:var(--mono);margin-right:1rem;opacity:.5;font-size:.85rem}.contact-link .label{flex:1}.contact-link .arrow{opacity:.6}.palette-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding-top:15vh}.palette-overlay.open{display:flex}.palette{width:92%;max-width:560px;background:#0d0d0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 30px 80px #0009,0 0 0 1px #ffffff08;overflow:hidden;font-family:var(--mono)}.palette-input-row{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08)}.palette-input-row .prompt{color:var(--accent);font-weight:700;font-size:.95rem}.palette-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-family:var(--mono);font-size:.95rem;caret-color:var(--accent)}.palette-input::placeholder{color:#555}.palette-output{padding:.75rem 1.25rem;font-size:.82rem;color:#aaa;line-height:1.7;border-bottom:1px solid rgba(255,255,255,.08);display:none;white-space:pre-wrap}.palette-output.shown{display:block}.palette-output .ok{color:#10b981}.palette-output .warn{color:#f59e0b}.palette-output .err{color:#ef4444}.palette-output .dim{color:#555}.palette-list{max-height:50vh;overflow-y:auto;padding:.5rem 0}.palette-item{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.25rem;cursor:pointer;font-size:.85rem;color:#bbb}.palette-item.active{background:#8b5cf61f;color:#fff;border-left:2px solid var(--accent);padding-left:calc(1.25rem - 2px)}.palette-item .cmd{font-weight:700;color:#fff}.palette-item .desc{color:#666;font-size:.78rem}.palette-item.active .desc{color:#999}.palette-hint{padding:.55rem 1.25rem;border-top:1px solid rgba(255,255,255,.08);font-size:.7rem;color:#555;display:flex;gap:1rem}.palette-hint .key{background:#ffffff0f;padding:1px 6px;border-radius:3px;color:#999}.detail-overlay{position:fixed;inset:0;z-index:50;pointer-events:none;opacity:0;transition:opacity .3s ease}.detail-overlay.open{pointer-events:auto;opacity:1}.detail-backdrop{position:absolute;inset:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.detail-panel{position:absolute;top:0;right:0;width:100%;max-width:640px;height:100%;background:#0b0b0b;border-left:1px solid rgba(255,255,255,.08);box-shadow:-20px 0 60px #0009;transform:translate(100%);transition:transform .45s cubic-bezier(.25,1,.3,1);overflow:hidden}.detail-overlay.open .detail-panel{transform:translate(0)}.detail-scroll{height:100%;overflow-y:auto;overflow-x:hidden;padding:3rem 2.5rem;scrollbar-width:thin;scrollbar-color:#333 #0b0b0b}.detail-scroll::-webkit-scrollbar{width:6px}.detail-scroll::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px}@media(max-width:1100px){.detail-panel{max-width:580px}.detail-scroll{padding:2.5rem 2rem}}.detail-close{position:absolute;top:1.25rem;right:1.25rem;width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s ease,border-color .2s ease}@media(hover:hover){.detail-close:hover{background:#ffffff14;border-color:#fff6}}.detail-close:before,.detail-close:after{content:"";position:absolute;width:16px;height:2px;background:#fff}.detail-close:before{transform:rotate(45deg)}.detail-close:after{transform:rotate(-45deg)}.detail-breadcrumb{font-family:var(--mono);font-size:.72rem;color:#666;letter-spacing:.08em;margin-bottom:.85rem}.detail-breadcrumb .sep{opacity:.4;margin:0 .4rem}.detail-breadcrumb .current{color:var(--accent)}.detail-status{display:inline-block;font-family:var(--mono);font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:3px;letter-spacing:.1em;margin-bottom:.85rem}.detail-status.active{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.detail-status.wip{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.detail-status.shipped{background:#34d3;color:#6b7cff;border:1px solid rgba(51,68,221,.4)}.detail-status.ongoing{background:#8b5cf626;color:#c4a5ff;border:1px solid rgba(139,92,246,.3)}.detail-status.archived{background:#64646426;color:#888;border:1px solid rgba(100,100,100,.3)}.detail-title{font-size:2.2rem;font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:.35rem}.detail-subtitle{font-family:var(--mono);font-size:.8rem;color:#888;letter-spacing:.05em;margin-bottom:1.5rem}.detail-thumb{width:100%;aspect-ratio:400/180;background:#000;border-radius:4px;overflow:hidden;margin-bottom:2rem;border:1px solid rgba(255,255,255,.06)}.detail-thumb svg{width:100%;height:100%;display:block}.detail-section{margin-bottom:1.75rem}.detail-section-title{font-family:var(--mono);font-size:.72rem;font-weight:700;color:var(--accent);text-transform:lowercase;letter-spacing:.15em;margin-bottom:.7rem}.detail-overview{font-size:.95rem;line-height:1.7;color:#ccc}.detail-stack{display:flex;flex-wrap:wrap;gap:.4rem}.detail-stack .tag{font-family:var(--mono);font-size:.72rem;font-weight:700;padding:4px 10px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.25);border-radius:3px;color:#c4a5ff;letter-spacing:.05em}.detail-features{list-style:none;padding:0;margin:0}.detail-features li{font-size:.9rem;line-height:1.55;color:#ccc;padding:.45rem 0 .45rem 1.5rem;position:relative}.detail-features li:before{content:"›";position:absolute;left:.25rem;top:.4rem;color:var(--accent);font-family:var(--mono);font-weight:700;font-size:1rem}.detail-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem}.detail-stats .cell{background:#ffffff08;border-left:2px solid rgba(139,92,246,.4);padding:.6rem .9rem;border-radius:0 4px 4px 0;min-width:0}.detail-stats .label{font-family:var(--mono);font-size:.62rem;color:#777;text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}.detail-stats .value{font-family:var(--mono);font-size:.85rem;font-weight:700;color:#fff}.detail-links{display:flex;flex-direction:column;gap:.5rem}.detail-links a{display:flex;align-items:center;padding:.7rem 1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:4px;color:#ccc;text-decoration:none;font-family:var(--mono);font-size:.8rem;transition:all .15s ease}@media(hover:hover){.detail-links a:hover{background:#8b5cf61a;border-color:#8b5cf659;color:#fff}}.detail-links a .num{color:#666;margin-right:.75rem}.detail-links a .label{flex:1}.detail-links a .arrow{opacity:.5}.detail-nav{display:flex;gap:.5rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.06)}.detail-nav button{flex:1;padding:.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#aaa;font-family:var(--mono);font-size:.72rem;font-weight:700;cursor:pointer;transition:all .15s ease;letter-spacing:.05em;text-align:center;text-transform:lowercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(hover:hover){.detail-nav button:hover:not(:disabled){background:#8b5cf614;border-color:#8b5cf659;color:#fff}}.detail-nav button:disabled{opacity:.25;cursor:not-allowed}@media(prefers-reduced-motion:reduce){.tab-inner h2,.tab-inner .subtitle,.tab-inner p,.tab-inner .body-block,.tab-inner,.detail-panel,.detail-overlay,.palette-overlay,.info-content,.close-btn,.boot-line,.cursor{transition-duration:.01s!important;animation-duration:.01s!important;animation-iteration-count:1!important}.tab-dissolve-canvas{display:none!important}}@media(max-width:768px){.info-area{top:1.25rem;right:1.25rem;left:1.25rem;max-width:none}.info-content h1{font-size:1.05rem}.info-content p,.boot-line{font-size:.72rem}.hint{display:none}.tab-inner{width:100%;padding:2rem 1.5rem}.tab-inner h2{font-size:1.7rem}.tab-label{font-size:.72rem}.palette-overlay{padding-top:5vh}.palette-list{max-height:60vh}.stat-grid{grid-template-columns:1fr}.detail-panel{max-width:100%}.detail-scroll{padding:2.5rem 1.5rem}.detail-title{font-size:1.6rem}.detail-stats{grid-template-columns:1fr}.detail-nav{margin-top:2rem}}
