*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b1220;--bg2:#111827;--surface:#161d2e;--text:#e2e8f0;--muted:#64748b;--dim:#334155;--green:#4ade80;--blue:#60a5fa;--purple:#a78bfa;--border:#ffffff0f;--mono:"JetBrains Mono", "Fira Code", "SF Mono", Consolas, monospace;--sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--content-width:680px}html{scroll-behavior:smooth;font-size:15px}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}ul{list-style:none}.dim{color:var(--muted)}.g{color:var(--green)}.clickable{cursor:pointer}.hero{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative}.hero-inner{max-width:540px;padding:40px 24px}.hero-prompt{font-family:var(--mono);color:var(--muted);margin-bottom:16px;font-size:.85rem}.hero-name{font-family:var(--sans);letter-spacing:-.02em;margin-bottom:12px;font-size:2.2rem;font-weight:700;line-height:1.2}.hero-bio{color:var(--muted);margin-bottom:20px;font-size:.9rem;line-height:1.7}.hero-meta{font-family:var(--mono);gap:8px;margin-bottom:16px;font-size:.8rem;display:flex}.hero-links{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:24px;font-size:.8rem;display:flex}.hero-stack{font-family:var(--mono);color:var(--muted);margin-bottom:32px;font-size:.75rem;line-height:1.8}.hero-cursor{font-family:var(--mono);color:var(--muted);font-size:.85rem}.blink{animation:1s step-end infinite blink}@keyframes blink{50%{opacity:0}}.hero-scroll-hint{position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.scroll-line{background:var(--dim);width:1px;height:40px;position:relative;overflow:hidden}.scroll-line:after{content:"";background:var(--green);width:100%;height:100%;animation:2s ease-in-out infinite scrollDown;position:absolute;top:-100%;left:0}@keyframes scrollDown{0%{top:-100%}to{top:100%}}.content{max-width:var(--content-width);margin:0 auto;padding:0 24px}.section{border-bottom:1px solid var(--border);flex-direction:column;justify-content:center;min-height:100dvh;padding:80px 0;display:flex}.section:last-child{border-bottom:none}.section-title{font-family:var(--mono);letter-spacing:.05em;color:var(--green);margin-bottom:28px;font-size:.72rem;font-weight:400}.edu-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;transition:border-color .2s;display:flex;overflow:hidden}.edu-card:hover{border-color:var(--green)}.edu-accent{background:var(--green);flex-shrink:0;width:3px}.edu-body{padding:28px 24px}.edu-date{font-family:var(--mono);color:var(--muted);margin-bottom:8px;font-size:.7rem;display:block}.edu-school{margin-bottom:4px;font-size:1.15rem;font-weight:700}.edu-major{color:var(--blue);margin-bottom:14px;font-size:.85rem;font-weight:500;display:block}.edu-clubs{flex-wrap:wrap;gap:6px;display:flex}.edu-club{font-family:var(--mono);color:var(--green);background:#4ade8014;border:1px solid #4ade8026;border-radius:2px;padding:3px 10px;font-size:.65rem}.exp-timeline{padding-left:24px;position:relative}.exp-timeline:before{content:"";background:var(--dim);width:1px;position:absolute;top:6px;bottom:6px;left:4px}.exp-item{padding:0 0 28px 18px;transition:transform .15s;position:relative}.exp-item:last-child{padding-bottom:0}.exp-item:hover{transform:translate(3px)}.exp-dot{background:var(--bg);border:2px solid var(--muted);z-index:1;border-radius:50%;width:9px;height:9px;transition:border-color .15s;position:absolute;top:7px;left:-23px}.exp-item:hover .exp-dot{border-color:var(--green)}.exp-date{font-family:var(--mono);color:var(--muted);margin-bottom:3px;font-size:.65rem;display:block}.exp-title{margin-bottom:1px;font-size:.92rem;font-weight:600}.exp-role{font-family:var(--mono);color:var(--blue);margin-bottom:4px;font-size:.72rem;display:block}.exp-desc{color:var(--muted);font-size:.76rem;line-height:1.55}.res-cloud{flex-wrap:wrap;gap:6px;display:flex}.res-chip{font-family:var(--mono);border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:2px;padding:6px 12px;font-size:.7rem;line-height:1.3;transition:all .15s}.res-chip:hover{border-color:var(--green);color:var(--green)}.res-chip--ctf{color:var(--blue);border-color:#60a5fa33}.res-chip--ctf:hover{border-color:var(--blue)}.res-chip--education{color:var(--green);border-color:#4ade8033}.res-chip--education:hover{border-color:var(--green)}.res-chip--project{color:var(--purple);border-color:#a78bfa33}.res-chip--project:hover{border-color:var(--purple)}.res-chip--infra{color:#fb923c;border-color:#fb923c33}.res-chip--infra:hover{border-color:#fb923c}.res-chip--wargame{color:#facc15;border-color:#facc1533}.res-chip--wargame:hover{border-color:#facc15}.award-list{flex-direction:column;gap:12px;display:flex}.award-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;transition:border-color .2s;overflow:hidden}.award-card:hover{border-color:var(--purple)}.award-stripe{background:linear-gradient(90deg, var(--green), var(--blue), var(--purple));height:2px}.award-body{padding:20px 24px}.award-date{font-family:var(--mono);color:var(--muted);margin-bottom:6px;font-size:.65rem;display:block}.award-title{margin-bottom:6px;font-size:.95rem;font-weight:600}.award-desc{color:var(--muted);margin-bottom:10px;font-size:.78rem;line-height:1.55}.award-techs{flex-wrap:wrap;gap:4px;display:flex}.award-tech{font-family:var(--mono);border:1px solid var(--border);color:var(--muted);border-radius:2px;padding:2px 8px;font-size:.6rem}.proj-list{flex-direction:column;gap:10px;display:flex}.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;transition:border-color .2s;display:flex;overflow:hidden}.proj-card:hover{border-color:var(--blue)}.proj-bar{flex-shrink:0;width:3px}.proj-body{flex:1;align-items:flex-start;gap:16px;padding:18px 20px;display:flex}.proj-num{font-family:var(--mono);color:var(--dim);flex-shrink:0;font-size:1.4rem;font-weight:700;line-height:1}.proj-info{flex:1}.proj-tag{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;margin-bottom:3px;font-size:.6rem}.proj-title{margin-bottom:3px;font-size:.9rem;font-weight:600}.proj-desc{color:var(--muted);font-size:.75rem;line-height:1.5}.cert-list{flex-direction:column;gap:4px;display:flex}.cert-item{border:1px solid #0000;border-radius:2px;align-items:center;gap:14px;padding:12px 16px;transition:border-color .15s,background .15s;display:flex}.cert-item:hover{border-color:var(--border);background:var(--surface)}.cert-date{font-family:var(--mono);color:var(--dim);flex-shrink:0;min-width:56px;font-size:.65rem}.cert-info{flex:1;min-width:0}.cert-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:1px;font-size:.82rem;font-weight:500;overflow:hidden}.cert-issuer{color:var(--muted);font-size:.7rem}.cert-badge{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--border);color:var(--muted);border-radius:2px;flex-shrink:0;padding:2px 8px;font-size:.55rem}.nav-dots{z-index:100;flex-direction:column;gap:10px;display:flex;position:fixed;top:50%;right:24px;transform:translateY(-50%)}.nav-dot{background:var(--dim);cursor:pointer;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:all .2s;position:relative}.nav-dot.active{background:var(--green);box-shadow:0 0 8px #4ade804d}.nav-dot-label{font-family:var(--mono);color:var(--muted);white-space:nowrap;opacity:0;pointer-events:none;font-size:.55rem;transition:opacity .15s;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.nav-dot:hover .nav-dot-label{opacity:1}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg2);border:1px solid var(--border);border-radius:6px;width:100%;max-width:500px;max-height:80vh;padding:32px 28px 28px;position:relative;overflow-y:auto}.modal-content::-webkit-scrollbar{width:3px}.modal-content::-webkit-scrollbar-thumb{background:var(--dim);border-radius:2px}.modal-close{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--muted);background:0 0;border-radius:4px;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex;position:absolute;top:12px;right:12px}.modal-close:hover{border-color:var(--text);color:var(--text)}.modal-tag{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--green);margin-bottom:10px;font-size:.58rem;display:inline-block}.modal-title{margin-bottom:4px;font-size:1.1rem;font-weight:700;line-height:1.3}.modal-subtitle{font-family:var(--mono);color:var(--blue);margin-bottom:4px;font-size:.8rem}.modal-date{font-family:var(--mono);color:var(--muted);font-size:.7rem}.modal-divider{background:var(--border);height:1px;margin:16px 0}.modal-body p{color:var(--muted);margin-bottom:8px;font-size:.82rem;line-height:1.7}.modal-body p:last-child{margin-bottom:0}.modal-techs{border-top:1px solid var(--border);flex-wrap:wrap;gap:4px;margin-top:16px;padding-top:12px;display:flex}.modal-tech-tag{font-family:var(--mono);border:1px solid var(--border);color:var(--muted);border-radius:2px;padding:2px 8px;font-size:.6rem}@media (width<=680px){.hero-name{font-size:1.7rem}.hero-meta{flex-wrap:wrap}.edu-school{font-size:1rem}.exp-timeline{padding-left:20px}.proj-num,.nav-dots{display:none}.section{min-height:100dvh;min-height:-webkit-fill-available;padding:56px 0}.modal-content{max-width:100%;max-height:85dvh;margin:0 8px;padding:28px 20px 24px}.cert-name{white-space:normal}}
