:root{--accent:#6ee7ff;--muted:#9aa4b2;--bg:#030312;--text:#e6eef6;--font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--field-default-bg:#fffaf0fa;--logo-gap:12px 14px}html,body,#__next{scrollbar-gutter:stable both-edges;height:100%;margin:0;overflow-x:hidden}body{font-family:var(--font-family);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.no-scroll{box-sizing:border-box;width:100vw;height:100vh;overflow:hidden}.content-wrap{box-sizing:border-box;max-width:none;margin:0 auto;padding:0 18px}.page-container{box-sizing:border-box;min-height:100vh;padding:36px}.mt-18{margin-top:18px}.mt-12{margin-top:12px}
.page-bg{box-sizing:border-box;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:relative;overflow:hidden}.cards{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(32px,2vw,40px);display:grid}.card{background:linear-gradient(#ffffff05,#ffffff03);border:1px solid #ffffff0a;border-radius:8px;padding:14px;transition:transform .22s,box-shadow .22s,border-color .22s;position:relative;overflow:visible}a:hover .card,.card:hover{transform:translateY(-6px)}.category-break{width:100%;height:18px;display:block}
.labels{z-index:3;pointer-events:none;box-sizing:border-box;padding:0 36px;display:flex;position:absolute;top:20px;left:0;right:0}.top-banner .labels{top:50%;transform:translateY(-50%)}.label{text-align:center;flex:1}.label h2{color:var(--text);transform-origin:50%;margin:0;font-size:1.6rem;font-weight:700;transition:transform .22s cubic-bezier(.2,.9,.2,1),text-shadow .22s cubic-bezier(.2,.9,.2,1),color .18s,opacity .16s}.label.active h2{color:#f5fbff;text-shadow:0 22px 44px #0206178c,0 10px 20px #02061759,0 6px 24px #6ee7ff0a;transform:translateY(-10px)}@media (max-width:720px){.labels{padding:0 18px;top:18px}.label h2{font-size:1.25rem}.label.active h2{transform:translateY(-6px)}}.intro{text-align:center;letter-spacing:.2px;max-width:1100px;color:var(--accent);opacity:0;will-change:opacity,transform;cursor:default;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;max-height:calc(100% - 24px);margin:0;padding:6px 20px;font-size:clamp(2rem,6vw,4rem);font-weight:700;transition:opacity .52s cubic-bezier(.2,.9,.2,1),transform .6s cubic-bezier(.2,.9,.2,1);display:flex;position:relative;transform:translateY(12px)scale(.995)}.intro.show{opacity:1;transform:translateY(0)scale(1)}.project-card{cursor:pointer;width:100%;max-width:360px;display:block;position:relative}.preview-box{aspect-ratio:16/9;background:#091020;border-radius:6px;width:100%;margin-bottom:12px;overflow:hidden}.preview-box img{object-fit:cover;width:100%;height:100%;display:block}.preview-fallback{color:#9aa4b2;justify-content:center;align-items:center;font-size:.95rem;font-weight:600;display:flex}.card.card--spaced{margin-top:18px}.tag-chip{color:inherit;background:#ffffff08;border:1px solid #ffffff0a;border-radius:9999px;padding:6px 10px;font-family:inherit;font-size:.85rem;display:inline-block}.try-live{z-index:5;color:inherit;font:inherit;box-shadow:none;box-sizing:border-box;background:0 0;border:2.5px solid;border-radius:0;outline:none;justify-content:center;align-items:center;height:40px;padding:6px 12px;text-decoration:none;display:inline-flex}.try-live:hover,.try-live:focus{border-color:var(--accent);color:var(--accent)}.project-card h4{margin:6px 0}.project-card-body{align-items:flex-end;gap:12px;display:flex}.project-card-left{flex:1;min-width:0}.project-card-left p{margin:0}.topic-wrap{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.preview-box.preview-fallback{background:linear-gradient(90deg,#112,#334);justify-content:center;align-items:center;display:flex}.try-live .label{font-weight:600;line-height:1.2;display:inline-block}.error{color:var(--accent,#f66)}@supports ((-webkit-background-clip:text)){.intro{background-image:linear-gradient(#6ee7ff5c,#6ee7ff5c),radial-gradient(circle at var(--mx,50%)var(--my,12%),#6ee7ff 0%,#6ee7fffa 6%,#6ee7ffb3 14%,#6ee7ff47 30%,transparent 60%);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}.intro.show{text-shadow:0 10px 40px #6ee7ff0f}}
.logo-grid{gap:var(--logo-gap);grid-template-columns:repeat(auto-fill,96px);justify-content:start;place-items:start center;display:grid}.logo{width:92px;height:92px;box-shadow:none;background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.logo:before{content:"";background:var(--field-default-bg);z-index:0;border-radius:50%;width:92px;height:92px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.logo img{filter:drop-shadow(0 10px 26px #0206178c);z-index:1;width:56px;height:56px;display:block;position:relative}.logo-fallback{z-index:1;color:#071124;text-align:center;justify-content:center;align-items:center;padding:6px 8px;font-size:1.28rem;font-weight:700;line-height:1;display:flex;position:relative}.tech-item{color:inherit;z-index:1;flex-direction:column;align-items:center;gap:10px;text-decoration:none;transition:transform .2s;display:flex;position:relative}.tech-item:hover{z-index:20;transform:translateY(-6px)}.tech-item:focus-within{z-index:20}.tech-item:hover .tech-label,.tech-item:focus-within .tech-label{opacity:1;pointer-events:auto;color:var(--accent);transform:translate(-50%)}.tech-label{opacity:0;pointer-events:none;text-align:center;min-width:160px;max-width:320px;color:var(--text);z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#080c14e0;border-radius:12px;padding:8px 12px;transition:opacity .18s,transform .18s,color .18s;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%,6px);box-shadow:0 8px 24px #02061773}.tech-label:after{content:"";border-top:8px solid #080c14e0;border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tech-label .bubble-name{color:var(--text);font-size:1.05rem;font-weight:700}.tech-label .bubble-desc{color:var(--muted);margin-top:4px;font-size:.85rem;font-weight:600}.tech-label.bubble-bottom{top:calc(100% + 12px);bottom:auto;transform:translate(-50%,-6px)}.tech-label.bubble-bottom:after{border-top:none;border-bottom:8px solid #080c14e0;top:auto;bottom:100%}@media (max-width:1024px){:root{--logo-gap:16px}.logo-grid{grid-template-columns:repeat(auto-fill,84px)}}@media (max-width:720px){:root{--logo-gap:20px}.logo-grid{gap:var(--logo-gap);grid-template-columns:repeat(auto-fill,72px)}.logo{width:84px;height:84px}.logo:before{width:74px;height:74px}.logo img{width:48px;height:48px}.tech-label{max-width:180px;font-size:.98rem}}
.profile-page{box-sizing:border-box;padding:36px}.profile-layout{gap:28px;height:calc(100vh - 72px);display:flex}.profile-left{box-sizing:border-box;flex-direction:column;flex:0 0 320px;align-items:flex-start;gap:20px;max-width:320px;padding:20px;display:flex}.profile-right{box-sizing:border-box;flex:auto;padding:20px;overflow:auto}.portrait{background-position:50%;background-size:cover;border:1px solid #ffffff0a;border-radius:50%;width:220px;height:220px;margin:0 auto;box-shadow:0 12px 40px #02061799}.portrait-img{object-fit:cover;border:1px solid #ffffff0a;border-radius:50%;width:220px;height:220px;margin:0 auto;display:block;box-shadow:0 12px 40px #02061799}.info-list{flex-direction:column;align-items:flex-start;gap:12px;width:100%;margin-top:6px;padding-left:6px;display:flex}.info-item{color:var(--text);align-items:center;gap:12px;font-size:.98rem;font-weight:600;text-decoration:none;display:flex}.info-item .icon-img{flex:0 0 20px;width:20px;height:20px;display:inline-block}.info-item a{color:inherit;text-decoration:none}.info-item a:hover{color:var(--accent)}@media (max-width:880px){.profile-layout{flex-direction:column;height:auto}.profile-left{flex-direction:row;flex:none;align-items:center;width:100%;max-width:100%;padding:12px}.portrait{width:96px;height:96px}.info-list{flex-direction:row;gap:8px}}
