@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-widest:.1em;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.-top-1{top:calc(var(--spacing) * -1)}.top-0{top:calc(var(--spacing) * 0)}.-right-1{right:calc(var(--spacing) * -1)}.bottom-0\.5{bottom:calc(var(--spacing) * .5)}.bottom-6{bottom:calc(var(--spacing) * 6)}.left-1{left:calc(var(--spacing) * 1)}.left-1\/2{left:50%}.-z-10{z-index:calc(10 * -1)}.z-10{z-index:10}.z-50{z-index:50}.z-\[2\]{z-index:2}.z-\[9999\]{z-index:9999}.col-span-2{grid-column:span 2/span 2}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-\[clamp\(40px\,6vw\,90px\)\]{margin-top:clamp(40px,6vw,90px)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.h-1{height:calc(var(--spacing) * 1)}.h-4{height:calc(var(--spacing) * 4)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-\[22px\]{height:22px}.h-\[68px\]{height:68px}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-\[28px\]{width:28px}.w-\[48px\]{width:48px}.w-\[52px\]{width:52px}.w-\[68px\]{width:68px}.w-\[100px\]{width:100px}.w-\[260px\]{width:260px}.w-\[360px\]{width:360px}.w-\[380px\]{width:380px}.w-full{width:100%}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-\[3px\]{--tw-translate-y:calc(3px * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-y{resize:vertical}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-5{column-gap:calc(var(--spacing) * 5)}.gap-y-2{row-gap:calc(var(--spacing) * 2)}.self-start{align-self:flex-start}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.object-cover{object-fit:cover}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-8{padding-inline:calc(var(--spacing) * 8)}.px-\[16px\]{padding-inline:16px}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-5{padding-top:calc(var(--spacing) * 5)}.pt-\[0\.66rem\]{padding-top:.66rem}.pr-\[16px\]{padding-right:16px}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-14{padding-bottom:calc(var(--spacing) * 14)}.pb-16{padding-bottom:calc(var(--spacing) * 16)}.pb-\[1px\]{padding-bottom:1px}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[17px\]{font-size:17px}.text-\[18px\]{font-size:18px}.text-\[22px\]{font-size:22px}.text-\[28px\]{font-size:28px}.leading-\[1\.5\]{--tw-leading:1.5;line-height:1.5}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.4px\]{--tw-tracking:-.4px;letter-spacing:-.4px}.tracking-\[-0\.5px\]{--tw-tracking:-.5px;letter-spacing:-.5px}.tracking-\[-0\.6px\]{--tw-tracking:-.6px;letter-spacing:-.6px}.tracking-\[-0\.8px\]{--tw-tracking:-.8px;letter-spacing:-.8px}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.whitespace-nowrap{white-space:nowrap}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.opacity-0{opacity:0}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}@media (min-width:40rem){.sm\:flex{display:flex}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-6{gap:calc(var(--spacing) * 6)}.sm\:self-auto{align-self:auto}}}:root{--bg:#1a1a1a;--fg:#fff;--muted:#969696;--border:#333;--card:#111;--accent:#fff;--font-arimo:"Arimo", sans-serif;--font-bricolage:"Bricolage Grotesque", sans-serif;--font-manrope:"Manrope", sans-serif;--mobile-fs-adjust:0px;--mobile-lh-adjust:0px;--sp-fs:0px}html{scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar{display:none}body{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .25s}::selection{color:#060606;background:#b5c7ba}body:has(.home-page){--bg:#eae5de;--fg:#0a0a0a;--muted:#969696;--border:#e0e0e0;--card:#eee;color:#0a0a0a;background:#fff;padding-inline:0}body:has(.project-detail-page){--bg:#fff;--fg:#0a0a0a;--muted:#969696;--border:#e0e0e0;--card:#eee;color:#0a0a0a;background:#fff;padding-inline:0}body:has(.admin-page){color:#0a0a0a;background:#f4f4f4;padding-inline:0}html:has(.about-page){background:linear-gradient(#fff,#82c9f2)}body:has(.about-page){--bg:#fff;--fg:#030303;--muted:#888;--border:#e5e5e5;--card:#f5f5f5;--accent:#030303;color:#030303;padding-inline:0;background:0 0;height:100dvh;padding-bottom:0;overflow:hidden}@font-face{font-family:PretendardKR;src:url(https://cdn.jsdelivr.net/npm/pretendard@1.3.9/dist/web/static/woff2/Pretendard-Regular.woff2)format("woff2");font-weight:300;font-style:normal;unicode-range:U+AC00-D7A3,U+11??,U+3130-318F,U+A960-A97F,U+D7B0-D7FF;size-adjust:90%}@font-face{font-family:PretendardKR;src:url(https://cdn.jsdelivr.net/npm/pretendard@1.3.9/dist/web/static/woff2/Pretendard-Medium.woff2)format("woff2");font-weight:400;font-style:normal;unicode-range:U+AC00-D7A3,U+11??,U+3130-318F,U+A960-A97F,U+D7B0-D7FF;size-adjust:90%}@font-face{font-family:PretendardKR;src:url(https://cdn.jsdelivr.net/npm/pretendard@1.3.9/dist/web/static/woff2/Pretendard-Medium.woff2)format("woff2");font-weight:500;font-style:normal;unicode-range:U+AC00-D7A3,U+11??,U+3130-318F,U+A960-A97F,U+D7B0-D7FF;size-adjust:90%}@font-face{font-family:PretendardKR;src:url(https://cdn.jsdelivr.net/npm/pretendard@1.3.9/dist/web/static/woff2/Pretendard-Bold.woff2)format("woff2");font-weight:600;font-style:normal;unicode-range:U+AC00-D7A3,U+11??,U+3130-318F,U+A960-A97F,U+D7B0-D7FF;size-adjust:90%}@font-face{font-family:PretendardKR;src:url(https://cdn.jsdelivr.net/npm/pretendard@1.3.9/dist/web/static/woff2/Pretendard-ExtraBold.woff2)format("woff2");font-weight:700;font-style:normal;unicode-range:U+AC00-D7A3,U+11??,U+3130-318F,U+A960-A97F,U+D7B0-D7FF;size-adjust:90%}@keyframes dolphin-tail{0%,to{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}.dolphin-img{image-rendering:pixelated}.dolphin-tail-swim{transform-origin:42% 0;animation:.28s ease-in-out infinite dolphin-tail}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}[contenteditable][data-placeholder]:empty:before{content:attr(data-placeholder);color:#bbb;pointer-events:none;font-style:normal;font-weight:400}.page-nav{padding-top:2rem;padding-bottom:calc(2rem + 7px);background:0 0;padding-inline:4vw}.nav-title,.nav-about{letter-spacing:-.3px;color:#0a0a0a;-webkit-backdrop-filter:blur(22px);background:#ffffffa8;border:1px solid #e0e0e0;border-radius:999px;padding:10px 13px;font-family:Manrope,sans-serif;font-size:clamp(14px,1.2vw,18px);font-weight:600;line-height:1;transition:background .18s,color .18s,border-color .18s;transform:translateY(1px)}.nav-title:hover,.nav-title-link:hover,.nav-about:hover,.nav-info-link:hover{color:#fff!important;background:#0a0a0a!important;border-color:#0a0a0a!important}.pg-toast{color:#444;font-family:Manrope,sans-serif;font-size:calc(13px + var(--sp-fs));letter-spacing:-.01em;white-space:nowrap;pointer-events:none;z-index:200;opacity:0;background:#fff;border:1px solid #e2e2e2;border-radius:999px;padding:9px 18px;font-weight:500;transition:opacity .4s,transform .4s;position:fixed;bottom:4.2rem;left:50%;transform:translate(-50%)translateY(8px);box-shadow:0 4px 16px #00000014}.pg-toast--visible{opacity:1;transform:translate(-50%)translateY(0)}@media (max-width:640px){.pg-toast,.pg-owner-bar{bottom:7.8rem}}@media (max-width:768px){body:has(.about-page) pre{font-size:calc(13px + var(--sp-fs))}body:has(.about-page) a.text-sm{font-size:calc(.875rem + var(--sp-fs))}}:is(body:has(.about-page) .nav-title,body:has(.about-page) .nav-about){border-color:#e0e0e0}.proj-main{padding-inline:4vw;padding-top:clamp(32px,4vw,64px)}.proj-section{margin-bottom:clamp(48px,6vw,96px)}.proj-section-title{color:#000;letter-spacing:-.03em;margin-bottom:clamp(20px,2.5vw,40px);font-family:Noto Sans KR,sans-serif;font-size:clamp(28px,4vw,52px);font-weight:700;line-height:1.1}.proj-card-grid{grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,32px);display:grid}.proj-card-link{color:inherit;text-decoration:none;display:block}.proj-card{flex-direction:column;gap:16px;display:flex}.proj-card-thumb{aspect-ratio:16/10;border-radius:clamp(12px,1.5vw,20px);width:100%;position:relative;overflow:hidden}.proj-card-thumb img,.proj-card-thumb video{object-fit:cover;width:100%;height:100%;display:block}.proj-card-body{flex-direction:column;gap:6px;display:flex}.proj-card-title{color:#000;letter-spacing:-.02em;margin:0;font-family:Manrope,sans-serif;font-size:clamp(16px,1.4vw,22px);font-weight:700;line-height:1.25}.proj-card-subtitle{color:#444;margin:0;font-family:Manrope,sans-serif;font-size:clamp(13px,1vw,16px);font-weight:500;line-height:1.4}.proj-card-meta{color:#888;margin:0;font-family:Manrope,sans-serif;font-size:clamp(11px,.85vw,13px)}.proj-card-desc{color:#555;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-family:Manrope,sans-serif;font-size:clamp(12px,.95vw,15px);line-height:1.6;display:-webkit-box;overflow:hidden}.proj-card-tags{flex-wrap:wrap;gap:6px;margin-top:2px;display:flex}.proj-card-tag{color:#333;letter-spacing:.02em;text-transform:uppercase;background:#f0f0f0;border-radius:999px;padding:4px 10px;font-family:Manrope,sans-serif;font-size:clamp(10px,.75vw,12px);font-weight:600}.proj-card-link:hover .proj-card-thumb{opacity:.88;transition:opacity .2s}@media (max-width:900px){.proj-card-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.proj-card-grid{grid-template-columns:1fr}}.home-proj-section{padding-inline:4vw}.project-content-wrapper{padding-inline:0}body:has(.project-detail-page) .home-proj-section{padding-inline:0}@media (min-width:1580px){body:has(.home-page) .home-proj-section{padding-inline:12vw}.project-content-wrapper{padding-inline:0}body:has(.project-detail-page) .home-proj-section{padding-inline:0}.page-nav{padding-inline:12vw}}@media (max-width:768px){.home-proj-section{padding-inline:4vw}.page-nav{padding-inline:5vw}:root{--mobile-fs-adjust:-1.2px;--mobile-lh-adjust:-.5px}.proj-desc p{font-size:calc(clamp(.9rem, 1.2vw, 1.125rem) - 1.2px + var(--sp-fs));line-height:calc(1.9em - .5px)}:is(body:has(.about-page),body:has(.project-detail-page),body:has(.playground-page)){--sp-fs:-2px}}.proj-grid{grid-template-columns:repeat(6,1fr);grid-auto-flow:dense;gap:clamp(14px,2.2vw,32px);display:grid}.proj-thumb--wide{aspect-ratio:10/11}.proj-thumb--narrow{aspect-ratio:1}.proj-thumb--landscape{aspect-ratio:989/478}.proj-thumb--full{aspect-ratio:5/2}@media (max-width:768px){.proj-grid{grid-template-columns:1fr;gap:10px}.proj-grid>*{grid-column:span 1!important}.proj-thumb--wide,.proj-thumb--landscape,.proj-thumb--narrow,.proj-thumb--full{aspect-ratio:3/4}}.proj-thumb{isolation:isolate;border-radius:clamp(20px,3vw,48px);position:relative;overflow:hidden}.proj-thumb:after{content:"";border-radius:inherit;pointer-events:none;z-index:1;position:absolute;inset:0;box-shadow:inset 0 0 0 1px #e0e0e0}.proj-thumb img,.proj-thumb video{z-index:0;object-fit:cover;border-radius:inherit;width:100%;height:100%;display:block;position:relative}.proj-thumb video::-webkit-media-controls{-webkit-appearance:none;display:none!important}.proj-thumb video::-webkit-media-controls-start-playback-button{-webkit-appearance:none;display:none!important}.proj-thumb video::-webkit-media-controls-play-button{-webkit-appearance:none;display:none!important}.proj-thumb video::-webkit-media-controls-panel{-webkit-appearance:none;display:none!important}.proj-hover-label{-webkit-backdrop-filter:blur(22px);letter-spacing:-.3px;color:#0a0a0a;white-space:nowrap;opacity:0;pointer-events:none;z-index:10;background:#ffffffa8;border:1px solid #e0e0e0;border-radius:999px;padding:10px 13px;font-family:Manrope,sans-serif;font-size:clamp(14px,1.2vw,18px);font-weight:600;line-height:1;transition:opacity .22s,transform .22s;position:absolute;bottom:21px;left:50%;transform:translate(-50%)translateY(20px)}.group:hover .proj-hover-label{opacity:1;transform:translate(-50%)translateY(0)}.proj-desc{text-align:center;padding-block:0}.proj-desc p{font-size:calc(clamp(.9rem, 1.2vw, 1.125rem) + var(--sp-fs));color:var(--fg);word-break:keep-all;overflow-wrap:break-word;max-width:calc(600px + 13rem);line-height:1.9;font-family:var(--font-noto-sans-kr), "Noto Sans KR", sans-serif;margin:0 auto 1.75em}.proj-desc p:last-child{margin-bottom:0}body:has(.playground-page){--bg:#f0f0f0;--fg:#1a1a1a;color:#1a1a1a;background:#f0f0f0;padding-inline:0}@media (max-width:768px){body:has(.playground-page){width:100%;height:100dvh;position:fixed;overflow:hidden}}.pg-root{position:relative}.pg-owner-bar{z-index:60;white-space:nowrap;align-items:center;gap:6px;display:flex;position:fixed;bottom:3.2rem;left:50%;transform:translate(-50%)}.pg-owner-badge{color:#fff;letter-spacing:.02em;background:#1a1a1a;border-radius:999px;padding:4px 10px;font-family:Manrope,sans-serif;font-size:11px;font-weight:700}.pg-owner-btn{color:#aaa;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffd9;border:1px solid #e2e2e2;border-radius:999px;padding:4px 12px;font-family:Manrope,sans-serif;font-size:11px;font-weight:600;transition:color .15s,border-color .15s}.pg-owner-btn:hover{color:#1a1a1a;border-color:#aaa}.pg-owner-btn--danger{color:#e53e3e;background:#fff0f0e6;border-color:#faa;align-items:center;gap:5px;display:flex}.pg-owner-btn--danger:hover{background:#ffe0e0;border-color:#e53e3e}.pg-board{z-index:0;cursor:crosshair;background:#f7f7f7;position:fixed;inset:0;overflow:hidden}.pg-grid{pointer-events:none;background-image:radial-gradient(circle,#d4d4d4 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}.pg-card{cursor:grab;z-index:10;-webkit-user-select:none;user-select:none;background:#fff;border:.6px solid #e2e2e2;border-radius:12px;flex-direction:column;gap:8px;width:200px;padding:10px 12px;transition:box-shadow .15s,border-color .15s;display:flex;position:absolute;transform:translateY(-50%);box-shadow:0 2px 12px #0000000a}.pg-card:active{cursor:grabbing}.pg-card:hover{box-shadow:0 4px 20px #0001}.pg-card--active{z-index:20;border-color:#1a1a1a;box-shadow:0 4px 20px #00000014}.pg-card--empty{opacity:.55}.pg-card-header{align-items:center;gap:7px;display:flex}.pg-card-num{font-family:Manrope,sans-serif;font-size:calc(10px + var(--sp-fs));color:#fff;background:#1a1a1a;border-radius:5px;flex-shrink:0;padding:1px 6px;font-weight:700;line-height:1.6}.pg-card-date{font-family:Manrope,sans-serif;font-size:calc(10px + var(--sp-fs));color:#bbb;white-space:nowrap;line-height:1.6}.pg-card-text{font-family:Manrope,sans-serif;font-size:calc(12px + var(--sp-fs));color:#1a1a1a;text-align:left;white-space:pre-wrap;word-break:break-word;-webkit-line-clamp:4;-webkit-box-orient:vertical;margin:0;line-height:1.6;display:-webkit-box;overflow:hidden}.pg-card-media{align-items:center;gap:4px;display:flex}.pg-card-media-thumb{background:#f0f0f0;border:1px solid #ebebeb;border-radius:6px;flex-shrink:0;width:48px;height:48px;overflow:hidden}.pg-card-media-thumb img,.pg-card-media-thumb video{object-fit:cover;width:100%;height:100%;display:block}.pg-card-media-more{font-family:Manrope,sans-serif;font-size:calc(11px + var(--sp-fs));color:#999;flex-shrink:0;font-weight:600}.pg-card-empty-label{font-family:Manrope,sans-serif;font-size:calc(11px + var(--sp-fs));color:#ccc;font-style:italic}@media (max-width:768px){.pg-card{width:auto!important;box-shadow:none!important;background:0 0!important;border:none!important;gap:0!important;padding:0!important}.pg-card--active{box-shadow:none!important;border:none!important}.pg-card-date,.pg-card-text,.pg-card-media,.pg-card-empty-label{display:none!important}}.pg-popup-backdrop{z-index:100;-webkit-backdrop-filter:blur(2px);background:#0000002e;justify-content:center;align-items:center;animation:.18s pg-fade-in;display:flex;position:fixed;inset:0}@keyframes pg-fade-in{0%{opacity:0}to{opacity:1}}.pg-popup{background:#fff;border:1px solid #e2e2e2;border-radius:18px;flex-direction:column;width:min(480px,92vw);max-height:82dvh;animation:.22s cubic-bezier(.22,1,.36,1) pg-slide-up;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000024,0 4px 12px #0000000f}@keyframes pg-slide-up{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.pg-popup-header{border-bottom:1px solid #f0f0f0;flex-shrink:0;align-items:center;gap:8px;padding:16px 16px 12px;display:flex}.pg-popup-num{font-family:Manrope,sans-serif;font-size:calc(12px + var(--sp-fs));color:#fff;letter-spacing:.02em;background:#1a1a1a;border-radius:6px;padding:2px 7px;font-weight:700}.pg-popup-date{font-family:Manrope,sans-serif;font-size:calc(12px + var(--sp-fs));color:#aaa;flex:1}.pg-popup-actions{align-items:center;gap:4px;display:flex}.pg-icon-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .13s,color .13s;display:flex}.pg-icon-btn:hover{color:#1a1a1a;background:#f0f0f0}.pg-delete-btn:hover{color:#e53e3e;background:#fff0ef}.pg-popup-text{font-family:Manrope,sans-serif;font-size:calc(14px + var(--sp-fs));color:#1a1a1a;resize:none;background:0 0;border:none;outline:none;flex-shrink:0;padding:14px 16px;line-height:1.7}.pg-popup-text::placeholder{color:#ccc}.pg-popup-text--readonly{color:#666;cursor:default}.pg-popup-footer{flex-shrink:0;padding:0 16px 16px}.pg-leave-btn{color:#fff;width:100%;font-family:Manrope,sans-serif;font-size:calc(13px + var(--sp-fs));letter-spacing:-.01em;cursor:pointer;background:#1a1a1a;border:none;border-radius:10px;padding:10px 0;font-weight:600;transition:background .15s}.pg-leave-btn:hover{background:#333}.pg-media-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;max-height:220px;padding:0 16px 16px;display:grid;overflow-y:auto}.pg-media-item{aspect-ratio:1;background:#f5f4f0;border:1px solid #e8e8e8;border-radius:10px;position:relative;overflow:hidden}.pg-media-item img,.pg-media-item video{object-fit:cover;width:100%;height:100%;display:block}.pg-media-remove{color:#fff;cursor:pointer;width:20px;height:20px;font-size:calc(13px + var(--sp-fs));opacity:0;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;line-height:1;transition:opacity .13s;display:flex;position:absolute;top:4px;right:4px}.pg-media-item:hover .pg-media-remove{opacity:1}.pg-media-name{color:#fff;font-family:Manrope,sans-serif;font-size:calc(9px + var(--sp-fs));white-space:nowrap;text-overflow:ellipsis;pointer-events:none;background:linear-gradient(#0000,#00000080);padding:10px 5px 4px;position:absolute;bottom:0;left:0;right:0;overflow:hidden}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
