:root{--color-bg:#ffffff;--color-bg-alt:#fafafa;--color-bg-dark:#0a0a0a;--color-text:#0a0a0a;--color-text-light:#666666;--color-text-muted:#999999;--color-border:#e5e5e5;--color-border-dark:#1a1a1a;--color-accent:#0a0a0a;--color-accent-hover:#333333;--color-gold:#c9a227;--color-silver:#8a8a8a;--color-bronze:#cd7f32;--font-primary:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:'JetBrains Mono','Fira Code',monospace;--space-xs:0.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2rem;--space-xl:3rem;--space-2xl:5rem;--transition-fast:0.2s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease;}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}html{scroll-behavior:smooth;font-size:16px;height:100%;}body{font-family:var(--font-primary);font-weight:400;line-height:1.6;color:var(--color-text);background-color:var(--color-bg-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100%;}a{text-decoration:none;color:inherit;}ul{list-style:none;}img{max-width:100%;display:block;}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-lg);}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:var(--space-md) 0;transition:var(--transition-normal);}.navbar.scrolled{background-color:rgba(255,255,255,0.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border);padding:var(--space-sm) 0;}.navbar.dark-mode{background-color:rgba(10,10,10,0.95);border-bottom:1px solid rgba(255,255,255,0.1);}.navbar.dark-mode .brand-text,.navbar.dark-mode .nav-link{color:#ffffff;}.navbar.dark-mode .nav-link::after{background-color:#ffffff;}.navbar.dark-mode .nav-toggle span{background-color:#ffffff;}@media (max-width:768px){.navbar.dark-mode .nav-links{background-color:#0a0a0a;}.navbar.dark-mode .nav-links .nav-link{color:#ffffff !important;}.navbar.dark-mode .nav-links li{border-bottom-color:rgba(255,255,255,0.1);}}.navbar .container{display:flex;align-items:center;justify-content:space-between;}.nav-brand{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-weight:600;}.nav-brand .logo{font-size:1.5rem;color:var(--color-accent);}.brand-text{font-size:0.875rem;letter-spacing:0.1em;}.nav-links{display:flex;gap:var(--space-lg);}.nav-link{font-size:0.875rem;font-weight:500;letter-spacing:0.02em;position:relative;padding:var(--space-xs) 0;}.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--color-accent);transition:var(--transition-normal);}.nav-link:hover::after{width:100%;}.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-xs);}.nav-toggle span{display:block;width:25px;height:2px;background-color:var(--color-text);transition:var(--transition-fast);}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;padding:calc(var(--space-2xl) * 2) 0 var(--space-2xl);background:radial-gradient(ellipse at 20% 30%,rgba(10,10,10,0.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(10,10,10,0.05) 0%,transparent 50%),linear-gradient(135deg,#ffffff 0%,#fafafa 50%,#f5f5f5 100%);overflow:hidden;}.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 49.5%,rgba(10,10,10,0.03) 49.5%,rgba(10,10,10,0.03) 50.5%,transparent 50.5%),linear-gradient(0deg,transparent 49.5%,rgba(10,10,10,0.03) 49.5%,rgba(10,10,10,0.03) 50.5%,transparent 50.5%);background-size:100px 100px;pointer-events:none;}.hero::after{content:'';position:absolute;top:-50%;right:-20%;width:80%;height:200%;background:radial-gradient(ellipse,rgba(10,10,10,0.08) 0%,transparent 70%);transform:rotate(-15deg);pointer-events:none;}.hero .container{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-2xl);align-items:center;}.hero-subtitle{font-family:var(--font-mono);font-size:0.875rem;color:var(--color-text-light);letter-spacing:0.1em;margin-bottom:var(--space-md);text-transform:uppercase;}.hero-title{font-size:clamp(3rem,8vw,6rem);font-weight:700;line-height:1.1;margin-bottom:var(--space-lg);}.hero-title .highlight{font-family:'Pacifico',cursive;color:var(--color-text);-webkit-text-stroke:0;font-weight:400;letter-spacing:0;}.developer-text{display:inline-block;font-size:clamp(3rem,8vw,6rem);font-weight:700;white-space:nowrap;}.dev-letter{display:inline-block;transition:transform 0.2s ease,font-family 0.1s ease;}.hero-description{font-size:1.125rem;color:var(--color-text-light);margin-bottom:var(--space-xl);max-width:500px;}.hero-buttons{display:flex;gap:var(--space-md);}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);font-size:0.9375rem;font-weight:500;border-radius:0;cursor:pointer;transition:var(--transition-normal);border:2px solid var(--color-accent);}.btn-primary{background-color:var(--color-accent);color:var(--color-bg);}.btn-primary:hover{background-color:transparent;color:var(--color-accent);}.btn-outline{background-color:transparent;color:var(--color-accent);}.btn-outline:hover{background-color:var(--color-accent);color:var(--color-bg);}.hero-profile{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);}.vinyl-wrapper{position:relative;width:200px;height:200px;}.profile-image-container{position:relative;width:200px;height:200px;border-radius:50%;overflow:hidden;border:none;box-shadow:0 0 0 3px var(--color-text),0 20px 40px rgba(0,0,0,0.1);animation:vinylRotate 8s linear infinite;-webkit-backface-visibility:hidden;backface-visibility:hidden;}@keyframes vinylRotate{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}.profile-image{width:100%;height:100%;object-fit:cover;}.profile-image-container:hover{animation-play-state:paused;}.profile-links{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%;}.profile-label{font-family:var(--font-mono);font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--color-text-muted);position:relative;}.profile-label::before,.profile-label::after{content:'';position:absolute;top:50%;width:40px;height:1px;background-color:var(--color-border);}.profile-label::before{right:calc(100% + var(--space-sm));}.profile-label::after{left:calc(100% + var(--space-sm));}.social-links{display:flex;gap:var(--space-md);}.social-link{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);font-size:0.875rem;font-weight:500;transition:var(--transition-normal);}.social-link svg{width:20px;height:20px;}.social-link:hover{border-color:var(--color-text);background-color:var(--color-text);color:var(--color-bg);}.project-links-row{flex-direction:column;align-items:stretch;width:100%;max-width:280px;gap:var(--space-sm);}.project-label{margin-top:var(--space-md);}.project-link-btn{width:100%;justify-content:center;min-width:unset;}.hero-stats{display:flex;flex-direction:column;gap:var(--space-xl);grid-column:1 / -1;margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border);}.stat-item{display:flex;flex-direction:column;gap:var(--space-xs);}.stat-number{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1;}.stat-label{font-size:0.875rem;color:var(--color-text-light);letter-spacing:0.05em;}.hero-scroll{position:absolute;bottom:var(--space-xl);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);}.hero-scroll span{font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--color-text-muted);}.scroll-line{width:1px;height:60px;background:linear-gradient(180deg,var(--color-text) 0%,transparent 100%);animation:scrollPulse 2s ease-in-out infinite;}@keyframes scrollPulse{0%,100%{opacity:0.3;transform:scaleY(0.8);}50%{opacity:1;transform:scaleY(1);}}section{padding:var(--space-2xl) 0;}.section-header{margin-bottom:var(--space-2xl);}.section-label{display:block;font-family:var(--font-mono);font-size:0.875rem;color:var(--color-text-muted);letter-spacing:0.1em;margin-bottom:var(--space-sm);}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.2;}.about{background-color:var(--color-bg-dark);color:#ffffff;}.about .section-label{color:rgba(255,255,255,0.5);}.about .section-title{color:#ffffff;}.education-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);}.education-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background-color:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);transition:opacity 0.6s ease,transform 0.6s ease;}.education-card.animate-in{opacity:1;transform:translateY(0);}.education-card:hover{border-color:rgba(255,255,255,0.3);box-shadow:8px 8px 0 rgba(255,255,255,0.1);background-color:rgba(255,255,255,0.08);}.edu-icon{color:#ffffff;flex-shrink:0;}.edu-content h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-xs);color:#ffffff;}.edu-period{font-size:0.875rem;color:rgba(255,255,255,0.6);}.skills{background-color:var(--color-bg-alt);}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-md);}.skill-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg);background-color:var(--color-bg);border:1px solid var(--color-border);transition:opacity 0.6s ease,transform 0.6s ease,border-color 0.3s ease;}.skill-card.animate-in{opacity:1;transform:translateY(0);}.skill-card:hover{border-color:var(--color-text);transform:translateY(-4px);}.skill-icon{width:40px;height:40px;margin-bottom:var(--space-sm);color:var(--color-accent);}.skill-icon svg{width:100%;height:100%;}.skill-name{font-size:0.9375rem;font-weight:500;}.awards{background-color:var(--color-bg-dark);color:#ffffff;}.awards .section-label{color:rgba(255,255,255,0.5);}.awards .section-title{color:#ffffff;}.awards .year{color:#ffffff;}.awards .year-line{background-color:rgba(255,255,255,0.2);}.awards .award-prize{color:rgba(255,255,255,0.9);}.awards .award-name{color:rgba(255,255,255,0.85);}.awards .award-item{border-bottom-color:rgba(255,255,255,0.08);}.award-year{margin-bottom:var(--space-2xl);}.award-year:last-child{margin-bottom:0;}.year-title{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);font-size:1.25rem;font-weight:700;}.year{font-family:var(--font-mono);color:var(--color-text);}.year-line{flex:1;height:1px;background-color:var(--color-border);}.awards-list{display:flex;flex-direction:column;border-left:2px solid rgba(255,255,255,0.12);margin-left:8px;padding-left:var(--space-lg);}.award-item{display:flex;align-items:baseline;flex-wrap:wrap;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid rgba(255,255,255,0.05);transition:background-color 0.2s ease;}.award-item:last-child{border-bottom:none;}.award-item:hover{background-color:rgba(255,255,255,0.03);}.award-prize{font-size:0.8125rem;font-weight:700;white-space:nowrap;}.award-prize.대상,.award-prize.최우수상,.award-prize.최우우상,.award-prize.장관상{color:#c4a35a;}.award-prize.금상{color:#FFD700;}.award-prize.은상{color:#C0C0C0;}.award-prize.동상{color:#CD7F32;}.award-prize.우수상{color:#4A90E2;}.award-prize.장려상{color:#50C878;}.award-prize.탐색상,.award-prize.Exploration{color:#E040FB;}.award-prize.인기상,.award-prize.Popularity{color:#FF4081;}.award-name{font-size:0.9375rem;font-weight:500;line-height:1.5;flex:1;min-width:200px;}.award-level{font-size:0.75rem;color:var(--color-text-light);background-color:var(--color-bg-alt);padding:2px 8px;border-radius:4px;white-space:nowrap;}.certifications{background-color:var(--color-bg-dark);color:#ffffff;}.certifications .section-label{color:rgba(255,255,255,0.5);}.certifications .section-title{color:#ffffff;}.cert-card{display:flex;flex-direction:row;align-items:center;justify-content:space-between;background-color:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:12px;transition:var(--transition-normal);transform:translateY(20px);padding:var(--space-md);}.cert-card.animate-in{opacity:1;transform:translateY(0);}.cert-card:hover{border-color:rgba(255,255,255,0.2);transform:translateY(-4px);background-color:rgba(255,255,255,0.08);}.cert-badge{font-family:var(--font-mono);font-size:0.75rem;font-weight:600;letter-spacing:0.05em;padding:4px 12px;background-color:#ffffff;color:#0a0a0a;}.cert-body h3{font-size:0.9375rem;font-weight:500;line-height:1.5;color:#ffffff;}.cert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md);}.cert-card{display:flex;flex-direction:row;align-items:center;justify-content:space-between;background-color:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:12px;transition:var(--transition-normal);transform:translateY(20px);padding:var(--space-md);}.cert-card.animate-in{opacity:1;transform:translateY(0);}.cert-card:hover{border-color:rgba(255,255,255,0.2);transform:translateY(-4px);background-color:rgba(255,255,255,0.08);}.cert-badge{font-family:var(--font-mono);font-size:0.75rem;font-weight:600;letter-spacing:0.05em;padding:4px 12px;background-color:#ffffff;color:#0a0a0a;}.cert-body h3{font-size:0.9375rem;font-weight:500;line-height:1.5;color:#ffffff;}.cert-card.animate-in{opacity:1;transform:translateY(0);}.cert-card:hover{border-color:var(--color-text);transform:translateY(-4px);}.cert-header{order:2;display:flex;justify-content:flex-end;}.cert-badge{font-family:var(--font-mono);font-size:0.75rem;font-weight:600;letter-spacing:0.05em;padding:4px 12px;background-color:var(--color-text);color:var(--color-bg);}.cert-body{order:1;flex:1;display:flex;align-items:center;}.cert-body h3{font-size:0.9375rem;font-weight:500;line-height:1.5;}.talent{background-color:var(--color-bg);color:var(--color-text);}.talent .section-label{color:var(--color-accent);}.talent .section-title{color:var(--color-text);}.talent .timeline::before{background-color:var(--color-border);}.talent .timeline-marker{background-color:var(--color-bg);border-color:var(--color-text);}.talent .timeline-year{color:rgba(0,0,0,0.6);}.talent .timeline-content p{color:var(--color-text);}.timeline{position:relative;padding-left:var(--space-xl);}.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background-color:var(--color-border);}.timeline-item{position:relative;padding-bottom:var(--space-xl);transform:translateY(20px);}.timeline-item:last-child{padding-bottom:0;}.timeline-item.animate-in{opacity:1;transform:translateY(0);}.timeline-marker{position:absolute;left:calc(-1 * var(--space-xl));top:4px;width:11px;height:11px;background-color:var(--color-bg);border:2px solid var(--color-accent);border-radius:50%;transform:translateX(-5px);}.timeline-content{padding-left:var(--space-md);}.timeline-year{font-family:var(--font-mono);font-size:0.875rem;font-weight:600;color:var(--color-accent);display:block;margin-bottom:var(--space-xs);}.timeline-content p{font-size:1rem;color:var(--color-text);line-height:1.6;}.footer{background-color:var(--color-bg-dark);color:var(--color-bg);padding:var(--space-xl) 0;}.footer-content{display:flex;justify-content:space-between;align-items:center;}.footer-brand{display:flex;align-items:center;gap:var(--space-sm);}.footer-brand .logo{font-family:var(--font-mono);font-size:1.5rem;color:var(--color-bg);}.footer-brand p{font-size:0.875rem;color:var(--color-text-muted);}.footer-copy{font-size:0.875rem;color:var(--color-text-muted);}@media (max-width:768px){.nav-links{position:fixed;top:0;right:-100%;width:70%;max-width:300px;height:100vh;background-color:var(--color-bg);flex-direction:column;padding:calc(var(--space-2xl) + 60px) var(--space-lg) var(--space-lg);gap:0;transition:var(--transition-normal);border-left:1px solid var(--color-border);z-index:1002;}.nav-links{background-color:#ffffff;}.nav-links.active{right:0;}.nav-links .nav-link{color:#0a0a0a !important;}.nav-links li{border-bottom:1px solid var(--color-border);}.nav-link{display:block;padding:var(--space-md) 0;font-size:1rem;}.nav-toggle{display:flex;z-index:1001;}.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}.nav-toggle.active span:nth-child(2){}.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}.hero .container{grid-template-columns:1fr;gap:var(--space-xl);}.hero-profile{order:-1;}.profile-image-container{width:160px;height:160px;}.hero-stats{flex-direction:row;justify-content:space-between;margin-top:var(--space-xl);}.footer-content{flex-direction:column;gap:var(--space-md);text-align:center;}}@media (max-width:480px){.container{padding:0 var(--space-md);}.hero-title{font-size:2.5rem;}.hero-buttons{flex-direction:column;}.btn{width:100%;}.profile-image-container{width:140px;height:140px;}.social-links{flex-direction:column;width:100%;}.social-link{justify-content:center;}.project-links{max-width:100%;}.stat-number{font-size:2rem;}.award-item{flex-direction:column;text-align:center;}.timeline{padding-left:var(--space-lg);}.timeline-marker{left:calc(-1 * var(--space-lg));}}@keyframes fadeInUp{from{}to{opacity:1;transform:translateY(0);}}.animate-in{animation:fadeInUp 0.6s ease forwards;}.education-card:nth-child(1){transition-delay:0.1s;}.education-card:nth-child(2){transition-delay:0.2s;}.skill-card:nth-child(1){transition-delay:0.05s;}.skill-card:nth-child(2){transition-delay:0.1s;}.skill-card:nth-child(3){transition-delay:0.15s;}.skill-card:nth-child(4){transition-delay:0.2s;}.skill-card:nth-child(5){transition-delay:0.25s;}.skill-card:nth-child(6){transition-delay:0.3s;}.skill-card:nth-child(7){transition-delay:0.35s;}.cert-card:nth-child(1){transition-delay:0.05s;}.cert-card:nth-child(2){transition-delay:0.1s;}.cert-card:nth-child(3){transition-delay:0.15s;}.cert-card:nth-child(4){transition-delay:0.2s;}.cert-card:nth-child(5){transition-delay:0.25s;}.cert-card:nth-child(6){transition-delay:0.3s;}.timeline-item:nth-child(1){transition-delay:0.1s;}.timeline-item:nth-child(2){transition-delay:0.2s;}.timeline-item:nth-child(3){transition-delay:0.3s;}.timeline-item:nth-child(4){transition-delay:0.4s;}.page-hero{min-height:40vh;display:flex;align-items:center;padding:calc(120px + var(--space-2xl)) 0 var(--space-2xl);background-color:var(--color-bg-dark);color:#ffffff;}.page-hero .section-label{color:rgba(255,255,255,0.5);}.page-title{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;line-height:1.1;color:#ffffff;margin-bottom:var(--space-md);}.page-subtitle{font-size:1.125rem;color:rgba(255,255,255,0.6);max-width:600px;line-height:1.6;}.repos-section{padding:var(--space-2xl) 0;background-color:var(--color-bg-dark);}.repo-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg);max-width:800px;margin:0 auto;}.repo-card{display:block;text-decoration:none;color:inherit;position:relative;border:1px solid rgba(255,255,255,0.1);background-color:rgba(255,255,255,0.05);transition:var(--transition-normal);overflow:hidden;}.repo-card:hover{border-color:rgba(255,255,255,0.3);transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,0.3);background-color:rgba(255,255,255,0.08);}.repo-card-inner{padding:var(--space-lg);position:relative;z-index:1;}.repo-card-featured{border:2px solid rgba(255,255,255,0.3);}.repo-card-featured:hover{box-shadow:0 20px 50px rgba(0,0,0,0.4);}.repo-card-glow{position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(90deg,#ff006e,#8338ec,#3a86ff,#06ffa5,#ffbe0b,#ff006e);background-size:300% 100%;animation:borderRotate 4s linear infinite;z-index:0;opacity:0;transition:opacity 0.3s ease;}.repo-card-featured:hover .repo-card-glow{opacity:1;}.repo-featured-badge{display:inline-block;font-family:var(--font-mono);font-size:0.7rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:#ffffff;background:linear-gradient(135deg,#0a0a0a 0%,#333333 100%);padding:4px 12px;margin-bottom:var(--space-md);}.repo-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);}.repo-icon{width:20px;height:20px;color:rgba(255,255,255,0.6);flex-shrink:0;}.repo-name{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;color:#ffffff;}.repo-desc{font-size:0.9375rem;color:rgba(255,255,255,0.6);margin-bottom:var(--space-md);line-height:1.5;}.repo-meta{display:flex;align-items:center;gap:var(--space-md);font-size:0.8125rem;color:rgba(255,255,255,0.4);}.repo-lang{display:flex;align-items:center;gap:6px;}.lang-dot{display:inline-block;width:12px;height:12px;border-radius:50%;}.lang-python{background-color:#3572A5;}.lang-html{background-color:#e34c26;}.blog-section{padding:var(--space-2xl) 0;background-color:var(--color-bg-dark);}.blog-list{display:grid;grid-template-columns:1fr;gap:var(--space-md);max-width:800px;margin:0 auto;}.blog-card{display:block;text-decoration:none;color:inherit;border:1px solid rgba(255,255,255,0.1);background-color:rgba(255,255,255,0.05);transition:var(--transition-normal);}.blog-card:hover{border-color:rgba(255,255,255,0.3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3);background-color:rgba(255,255,255,0.08);}.blog-card-inner{padding:var(--space-lg);}.blog-card-meta{margin-bottom:var(--space-sm);}.blog-date{font-family:var(--font-mono);font-size:0.75rem;color:rgba(255,255,255,0.5);letter-spacing:0.05em;}.blog-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-xs);line-height:1.3;color:#ffffff;}.blog-preview{font-size:0.875rem;color:rgba(255,255,255,0.6);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}.blog-empty{text-align:center;padding:var(--space-2xl) 0;color:rgba(255,255,255,0.4);}.blog-empty svg{opacity:0.3;margin-bottom:var(--space-md);}.blog-empty p{font-size:1rem;}.blog-post{padding:calc(120px + var(--space-2xl)) 0 var(--space-2xl);background-color:var(--color-bg-dark);color:#ffffff;}.blog-post-header{margin-bottom:var(--space-2xl);padding-bottom:var(--space-lg);border-bottom:1px solid rgba(255,255,255,0.1);}.blog-back{font-family:var(--font-mono);font-size:0.8125rem;color:rgba(255,255,255,0.5);letter-spacing:0.05em;text-decoration:none;display:inline-block;margin-bottom:var(--space-md);transition:color 0.3s ease;}.blog-back::before{content:'← ';}.blog-back:hover{color:#ffffff;}.blog-post-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.2;margin-bottom:var(--space-sm);color:#ffffff;}.blog-post-date{font-family:var(--font-mono);font-size:0.8125rem;color:rgba(255,255,255,0.5);}.blog-post-content{max-width:100%;font-size:1.0625rem;line-height:1.8;color:rgba(255,255,255,0.85);}.blog-post-content h1,.blog-post-content h2,.blog-post-content h3{font-weight:700;margin-top:var(--space-xl);margin-bottom:var(--space-sm);line-height:1.3;color:#ffffff;}.blog-post-content h1{font-size:2rem;}.blog-post-content h2{font-size:1.5rem;}.blog-post-content h3{font-size:1.25rem;}.blog-post-content p{margin-bottom:var(--space-md);}.blog-post-content code{font-family:var(--font-mono);background-color:rgba(255,255,255,0.1);padding:2px 6px;font-size:0.9em;border-radius:3px;color:#ffffff;}.blog-post-content pre{background-color:#1a1a1a;color:#ffffff;padding:var(--space-lg);overflow-x:auto;margin-bottom:var(--space-md);border-radius:4px;border:1px solid rgba(255,255,255,0.1);}.blog-post-content pre code{background:none;padding:0;color:inherit;}.blog-post-content ul,.blog-post-content ol{margin-bottom:var(--space-md);padding-left:var(--space-lg);}.blog-post-content li{margin-bottom:var(--space-xs);}.blog-post-content blockquote{border-left:3px solid rgba(255,255,255,0.3);padding-left:var(--space-md);margin:var(--space-md) 0;color:rgba(255,255,255,0.6);font-style:italic;}.blog-post-content img{max-width:100%;margin:var(--space-md) 0;}.blog-post-content a{color:#ffffff;text-decoration:underline;}.blog-post-content hr{border:none;border-top:1px solid rgba(255,255,255,0.1);margin:var(--space-xl) 0;}.nav-link.active{color:var(--color-accent);font-weight:600;}.nav-link.active::after{width:100%;}.navbar.dark-mode .nav-link.active{color:#ffffff;}@media (max-width:768px){.page-hero{min-height:30vh;padding:calc(100px + var(--space-xl)) 0 var(--space-xl);}.repo-grid,.blog-list{max-width:100%;}}.entry-section{background-color:var(--color-bg);padding:var(--space-2xl) 0;}.entry-section .section-title{color:var(--color-text);}.entry-section .section-header{margin-bottom:var(--space-xl);}.entry-cards{display:flex;gap:var(--space-lg);max-width:900px;margin:0 auto;}.entry-card{flex:1;display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl);background-color:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:16px;text-decoration:none;transition:all 0.3s ease;}.entry-card:hover{border-color:#50C878;background-color:rgba(80,200,120,0.04);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,0.08);}.entry-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex-shrink:0;background-color:rgba(80,200,120,0.12);border-radius:12px;color:#50C878;}.entry-card-icon svg{width:24px;height:24px;}.entry-card-body{flex:1;display:flex;flex-direction:column;gap:4px;}.entry-card-label{font-size:0.9375rem;font-weight:600;color:var(--color-text);}.entry-card-desc{font-size:0.8125rem;color:var(--color-text-light);}.entry-card-arrow{font-size:1.25rem;color:rgba(0,0,0,0.2);transition:all 0.3s ease;}.entry-card:hover .entry-card-arrow{color:#50C878;transform:translateX(4px);}@media (max-width:768px){.entry-cards{flex-direction:column;}.entry-card{padding:var(--space-md) var(--space-lg);}}.award-item.has-portfolio{cursor:pointer;}.award-name.portfolio-link{color:#ffffff;text-decoration:none;transition:color 0.2s ease,padding-left 0.2s ease;position:relative;}.award-name.portfolio-link:hover{color:#ffffff;padding-left:4px;}.award-name.portfolio-link::after{content:' →';opacity:0;transition:opacity 0.2s ease;}.award-name.portfolio-link:hover::after{opacity:1;}.portfolio-detail{min-height:70vh;padding:120px 0 var(--space-2xl);background-color:var(--color-bg-dark);color:#ffffff;}.portfolio-header{margin-bottom:var(--space-2xl);}.portfolio-back{display:inline-block;color:rgba(255,255,255,0.5);text-decoration:none;font-size:0.875rem;margin-bottom:var(--space-md);transition:color 0.2s ease;}.portfolio-back:hover{color:#ffffff;}.portfolio-title{font-size:2rem;font-weight:700;color:#ffffff;line-height:1.4;}.portfolio-script{background-color:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:var(--space-xl);margin-bottom:var(--space-2xl);line-height:1.8;font-size:0.95rem;color:rgba(255,255,255,0.9);}.portfolio-script h1,.portfolio-script h2,.portfolio-script h3{color:#ffffff;margin-top:var(--space-lg);margin-bottom:var(--space-md);font-weight:700;}.portfolio-script h2{font-size:1.3rem;border-left:3px solid var(--color-accent);padding-left:var(--space-md);}.portfolio-script p{margin-bottom:var(--space-md);}.portfolio-script strong{color:#ffffff;}.portfolio-script a{color:#50C878;text-decoration:underline;text-underline-offset:4px;}.portfolio-script a:hover{color:#6edc9a;}.portfolio-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-md);}.portfolio-gallery-item{border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,0.08);transition:transform 0.3s ease,box-shadow 0.3s ease;}.portfolio-gallery-item:hover{transform:scale(1.02);box-shadow:0 8px 30px rgba(0,0,0,0.3);}.portfolio-gallery-item img{width:100%;height:auto;display:block;}@media (max-width:768px){.portfolio-title{font-size:1.5rem;}.portfolio-script{padding:var(--space-md);}.portfolio-gallery{grid-template-columns:1fr;}}.edu-current-tag{position:absolute;top:12px;right:12px;display:inline-block;font-size:0.65rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);padding:3px 10px;border-radius:9999px;letter-spacing:0.03em;text-transform:uppercase;animation:pulse-tag 2s ease-in-out infinite;}.education-card{position:relative;}.award-tag{font-size:0.7rem;font-weight:500;color:rgba(255,255,255,0.72);background-color:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.14);padding:2px 9px;border-radius:9999px;white-space:nowrap;letter-spacing:0.02em;}
.social-links.icon-only{gap:12px;}.social-link.icon-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:2px solid var(--color-border);transition:var(--transition-normal);}.social-link.icon-link:hover{border-color:var(--color-text);background-color:var(--color-text);color:var(--color-bg);}.social-link.icon-link svg{width:22px;height:22px;}
.social-link.icon-link:hover .solved-ac-text{fill:#0a0a0a;}
