@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg:#fafafa;--bg-white:#fff;--bg-dark:#0a0a0a;--text:#111;--text-secondary:#555;--text-muted:#999;--border:#e8e8e8;--border-light:#f0f0f0;--accent:#1a1a1a;--radius:16px;--radius-sm:10px;--transition:.3s cubic-bezier(.4, 0, .2, 1);--max-w:1100px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Noto Sans KR,-apple-system,sans-serif;line-height:1.7}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}.header{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-light);background:#fafafad9;position:fixed;top:0;left:0;right:0}.header-inner{max-width:var(--max-w);justify-content:space-between;align-items:center;height:64px;margin:0 auto;padding:0 2rem;display:flex}.header-logo{letter-spacing:.04em;color:var(--text);font-size:.95rem;font-weight:700}.header-nav{align-items:center;gap:2rem;display:flex}.header-nav a{color:var(--text-secondary);transition:color var(--transition);font-size:.85rem;font-weight:500;position:relative}.header-nav a:hover{color:var(--text)}.lang-toggle{border:1.5px solid var(--border);color:var(--text);transition:all var(--transition);letter-spacing:.04em;background:0 0;border-radius:999px;padding:6px 14px;font-size:.75rem;font-weight:600}.lang-toggle:hover{background:var(--text);color:var(--bg);border-color:var(--text)}.mobile-toggle{background:0 0;border:none;flex-direction:column;justify-content:space-between;width:24px;height:20px;padding:0;display:none}.mobile-toggle span{background:var(--text);width:100%;height:2px;transition:var(--transition);border-radius:2px;display:block}.mobile-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#fafafafa;flex-direction:column;gap:1.25rem;padding:1.5rem 2rem 2rem;display:none;position:fixed;top:64px;left:0;right:0}.mobile-nav.open{display:flex}.mobile-nav a{color:var(--text-secondary);font-size:1rem;font-weight:500}@media (width<=768px){.header-nav{display:none}.mobile-toggle{display:flex}}.hero{align-items:center;min-height:100vh;padding-top:64px;display:flex}.hero-grid{grid-template-columns:1.2fr .8fr;align-items:center;gap:3rem;width:100%;display:grid}.hero-title{letter-spacing:-.025em;white-space:pre-line;word-break:keep-all;margin-bottom:1.5rem;font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:700;line-height:1.35}.hero-desc{color:var(--text-secondary);white-space:pre-line;word-break:keep-all;max-width:480px;margin-bottom:2.5rem;font-size:.98rem;line-height:1.85}.hero-stats{gap:3rem;display:flex}.hero-stat-value{letter-spacing:-.02em;font-size:2rem;font-weight:700;line-height:1.2}.hero-stat-label{color:var(--text-muted);margin-top:4px;font-size:.8rem}.hero-anim-wrapper{justify-content:flex-end;align-items:center;display:flex}.hero-anim-wrapper .fade-up{width:320px;height:320px}@media (width<=900px){.hero-grid{text-align:center;grid-template-columns:1fr}.hero-desc{margin-left:auto;margin-right:auto}.hero-stats{justify-content:center}.hero-anim-wrapper{justify-content:center;margin-top:1rem}.hero-anim-wrapper .fade-up{width:280px;height:280px}}.section{padding:6rem 0}.section-label{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.section-title{letter-spacing:-.02em;margin-bottom:3rem;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700}.featured-item{border-bottom:1px solid var(--border-light);grid-template-columns:1fr 1fr;align-items:center;gap:3.5rem;padding:3.5rem 0;display:grid}.featured-item:last-child{border-bottom:none}.featured-item.reverse .featured-image{order:-1}.featured-image{border-radius:var(--radius);background:var(--bg-white);aspect-ratio:16/10;overflow:hidden;box-shadow:0 8px 40px #0000000f}.featured-image img{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1)}.featured-item:hover .featured-image img{transform:scale(1.03)}.featured-meta{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.featured-tag{background:var(--border-light);color:var(--text-secondary);letter-spacing:.02em;border-radius:999px;padding:4px 12px;font-size:.72rem;font-weight:600}.featured-period{color:var(--text-muted);font-size:.8rem}.featured-info h3{letter-spacing:-.01em;margin-bottom:.75rem;font-size:1.6rem;font-weight:700}.featured-info>p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.8}.featured-results{gap:2.5rem;display:flex}.result-value{letter-spacing:-.02em;font-size:1.6rem;font-weight:700;line-height:1.2}.result-label{color:var(--text-muted);margin-top:2px;font-size:.75rem}@media (width<=900px){.featured-item,.featured-item.reverse{grid-template-columns:1fr}.featured-item.reverse .featured-image{order:0}.featured-info h3{font-size:1.3rem}}.more-projects-label{margin-top:4rem}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.project-card{background:var(--bg-white);border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:transform var(--transition), box-shadow var(--transition);overflow:hidden}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px #00000014}.project-card-img{aspect-ratio:16/10;overflow:hidden}.project-card-img img{object-fit:cover;width:100%;height:100%;transition:transform .5s cubic-bezier(.4,0,.2,1)}.project-card:hover .project-card-img img{transform:scale(1.05)}.project-card-body{padding:1.25rem 1.25rem 1.5rem}.project-card-body h4{margin-bottom:.2rem;font-size:.95rem;font-weight:600}.project-card-period{color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem}.project-card-body p{color:var(--text-secondary);font-size:.85rem;line-height:1.6}@media (width<=900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.projects-grid{grid-template-columns:1fr}}.section-exp{background:var(--bg-white)}.exp-list{flex-direction:column;gap:0;padding-left:2rem;display:flex;position:relative}.exp-list:before{content:"";background:var(--border);width:1.5px;position:absolute;top:8px;bottom:8px;left:7px}.exp-entry{border-bottom:1px solid var(--border-light);grid-template-columns:180px 1fr;gap:2rem;padding:2rem 0;display:grid;position:relative}.exp-entry:last-child{border-bottom:none}.exp-entry:before{content:"";background:var(--text);border-radius:50%;width:8px;height:8px;position:absolute;top:2.35rem;left:-2rem;transform:translate(3.5px)}.exp-period{color:var(--text-muted);padding-top:2px;font-size:.82rem}.exp-role{margin-bottom:.15rem;font-size:1.05rem;font-weight:600}.exp-company{color:var(--text-secondary);margin-bottom:.5rem;font-size:.88rem;font-weight:500}.exp-desc{color:var(--text-secondary);font-size:.88rem;line-height:1.7}@media (width<=768px){.exp-entry{grid-template-columns:1fr;gap:.25rem}}.skills-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}.skill-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-white);transition:box-shadow var(--transition), transform var(--transition);padding:1.5rem}.skill-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000d}.skill-icon{margin-bottom:.75rem;font-size:1.5rem}.skill-card h4{text-transform:uppercase;letter-spacing:.08em;color:var(--text);margin-bottom:.75rem;font-size:.78rem;font-weight:600}.skill-card ul{flex-direction:column;gap:.35rem;list-style:none;display:flex}.skill-card li{color:var(--text-secondary);font-size:.85rem}@media (width<=768px){.skills-grid{grid-template-columns:repeat(2,1fr)}}.section-contact{background:var(--bg-dark);color:#fff;padding:6rem 0}.contact-grid{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.contact-title{letter-spacing:-.02em;margin-bottom:.75rem;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:700}.contact-desc{color:#888;font-size:1rem}.contact-email{color:#ccc;transition:color var(--transition), border-color var(--transition);border-bottom:1px solid #fff3;margin-top:1.25rem;padding-bottom:2px;font-size:1.1rem;display:inline-block}.contact-email:hover{color:#fff;border-color:#fff}.contact-cta{flex-direction:column;align-items:flex-start;gap:1.5rem;display:flex}.contact-cta-msg{color:#888;font-size:.95rem;line-height:1.7}.contact-btn{color:var(--bg-dark);transition:opacity var(--transition), transform var(--transition);background:#fff;border-radius:8px;padding:.9rem 2.5rem;font-size:.9rem;font-weight:600;display:inline-block}.contact-btn:hover{opacity:.88;transform:translateY(-1px)}@media (width<=768px){.contact-grid{grid-template-columns:1fr;gap:2.5rem}}.footer{background:var(--bg-dark);color:#555;border-top:1px solid #ffffff0f;padding:1.5rem 0}.footer-inner{justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.footer a{color:#666;transition:color var(--transition)}.footer a:hover{color:#fff}@media (width<=600px){.footer-inner{text-align:center;flex-direction:column;gap:.75rem}}.fade-up{opacity:0;transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);transform:translateY(24px)}.fade-up.visible{opacity:1;transform:translateY(0)}
