:root{--color-bg:#0f172a;--color-bg-alt:#1e293b;--color-surface:#1e293b80;--color-text:#e2e8f0;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-accent:#5eead4;--color-accent-muted:#5eead41a;--color-link:#e2e8f0;--color-link-hover:#5eead4;--color-border:#94a3b81a;--color-card-hover:#94a3b80f;--color-tag-bg:#5eead41a;--color-tag-text:#5eead4;--font-sans:"Inter", "Noto Sans SC", system-ui, -apple-system, sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--space-4xl:96px;--max-width:960px;--header-height:auto;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--mouse-x:50%;--mouse-y:50%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text-secondary);min-height:100vh;font-size:15px;line-height:1.7;position:relative}.spotlight{pointer-events:none;z-index:1;background:radial-gradient(600px circle at var(--mouse-x) var(--mouse-y), #1d4ed81f, transparent 40%);transition:background .15s;position:fixed;inset:0}.particle-canvas{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;inset:0}.bg-glow{pointer-events:none;z-index:0;filter:blur(120px);opacity:0;border-radius:50%;animation:2.5s forwards glowFadeIn;position:fixed}.bg-glow--teal{background:#5eead440;width:700px;height:700px;animation-delay:.3s;top:-200px;right:-150px}.bg-glow--purple{background:#7c3aed33;width:600px;height:600px;animation-delay:.8s;bottom:15%;left:-200px}.bg-glow--blue{background:#38bdf826;width:500px;height:500px;animation-delay:1.2s;top:50%;right:-120px}@keyframes glowFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.top-header{z-index:50;background:var(--color-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);position:sticky;top:0}.top-header__inner{max-width:var(--max-width);padding:var(--space-2xl) var(--space-lg) var(--space-lg);gap:var(--space-md);flex-direction:column;margin:0 auto;display:flex}.top-header__brand{align-items:baseline;gap:var(--space-lg);display:flex}.top-header__name{color:var(--color-text);letter-spacing:-1px;white-space:nowrap;font-size:42px;font-weight:700;line-height:1.1}.top-header__name a{color:inherit;text-decoration:none}.gradient-name{background:linear-gradient(135deg,#5eead4 0%,#818cf8 50%,#c084fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.top-header__title{color:var(--color-accent);white-space:nowrap;font-size:20px;font-weight:500}.top-header__tagline{color:var(--color-text-secondary);max-width:600px;font-size:14px;line-height:1.6}.top-header__contact{align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:16px;line-height:1.6;display:flex}.top-header__contact-divider{opacity:.3}.scroll-reveal{opacity:0;transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);transform:translateY(30px)}.scroll-reveal--visible{opacity:1;transform:translateY(0)}.top-header__bottom{justify-content:space-between;align-items:center;gap:var(--space-lg);margin-top:var(--space-xs);display:flex}.nav{flex-shrink:0}.nav__list{gap:var(--space-xs);list-style:none;display:flex}.nav__link{padding:var(--space-md) var(--space-xl);color:var(--color-text-muted);letter-spacing:.5px;transition:all var(--transition-normal);cursor:pointer;border-radius:10px;align-items:center;font-size:26px;font-weight:600;text-decoration:none;display:inline-flex;position:relative}.nav__link:after{content:"";background:var(--color-accent);width:0;height:2px;transition:width var(--transition-normal);border-radius:1px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.nav__link:hover{color:var(--color-accent)}.nav__link:hover:after{width:50%}.nav__link.active{color:var(--color-accent)}.nav__link.active:after{width:60%}.social-links{gap:var(--space-md);align-items:center;display:flex}.social-link{color:var(--color-text-muted);transition:color var(--transition-normal);justify-content:center;align-items:center;display:flex}.social-link:hover{color:var(--color-accent)}.main-content{z-index:2;max-width:var(--max-width);padding:var(--space-3xl) var(--space-lg) var(--space-2xl);margin:0 auto;position:relative}.section{margin-bottom:var(--space-4xl);scroll-margin-top:200px}.section:last-child{margin-bottom:var(--space-2xl)}.section__label{letter-spacing:.5px;color:var(--color-text);margin-bottom:var(--space-xl);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-border);align-items:center;gap:var(--space-sm);font-size:20px;font-weight:700;display:flex}.section__label:before{content:"";background:var(--color-accent);border-radius:2px;flex-shrink:0;width:4px;height:20px}.about__stats{gap:var(--space-md);margin-bottom:var(--space-2xl);grid-template-columns:repeat(4,1fr);display:grid}.about__stat{padding:var(--space-lg) var(--space-md);-webkit-backdrop-filter:blur(8px);background:linear-gradient(160deg,#1e293b80 0%,#0f172a99 100%);border:1px solid #94a3b814;border-radius:14px;flex-direction:column;align-items:center;gap:6px;transition:all .3s;display:flex}.about__stat:hover{border-color:#5eead433;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.about__stat-value{letter-spacing:-.5px;background:linear-gradient(135deg,#5eead4 0%,#818cf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800;line-height:1.1}.about__stat-label{color:var(--color-text-muted);letter-spacing:.3px;white-space:nowrap;font-size:13px;font-weight:500}.about__text{gap:var(--space-md);flex-direction:column;display:flex}.about__paragraph{font-size:15px;line-height:1.8}.about__highlight{color:var(--color-text);font-weight:600}.about__paragraph a,.text-link{color:var(--color-text);transition:color var(--transition-fast);font-weight:500;text-decoration:none;position:relative}.about__paragraph a:after,.text-link:after{content:"";background:var(--color-accent);opacity:0;width:100%;height:1px;transition:opacity var(--transition-fast);position:absolute;bottom:-1px;left:0}.about__paragraph a:hover,.text-link:hover{color:var(--color-accent)}.about__paragraph a:hover:after,.text-link:hover:after{opacity:1}.experience__list{gap:var(--space-md);flex-direction:column;display:flex}.experience__item{gap:var(--space-lg);padding:var(--space-lg);transition:all var(--transition-normal);cursor:pointer;color:inherit;border:1px solid var(--color-border);background:var(--color-bg-alt);border-radius:12px;grid-template-columns:120px 1fr;text-decoration:none;display:grid;position:relative}.experience__item:hover{background:#1e293bcc;border-color:#5eead459;transform:translateY(-4px);box-shadow:0 12px 40px -8px #00000080,0 0 24px #5eead414}.experience__item:hover .experience__title{color:var(--color-accent)}.experience__period{color:var(--color-text-muted);letter-spacing:.5px;white-space:nowrap;padding-top:4px;font-size:12px;font-weight:600}.experience__content{gap:var(--space-sm);flex-direction:column;display:flex}.experience__title{color:var(--color-text);transition:color var(--transition-fast);align-items:center;gap:6px;font-size:16px;font-weight:600;line-height:1.3;display:inline-flex}.experience__title .arrow{transition:transform var(--transition-fast);font-size:12px;display:inline-block}.experience__item:hover .experience__title .arrow{transform:translate(3px,-3px)}.experience__company{font-weight:400}.experience__description{color:var(--color-text-secondary);font-size:14px;line-height:1.6}.experience__links{gap:var(--space-md);margin-top:var(--space-xs);flex-wrap:wrap;display:flex}.experience__ext-link{color:var(--color-text);transition:color var(--transition-fast);align-items:center;gap:4px;font-size:13px;text-decoration:none;display:inline-flex}.experience__ext-link:hover{color:var(--color-accent)}.experience__ext-link svg{width:13px;height:13px}.tags{gap:var(--space-sm);margin-top:var(--space-sm);flex-wrap:wrap;display:flex}.tag{color:var(--color-tag-text);background:var(--color-tag-bg);white-space:nowrap;border-radius:9999px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.resume-link{align-items:center;gap:var(--space-sm);margin-top:var(--space-lg);padding:var(--space-lg);color:var(--color-text);transition:color var(--transition-fast);font-size:15px;font-weight:600;text-decoration:none;display:inline-flex}.resume-link:hover{color:var(--color-accent)}.resume-link .arrow{transition:transform var(--transition-fast);display:inline-block}.resume-link:hover .arrow{transform:translate(4px)}.projects__list{gap:var(--space-2xl);flex-direction:column;display:flex}.project__card{align-items:center;gap:var(--space-md);cursor:pointer;color:inherit;background:0 0;border:none;grid-template-columns:400px 1fr;text-decoration:none;transition:transform .4s cubic-bezier(.16,1,.3,1);display:grid;position:relative;overflow:visible}.project__card:before,.project__card-shine{display:none}.project__card:hover{transform:translateY(-4px)}.project__media{flex-shrink:0;align-items:flex-start;display:flex}.project__media-inner{aspect-ratio:16/10;background:linear-gradient(135deg,#0a0f1a 0%,#111827 100%);border:1px solid #94a3b81a;border-radius:16px;width:100%;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;box-shadow:0 4px 24px #0006,inset 0 1px #ffffff0a}.project__card:hover .project__media-inner{border-color:#5eead440;box-shadow:0 12px 40px #00000080,0 0 30px #5eead414,inset 0 1px #ffffff0f}.project__media-inner img,.project__media-inner video{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.16,1,.3,1)}.project__card:hover .project__media-inner img,.project__card:hover .project__media-inner video{transform:scale(1.04)}.project__media-placeholder{opacity:.2;justify-content:center;align-items:center;width:100%;height:100%;font-size:32px;display:flex}.project__play-hint{opacity:1;background:#0000004d;justify-content:center;align-items:center;transition:all .4s;display:flex;position:absolute;inset:0}.project__play-hint svg{color:#ffffffe6;filter:drop-shadow(0 2px 12px #0009);width:44px;height:44px;transition:all .3s}.project__card:hover .project__play-hint{opacity:0}.project__detail{padding:var(--space-xl) var(--space-2xl);justify-content:center;gap:var(--space-md);-webkit-backdrop-filter:blur(12px);background:linear-gradient(160deg,#1e293b8c 0%,#0f172ab3 100%);border:1px solid #94a3b814;border-radius:16px;flex-direction:column;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;box-shadow:inset 0 1px #ffffff08}.project__card:hover .project__detail{background:linear-gradient(160deg,#1e293bb3 0%,#0f172ad9 100%);border-color:#5eead433;box-shadow:0 8px 32px #0000004d,0 0 20px #5eead40a,inset 0 1px #ffffff0d}.project__detail-header{gap:var(--space-sm);flex-direction:column;display:flex}.project__index{letter-spacing:2px;color:var(--color-accent);opacity:.5;font-family:Inter,monospace;font-size:13px;font-weight:700}.project__title{color:var(--color-text);flex-wrap:wrap;align-items:center;gap:8px;font-size:18px;font-weight:700;line-height:1.4;transition:color .3s;display:inline-flex}.project__title .arrow{color:var(--color-accent);opacity:0;font-size:14px;transition:all .3s cubic-bezier(.16,1,.3,1);display:inline-flex;transform:translate(-4px,4px)}.project__card:hover .project__title{color:var(--color-accent)}.project__card:hover .project__title .arrow{opacity:1;transform:translate(0)}.project__description{color:var(--color-text-secondary);font-size:14px;line-height:1.75;overflow:hidden}.project__footer{margin-top:auto}.project__footer .tags{margin-top:var(--space-sm)}#videos{position:relative}.videos__grid{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.video__card{border:1px solid var(--color-border);background:var(--color-bg-alt);transition:all var(--transition-normal);cursor:pointer;border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.video__card:hover{border-color:#5eead459;transform:translateY(-4px);box-shadow:0 12px 40px -8px #00000080,0 0 24px #5eead414}.video__card:hover .video__title{color:var(--color-accent)}.video__thumbnail{aspect-ratio:16/9;background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.video__thumbnail img,.video__thumbnail video{object-fit:cover;width:100%;height:100%}.video__play-icon{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:48px;height:48px;transition:all var(--transition-normal);background:#00000080;border:2px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.video__card:hover .video__play-icon{background:var(--color-accent);color:var(--color-bg);border-color:#0000;transform:scale(1.2);box-shadow:0 0 16px #5eead466}.video__play-icon svg{width:20px;height:20px;margin-left:2px}.video__thumbnail-placeholder{opacity:.25;font-size:40px}.video__content{padding:var(--space-md) var(--space-lg) var(--space-lg);gap:var(--space-xs);flex-direction:column;display:flex}.video__year{color:var(--color-text-muted);letter-spacing:.5px;font-size:12px;font-weight:600}.video__title{color:var(--color-text);transition:color var(--transition-fast);font-size:15px;font-weight:600;line-height:1.3}.video__description{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.theater-overlay{z-index:9999;-webkit-backdrop-filter:blur(20px);cursor:pointer;background:#000000eb;justify-content:center;align-items:center;animation:.35s cubic-bezier(.16,1,.3,1) theaterFadeIn;display:flex;position:fixed;inset:0}@keyframes theaterFadeIn{0%{opacity:0}to{opacity:1}}.theater-content{cursor:default;flex-direction:column;width:72vw;max-width:1200px;max-height:90vh;animation:.4s cubic-bezier(.16,1,.3,1) theaterSlideUp;display:flex;position:relative}@keyframes theaterSlideUp{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.theater-player{aspect-ratio:16/9;background:#000;border-radius:16px 16px 0 0;width:100%;position:relative;overflow:hidden;box-shadow:0 30px 80px -20px #000c,0 0 60px #5eead40f}.theater-player video{object-fit:contain;background:#000;width:100%;height:100%}.theater-info{padding:var(--space-lg) var(--space-xl);-webkit-backdrop-filter:blur(12px);background:linear-gradient(#1e293bf2 0%,#0f172afa 100%);border:1px solid #94a3b814;border-top:none;border-radius:0 0 16px 16px}.theater-info__header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.theater-info__title{color:var(--color-text);font-size:20px;font-weight:700;line-height:1.3}.theater-info__counter{color:var(--color-accent);opacity:.6;letter-spacing:1px;white-space:nowrap;margin-left:var(--space-lg);font-family:Inter,monospace;font-size:13px;font-weight:600}.theater-info__description{color:var(--color-text-secondary);margin-bottom:var(--space-md);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:14px;line-height:1.7;display:-webkit-box;overflow:hidden}.theater-info .tags{margin-top:var(--space-xs)}.theater-close{z-index:10001;color:#ffffffb3;cursor:pointer;-webkit-backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff0f;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .25s;display:flex;position:fixed;top:24px;right:28px}.theater-close:hover{color:#fff;background:#ffffff26;border-color:#ffffff26;transform:scale(1.1)}.theater-nav{z-index:10001;color:#fff9;cursor:pointer;-webkit-backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff0f;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:50%;transform:translateY(-50%)}.theater-nav:hover{color:var(--color-accent);background:#5eead426;border-color:#5eead44d;transform:translateY(-50%)scale(1.12);box-shadow:0 0 24px #5eead426}.theater-nav--prev{left:24px}.theater-nav--next{right:24px}.theater-nav--prev:hover{transform:translateY(-50%)scale(1.12)translate(-3px)}.theater-nav--next:hover{transform:translateY(-50%)scale(1.12)translate(3px)}.footer{margin-top:var(--space-3xl);padding:var(--space-xl) 0;border-top:1px solid var(--color-border);color:var(--color-text-muted);text-align:center;font-size:13px;line-height:1.8}.footer a{color:var(--color-text-secondary);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.footer a:hover{color:var(--color-accent)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.top-header__inner{padding:var(--space-lg) var(--space-md) var(--space-md)}.top-header__brand{gap:var(--space-xs);flex-direction:column}.top-header__name{font-size:24px}.top-header__bottom{align-items:flex-start;gap:var(--space-md);flex-direction:column}.nav__list{flex-wrap:wrap}.nav__link{padding:var(--space-xs) var(--space-sm);font-size:12px}.main-content{padding:var(--space-xl) var(--space-md) var(--space-lg)}.about__stats{grid-template-columns:repeat(2,1fr)}.about__stat-value{font-size:22px}.section{scroll-margin-top:260px}.section__label{font-size:18px}.experience__item{gap:var(--space-sm);grid-template-columns:1fr}.experience__period{font-size:11px}.project__card{gap:var(--space-md);grid-template-columns:1fr}.project__detail{padding:var(--space-lg)}.videos__grid{grid-template-columns:1fr}.theater-content{width:95vw}.theater-nav{width:40px;height:40px}.theater-nav--prev{left:8px}.theater-nav--next{right:8px}.theater-info__title{font-size:16px}}@media (max-width:480px){.top-header__name{font-size:20px}.top-header__title{font-size:14px}.top-header__tagline{font-size:13px}}::selection{color:var(--color-text);background:#5eead433}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}
