*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:#0d0d0d;color:#f0f0f0;font-family:"Noto Sans KR",sans-serif}a{color:inherit;text-decoration:none}body.body--modal-open{overflow:hidden}.label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500}.label--accent{color:#ffe100}.label--dim{color:#555}.label--dark{color:#444}.label--dark-strong{color:#333;font-weight:700}.meta{font-size:.68rem;color:#444}.meta--dark{font-size:.7rem;color:#555}.desc,.about-item p,.card__desc{font-size:.88rem;color:#888;line-height:1.85}.highlight{color:#ffe100;font-weight:500}.section-title{font-family:"Bebas Neue",sans-serif;font-size:clamp(2rem,5vw,4rem)}.section-title--about{font-family:"Bebas Neue",sans-serif;font-size:clamp(2.5rem,4vw,4rem);line-height:1.05}.section-title--skills{font-family:"Bebas Neue",sans-serif;font-size:clamp(2rem,4vw,3.5rem)}nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.5rem 3rem;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,0);transition:border-color .3s}nav.scrolled{border-color:#1a1a1a;background:rgba(13,13,13,.8)}.nav-logo{font-family:"Bebas Neue",sans-serif;font-size:1.3rem;letter-spacing:.12em}.nav-links{display:flex;gap:2rem;align-items:center}.nav-link{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#999;transition:color .2s}.nav-link:hover{color:#ffe100}.nav-cta{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#0d0d0d;background:#ffe100;padding:8px 20px;border-radius:999px;font-weight:700;transition:background .2s}.nav-cta:hover{background:#fff}.hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;justify-content:flex-end;padding:9rem 3rem 4rem}.hero__eyebrow{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:#ffe100;margin-bottom:1.2rem;font-weight:500}.hero__title{font-family:"Bebas Neue",sans-serif;font-size:clamp(5rem,16vw,15rem);line-height:.88;color:#f0f0f0;margin-bottom:3rem}.hero__footer{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid #2a2a2a;padding-top:2rem;flex-wrap:wrap;gap:1.5rem}.hero__desc{max-width:420px;font-size:1rem;line-height:1.9;color:#888;font-weight:300}.hero__desc strong{color:#f0f0f0;font-weight:400}.hero__avail{text-align:right}.avail-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#444;margin-bottom:.3rem}.avail-value{font-size:.95rem;color:#ffe100}.cursor::after{content:"_";color:#ffe100;animation:blink 1s step-end infinite}@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}.scroll-hint{position:absolute;bottom:2.5rem;right:3rem;opacity:.4;display:flex;flex-direction:column;align-items:center;gap:6px}.scroll-hint__line{width:1px;height:48px;background:linear-gradient(to bottom, transparent, #FFE100);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.9}}.stats-bar{border-top:1px solid #1a1a1a;border-bottom:1px solid #1a1a1a;padding:2rem 3rem;display:grid;grid-template-columns:repeat(4, 1fr);gap:1rem}.stats-bar__item{text-align:center;padding:1rem 0}.stats-bar__item+.stats-bar__item{border-left:1px solid #1a1a1a}.stats-bar__number{font-family:"Bebas Neue",sans-serif;font-size:2.8rem;color:#ffe100;line-height:1}.stats-bar__label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#555;margin-top:.3rem}#work{padding:7rem 3rem}.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3rem}.work-period{font-size:.72rem;color:#444;letter-spacing:.12em}.bento-grid{display:grid;grid-template-columns:repeat(12, 1fr);gap:14px}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:20px;padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:transform .3s ease,border-color .3s ease}.card:hover{transform:translateY(-6px);border-color:#ffe100}.card--accent{background:#ffe100;border-color:#ffe100;color:#0d0d0d}.card--accent:hover{border-color:#ccb400}.card--accent .card__title,.card--accent .card__title--sm,.card--accent .card__title--md,.card--accent .card__title--lg{color:#0d0d0d !important}.card--lg{min-height:380px}.card--md{min-height:340px}.card--sm{padding:2rem;min-height:280px}.card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.card__title{font-family:"Bebas Neue",sans-serif;font-size:clamp(2rem,4vw,3.2rem);line-height:1;margin-bottom:1rem;margin-top:1rem}.card__title--sm{font-family:"Bebas Neue",sans-serif;font-size:2.2rem;line-height:1.05;margin-bottom:1rem;margin-top:1rem}.card__title--md{font-family:"Bebas Neue",sans-serif;font-size:2.6rem;line-height:1.05;margin-bottom:1rem;margin-top:1rem}.card__title--lg{font-family:"Bebas Neue",sans-serif;font-size:3rem;line-height:1.05;margin-bottom:1rem;margin-top:1rem}.card__desc{max-width:480px}.card__desc--dark{font-size:.85rem;color:#333;line-height:1.7}.card__desc--narrow{font-size:.88rem;color:#888;line-height:1.85;max-width:400px}.card__body{font-size:.85rem;color:#888;line-height:1.7}.card__footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.card__accent-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.2rem}.card__tools{display:flex;gap:8px;flex-wrap:wrap}.tag-pill{font-size:.68rem;padding:4px 12px;border:1px solid #2a2a2a;border-radius:999px;color:#777}.view-link{font-size:.78rem;color:#ffe100;letter-spacing:.05em}.view-link--dark{font-size:.78rem;color:#0d0d0d;font-weight:700}.stat-card{background:#111;border:1px solid #1e1e1e;border-radius:20px;padding:2rem;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:.4rem}.stat-card__number{font-family:"Bebas Neue",sans-serif;font-size:4rem;color:#ffe100;line-height:1}.stat-card__label{font-size:.75rem;color:#555;letter-spacing:.08em;line-height:1.5}#about{padding:7rem 3rem;border-top:1px solid #1a1a1a}.about-grid{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}.about-sub{font-size:.85rem;color:#666;line-height:1.8;margin-top:1.5rem}.about-items{display:flex;flex-direction:column}.about-item{border-top:1px solid #2a2a2a;padding:2rem 0}.about-item--last{border-bottom:1px solid #2a2a2a}.about-item__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.9rem}.about-item__num{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:#ffe100;font-weight:500}.about-item__category{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:#444}.about-item h3{font-size:1.15rem;font-weight:500;margin-bottom:.6rem}#skills{padding:7rem 3rem;border-top:1px solid #1a1a1a}#skills .section-title{margin-bottom:3rem}#skills-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:0}.skill-row{display:flex;align-items:center;gap:1rem;padding:1.1rem 0;border-bottom:1px solid #1a1a1a}.skill-row:nth-child(odd){padding-right:2.5rem}.skill-row:nth-child(even){padding-left:2.5rem;border-left:1px solid #1a1a1a}.skill-name{font-size:.85rem;color:#999;flex:1;min-width:0}.skill-sub{font-size:.7rem;color:#555}.skill-dots{display:flex;gap:5px;flex-shrink:0}.dot{width:7px;height:7px;border-radius:50%;display:inline-block}.dot.on{background:#ffe100}.dot.off{background:#2a2a2a;border:1px solid #333}.skill-level{font-size:.68rem;color:#444;letter-spacing:.08em;flex-shrink:0;width:72px;text-align:right}#contact{padding:7rem 3rem 5rem;border-top:1px solid #1a1a1a}.contact-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:3rem}.contact__title{font-family:"Bebas Neue",sans-serif;font-size:clamp(3.5rem,10vw,10rem);line-height:.88;color:#f0f0f0}.contact__info{text-align:right;display:flex;flex-direction:column;gap:1rem}.contact__email-wrap{position:relative;display:inline-block;align-self:flex-end}.contact__email{font-size:1.1rem;color:#f0f0f0;background:none;border:none;border-bottom:2px solid #ffe100;padding:0 0 4px 0;cursor:pointer;font-family:"Noto Sans KR",sans-serif;transition:color .2s;text-align:inherit}.contact__email:hover{color:#ffe100}.copy-toast{position:absolute;top:calc(100% + 8px);right:0;white-space:nowrap;font-size:.78rem;color:#ffe100;padding:6px 10px;border-radius:6px;background:rgba(26,26,26,.95);border:1px solid #2a2a2a;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .25s ease,transform .25s ease,visibility .25s;pointer-events:none}.copy-toast.show{opacity:1;visibility:visible;transform:translateY(0)}.contact__social{display:flex;gap:1.5rem;justify-content:flex-end}.contact__social a{font-size:.85rem;color:#666;transition:color .2s}.contact__social a:hover{color:#ffe100}.footer{display:flex;justify-content:space-between;border-top:1px solid #1a1a1a;margin-top:5rem;padding-top:2rem;flex-wrap:wrap;gap:1rem}.footer p{font-size:.8125rem;line-height:1.5;color:#4c4945}#modal-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:2rem}#modal-overlay.open{display:flex}#modal-overlay.open #modal-box{opacity:1;transform:translateY(0) scale(1)}#modal-box{background:#111;border:1px solid #2a2a2a;border-radius:24px;width:100%;max-width:780px;max-height:90vh;overflow-y:auto;opacity:0;transform:translateY(30px) scale(0.97);transition:opacity .35s ease,transform .35s ease}#modal-box::-webkit-scrollbar{width:4px}#modal-box::-webkit-scrollbar-track{background:rgba(0,0,0,0)}#modal-box::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.modal-img-placeholder{width:100%;aspect-ratio:16/9;border-radius:24px 24px 0 0;background:linear-gradient(135deg, #1A1A1A 0%, #222 100%);display:flex;align-items:center;justify-content:center;color:#333;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}.modal-body{padding:2.5rem}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.modal-tag{margin-bottom:.5rem}.modal-year{font-size:.78rem;color:#444;margin-top:.3rem}.modal-title{font-family:"Bebas Neue",sans-serif;font-size:2.8rem;line-height:1.05}.modal-close{font-family:"Noto Sans KR",sans-serif;background:none;border:1px solid #2a2a2a;color:#666;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s,color .2s}.modal-close:hover{border-color:#ffe100;color:#ffe100}.modal-desc{font-size:.92rem;color:#888;line-height:1.9;margin-bottom:2.5rem}.modal-contrib-label{margin-bottom:.5rem}.modal-contrib-key{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#ffe100;font-weight:500;padding-top:2px}.modal-contrib-text{font-size:.88rem;color:#888;line-height:1.8}.modal-contribution{border-top:1px solid #1e1e1e;padding:1.2rem 0;display:grid;grid-template-columns:80px 1fr;gap:0 1.5rem;align-items:baseline}.modal-contribution:last-child{border-bottom:1px solid #1e1e1e}.modal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:2.5rem;flex-wrap:wrap;gap:1rem}.modal-tags{display:flex;gap:8px;flex-wrap:wrap}.modal-tags .tag-pill{color:#666;border-color:#2a2a2a}.none{display:none !important}.modal-link-btn{font-size:.82rem;color:#ffe100;border:1px solid #ffe100;padding:8px 20px;border-radius:999px;transition:background .2s,color .2s}.modal-link-btn:hover{background:#ffe100;color:#0d0d0d}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal.delay-1{transition-delay:.1s}.reveal.delay-2{transition-delay:.2s}.reveal.delay-3{transition-delay:.3s}@media(max-width: 768px){nav{padding:1.2rem 1.5rem}nav .nav-links{gap:1.2rem}nav .nav-link{display:none}.hero{padding:7rem 1.5rem 3rem}.stats-bar{grid-template-columns:repeat(2, 1fr);padding:1.5rem}.stats-bar__item{border-left:none;border-top:1px solid #1a1a1a}.stats-bar__item:nth-child(1),.stats-bar__item:nth-child(2){border-top:none}#work{padding:4rem 1.5rem}.bento-grid{display:flex;flex-direction:column;gap:12px}.col-3,.col-4,.col-5,.col-7,.col-8{grid-column:span 12 !important}#work .bento-grid>.card,#work .bento-grid>.stat-card{min-height:auto !important}#work .bento-grid>.card{padding:1.75rem !important}#work .bento-grid>.stat-card{padding:1.75rem !important}#work .bento-grid .card__title,#work .bento-grid .card__title--sm,#work .bento-grid .card__title--md,#work .bento-grid .card__title--lg{font-size:1.85rem !important;line-height:1.12;margin-top:.65rem;margin-bottom:.65rem}#work .bento-grid .card__desc,#work .bento-grid .card__desc--narrow,#work .bento-grid .card__body,#work .bento-grid .card__desc--dark{font-size:.875rem;line-height:1.65;max-width:none}#work .bento-grid .stat-card__number{font-size:2.35rem}#work .bento-grid .stat-card__label{font-size:.72rem}#about{padding:4rem 1.5rem}.about-grid{grid-template-columns:1fr;gap:2.5rem}#skills{padding:4rem 1.5rem}#skills-grid{grid-template-columns:1fr}.skill-row:nth-child(odd){padding-right:0}.skill-row:nth-child(even){padding-left:0;border-left:none}#contact{padding:4rem 1.5rem 3rem}.contact-top{flex-direction:column;align-items:flex-start}.contact__info{text-align:left}.contact__email-wrap{align-self:flex-start}.copy-toast{left:0;right:auto}.contact__social{justify-content:flex-start}#modal-overlay{padding:1rem;align-items:flex-end}#modal-box{border-radius:20px 20px 0 0;max-height:88vh}.modal-body{padding:1.5rem}.modal-title{font-size:2rem}}#scroll-top{position:fixed;bottom:2.5rem;right:2.5rem;z-index:200;width:48px;height:48px;border-radius:50%;background:rgba(105,105,105,.35);color:#fff;border:none;cursor:pointer;font-size:1.2rem;font-family:"Noto Sans KR",sans-serif;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);transition:opacity .3s ease,transform .3s ease,background .2s;pointer-events:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}#scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}#scroll-top:hover{background:rgba(105,105,105,.65)}.view-link,.view-link--dark{display:none !important}.card--disabled{cursor:default !important;pointer-events:none}
