:root{
  --white:#ffffff;
  --ink:#0a0a0a;
  --grey:#8a8a8a;
  --line:#e6e6e6;
  --sans:'Archivo','Noto Sans KR','Helvetica Neue',Helvetica,Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--white);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--ink);color:var(--white)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;color:inherit;-webkit-tap-highlight-color:transparent}

/* ---------- custom cursor ---------- */
.cursor{
  position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;
  background:var(--ink);pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .25s,height .25s,background .25s;
  mix-blend-mode:difference;background:#fff;
}
.cursor.is-hover{width:40px;height:40px}
@media (hover:none){.cursor{display:none}}

/* ---------- micro label ---------- */
.label{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;font-variation-settings:'wdth' 100;
}

/* ---------- header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 24px;
  background:rgba(255,255,255,.88);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .4s;
}
header.is-scrolled{border-color:var(--line)}
.header-logo img{height:18px;width:auto;opacity:0;transform:translateY(6px);transition:opacity .5s,transform .5s}
header.is-scrolled .header-logo img{opacity:1;transform:none}
nav{display:flex;gap:28px}
nav a{position:relative;padding:4px 0}
nav a::after{
  content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:right;
  transition:transform .35s cubic-bezier(.7,0,.3,1);
}
nav a:hover::after{transform:scaleX(1);transform-origin:left}
header nav.label{font-size:12px}
.menu-btn{display:none;background:none;border:0;color:var(--ink);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700}

/* ---------- loader curtain ---------- */
.loader{
  position:fixed;inset:0;background:var(--ink);z-index:1000;
  display:flex;align-items:center;justify-content:center;
  animation:curtain 1s cubic-bezier(.76,0,.24,1) 1.5s forwards;
}
.loader .label{color:#666;animation:loaderFade .5s ease 1.1s forwards}
@keyframes curtain{to{transform:translateY(-100%)}}
@keyframes loaderFade{to{opacity:0}}
body.loaded .loader{display:none}

/* ---------- hero ---------- */
.hero{
  min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;position:relative;
  padding:120px 24px 80px;
}
.hero-inner{
  display:flex;flex-direction:column;align-items:center;
  will-change:transform,opacity;
}
.hero-logo{width:min(76vw,900px);will-change:transform}
.hero-logo img,.hero-logo svg{
  width:100%;height:auto;display:block;
  clip-path:inset(0 100% 0 0);
  animation:logoWipe 1.2s cubic-bezier(.76,0,.24,1) 1.9s forwards;
}
.hero-logo svg text{fill:var(--ink)}
@keyframes logoWipe{to{clip-path:inset(0 0 0 0)}}
.hero-tag{
  margin-top:40px;text-align:center;color:var(--grey);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  display:flex;gap:14px;align-items:center;
}
.hero-tag>span{
  opacity:0;transform:translateY(14px);
  animation:tagUp .7s cubic-bezier(.2,.6,.2,1) forwards;
}
.hero-tag>span:nth-child(1){animation-delay:2.5s}
.hero-tag>span:nth-child(2){animation-delay:2.62s}
.hero-tag>span:nth-child(3){animation-delay:2.74s}
.hero-tag>span:nth-child(4){animation-delay:2.86s}
.hero-tag>span:nth-child(5){animation-delay:2.98s}
@keyframes tagUp{to{opacity:1;transform:none}}
.hero-tag span.dot{width:3px;height:3px;border-radius:50%;background:var(--ink);display:inline-block}
.hero-scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--grey);
  opacity:0;animation:scrollIn .8s ease 3.3s forwards, bob 2.4s ease-in-out 3.3s infinite;
}
@keyframes scrollIn{to{opacity:1}}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
/* skip the intro when user prefers reduced motion */
@media (prefers-reduced-motion:reduce){
  .loader{display:none}
  .hero-logo img,.hero-logo svg{clip-path:none;animation:none}
  .hero-tag>span{opacity:1;transform:none;animation:none}
  .hero-scroll{opacity:1;animation:none}
}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- marquee ---------- */
.marquee{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  overflow:hidden;padding:14px 0;white-space:nowrap;
}
.marquee-track{display:inline-block;animation:scroll 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  padding:0 34px;
}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
section{padding:120px 24px}
.sec-head{
  display:flex;justify-content:space-between;align-items:baseline;
  border-bottom:1px solid var(--ink);padding-bottom:16px;margin-bottom:0;
}
.sec-head h2{
  font-size:clamp(34px,6vw,72px);font-weight:600;letter-spacing:-.02em;
  text-transform:uppercase;font-variation-settings:'wdth' 95;
}
.sec-head .label{color:var(--grey)}

/* ---------- work index ---------- */
#work{padding-bottom:60px}
.work-list{list-style:none}
.work-row{
  display:grid;grid-template-columns:60px 1fr auto auto;gap:24px;align-items:center;
  padding:30px 0;border-bottom:1px solid var(--line);
  transition:padding .35s;position:relative;
}
.work-row:hover{padding-left:16px}
.work-row .idx{font-size:11px;color:var(--grey);letter-spacing:.1em}
.work-row .name{
  font-size:clamp(20px,3vw,34px);font-weight:500;letter-spacing:-.01em;
  text-transform:uppercase;font-variation-settings:'wdth' 95;
}
.work-row .cat,.work-row .year{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey)}
.work-empty{padding:60px 0;color:var(--grey);font-size:13px;letter-spacing:.06em}
.work-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.wf{background:none;border:1px solid var(--line);color:var(--grey);padding:9px 22px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;transition:background .2s,color .2s,border-color .2s}
.wf:hover{color:var(--ink);border-color:var(--ink)}
.wf.on{background:var(--ink);color:var(--white);border-color:var(--ink)}

/* cursor-following preview */
.preview{
  position:fixed;top:0;left:0;width:300px;height:380px;
  pointer-events:none;z-index:90;overflow:hidden;
  opacity:0;transform:scale(.92);
  transition:opacity .3s,transform .3s;
}
.preview.on{opacity:1;transform:scale(1)}
.preview svg{width:100%;height:100%;display:block}

/* ---------- studio ---------- */
#studio .grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;padding-top:60px;
}
#studio p.big{
  font-size:clamp(22px,3.2vw,40px);font-weight:400;line-height:1.35;
  letter-spacing:-.01em;word-break:keep-all;
}
#studio .col p{font-size:14px;line-height:1.9;color:#333;word-break:keep-all;font-weight:300}
#studio .col p+p{margin-top:18px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink);margin-top:80px}
.stat{padding:28px 0;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat b{display:block;font-size:clamp(30px,4vw,52px);font-weight:600;letter-spacing:-.02em}
.stat span{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey)}

/* ---------- services (dark) ---------- */
#services{background:var(--ink);color:var(--white)}
#services .sec-head{border-color:var(--white)}
#services .sec-head .label{color:#777}
.svc-list{list-style:none;counter-reset:svc}
.svc{
  border-bottom:1px solid #2a2a2a;padding:0;overflow:hidden;
}
.svc-head{
  width:100%;background:none;border:0;color:inherit;text-align:left;
  display:flex;justify-content:space-between;align-items:center;
  padding:34px 0;
}
.svc-head h3{
  font-size:clamp(22px,3.4vw,40px);font-weight:500;text-transform:uppercase;
  letter-spacing:-.01em;font-variation-settings:'wdth' 95;
  transition:transform .35s;
}
.svc-head:hover h3{transform:translateX(14px)}
.svc-head .plus{font-size:22px;font-weight:300;transition:transform .4s}
.svc.open .plus{transform:rotate(45deg)}
.svc-body{
  max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.7,0,.3,1);
}
.svc-body p{
  font-size:14px;line-height:1.9;color:#bbb;max-width:640px;
  padding:0 0 36px;word-break:keep-all;font-weight:300;
}
.svc-sub{font-size:13px;font-weight:300;color:#8a8a8a;letter-spacing:.03em;margin-left:14px;text-transform:none;font-variation-settings:'wdth' 100}
.svc-deliver{list-style:none;margin-top:14px}
.svc-deliver li{padding:11px 0;border-bottom:1px solid var(--line);font-size:14px;letter-spacing:.02em;color:#333}

/* ---------- contact ---------- */
#contact{padding-bottom:60px}
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;padding-top:60px}
.contact-grid h3{
  font-size:clamp(28px,4.4vw,58px);font-weight:500;line-height:1.15;
  letter-spacing:-.02em;word-break:keep-all;
}
.contact-grid h3 a{border-bottom:2px solid var(--ink);transition:opacity .3s}
.contact-grid h3 a:hover{opacity:.4}
.c-info{display:flex;flex-direction:column;gap:26px;font-size:13px;line-height:1.8}
.c-info .label{color:var(--grey);display:block;margin-bottom:6px}

/* ---------- footer ---------- */
footer{
  background:var(--ink);color:var(--white);padding:60px 24px 28px;
}
.foot-logo svg{width:min(70vw,760px);margin:0 auto 60px;display:block}
.foot-logo svg text{fill:var(--white)}
.foot-bar{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid #2a2a2a;padding-top:22px;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#777;
}
.foot-bar a:hover{color:#fff}

/* ---------- fullscreen menu ---------- */
.menu-overlay{
  position:fixed;inset:0;background:var(--white);z-index:200;
  display:flex;flex-direction:column;justify-content:center;padding:24px;
  clip-path:inset(0 0 100% 0);transition:clip-path .6s cubic-bezier(.7,0,.3,1);
}
.menu-overlay.open{clip-path:inset(0 0 0 0)}
.menu-overlay a.big{
  font-size:clamp(38px,9vw,84px);font-weight:800;text-transform:uppercase;
  letter-spacing:-.02em;padding:6px 0;font-variation-settings:'wght' 800,'wdth' 95;
  color:var(--ink);-webkit-tap-highlight-color:transparent;
  transition:padding-left .3s,color .3s;
}
.menu-overlay a.big:hover{padding-left:22px}
.menu-close{
  position:absolute;top:18px;right:24px;background:none;border:0;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
}

/* =================================================
   ADMIN
================================================= */
.admin{display:none;min-height:100vh}
body.admin-mode .site{display:none}
body.admin-mode .loader{display:none}
body.admin-mode .admin{display:block}
body.admin-mode .cursor{display:none}

.admin-login{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
}
.login-box{width:100%;max-width:380px}
.login-box img{height:16px;margin-bottom:48px}
.login-box h1{font-size:13px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;margin-bottom:28px}
.field{margin-bottom:18px}
.field label{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);margin-bottom:8px}
.field label .req{color:#e02b2b;font-weight:700}
.field input,.field select,.field textarea{
  width:100%;border:1px solid var(--ink);background:var(--white);
  padding:13px 14px;font-size:14px;font-family:inherit;border-radius:0;
  outline:none;transition:background .2s,color .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{background:var(--ink);color:var(--white)}
.btn{
  display:inline-block;border:1px solid var(--ink);background:var(--ink);color:var(--white);
  padding:13px 30px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  transition:background .25s,color .25s;border-radius:0;
}
.cta-lg{padding:18px 46px;font-size:13px;letter-spacing:.16em;margin-top:8px}
.btn:hover{background:var(--white);color:var(--ink)}
.btn.ghost{background:var(--white);color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--white)}
.login-err{font-size:12px;color:var(--ink);margin-top:14px;display:none}
.login-hint{font-size:11px;color:var(--grey);margin-top:22px;line-height:1.7}

.admin-shell{display:none;min-height:100vh}
.admin-shell.on{display:grid;grid-template-columns:230px 1fr}
.admin-side{
  border-right:1px solid var(--ink);padding:24px;
  display:flex;flex-direction:column;gap:8px;position:sticky;top:0;height:100vh;
}
.admin-side img{height:13px;margin-bottom:36px}
.admin-side a{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:10px 0;
  border-bottom:1px solid var(--line);color:var(--grey);
}
.admin-side a.on,.admin-side a:hover{color:var(--ink)}
.admin-side .logout{margin-top:auto;font-size:10px}
.admin-main{padding:40px}
.admin-main h2{
  font-size:clamp(26px,3.6vw,44px);font-weight:600;text-transform:uppercase;
  letter-spacing:-.02em;border-bottom:1px solid var(--ink);padding-bottom:14px;margin-bottom:30px;
}
.admin-note{font-size:12px;color:var(--grey);line-height:1.8;margin-bottom:30px;max-width:560px;word-break:keep-all}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{
  text-align:left;font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--grey);font-weight:500;padding:10px 12px 10px 0;border-bottom:1px solid var(--ink);
}
.admin-table td{padding:16px 12px 16px 0;border-bottom:1px solid var(--line);vertical-align:middle}
.admin-table td.t-name{font-weight:500;text-transform:uppercase}
.row-actions button{
  background:none;border:1px solid var(--ink);padding:6px 12px;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;margin-right:6px;transition:all .2s;
}
.row-actions button:hover{background:var(--ink);color:var(--white)}
.admin-form{max-width:560px;border:1px solid var(--ink);padding:28px;margin-top:36px}
.admin-form h3{font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.admin-panel{display:none}
.admin-panel.on{display:block}
.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--ink);margin-bottom:36px}
.kpi{padding:24px;border-right:1px solid var(--ink)}
.kpi:last-child{border-right:0}
.kpi b{display:block;font-size:40px;font-weight:600;letter-spacing:-.02em}
.kpi span{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey)}
.toast{
  position:fixed;bottom:24px;left:50%;transform:translate(-50%,80px);
  background:var(--ink);color:var(--white);padding:13px 26px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;z-index:300;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.toast.on{transform:translate(-50%,0)}

/* ---------- responsive ---------- */
@media (max-width:860px){
  nav{display:none}
  .menu-btn{display:block}
  section{padding:90px 18px}
  header{padding:16px 18px}
  .work-row{grid-template-columns:40px 1fr auto;gap:14px}
  .work-row .cat{display:none}
  #studio .grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .stats{grid-template-columns:1fr;border-top:0}
  .stat{border-right:0;border-top:1px solid var(--line);padding-left:0}
  .preview{display:none}
  .admin-shell.on{grid-template-columns:1fr}
  .admin-side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;border-right:0;border-bottom:1px solid var(--ink)}
  .admin-side img{margin-bottom:0;margin-right:auto}
  .admin-side a{border-bottom:0;padding:6px 10px}
  .admin-main{padding:24px 18px}
  .form-row{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr}
  .kpi{border-right:0;border-bottom:1px solid var(--ink)}
  .kpi:last-child{border-bottom:0}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* =================================================
   MULTI-PAGE ADDITIONS
================================================= */

/* sub-pages have no loader/hero intro — header shows solid from the start */
body.subpage{padding-top:0}
body.subpage header{border-color:var(--line)}
body.subpage .header-logo img{opacity:1;transform:none}

/* generic back / breadcrumb link */
.crumb{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  color:var(--grey);transition:color .25s;
}
.crumb:hover{color:var(--ink)}

/* ---------- page header (sub-page hero) ---------- */
.page-hero{
  padding:160px 24px 70px;border-bottom:1px solid var(--ink);
}
.page-hero .eyebrow{
  display:block;font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--grey);font-weight:500;margin-bottom:22px;
}
.page-hero h1{
  font-size:clamp(44px,9vw,118px);font-weight:600;letter-spacing:-.03em;
  text-transform:uppercase;line-height:.95;font-variation-settings:'wdth' 95;
}
.page-hero p.lead{
  margin-top:30px;max-width:620px;font-size:clamp(15px,2vw,19px);
  line-height:1.7;color:#333;font-weight:300;word-break:keep-all;
}

/* ---------- work index as links ---------- */
a.work-row{color:inherit}
a.work-row .go{
  font-size:16px;color:var(--grey);justify-self:end;
  transition:transform .35s,color .35s;
}
a.work-row:hover .go{transform:translateX(6px);color:var(--ink)}

/* ---------- project detail ---------- */
.proj-head{padding:150px 24px 0}
.proj-head .meta-top{
  display:flex;gap:18px;flex-wrap:wrap;align-items:center;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--grey);
  margin-bottom:26px;
}
.proj-head .meta-top .dot{width:3px;height:3px;border-radius:50%;background:var(--grey);display:inline-block}
.proj-head h1{
  font-size:clamp(40px,8.5vw,120px);font-weight:600;letter-spacing:-.03em;
  text-transform:uppercase;line-height:.92;font-variation-settings:'wdth' 95;
}
.proj-visual{
  margin:60px 0 0;border:1px solid var(--line);overflow:hidden;background:var(--ink);
}
.proj-visual svg{width:100%;height:auto;display:block}
.proj-grid{
  display:grid;grid-template-columns:1fr 320px;gap:60px;
  padding:90px 24px;max-width:1280px;margin:0 auto;align-items:start;
}
.proj-grid .lead{
  font-size:clamp(20px,2.8vw,32px);font-weight:400;line-height:1.4;
  letter-spacing:-.01em;word-break:keep-all;
}
.proj-grid .body p{
  font-size:14px;line-height:1.95;color:#333;font-weight:300;
  word-break:keep-all;margin-top:20px;max-width:640px;
}
.proj-facts{
  border-top:1px solid var(--ink);position:sticky;top:90px;
}
.proj-facts .fact{
  padding:18px 0;border-bottom:1px solid var(--line);
}
.proj-facts .fact span{
  display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--grey);margin-bottom:7px;
}
.proj-facts .fact b{font-size:14px;font-weight:500;letter-spacing:.01em}
.proj-gallery{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  padding:0 24px 90px;max-width:1280px;margin:0 auto;
}
.proj-gallery .cell{border:1px solid var(--line);overflow:hidden;background:var(--ink)}
.proj-gallery .cell.wide{grid-column:1 / -1}
.proj-gallery svg{width:100%;height:auto;display:block}

/* prev / next project nav */
.proj-nav{
  display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--ink);
}
.proj-nav a{
  padding:50px 24px;transition:background .3s,color .3s;
}
.proj-nav a:last-child{border-left:1px solid var(--ink);text-align:right}
.proj-nav a:hover{background:var(--ink);color:var(--white)}
.proj-nav span{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--grey);display:block;margin-bottom:14px}
.proj-nav a:hover span{color:#777}
.proj-nav b{font-size:clamp(20px,3vw,34px);font-weight:600;text-transform:uppercase;letter-spacing:-.01em;font-variation-settings:'wdth' 95}

/* ---------- studio page extras ---------- */
.studio-values{
  display:grid;grid-template-columns:repeat(2,1fr);
  border-top:1px solid var(--ink);margin-top:0;
}
.studio-values .val{
  padding:40px 30px 40px 0;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
}
.studio-values .val:nth-child(2n){border-right:0;padding-right:0;padding-left:30px}
.studio-values .val .num{font-size:10px;letter-spacing:.18em;color:var(--grey);display:block;margin-bottom:14px}
.studio-values .val h3{font-size:clamp(20px,2.6vw,28px);font-weight:600;letter-spacing:-.01em;margin-bottom:14px}
.studio-values .val p{font-size:14px;line-height:1.9;color:#333;font-weight:300;word-break:keep-all}

/* generic two-column section */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding-top:60px}

/* ---------- services page process ---------- */
.process{counter-reset:step;border-top:1px solid var(--ink);margin-top:60px}
.process .step{
  display:grid;grid-template-columns:80px 1fr;gap:24px;
  padding:36px 0;border-bottom:1px solid var(--line);
}
.process .step .n{font-size:12px;color:var(--grey);letter-spacing:.1em}
.process .step h3{font-size:clamp(20px,2.6vw,30px);font-weight:600;letter-spacing:-.01em;margin-bottom:12px}
.process .step p{font-size:14px;line-height:1.9;color:#333;font-weight:300;max-width:620px;word-break:keep-all}

/* services list: open by default style on services page */
.svc-list.expanded .svc-body{max-height:none}
.svc-list.expanded .svc-body p{padding-bottom:36px}

/* ---------- contact page ---------- */
.contact-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;padding-top:60px}
.contact-form .field{margin-bottom:22px}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-detail .block{padding:22px 0;border-bottom:1px solid var(--line)}
.contact-detail .block:first-child{border-top:1px solid var(--ink)}
.contact-detail .block span{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);margin-bottom:8px}
.contact-detail .block a,.contact-detail .block p{font-size:15px;line-height:1.6;font-weight:400}
.contact-detail .block a{border-bottom:1px solid var(--ink);transition:opacity .3s}
.contact-detail .block a:hover{opacity:.5}

/* ---------- footer nav ---------- */
.foot-nav{display:flex;gap:24px;flex-wrap:wrap}
.foot-nav a{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#777;transition:color .25s}
.foot-nav a:hover{color:#fff}

/* ---------- responsive (multi-page) ---------- */
@media (max-width:860px){
  .proj-grid{grid-template-columns:1fr;gap:40px;padding:60px 18px}
  .proj-facts{position:static}
  .proj-gallery{grid-template-columns:1fr;padding:0 18px 60px}
  .proj-gallery .cell.wide{grid-column:auto}
  .studio-values{grid-template-columns:1fr}
  .studio-values .val,.studio-values .val:nth-child(2n){padding:30px 0;border-right:0}
  .split,.contact-page-grid{grid-template-columns:1fr;gap:36px}
  .contact-form .form-row{grid-template-columns:1fr}
  .page-hero{padding:130px 18px 50px}
  .proj-head{padding:120px 18px 0}
  .proj-nav a{padding:34px 18px}
}

/* work rows now carry a trailing "↗" indicator — give it an explicit track */
.work-row{grid-template-columns:60px 1fr auto auto 22px}
@media (max-width:860px){ .work-row{grid-template-columns:40px 1fr auto 18px} }

/* ---------- uploaded images ---------- */
.preview img{width:100%;height:100%;object-fit:cover;display:block}
.proj-visual img,.proj-gallery .cell img{width:100%;height:100%;object-fit:cover;display:block}
.proj-gallery .cell img{aspect-ratio:4/3}
.proj-gallery .cell.wide img{aspect-ratio:16/7}

/* ---------- admin image uploader ---------- */
.img-drop{
  display:block;border:1px dashed var(--ink);padding:18px;text-align:center;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);
  cursor:pointer;transition:background .2s,color .2s;
}
.img-drop:hover{background:var(--ink);color:var(--white)}
.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;margin-top:14px}
.thumb{position:relative;border:1px solid var(--line);aspect-ratio:1;overflow:hidden;cursor:pointer}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb button{
  position:absolute;top:4px;right:4px;width:22px;height:22px;border:0;
  background:var(--ink);color:#fff;font-size:13px;line-height:22px;text-align:center;
  border-radius:0;cursor:pointer;padding:0;
}
.thumb.is-cover{outline:2px solid var(--ink);outline-offset:-2px}
.thumb.is-cover::after{
  content:'★ 대표';position:absolute;bottom:0;left:0;right:0;background:var(--ink);
  color:#fff;font-size:9px;letter-spacing:.12em;text-align:center;padding:3px 0;
}
.thumb .thumb-no{position:absolute;top:4px;left:4px;background:rgba(0,0,0,.62);color:#fff;
  font-size:9px;line-height:1;padding:3px 5px;z-index:1}
.thumb .cover-set{position:absolute;left:4px;right:auto;top:auto;bottom:5px;width:auto;height:auto;
  padding:3px 8px;font-size:9px;letter-spacing:.04em;line-height:1.2;
  background:rgba(255,255,255,.92);color:var(--ink);border:1px solid var(--ink)}
.thumb:hover .cover-set{background:var(--ink);color:#fff}
.row-thumb{width:46px;height:34px;object-fit:cover;border:1px solid var(--line);display:block}
