@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=Fraunces:ital,opsz,wght@1,9..144,400;1,9..144,500&family=Space+Mono:wght@400;700&display=swap');
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css');

:root{
  --bg:#f4f4f5;
  --ink:#16161a;
  --gray:#8e8e95;
  --gray-soft:#bcbcc2;
  --line:#e2e2e5;
  --line-soft:#ebebee;
  --maxw:1280px;
  --sans:'Archivo',-apple-system,sans-serif;
  --kr:'Pretendard Variable','Pretendard',sans-serif;
  --mono:'Space Mono',monospace;
  --serif:'Fraunces',serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-y:scroll;scrollbar-gutter:stable}
body{font-family:var(--kr);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .3s,border-color .3s;border-bottom:1px solid transparent}
.nav.scrolled,.nav.solid{background:rgba(244,244,245,.5);backdrop-filter:saturate(180%) blur(26px);border-bottom-color:rgba(226,226,229,.6)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 48px;height:74px;display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--sans);font-size:22px;font-weight:800;letter-spacing:-.04em;display:inline-flex;align-items:center}
.brand img{height:24px;width:auto;display:block;transition:filter .3s}
.nav.onhero .brand img{filter:invert(1)}
.menu{display:flex;gap:34px}
.menu a{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--gray);transition:color .25s}
.menu a:hover,.menu a.active{color:var(--ink)}

/* HOME HERO */
.hero{max-width:var(--maxw);margin:0 auto;padding:0 48px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative}
.hero-top{position:absolute;top:140px;left:48px;right:48px;display:flex;justify-content:space-between;align-items:baseline}
.hero-eye{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray)}
.hero-name{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.hero-type{font-family:var(--sans);font-weight:900;line-height:.92;letter-spacing:-.04em;font-size:100px;opacity:0;transform:translateY(28px);animation:rise 1.1s .1s cubic-bezier(.16,1,.3,1) forwards}
.hero-sub{margin-top:40px;font-family:var(--kr);font-size:clamp(15px,1.7vw,19px);color:var(--gray);max-width:480px;line-height:1.75;opacity:0;animation:fade 1s .7s forwards}
.hero-labels{position:absolute;bottom:44px;left:48px;right:48px;display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);opacity:0;animation:fade 1s .9s forwards}
.hero-labels span{font-family:var(--mono);font-size:12px;letter-spacing:.03em;color:var(--ink);padding:18px 0 0 20px;border-left:1px solid var(--line)}
.hero-labels span:first-child{border-left:none;padding-left:0}
.hero-labels span small{display:block;font-size:10px;color:var(--gray-soft);margin-bottom:7px;letter-spacing:.1em}

@keyframes rise{to{opacity:1;transform:none}}
@keyframes fade{to{opacity:1}}

/* SECTION FRAME */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 48px}
.page-top{padding:150px 48px 0;max-width:var(--maxw);margin:0 auto}
.page-title{font-family:var(--sans);font-weight:900;font-size:clamp(52px,8vw,96px);letter-spacing:-.04em;line-height:1}
.page-lead{font-family:var(--kr);color:var(--gray);font-size:clamp(17px,1.6vw,20px);margin-top:24px;max-width:none;line-height:1.75}

/* HOME WORK (full width, regular) */
.work{max-width:var(--maxw);margin:0 auto;padding:140px 48px 40px}
.work-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:60px;border-top:1px solid var(--ink);padding-top:20px}
.work-head h2{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--gray)}
.work-head a{font-family:var(--mono);font-size:12px;color:var(--gray);transition:color .25s}
.work-head a:hover{color:var(--ink)}
.proj{margin-bottom:80px;width:100%}
.proj-img{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:16/9}
.proj-img .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:14px;color:var(--gray-soft);letter-spacing:.05em;transition:transform 1s cubic-bezier(.16,1,.3,1)}
.proj-img:hover .ph{transform:scale(1.04)}
.c1 .ph{background:linear-gradient(135deg,#e7e7ec,#d3d4db)}
.c2 .ph{background:linear-gradient(135deg,#e9e9ed,#d6d7dd)}
.c3 .ph{background:linear-gradient(135deg,#e6e7ea,#d1d3d9)}
.c4 .ph{background:linear-gradient(135deg,#eaeaed,#d4d5da)}
.cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.cap-l{display:flex;align-items:baseline;gap:14px}
.cap .num{font-family:var(--mono);font-size:12px;color:var(--gray)}
.cap h3{font-family:var(--sans);font-weight:700;font-size:clamp(19px,2vw,26px);letter-spacing:-.02em;line-height:1.1}
.cap-r{text-align:right;font-family:var(--mono);font-size:11px;letter-spacing:.04em;line-height:1.7}
.cap-r .meta{color:var(--ink);text-transform:uppercase;display:block}
.cap-r .yr{color:var(--gray);display:block}

.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* QUOTE */
.quote{max-width:900px;margin:0 auto;padding:130px 48px;text-align:center}
.quote p{font-family:var(--serif);font-weight:400;font-style:italic;font-size:clamp(26px,3.8vw,46px);line-height:1.3;color:var(--ink)}
.quote cite{font-family:var(--mono);display:block;margin-top:28px;font-size:13px;font-style:normal;color:var(--gray);letter-spacing:.08em}

/* FOOTER */
footer{border-top:1px solid var(--line)}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:48px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
.foot-brand{font-family:var(--sans);font-size:24px;font-weight:600;letter-spacing:-.03em;color:var(--gray)}
.foot-brand img{height:22px;width:auto;display:block;opacity:.5}
.brand-mark{max-width:var(--maxw);margin:0 auto;padding:80px 48px 10px;display:flex;justify-content:center}
.brand-mark img{width:clamp(150px,18vw,210px);height:auto;opacity:.9}
.foot-info{font-family:var(--mono);font-size:12px;color:var(--gray);line-height:2;text-align:right}
.foot-info a:hover{color:var(--ink)}

/* WORK PAGE — filters + grid */
.filters{max-width:var(--maxw);margin:0 auto;padding:60px 48px 0}
.filter-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}
.filter-row .chips{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.filter-row .lab{font-family:var(--mono);font-size:16px;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-soft);width:auto;margin-right:6px;flex-shrink:0}
.chip{font-family:var(--mono);font-size:16px;padding:8px 17px;border:1px solid var(--line);border-radius:99px;color:var(--gray);cursor:pointer;transition:all .2s;background:transparent}
.chip:hover{border-color:var(--gray);color:var(--ink)}
.chip.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.wgrid{max-width:var(--maxw);margin:0 auto;padding:50px 48px 40px;display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
.wcard{position:relative;border-radius:3px;overflow:hidden;cursor:pointer}
.wcard.size-l{grid-column:span 8}
.wcard.size-m{grid-column:span 4}
.wcard.size-s{grid-column:span 4}
.wcard.size-w{grid-column:span 12}
.wcard.size-l,.wcard.size-m{height:clamp(300px,33vw,420px)}
.wcard.size-s{height:clamp(210px,23vw,290px)}
.wcard.size-w{height:clamp(220px,26vw,330px)}
.wcard .ph{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(1.05);transition:transform .9s cubic-bezier(.16,1,.3,1)}
.wcard:hover .ph{transform:scale(1)}
.wcard .ov{position:absolute;inset:0;background:rgba(22,22,26,0);display:flex;flex-direction:column;justify-content:flex-end;padding:28px;transition:background .45s}
.wcard:hover .ov{background:rgba(22,22,26,.6)}
.wcard .ov .t,.wcard .ov .c{color:#fff;opacity:0;transform:translateY(8px);transition:opacity .45s,transform .45s}
.wcard .ov .t{font-family:var(--sans);font-size:22px;font-weight:600;letter-spacing:-.02em}
.wcard .ov .c{font-family:var(--mono);font-size:16px;color:rgba(255,255,255,.75);margin-top:6px;text-transform:uppercase;letter-spacing:.05em}
.wcard:hover .ov .t{opacity:1;transform:none;transition-delay:.05s}
.wcard:hover .ov .c{opacity:1;transform:none;transition-delay:.1s}

/* ABOUT PAGE */
.section{max-width:var(--maxw);margin:0 auto;padding:0 48px}
.sec-line{border-top:1px solid var(--line);margin-top:90px;padding-top:40px}
.sec-label{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--gray);font-weight:700;margin-bottom:40px}
.about-intro{font-family:var(--sans);font-weight:500;font-size:clamp(22px,3vw,36px);line-height:1.4;letter-spacing:-.02em;max-width:900px;margin-top:50px}
.approach{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.approach .item{background:var(--bg);padding:34px}
.approach .item h4{font-family:var(--sans);font-size:20px;font-weight:600;letter-spacing:-.02em;margin-bottom:10px}
.approach .item p{font-family:var(--kr);font-size:14px;color:var(--gray);line-height:1.7}
.approach-note{font-family:var(--mono);font-size:12px;color:var(--gray-soft);margin-bottom:20px;letter-spacing:.03em}
.skills-grid{display:flex;flex-direction:column;gap:22px}
.skill-row{display:flex;align-items:baseline;gap:24px;border-bottom:1px solid var(--line-soft);padding-bottom:18px}
.skill-row .sk-cat{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray);width:130px;flex-shrink:0}
.skill-row .sk-list{font-family:var(--sans);font-size:clamp(16px,1.8vw,21px);font-weight:500;letter-spacing:-.01em}
.duties{font-family:var(--sans);font-weight:500;font-size:clamp(18px,2.2vw,28px);line-height:1.7;letter-spacing:-.02em;max-width:1000px}
.duties span{color:var(--gray-soft)}
.about-quote{font-family:var(--serif);font-style:italic;font-size:clamp(30px,4.5vw,56px);line-height:1.25;letter-spacing:-.01em;margin-top:40px;max-width:1000px}
.about-cite{font-family:var(--mono);font-size:14px;color:var(--gray);margin-top:22px;letter-spacing:.06em}
.about-desc{font-family:var(--kr);font-size:clamp(17px,1.8vw,20px);color:var(--gray);line-height:1.8;margin-top:40px;max-width:680px}

/* SERVICE PAGE */
.tabs{display:flex;gap:10px;flex-wrap:nowrap;margin-top:40px;border-bottom:none;padding-bottom:0}
.tab{flex:1;display:flex;align-items:center;gap:16px;font-family:var(--kr);padding:20px 26px;cursor:pointer;color:var(--gray);border:1px solid var(--line);border-radius:10px;background:var(--bg);transition:all .2s;position:static}
.tab-ic{display:inline-flex;color:var(--gray-soft);transition:color .2s}
.tab-ic svg{width:26px;height:26px}
.tab-tx{display:flex;flex-direction:column;gap:5px;align-items:flex-start}
.tab b{font-family:var(--sans);font-weight:700;font-size:18px;letter-spacing:-.02em;color:var(--gray);line-height:1}
.tab em{font-style:normal;font-family:var(--mono);font-size:16px;letter-spacing:.01em;color:var(--gray-soft);white-space:nowrap;line-height:1}
.tab:hover{border-color:var(--gray)}
.tab:hover b,.tab:hover .tab-ic{color:var(--ink)}
.tab.on{color:#fff;border-color:var(--ink);background:var(--ink);font-weight:700}
.tab.on b{color:#fff}
.tab.on em,.tab.on .tab-ic{color:rgba(255,255,255,.6)}
.svc-panel{display:none;padding-top:60px}
.svc-panel.on{display:block;animation:fade .5s forwards;opacity:0}
.svc-head{margin-bottom:64px}
.svc-copy{font-family:var(--sans);font-weight:600;font-size:clamp(24px,3.4vw,42px);letter-spacing:-.03em;line-height:1.25;max-width:820px;margin-bottom:16px}
.svc-copy-sub{font-family:var(--kr);color:var(--gray);font-size:16px;margin-bottom:0}
.packages{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:0}
.pkg{border:1px solid var(--line);border-radius:4px;padding:28px 24px;display:flex;flex-direction:column;min-height:250px;transition:border-color .25s}
.pkg:hover{border-color:var(--gray)}
.pkg.feat{border-color:var(--ink);border-width:1.5px}
.pkg .pk-name{font-family:var(--sans);font-weight:700;font-size:20px;margin-bottom:4px}
.pkg .pk-badge{font-family:var(--mono);font-size:16px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray);margin-bottom:18px;height:20px}
.pkg ul{list-style:none;font-family:var(--kr);font-size:16px;color:var(--gray);line-height:1.95;flex:1}
.pkg .pk-foot{font-family:var(--mono);font-size:16px;color:var(--ink);margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.pkg-cta{display:flex;justify-content:center;margin:40px 0 88px}
.flow{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.flow .step{flex:1;min-width:140px;padding:26px 22px;border-right:1px solid var(--line)}
.flow .step:last-child{border-right:none}
.flow .step .st-num{font-family:var(--mono);font-size:16px;color:var(--gray-soft);margin-bottom:10px}
.flow .step .st-name{font-family:var(--sans);font-weight:600;font-size:17px;margin-bottom:8px}
.flow .step .st-desc{font-family:var(--kr);font-size:16px;color:var(--gray);line-height:1.55}
.flow-label{font-family:var(--mono);font-size:16px;color:var(--gray);margin-bottom:24px;letter-spacing:.03em}

/* CONTACT PAGE */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch;padding-bottom:30px}
.contact-col{display:flex;flex-direction:column}
.c-sublabel{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--gray);margin-bottom:20px}
.map{flex:1;min-height:230px;border-radius:3px;background:linear-gradient(135deg,#e7e7ec,#d6d7dd);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;color:var(--gray-soft)}
.cinfo{margin-top:26px;font-family:var(--mono);font-size:13px;line-height:2;color:var(--ink)}
.cinfo .g{color:var(--gray)}
.form-field{width:100%;border:1px solid var(--line);background:transparent;border-radius:6px;padding:16px 18px;font-family:var(--kr);font-size:15px;color:var(--ink);margin-bottom:14px;transition:border-color .2s}
.form-field:focus{outline:none;border-color:var(--ink)}
textarea.form-field{flex:1;min-height:120px;resize:none}
.form-btn{width:100%;padding:17px;background:var(--ink);color:var(--bg);border:none;border-radius:6px;font-family:var(--mono);font-size:13px;letter-spacing:.05em;cursor:pointer;transition:opacity .2s}
.form-btn:hover{opacity:.85}
.form-note{font-family:var(--mono);font-size:11px;color:var(--gray-soft);margin-top:14px;letter-spacing:.02em}

/* ===== 영상 히어로 (검정) ===== */
.nav.onhero .brand{color:#fff}
.nav.onhero .menu a{color:rgba(255,255,255,.7)}
.nav.onhero .menu a:hover,.nav.onhero .menu a.active{color:#fff}
.hero-v{position:relative;height:100vh;background:#000;overflow:hidden;display:flex;align-items:center}
.hero-v video,.hero-v .hero-img{position:absolute;top:0;right:0;height:100%;width:62%;object-fit:cover;object-position:center;z-index:1;opacity:.95}
.hero-v .hero-img{background-size:cover;background-position:center}
.hero-v::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,#000 28%,transparent 64%)}
.hero-v .inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 48px;width:100%}
.hero-v .eye{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:30px}
.hero-v h1{font-family:var(--sans);font-weight:900;font-size:100px;line-height:.92;letter-spacing:-.04em;color:#fff}
.hero-v .sub{font-family:var(--mono);margin-top:34px;font-size:14px;color:rgba(255,255,255,.6);line-height:1.9}
.hero-v .cue{position:absolute;bottom:40px;left:48px;z-index:3;font-family:var(--mono);font-size:11px;letter-spacing:.15em;color:rgba(255,255,255,.5)}

/* ===== Contact — 큰 지도 + 그리드 ===== */
.contact-wrap{max-width:var(--maxw);margin:0 auto;padding:60px 48px 0}
.mapblock{width:100%;margin:48px 0 0;padding:0}
.contact-map{position:relative;width:100%;height:clamp(340px,44vw,520px);overflow:hidden;background:#eaeaee;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.contact-map iframe{width:100%;height:100%;border:0;filter:grayscale(.45) contrast(.96)}
.map-naver{position:absolute;right:18px;bottom:18px;z-index:4;display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:16px;color:#fff;background:#03c75a;padding:12px 19px;border-radius:99px;box-shadow:0 6px 20px rgba(0,0,0,.18);letter-spacing:.01em;transition:transform .25s,box-shadow .25s}
.map-naver:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.26)}
.map-naver svg{width:15px;height:15px}
.contact-grid2{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;margin-top:48px;padding-bottom:30px}
.contact-info{grid-column:1/5}
.contact-info .row{padding:18px 0;border-top:1px solid var(--line)}
.contact-info .row:first-child{border-top:none;padding-top:0}
.contact-info .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--gray);margin-bottom:7px}
.contact-info .v{font-family:var(--mono);font-size:14px;color:var(--ink);line-height:1.6}
.contact-form{grid-column:7/13;display:flex;flex-direction:column}
.contact-form .clabel{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--gray);margin-bottom:20px}

/* ===== 세로 Selected Work (4개 한 줄, 텍스트 이미지 위) ===== */
.swork{max-width:var(--maxw);margin:0 auto;padding:16px 48px 40px}
.swork-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:48px;border-top:1px solid var(--ink);padding-top:22px}
.swork-head h2{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--gray)}
.swork-head a{font-family:var(--mono);font-size:13px;color:var(--gray);transition:color .25s}
.swork-head a:hover{color:var(--ink)}
.swork-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.scard{position:relative;aspect-ratio:62/100;border-radius:3px;overflow:hidden;cursor:pointer}
.scard .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1s cubic-bezier(.16,1,.3,1)}
.scard:hover .bg{transform:scale(1.06)}
.scard.s1 .bg{background-image:url(img/sw1.jpg)}
.scard.s2 .bg{background-image:url(img/sw2.jpg)}
.scard.s3 .bg{background-image:url(img/sw3.jpg)}
.scard.s4 .bg{background-image:url(img/sw4.jpg)}
.scard .ov{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;opacity:0;background:linear-gradient(to top,rgba(11,11,14,.82),rgba(11,11,14,.2) 55%,transparent);transition:opacity .42s cubic-bezier(.16,1,.3,1)}
.scard:hover .ov{opacity:1}
.scard .ov .num{font-family:var(--mono);font-size:16px;color:rgba(255,255,255,.7);margin-bottom:8px;transform:translateY(10px);transition:transform .42s .04s}
.scard .ov h3{font-family:var(--sans);font-weight:700;font-size:21px;color:#fff;letter-spacing:-.02em;line-height:1.15;transform:translateY(10px);transition:transform .42s .08s}
.scard .ov .meta{font-family:var(--mono);font-size:16px;color:rgba(255,255,255,.72);margin-top:8px;text-transform:uppercase;letter-spacing:.04em;transform:translateY(10px);transition:transform .42s .12s}
.scard:hover .ov .num,.scard:hover .ov h3,.scard:hover .ov .meta{transform:translateY(0)}
.swork-more{display:flex;justify-content:center;margin-top:48px}
.btn-line{font-family:var(--mono);font-size:16px;letter-spacing:.04em;color:var(--ink);border:1px solid var(--ink);border-radius:99px;padding:15px 34px;transition:all .3s cubic-bezier(.16,1,.3,1);display:inline-block}
.btn-line:hover{background:var(--ink);color:var(--bg);transform:translateY(-2px)}

/* ===== WHAT WE DO (아이콘 마퀴) ===== */
.section-wide{max-width:var(--maxw);margin:0 auto;padding:52px 48px}
.sec-eyebrow{font-family:var(--mono);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gray);margin-bottom:40px;display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--ink);padding-top:22px}
.sec-eyebrow.single{justify-content:flex-start}
.wwd .wwd-marquee{position:relative;width:100%;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.wwd-track{display:flex;width:max-content;animation:wwd-scroll 46s linear infinite}
.wwd .wwd-marquee:hover .wwd-track{animation-play-state:paused}
@keyframes wwd-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.wwd-chip{display:inline-flex;align-items:center;gap:14px;padding:0 34px;color:var(--ink);white-space:nowrap;position:relative;transition:color .3s}
.wwd-chip::after{content:"";display:block;width:6px;height:6px;border-radius:50%;background:var(--gray-soft);flex-shrink:0;order:-1}
.wwd-chip svg{width:26px;height:26px;flex-shrink:0;color:var(--gray);transition:color .3s,transform .3s}
.wwd-chip .t{font-family:var(--sans);font-weight:600;font-size:clamp(20px,2.4vw,32px);letter-spacing:-.03em;line-height:1}
.wwd-chip:hover{color:var(--gray)}
.wwd-chip:hover svg{color:var(--ink);transform:rotate(-6deg) scale(1.08)}

/* ===== 수치 (stats) ===== */
.stats{position:relative;background:#0b0b0e;color:#fff;overflow:hidden}
.stats-parallax{position:absolute;inset:-20% 0;z-index:0;will-change:transform;
  background:
    radial-gradient(48% 42% at 18% 22%,rgba(132,142,170,.22),transparent 70%),
    radial-gradient(42% 40% at 82% 28%,rgba(96,108,132,.18),transparent 70%),
    radial-gradient(60% 55% at 50% 96%,rgba(150,160,184,.14),transparent 72%);}
.stats-parallax::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px;mask:radial-gradient(70% 70% at 50% 50%,#000,transparent)}
.stats-parallax.img{background:#000 center/cover no-repeat}
.stats-parallax.img::before{display:none}
.stats-shade{position:absolute;inset:0;z-index:1;background:#000;opacity:.55;pointer-events:none}
.stats-glow{position:absolute;z-index:2;left:50%;top:0;width:60%;height:1px;transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent)}
.stats-wrap{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:120px 48px;text-align:center}
.stats-title{font-family:var(--sans);font-weight:800;font-size:clamp(16px,2vw,24px);letter-spacing:-.02em;line-height:1.05;margin-bottom:48px;color:#fff}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:40px 30px}
.stat{text-align:center}
.stat .num{font-family:var(--sans);font-weight:900;font-size:clamp(30px,4vw,58px);letter-spacing:-.04em;line-height:.95;
  background:linear-gradient(180deg,#fff 30%,rgba(255,255,255,.55));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lab{font-family:var(--mono);font-size:16px;color:rgba(255,255,255,.5);margin-top:16px;letter-spacing:.02em}

/* ===== 고객사 (clients) ===== */
.clients{position:relative;overflow:hidden;padding:118px 0}
.clients-parallax{position:absolute;inset:-20% 0;z-index:0;will-change:transform;
  background-image:url(img/clients_parallax.jpg);background-size:cover;background-position:center;opacity:.9}
.clients-parallax::after{content:"";position:absolute;inset:0;background:rgba(244,244,245,var(--client-ov,.8))}
.clients-body{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 48px}
.clients-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:transparent;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.client{position:relative;background:transparent;aspect-ratio:3/2;display:flex;align-items:center;justify-content:center;transition:background .3s;overflow:hidden;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.client:hover{background:rgba(255,255,255,.4)}
.client .en,.client .kr,.client .logo{position:absolute;transition:opacity .32s cubic-bezier(.16,1,.3,1),transform .32s cubic-bezier(.16,1,.3,1)}
.client .en{font-family:var(--sans);font-weight:700;font-size:22px;color:var(--gray-soft);letter-spacing:-.02em}
.client .logo{max-height:94px;max-width:72%;width:auto;object-fit:contain;opacity:.85;filter:grayscale(1)}
.client .kr{font-family:var(--kr);font-weight:600;font-size:18px;color:var(--ink);opacity:0;transform:translateY(8px)}
.client:hover .en,.client:hover .logo{opacity:0;transform:translateY(-8px)}
.client:hover .logo{transform:translateY(-8px) scale(.96)}
.client:hover .kr{opacity:1;transform:none}

/* ===== 어떤 서비스가 필요한가요 ===== */
.services{max-width:var(--maxw);margin:0 auto;padding:120px 48px}
.srv-row{display:flex;align-items:center;justify-content:space-between;padding:30px 0;border-top:1px solid var(--line);cursor:pointer;transition:padding .3s}
.srv-row:last-child{border-bottom:1px solid var(--line)}
.srv-row:hover{padding-left:16px}
.srv-row .name{font-family:var(--sans);font-weight:600;font-size:clamp(24px,3vw,40px);letter-spacing:-.02em}
.srv-row .arr{font-family:var(--mono);font-size:22px;color:var(--gray-soft);transition:transform .3s,color .3s}
.srv-row:hover .arr{transform:translateX(8px);color:var(--ink)}

/* ===== FAQ ===== */
.faq{max-width:var(--maxw);margin:0 auto;padding:118px 48px}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:26px 0;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:clamp(17px,1.9vw,22px);letter-spacing:-.01em}
.faq-q .pm{font-family:var(--mono);font-size:22px;color:var(--gray);transition:transform .3s}
.faq-item.open .faq-q .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-a p{font-family:var(--kr);font-size:16px;color:var(--gray);line-height:1.8;padding:0 0 0}
.faq-item.open .faq-a{max-height:240px;padding-bottom:26px}

/* ===== 작업흐름 화살표 ===== */
.flow{position:relative}
.flow .step{position:relative}
.flow .step:not(:last-child)::after{content:"→";position:absolute;right:-9px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:16px;color:var(--gray-soft);z-index:3;background:var(--bg);padding:2px 0}

/* ===== 약도 (네이버지도 링크) ===== */
.mapwrap{position:relative;width:100%;height:460px;background:#ececef;overflow:hidden;display:block;cursor:pointer;border-bottom:1px solid var(--line)}
.mapwrap svg{position:absolute;inset:0;width:100%;height:100%}
.mapwrap .pin-label{position:absolute;z-index:4;font-family:var(--mono);font-size:13px;color:var(--ink);background:#fff;padding:9px 15px;border-radius:99px;box-shadow:0 4px 18px rgba(0,0,0,.1);transform:translate(-50%,-150%);transition:transform .3s}
.mapwrap:hover .pin-label{transform:translate(-50%,-165%)}
.mapwrap .map-cta{position:absolute;right:24px;bottom:24px;z-index:4;font-family:var(--mono);font-size:12px;color:var(--ink);background:#fff;padding:11px 18px;border-radius:99px;box-shadow:0 4px 18px rgba(0,0,0,.08);letter-spacing:.03em}

/* ===== 텍스트 크기 상향 — 최소 16px ===== */
.menu a{font-size:16px}
.quote cite{font-size:16px}
.foot-info{font-size:16px}
.sec-label{font-size:13px}
.approach .item p{font-size:16px}
.approach-note{font-size:16px}
.about-cite{font-size:16px}
.form-field{font-size:16px}
.form-note{font-size:16px}
.form-btn{font-size:16px}
.hero-v .eye{font-size:16px}
.hero-v .sub{font-size:16px}
.hero-v .cue{font-size:16px}
.contact-info .k{font-size:16px}
.contact-info .v{font-size:16px}
.contact-form .clabel{font-size:16px}
.swork-head h2{font-size:13px}
.swork-head a{font-size:16px}
.about-intro{font-size:clamp(24px,3.2vw,40px)}
.duties{font-size:clamp(20px,2.4vw,30px)}

/* ===== About — Approach 아이콘 ===== */
.approach .item{display:flex;flex-direction:column}
.approach .item .ic{display:inline-flex;color:var(--gray-soft);margin-bottom:18px;transition:color .3s}
.approach .item .ic svg{width:34px;height:34px}
.approach .item .ic .ic-img{width:34px;height:34px;object-fit:contain}
.approach .item:hover .ic{color:var(--ink)}

/* ===== About — What we do 아이콘 그리드 ===== */
.cap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:6px}
.cap-item{background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;padding:36px 16px;text-align:center;transition:background .3s}
.cap-item:hover{background:#fff}
.cap-item svg{width:30px;height:30px;color:var(--gray);transition:color .3s,transform .3s}
.cap-item .ic-img{width:30px;height:30px;object-fit:contain}
.tab-ic .ic-img{width:26px;height:26px;object-fit:contain}
.cap-item:hover svg{color:var(--ink);transform:translateY(-2px)}
.cap-item span{font-family:var(--sans);font-weight:600;font-size:16px;letter-spacing:-.01em;line-height:1.3}

/* ===== WORK 리스팅 빈 상태 ===== */
.wempty{max-width:var(--maxw);margin:0 auto;padding:0 48px 80px;font-family:var(--kr);font-size:16px;color:var(--gray)}

/* ===== WORK 상세 페이지 ===== */
.detail-top{max-width:var(--maxw);margin:0 auto;padding:130px 48px 0;position:relative}
.d-back{font-family:var(--mono);font-size:16px;color:var(--gray);letter-spacing:.04em;display:inline-block;margin-bottom:34px;transition:color .25s}
.d-back:hover{color:var(--ink)}
.d-eyebrow{font-family:var(--mono);font-size:16px;text-transform:uppercase;letter-spacing:.1em;color:var(--gray);display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--ink);padding-top:20px;margin-bottom:30px}
.detail-title{font-family:var(--sans);font-weight:900;font-size:clamp(40px,6.5vw,84px);letter-spacing:-.04em;line-height:1.02}
.detail-summary{font-family:var(--kr);color:var(--gray);font-size:clamp(17px,1.7vw,21px);line-height:1.7;margin-top:22px;max-width:680px}
.detail-cover{max-width:var(--maxw);margin:56px auto 0;padding:0 48px}
.detail-cover-wrap{overflow:hidden;border-radius:4px;cursor:zoom-in;display:inline-block;width:100%}
.detail-cover-wrap img{max-width:100%;width:100%;height:auto;display:block;transform:scale(1.05);transition:transform 1s cubic-bezier(.16,1,.3,1)}
.detail-cover-wrap:hover img{transform:scale(1)}
.detail-grid{max-width:var(--maxw);margin:0 auto;padding:72px 48px 0;display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:start}
.detail-meta{position:sticky;top:104px}
.detail-meta .row{padding:16px 0;border-top:1px solid var(--line)}
.detail-meta .row:first-child{border-top:none;padding-top:0}
.detail-meta .k{font-family:var(--mono);font-size:16px;text-transform:uppercase;letter-spacing:.07em;color:var(--gray);margin-bottom:7px}
.detail-meta .v{font-family:var(--mono);font-size:16px;color:var(--ink);line-height:1.5}
.detail-meta .d-link{color:var(--ink);border-bottom:1px solid var(--gray-soft);transition:border-color .25s,color .25s;word-break:break-all}
.detail-meta .d-link:hover{border-color:var(--ink)}
.detail-meta .d-link.none{color:var(--gray-soft);border:none}
.detail-body p{font-family:var(--kr);font-size:clamp(16px,1.5vw,19px);line-height:1.95;color:#33343a;margin-bottom:24px}
.detail-body p:last-child{margin-bottom:0}
.detail-gallery{max-width:var(--maxw);margin:0 auto;padding:80px 48px 0;display:flex;flex-direction:column;gap:22px;align-items:center}
.detail-gallery .gallery-item{overflow:hidden;border-radius:4px;cursor:zoom-in}
.detail-gallery .gallery-item img{max-width:100%;width:auto;height:auto;display:block;transform:scale(1.05);transition:transform 1s cubic-bezier(.16,1,.3,1)}
.detail-gallery .gallery-item:hover img{transform:scale(1)}
/* 프로토타입 */
.detail-proto{max-width:var(--maxw);margin:0 auto;padding:92px 48px 0}
.proto-browser{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 30px 60px -30px rgba(16,16,22,.25)}
.proto-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line);background:#f0f0f2}
.proto-bar span{width:11px;height:11px;border-radius:50%;background:#d3d4da}
.proto-bar em{margin-left:14px;font-family:var(--mono);font-style:normal;font-size:16px;color:var(--gray);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.proto-screen{position:relative;width:100%;height:clamp(360px,52vw,640px);background:#ececed}
.proto-screen iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:1}
.proto-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.proto-pdf{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#ececed}
.proto-pdf iframe{width:100%;height:clamp(420px,70vw,820px);border:0;display:block}
.proto-pdf.empty{position:relative;height:clamp(360px,46vw,520px)}
.proto-pdf.empty img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2)}
.proto-pdf.empty span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:16px;color:var(--ink);background:rgba(244,244,245,.7)}
.proto-images{display:flex;flex-direction:column;gap:22px;align-items:center}
.proto-images img{max-width:100%;width:auto;height:auto;border-radius:6px;border:1px solid var(--line);display:block}
.proto-cta{display:flex;justify-content:center;margin-top:36px}
/* 이전/다음/목록 */
.prevnext{max-width:var(--maxw);margin:100px auto 0;padding:0 48px;display:grid;grid-template-columns:1fr auto 1fr;gap:18px;border-top:1px solid var(--line);padding-top:34px}
.pn{display:flex;flex-direction:column;gap:6px;padding:14px 4px;transition:transform .25s}
.pn .dir{font-family:var(--mono);font-size:16px;color:var(--gray);letter-spacing:.04em}
.pn .nm{font-family:var(--sans);font-weight:600;font-size:clamp(16px,1.6vw,20px);letter-spacing:-.01em;color:var(--ink)}
.pn.next{text-align:right;align-items:flex-end}
.pn.list{text-align:center;align-items:center;justify-content:center;border-left:1px solid var(--line);border-right:1px solid var(--line);padding-left:28px;padding-right:28px}
.pn.list .nm{color:var(--gray)}
.pn.prev:hover{transform:translateX(-4px)}
.pn.next:hover{transform:translateX(4px)}
.pn.list:hover .nm{color:var(--ink)}

/* MOBILE */
@media(max-width:768px){
  .swork,.section-wide,.faq{padding-left:22px;padding-right:22px}
  .clients-body{padding-left:22px;padding-right:22px}
  .swork-grid{grid-template-columns:1fr 1fr;gap:12px}
  .stats-wrap{padding:80px 22px}
  .stats-inner{grid-template-columns:1fr 1fr;gap:44px 20px}
  .stats-title{margin-bottom:48px}
  .clients-grid{grid-template-columns:repeat(2,1fr)}
  .wwd .sec-eyebrow{padding-top:12px;margin-bottom:12px}
  .wwd .wwd-marquee{-webkit-mask:none;mask:none;overflow:visible}
  .wwd-track{animation:none;width:auto;display:flex;flex-wrap:wrap;justify-content:center}
  .wwd-chip{gap:11px;padding:12px 8px;width:50%;justify-content:center}
  .wwd-chip[aria-hidden="true"]{display:none}
  .wwd-chip svg{width:22px;height:22px}
  .wwd-chip .t{font-size:20px}
  .section-wide.wwd{padding-top:16px!important;padding-bottom:16px!important}
  .hero-v{align-items:flex-end;padding-bottom:120px}
  .hero-v video,.hero-v .hero-img{top:0;right:0;left:0;width:100%;height:100%;object-position:60% center}
  .hero-v::after{background:linear-gradient(0deg,#000 18%,rgba(0,0,0,.35) 52%,rgba(0,0,0,.6) 100%)}
  .hero-v .inner{padding-left:22px;padding-right:22px}
  .hero-v h1{font-size:52px}
  .hero-v .cue{left:22px}
  .contact-wrap{padding-left:22px;padding-right:22px}
  .contact-map{height:300px}
  .contact-info,.contact-form{grid-column:1/13}
  .contact-form{margin-top:8px}
  .nav-inner,.hero,.work,.quote,.foot-inner,.wrap,.page-top,.filters,.wgrid,.section{padding-left:22px;padding-right:22px}
  .hero-top{left:22px;right:22px;top:104px}
  .hero{min-height:auto;padding-top:168px;padding-bottom:64px}
  .hero-type{font-size:clamp(46px,13.5vw,72px);line-height:.96}
  .hero-sub{margin-top:28px}
  .hero-labels{position:static;margin-top:42px;grid-template-columns:1fr 1fr;gap:0}
  .hero-labels span{padding:14px 0 14px 16px;border-bottom:1px solid var(--line)}
  .hero-labels span:nth-child(odd){border-left:none;padding-left:0}
  .hero-labels span:nth-child(3),.hero-labels span:nth-child(4){border-bottom:none}
  .menu{gap:10px}.menu a{font-size:12px;letter-spacing:.05em}
  .nav-inner{gap:14px}
  .brand img{height:20px}
  .work{padding-top:80px}
  .proj{margin-bottom:52px}
  .wgrid{grid-template-columns:1fr;gap:32px;padding-top:36px}
  .wcard.size-l,.wcard.size-m,.wcard.size-s,.wcard.size-w{grid-column:span 1;height:auto}
  .wcard{overflow:visible}
  .wcard .ph{position:relative;inset:auto;aspect-ratio:16/9;border-radius:3px;transform:none}
  .wcard .ov{position:static;background:transparent!important;padding:10px 0 0;display:flex;flex-direction:column;gap:4px}
  .wcard .ov .t,.wcard .ov .c{opacity:1!important;transform:none!important}
  .wcard .ov .t{color:var(--ink);font-size:16px}
  .wcard .ov .c{color:var(--gray);font-size:13px}
  .wcard:hover .ph{transform:none}
  .wcard:hover .ov{background:transparent!important}
  .cap-grid{grid-template-columns:repeat(2,1fr)}
  .approach{grid-template-columns:1fr}
  .skill-row{flex-direction:column;gap:8px}
  .skill-row .sk-cat{width:auto}
  .packages{grid-template-columns:1fr;gap:14px}
  .pkg{min-height:auto}
  .flow .step{flex-basis:50%;border-bottom:1px solid var(--line)}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .page-top{padding-top:120px}
  .foot-inner{flex-direction:column;align-items:flex-start}
  .foot-info{text-align:left}
  .tabs{gap:8px;flex-direction:column}
  .brand-mark{padding:48px 22px 0}
  .detail-top{padding-left:22px;padding-right:22px;padding-top:118px}
  .detail-cover,.detail-grid,.detail-gallery,.detail-proto,.prevnext{padding-left:22px;padding-right:22px}
  .detail-grid{grid-template-columns:1fr;gap:28px}
  .detail-meta{position:static}
  .detail-meta .row{padding:14px 0}
  .prevnext{grid-template-columns:1fr;gap:0}
  .pn{padding:16px 0;border-top:1px solid var(--line)}
  .pn:first-child{border-top:none}
  .pn.next{text-align:left;align-items:flex-start}
  .pn.list{text-align:left;align-items:flex-start;border:none;padding-left:0;padding-right:0}
  .tab{width:100%;flex-direction:row;align-items:center;gap:13px;padding:14px 18px}
  .mapblock{padding:0}
}
