/* 팬텀디자인 웹에이전시 — 공통 스타일 (giantsoft 톤: 화이트 베이스 + 오렌지 포인트 + Pretendard/Play) */
:root{
  --orange:#f56620; --orange-d:#e0550f; --ink:#1d1b1b; --body:#666666; --sub:#9a9a9a;
  --line:#e3e3e3; --bg:#f6f6f7; --white:#fff;
  --sans:'Pretendard',-apple-system,'Noto Sans KR',sans-serif; --play:'Play',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--body);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{width:90%;max-width:1560px;margin:0 auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;cursor:pointer;transition:.22s;border:none;font-size:15px;font-family:var(--sans)}
.b-orange{background:var(--orange);color:#fff;padding:15px 32px;border-radius:9999px;font-weight:700}
.b-orange:hover{background:var(--orange-d);color:#fff}
.b-dark{background:var(--ink);color:#fff;padding:15px 30px;border-radius:9999px;font-weight:700}
.b-white{background:#fff;color:var(--orange);padding:15px 32px;border-radius:9999px;font-weight:700}
.ghost{font-family:var(--play);font-size:14px;letter-spacing:.1em;color:var(--ink);border:1px solid var(--ink);padding:14px 30px;border-radius:9999px;display:inline-block;transition:.2s}
.ghost:hover{background:var(--ink);color:#fff}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:60;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;width:90%;max-width:1560px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;letter-spacing:-.03em;color:var(--ink)}
.brand .mk{width:30px;height:30px;border-radius:7px;background:var(--orange);display:grid;place-items:center;color:#fff;font-family:var(--play);font-size:15px;font-weight:700}
.menu{display:flex;align-items:center;gap:38px}
.menu a{font-family:var(--play);font-size:15px;letter-spacing:.04em;color:#3a3a3a}
.menu a:hover,.menu a.on{color:var(--orange)}
.menu .pill{font-family:var(--sans);background:var(--orange);color:#fff;font-weight:700;font-size:14px;padding:10px 20px;border-radius:9999px}
.menu .pill:hover{background:var(--orange-d);color:#fff}
@media(max-width:980px){.menu a:not(.pill){display:none}}

/* floating CTA */
.float{position:fixed;right:28px;bottom:28px;z-index:50;background:var(--orange);color:#fff;width:120px;height:120px;border-radius:50%;
  display:grid;place-items:center;text-align:center;font-weight:700;font-size:14px;box-shadow:0 12px 30px rgba(245,102,32,.45);transition:.2s}
.float:hover{background:var(--orange-d);transform:scale(1.04);color:#fff}
.float span{font-family:var(--play);font-size:11px;letter-spacing:.1em;display:block;opacity:.85;margin-bottom:3px}
@media(max-width:640px){.float{width:92px;height:92px;font-size:12px}}

/* page hero (서브페이지 공통: 워터마크 + 타이틀 + 슬로건) */
.phero{position:relative;padding:170px 0 84px;overflow:hidden}
.phero .inner{position:relative;z-index:1}
/* 워터마크: 타이틀 줄에 세로중앙·우측정렬 → 왼쪽 텍스트와 겹치지 않음 */
.phero .wm{position:absolute;right:0;top:32px;transform:translateY(-50%);font-family:var(--play);font-size:clamp(50px,8.5vw,124px);font-weight:700;color:#f4f4f4;
  letter-spacing:-.02em;line-height:.8;white-space:nowrap;z-index:0;pointer-events:none}
.phero .ptitle{position:relative;z-index:1;font-family:var(--play);font-size:clamp(34px,5vw,58px);font-weight:700;color:var(--ink);letter-spacing:-.01em}
.phero .pslogan{position:relative;z-index:1;font-size:clamp(21px,2.9vw,33px);font-weight:800;color:var(--ink);margin-top:44px;letter-spacing:-.03em;line-height:1.42}
.phero .pdesc{position:relative;z-index:1}
.phero .pdesc{color:var(--body);font-size:15px;margin-top:20px;line-height:1.9;max-width:780px}

/* section + centered header */
section{padding:110px 0}
.sh{text-align:center;margin-bottom:56px}
.sh .plus{color:var(--orange);font-size:22px;font-weight:300;display:block;margin-bottom:16px}
.sh .wm{font-family:var(--play);font-size:clamp(28px,4vw,44px);font-weight:700;color:var(--ink);letter-spacing:-.01em}
.sh p{color:var(--sub);font-size:16px;margin-top:14px}

/* filter tabs (black pill) */
.tabs{display:inline-flex;flex-wrap:wrap;gap:4px;background:#f1f1f2;border-radius:9999px;padding:5px;margin-bottom:38px}
.tabs button{font-family:var(--sans);font-size:14px;font-weight:600;color:#777;background:transparent;border:none;cursor:pointer;padding:11px 22px;border-radius:9999px;transition:.2s}
.tabs button.on{background:var(--ink);color:#fff}

/* portfolio grid */
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pf{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:6px;background:#111;display:block}
.pf img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pf:hover img{transform:scale(1.05)}
.pf .cap{position:absolute;left:0;right:0;bottom:0;padding:22px;background:linear-gradient(transparent,rgba(10,8,6,.82));color:#fff}
.pf .cap .c{font-family:var(--play);font-size:12px;letter-spacing:.12em;color:var(--orange);font-weight:700}
.pf .cap .t{font-size:17px;font-weight:700;margin-top:3px;letter-spacing:-.02em}
.pf-more{text-align:center;margin-top:50px}
@media(max-width:900px){.pf-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pf-grid{grid-template-columns:1fr}}

/* services */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc .c{background:#fff;border:1px solid var(--line);border-radius:10px;padding:38px 32px;transition:.25s}
.svc .c:hover{border-color:var(--orange);box-shadow:0 16px 40px rgba(29,27,27,.07);transform:translateY(-4px)}
.svc .no{font-family:var(--play);color:var(--orange);font-size:14px;font-weight:700;letter-spacing:.08em}
.svc h3{color:var(--ink);font-size:20px;font-weight:800;margin-top:16px;letter-spacing:-.02em}
.svc p{margin-top:12px;font-size:15px;color:var(--body)}
@media(max-width:900px){.svc{grid-template-columns:1fr}}
.bg-soft{background:var(--bg)}

/* process */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.steps .st{padding:0 22px;text-align:center;position:relative}
.steps .st:not(:last-child)::after{content:"";position:absolute;right:0;top:34px;width:1px;height:60%;background:var(--line)}
.steps .st .n{font-family:var(--play);font-size:34px;font-weight:700;color:var(--orange)}
.steps .st h4{color:var(--ink);font-size:18px;font-weight:800;margin-top:12px;letter-spacing:-.02em}
.steps .st p{font-size:14px;color:var(--sub);margin-top:8px}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr;gap:40px 0}.steps .st::after{display:none}}

/* stats */
.stat-sec{background:var(--ink);color:#fff}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stats b{font-family:var(--play);font-size:46px;font-weight:700;color:#fff;display:block}
.stats b em{color:var(--orange);font-style:normal}
.stats p{color:#b3aba3;font-size:15px;margin-top:6px}
@media(max-width:700px){.stats{grid-template-columns:1fr 1fr;gap:40px 20px}}

/* big display block (service/about) */
.split .bigword{font-family:var(--play);font-size:clamp(56px,11vw,140px);font-weight:700;color:var(--ink);letter-spacing:-.03em;line-height:.95;margin:0}
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:54px;align-items:center}
.split img{width:100%;border-radius:10px;object-fit:cover}
.split h3{font-size:clamp(22px,3vw,30px);font-weight:800;color:var(--ink);letter-spacing:-.03em;line-height:1.4}
.split p{margin-top:18px;font-size:16px;color:var(--body);line-height:1.9}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:30px}}

/* form (consulting) */
.form{max-width:920px;margin:0 auto}
.frow{display:grid;grid-template-columns:170px 1fr;gap:0;border-top:1px solid var(--line);padding:22px 0;align-items:center}
.frow:last-of-type{border-bottom:1px solid var(--line)}
.frow .lb{font-weight:700;color:var(--ink);font-size:15px}
.frow .lb em{color:var(--orange);font-style:normal}
.frow input[type=text],.frow input[type=tel],.frow textarea,.frow select{width:100%;border:1px solid var(--line);border-radius:8px;padding:13px 14px;font-size:15px;font-family:var(--sans);outline:none;color:var(--ink)}
.frow input:focus,.frow textarea:focus,.frow select:focus{border-color:var(--orange)}
.frow textarea{resize:vertical;min-height:120px}
.chips{display:flex;flex-wrap:wrap;gap:18px}
.chips label{display:inline-flex;align-items:center;gap:7px;font-size:15px;cursor:pointer;color:var(--ink)}
.chips input{accent-color:var(--orange);width:17px;height:17px}
.form-submit{text-align:center;margin-top:40px}
@media(max-width:680px){.frow{grid-template-columns:1fr;gap:10px;align-items:flex-start}}

/* contact band */
.contact{position:relative;overflow:hidden;background:var(--ink);color:#fff;text-align:center}
.contact::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(760px circle at 50% 122%,rgba(245,102,32,.42),transparent 58%)}
.contact::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(520px circle at 12% -12%,rgba(245,102,32,.16),transparent 55%)}
.contact .wrap{position:relative;z-index:1}
.contact .ck{font-family:var(--play);color:var(--orange);font-size:14px;letter-spacing:.22em;font-weight:700;text-transform:uppercase}
.contact .big{font-family:var(--play);font-size:clamp(44px,8.5vw,114px);font-weight:700;line-height:1.02;letter-spacing:-.03em;color:#fff;margin-top:22px}
.contact .big em{color:var(--orange);font-style:normal}
.contact .sub{color:#b3aba3;font-size:clamp(16px,1.8vw,19px);margin-top:24px}
.contact .row{margin-top:42px;display:flex;gap:18px;justify-content:center;align-items:center;flex-wrap:wrap}
.contact .tel-link{font-family:var(--play);color:#fff;font-size:19px;font-weight:700;letter-spacing:.02em;display:inline-flex;align-items:center;gap:8px}
.contact .tel-link:hover{color:var(--orange)}

footer{background:#161412;color:#9a9088;padding:56px 0 40px}
footer .ft{display:flex;flex-wrap:wrap;justify-content:space-between;gap:28px}
footer .brand{color:#fff}
footer nav{display:flex;gap:24px;flex-wrap:wrap}
footer a{font-family:var(--play);font-size:14px;color:#9a9088}
footer a:hover{color:#fff}
footer .bot{margin-top:40px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:#6b6259}

/* ===== 스크롤 등장 애니메이션 ===== */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);will-change:opacity,transform}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important;transition:none}}

/* 공통 키프레임 (히어로 마퀴·켄번스 등) */
@keyframes scrollUp{from{transform:translateY(0)}to{transform:translateY(-50%)}}
@keyframes scrollDown{from{transform:translateY(-50%)}to{transform:translateY(0)}}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.14)}}
@keyframes heroIn{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}

/* split 이미지 */
.split .ph-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;box-shadow:0 24px 60px rgba(29,27,27,.14)}

/* ===== 모바일 최적화 (320px~) ===== */
@media(max-width:760px){
  section{padding:78px 0}
  .phero{padding:140px 0 60px}
}
@media(max-width:600px){
  .wrap{width:92%}
  .nav{height:62px;width:92%}
  section{padding:64px 0}
  .phero{padding:118px 0 50px}
  .phero .wm{display:none}
  .phero .pslogan{margin-top:22px}
  .sh{margin-bottom:36px}
  .float{right:16px;bottom:16px}
  .stat-sec,.contact{padding:68px 0}
  .frow{padding:18px 0}
  .tabs{display:flex;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start}
  .tabs::-webkit-scrollbar{display:none}
  .bigword,.split .bigword{font-size:clamp(48px,16vw,90px)}
  footer .ft{flex-direction:column;gap:24px}
}
@media(max-width:380px){
  .wrap{width:92%}
  .brand{font-size:17px}.brand .mk{width:26px;height:26px;font-size:13px}
  .menu .pill{padding:9px 14px;font-size:13px}
  .float{width:84px;height:84px;font-size:11px}
  .contact .big{font-size:clamp(38px,12vw,62px)}
}

/* ===== 페이지별 차별화 레이아웃 컴포넌트 ===== */

/* 지그재그 피처 행 (서비스) */
.zig{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-bottom:84px}
.zig:last-child{margin-bottom:0}
.zig .zimg{width:100%;aspect-ratio:16/11;object-fit:cover;border-radius:12px;box-shadow:0 24px 60px rgba(29,27,27,.13)}
.zig.rev .zimg{order:2}
.zig .num{font-family:var(--play);color:var(--orange);font-size:18px;font-weight:700;letter-spacing:.05em}
.zig h3{font-size:clamp(22px,2.6vw,30px);font-weight:800;color:var(--ink);letter-spacing:-.03em;margin-top:12px}
.zig p{margin-top:16px;font-size:16px;color:var(--body);line-height:1.9}
.zig .tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.zig .tags span{font-size:13px;color:var(--ink);border:1px solid var(--line);border-radius:9999px;padding:6px 14px}
@media(max-width:860px){.zig{grid-template-columns:1fr;gap:24px;margin-bottom:54px}.zig.rev .zimg{order:0}}

/* 가로 타임라인 (서비스 프로세스) */
.tl{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:64px}
.tl::before{content:"";position:absolute;left:6%;right:6%;top:19px;height:2px;background:var(--line)}
.tl .tlx{position:relative;text-align:center}
.tl .dot{width:40px;height:40px;border-radius:50%;background:var(--orange);color:#fff;font-family:var(--play);font-weight:700;font-size:15px;display:grid;place-items:center;margin:0 auto;position:relative;z-index:1}
.tl h4{font-size:17px;font-weight:800;color:var(--ink);margin-top:18px;letter-spacing:-.02em}
.tl p{font-size:14px;color:var(--sub);margin-top:7px}
@media(max-width:760px){.tl{grid-template-columns:1fr 1fr;gap:34px 18px}.tl::before{display:none}}

/* 에디토리얼 넘버 행 (회사소개 가치) */
.edit{border-top:1px solid var(--line);margin-top:10px}
.edit .row{display:grid;grid-template-columns:130px 1fr;gap:34px;padding:40px 0;border-bottom:1px solid var(--line);align-items:start;transition:.25s}
.edit .row:hover{background:#fafafa;padding-left:10px;padding-right:10px}
.edit .row .n{font-family:var(--play);font-size:clamp(32px,4vw,48px);font-weight:700;color:var(--orange);line-height:1}
.edit .row h3{font-size:clamp(20px,2.4vw,26px);font-weight:800;color:var(--ink);letter-spacing:-.03em}
.edit .row p{margin-top:12px;font-size:16px;color:var(--body);line-height:1.85;max-width:680px}
@media(max-width:680px){.edit .row{grid-template-columns:1fr;gap:10px;padding:30px 0}}

/* 풀블리드 이미지 밴드 (회사소개) */
.band{position:relative;min-height:440px;display:flex;align-items:center;background:#1d1b1b center/cover no-repeat;overflow:hidden}
.band::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,13,12,.9),rgba(15,13,12,.55))}
.band .bt{position:relative;z-index:1;color:#fff;max-width:680px}
.band .bt .k{font-family:var(--play);color:var(--orange);font-size:13px;letter-spacing:.2em;font-weight:700;text-transform:uppercase}
.band .bt h2{font-size:clamp(26px,3.6vw,40px);font-weight:800;letter-spacing:-.03em;line-height:1.35;margin-top:16px;color:#fff}
.band .bt p{margin-top:16px;color:#cfc8c1;font-size:16px;line-height:1.9}

/* 포트폴리오 피처(대형) + 오프셋 */
.feat{display:grid;grid-template-columns:1.55fr 1fr;gap:16px;margin-bottom:16px}
.feat .pf{aspect-ratio:auto}
.feat .pf.big{aspect-ratio:16/10}
.feat .side{display:grid;grid-template-rows:1fr 1fr;gap:16px}
.feat .side .pf{aspect-ratio:auto}
@media(max-width:860px){.feat{grid-template-columns:1fr}.feat .pf.big{aspect-ratio:4/3}.feat .side{grid-template-rows:none;grid-template-columns:1fr 1fr}}
@media(max-width:560px){.feat .side{grid-template-columns:1fr}}

/* ===== 소식 카드 (STORY/홈) ===== */
.news{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.news .card{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;display:block;transition:.25s}
.news .card:hover{box-shadow:0 16px 40px rgba(29,27,27,.08);transform:translateY(-5px)}
.news .th{aspect-ratio:16/10;overflow:hidden;background:#eee}
.news .th img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.news .card:hover .th img{transform:scale(1.06)}
.news .bd{padding:24px}
.news .cat{font-family:var(--play);color:var(--orange);font-size:12px;letter-spacing:.1em;font-weight:700}
.news .bd h3{font-size:18px;font-weight:800;color:var(--ink);margin-top:9px;letter-spacing:-.02em;line-height:1.4}
.news .bd p{margin-top:10px;font-size:14px;color:var(--body);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news .dt{font-family:var(--play);color:var(--sub);font-size:13px;margin-top:16px}
@media(max-width:900px){.news{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.news{grid-template-columns:1fr}}

/* ===== 채용 ===== */
.jobs{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.job{border:1px solid var(--line);border-radius:12px;padding:32px;display:flex;justify-content:space-between;align-items:center;gap:20px;transition:.25s;background:#fff}
.job:hover{border-color:var(--orange);transform:translateY(-3px)}
.job h3{font-size:20px;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.job p{margin-top:8px;font-size:14px;color:var(--body)}
.job .ar{font-family:var(--play);color:var(--orange);font-size:24px;flex:none}
@media(max-width:680px){.jobs{grid-template-columns:1fr}}
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.perks .p{background:#fff;border:1px solid var(--line);border-radius:12px;padding:28px;text-align:center}
.perks .p .ic{font-size:26px}
.perks .p h4{font-size:16px;font-weight:800;color:var(--ink);margin-top:12px}
.perks .p span{font-size:13px;color:var(--sub);margin-top:6px;display:block}
@media(max-width:760px){.perks{grid-template-columns:1fr 1fr}}

/* ===== 작업 상세 ===== */
.whero{position:relative;min-height:78vh;display:flex;align-items:flex-end;background:#1d1b1b center/cover no-repeat;color:#fff;margin-top:74px}
.whero::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent,rgba(8,6,5,.88))}
.whero .wh{position:relative;z-index:1;padding-bottom:64px}
.whero .cat{font-family:var(--play);color:var(--orange);letter-spacing:.14em;font-weight:700;font-size:14px}
.whero h1{font-size:clamp(34px,5vw,62px);font-weight:800;letter-spacing:-.03em;margin-top:14px;color:#fff}
.winfo{display:grid;grid-template-columns:1.6fr 1fr;gap:64px;align-items:start}
.winfo .ov h2{font-size:clamp(22px,2.6vw,30px);font-weight:800;color:var(--ink);letter-spacing:-.03em}
.winfo .ov p{margin-top:18px;font-size:16px;color:var(--body);line-height:1.95}
.winfo .meta{border-top:2px solid var(--ink)}
.winfo .meta .r{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--line);font-size:15px}
.winfo .meta .r .k{color:var(--sub)}.winfo .meta .r .v{color:var(--ink);font-weight:700;text-align:right}
.wshot{margin-top:76px}
.wshot img{width:100%;border-radius:12px;box-shadow:0 30px 70px rgba(29,27,27,.16)}
@media(max-width:860px){.winfo{grid-template-columns:1fr;gap:34px}}

.contact .b-dark{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.4)}
.contact .b-dark:hover{background:rgba(255,255,255,.16)}
