@font-face{
  font-family:"Pretendard Variable";
  font-weight:45 920;
  font-style:normal;
  font-display:swap;
  src:url("assets/fonts/PretendardVariable.woff2") format("woff2-variations");
}
/* ============================================================
   퍼스트디자인 스튜디오 — 공통 스타일시트
   블랙 + 그린 / 프리미엄 에디토리얼
   ============================================================ */
:root{
  --ink:#0e0f0d;
  --ink-2:#1a1c18;
  --paper:#ffffff;
  --paper-2:#f5f6f2;
  --green:#2faa54;
  --green-dark:#1f8a3f;
  --olive:#3a4a2a;
  --gray:#6b6f66;
  --line:#e6e8e1;
  --radius:16px;
  --max:1180px;
  --shadow:0 18px 50px rgba(14,15,13,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Pretendard Variable","Pretendard",-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.accent{color:var(--green)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- 버튼 ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:999px;font-weight:700;font-size:15px;transition:.2s;cursor:pointer;border:none}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--green);color:#fff}

/* ---------- 공통 섹션 ---------- */
.eyebrow{display:inline-block;font-size:13px;font-weight:800;letter-spacing:.14em;color:var(--green);text-transform:uppercase;margin-bottom:14px}
.section{padding:96px 0}
.section h2{font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.25}
.section .lead{color:var(--gray);font-size:17px;margin-top:14px;max-width:640px}

/* ---------- 상단 바 ---------- */
.topbar{background:var(--ink);color:#c8ccc2;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a:hover{color:#fff}
.topbar .cs strong{color:var(--green);letter-spacing:.04em}
.topbar .links{display:flex;gap:18px}

/* ---------- 네비게이션 ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo-lockup{display:flex;align-items:baseline;gap:7px}
.logo-lockup img{height:24px;width:auto}
.logo-lockup span{font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--ink)}
nav.menu{display:flex;gap:28px;align-items:center}
nav.menu>a,.dropdown>.drop-toggle{font-weight:600;font-size:15px;color:var(--ink-2);cursor:pointer;white-space:nowrap}
nav.menu>a:hover,.dropdown:hover>.drop-toggle{color:var(--green)}
nav.menu a.active{color:var(--green)}
/* 드롭다운 */
.dropdown{position:relative}
.dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;min-width:200px;opacity:0;visibility:hidden;transition:.18s;z-index:60}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(4px)}
.dropdown-menu a{display:block;padding:11px 16px;border-radius:9px;font-size:14.5px;font-weight:600;color:var(--ink-2);white-space:nowrap}
.dropdown-menu a:hover{background:var(--paper-2);color:var(--green)}
.nav-cta{display:flex;gap:10px;align-items:center}
.hamburger{display:none;font-size:26px;background:none;border:none;cursor:pointer}

/* ---------- 홈 히어로 (분할형) ---------- */
.hero{background:var(--paper-2);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.02fr .98fr;gap:48px;align-items:center;padding-top:84px;padding-bottom:84px}
.hero h1{font-size:clamp(34px,5vw,56px);font-weight:900;letter-spacing:-.035em;line-height:1.16}
.hero p.sub{font-size:18px;color:var(--gray);margin:22px 0 32px;max-width:480px}
.hero .hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-visual{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3.2}
.hero-visual img{width:100%;height:100%;object-fit:cover}
.hero-visual .badge{position:absolute;left:18px;bottom:18px;background:#fff;color:var(--ink);font-weight:800;font-size:13px;padding:10px 16px;border-radius:999px;box-shadow:var(--shadow)}

/* ---------- 풀블리드 히어로 슬라이더 (designhm 스타일) ---------- */
.hero-slider{position:relative;height:min(86vh,680px);min-height:480px;overflow:hidden;background:#fff}
.hslide{position:absolute;inset:0;opacity:0;transition:opacity .9s ease;pointer-events:none}
.hslide.is-active{opacity:1;pointer-events:auto}
.hs-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);transition:transform 7s ease}
.hslide.is-active .hs-bg{transform:scale(1)}
.hslide::after{display:none}
/* 화이트 글자 버전 (어두운 배경용) */
.hslide.hs-light::after{display:block;content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,12,8,.58) 0%,rgba(8,12,8,.3) 46%,rgba(8,12,8,0) 82%)}
.hslide.hs-light .hs-content h2{color:#fff}
.hslide.hs-light .hs-content p{color:rgba(255,255,255,.9)}
.hslide.hs-light .hs-content .eyebrow{color:#c9f0d6}
.hslide.hs-light .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.hslide.hs-light .btn-ghost:hover{background:rgba(255,255,255,.14);border-color:#fff}
.hs-content{position:absolute;inset:0;z-index:2;display:flex;align-items:center;color:var(--ink)}
.hs-content .wrap{width:100%}
.hs-content .eyebrow{color:var(--green);margin-bottom:14px}
.hs-content h2{font-size:clamp(32px,5vw,56px);font-weight:900;letter-spacing:-.03em;line-height:1.16;max-width:680px;color:var(--ink)}
.hs-content h2 .accent{color:var(--green)}
.hs-content p{font-size:clamp(15px,1.7vw,19px);color:#3a3d36;margin:18px 0 30px;max-width:520px;line-height:1.6}
.hs-content .hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hs-content .btn-ghost{color:var(--ink);border-color:rgba(14,15,13,.28)}
.hs-content .btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.hs-dots{position:absolute;left:0;right:0;bottom:26px;z-index:5;display:flex;gap:10px;justify-content:center}
.hs-dots button{width:34px;height:4px;border-radius:3px;border:none;background:rgba(14,15,13,.2);cursor:pointer;padding:0;transition:.25s}
.hs-dots button.on{background:var(--green);width:48px}

/* ---------- 서브페이지 히어로 ---------- */
.page-hero{background:var(--ink);color:#fff;padding:70px 0 64px;position:relative;overflow:hidden}
.page-hero.gov-hero{background:linear-gradient(rgba(8,10,7,.62),rgba(8,10,7,.74)),url('assets/gov/gov_hero.jpg') center/cover no-repeat;padding:96px 0 88px}
.page-hero.grad-hero{padding:120px 0 110px;background:radial-gradient(72% 62% at 50% -8%,rgba(47,170,84,.36),transparent 62%),radial-gradient(54% 80% at 92% 112%,rgba(31,138,63,.22),transparent 60%),linear-gradient(165deg,#0e2517 0%,#0e0f0d 58%)}
.page-hero.grad-hero::after{display:none}
.page-hero.grad-hero h1{line-height:1.32}
.page-hero.grad-hero .breadcrumb{color:#9aa093}
.page-hero.grad-hero .breadcrumb a{color:#9aa093}
.page-hero.grad-hero .breadcrumb a:hover{color:var(--green)}
.page-hero.grad-hero p{margin-top:24px;color:#c7ccc1}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(47,170,84,.28),transparent 70%)}
.page-hero .wrap{position:relative;z-index:1;text-align:center}
.breadcrumb{font-size:13px;color:#9aa093;margin-bottom:18px;letter-spacing:.02em}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb span{color:var(--green)}
.page-hero h1{font-size:clamp(30px,4.6vw,48px);font-weight:900;letter-spacing:-.03em;line-height:1.18}
.page-hero p{color:#b9bdb2;font-size:17px;margin:16px auto 0;max-width:620px}
.page-hero .eyebrow{margin-bottom:12px}

/* ---------- 신뢰 스트립 ---------- */
.trust{background:var(--ink);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:46px 24px}
.trust .stat{text-align:center}
.trust .stat b{display:block;font-size:38px;font-weight:900;color:var(--green);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.trust .stat .count{font-size:inherit;color:inherit;font-weight:inherit;font-variant-numeric:tabular-nums}
.trust .stat span{font-size:14px;color:#aab0a4}

/* ---------- 파트너 로고 ---------- */
.partners{background:#fff;padding:64px 0;border-bottom:1px solid var(--line)}
.partners .ptitle{text-align:center;font-size:13px;font-weight:800;letter-spacing:.16em;color:var(--gray);text-transform:uppercase;margin-bottom:12px}
.partners .psub{text-align:center;font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:36px}
.partners .psub b{color:var(--green)}
.plogos{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.plogo{display:grid;place-items:center;height:92px;border:1px solid var(--line);border-radius:14px;background:#fff;transition:.22s;padding:16px}
.plogo img{max-width:100%;max-height:46px;object-fit:contain;filter:grayscale(1);opacity:.6;transition:.22s}
.plogo:hover{border-color:var(--green);box-shadow:var(--shadow);transform:translateY(-4px)}
.plogo:hover img{filter:none;opacity:1}
/* 파트너 로고 한 줄 무한 롤링 */
.logo-marquee{overflow:hidden;padding:8px 0;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%)}
.logo-marquee .lm-track{display:flex;width:max-content;animation:lm-scroll 70s linear infinite}
.logo-marquee .lm-track .plogo{flex:0 0 auto;width:158px;margin-right:14px;height:92px}
.logo-marquee:hover .lm-track{animation-play-state:paused}
@keyframes lm-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes lm-scroll-rev{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.logo-marquee .lm-track.rev{animation-name:lm-scroll-rev}
.logo-marquee.three .lm-track + .lm-track{margin-top:14px}

/* 이미지 라이트박스 */
.pf-grid .pf,.gallery .g-item{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:100000;background:rgba(8,9,7,.93);display:flex;align-items:center;justify-content:center;padding:40px;opacity:0;transition:opacity .25s}
.lightbox.open{opacity:1}
.lightbox[hidden]{display:none}
.lb-img{max-width:90vw;max-height:86vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.55);object-fit:contain}
.lb-close,.lb-nav{position:absolute;border:0;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;display:grid;place-items:center;line-height:1;transition:background .15s}
.lb-close:hover,.lb-nav:hover{background:rgba(255,255,255,.24)}
.lb-close{top:22px;right:26px;width:46px;height:46px;border-radius:50%;font-size:26px}
.lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;font-size:30px}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:#fff;font-weight:600;font-size:15px;padding:0 20px;text-shadow:0 1px 6px rgba(0,0,0,.5)}
@media (max-width:680px){.lb-nav{width:42px;height:42px;font-size:24px}.lb-prev{left:10px}.lb-next{right:10px}.lb-close{top:12px;right:12px}}

/* 작업 사진 정사각형 2줄 롤링 */
.photo-marquee{overflow:hidden;padding:clamp(28px,4vw,52px) 0;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}
.photo-marquee .pm-track{display:flex;width:max-content;animation:lm-scroll 50s linear infinite}
.photo-marquee .pm-track.rev{animation-name:lm-scroll-rev}
.photo-marquee .pm-track + .pm-track{margin-top:14px}
.photo-marquee .pshot{flex:0 0 auto;width:clamp(170px,21vw,280px);height:clamp(170px,21vw,280px);margin-right:14px;border-radius:16px;overflow:hidden;background:var(--paper-2)}
.photo-marquee .pshot img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.photo-marquee .pshot:hover img{transform:scale(1.05)}
.photo-marquee:hover .pm-track{animation-play-state:paused}
@media (prefers-reduced-motion:reduce){.photo-marquee .pm-track{animation:none}}
@media (prefers-reduced-motion:reduce){.logo-marquee .lm-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center;gap:14px}.logo-marquee .lm-track .plogo{margin-right:0}}

/* ---------- 서비스 그리드 ---------- */
.services .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:.22s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .thumb{aspect-ratio:16/10;overflow:hidden;background:#eee}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .thumb img{transform:scale(1.06)}
.card .body{padding:22px 24px 26px}
.card .num{font-size:12px;font-weight:800;color:var(--green);letter-spacing:.12em}
.card h3{font-size:19px;font-weight:800;margin:8px 0 6px}
.card p{font-size:14px;color:var(--gray)}
.card .arrow{margin-top:14px;font-weight:800;color:var(--green);font-size:14px}
.card.feature{grid-column:span 2;grid-row:span 2;flex-direction:column}
.card.feature .thumb{flex:1;aspect-ratio:auto;min-height:200px}
.card.feature .body{display:flex;flex-direction:column;justify-content:center;background:var(--ink);color:#fff}
.card.feature h3{font-size:26px}
.card.feature p{color:#b9bdb2;margin-top:4px}
.card.feature .num{color:var(--green)}

/* ---------- 포트폴리오 그리드 ---------- */
.portfolio{background:var(--paper-2)}
.pf-filter{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.pf-filter button{border:1.5px solid var(--line);background:#fff;color:var(--gray);font-weight:700;font-size:14px;padding:9px 18px;border-radius:999px;cursor:pointer;transition:.18s;font-family:inherit}
.pf-filter button:hover{border-color:var(--green);color:var(--ink)}
.pf-filter button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:34px}
.pf{aspect-ratio:1;border-radius:14px;overflow:hidden;position:relative;background:#ddd}
.pf img{width:100%;height:100%;object-fit:cover;transition:.4s}
.pf:hover img{transform:scale(1.07)}
.pf::after{content:attr(data-label);position:absolute;left:0;right:0;bottom:0;padding:14px;color:#fff;font-weight:700;font-size:14px;background:linear-gradient(transparent,rgba(0,0,0,.78))}
.pf.hide{display:none}

/* 작업 갤러리 (서비스 페이지) */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.gallery .g-item{border-radius:14px;overflow:hidden;position:relative;aspect-ratio:4/3;background:#eee}
.gallery .g-item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery .g-item:hover img{transform:scale(1.06)}
.gallery .g-item .cap{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;font-weight:700;font-size:14px;background:linear-gradient(transparent,rgba(0,0,0,.8))}
.gallery .g-item.wide{grid-column:span 1;aspect-ratio:4/3}
/* 인쇄가이드 이미지 카드 */
.pg-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.pg-cards.four{grid-template-columns:repeat(4,1fr)}
.pg-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .2s,box-shadow .2s}
.pg-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.pg-card>img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--paper-2);display:block}
.pg-card .b{padding:20px 22px}
.pg-card .b h4{font-size:17px;font-weight:800;margin-bottom:8px}
.pg-card .b p{font-size:14px;color:var(--gray);line-height:1.62}
.pg-fold img{width:100%;max-width:920px;margin:40px auto 0;display:block;border-radius:14px;border:1px solid var(--line);background:#fff}

/* 수행기관 로고 롤링 (다크) */
.gov-marquee{position:relative;background:var(--ink);overflow:hidden;padding:26px 0}
.gov-marquee::before,.gov-marquee::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.gov-marquee::before{left:0;background:linear-gradient(90deg,var(--ink),transparent)}
.gov-marquee::after{right:0;background:linear-gradient(270deg,var(--ink),transparent)}
.gov-marquee .gm-track{display:flex;align-items:center;width:max-content;animation:lm-scroll 34s linear infinite}
.gov-marquee:hover .gm-track{animation-play-state:paused}
.gov-marquee .glogo{flex:0 0 auto;margin:0 40px;display:flex;align-items:center}
.gov-marquee .glogo img{height:34px;width:auto;object-fit:contain;display:block;opacity:.88;transition:opacity .2s}
.gov-marquee .glogo:hover img{opacity:1}
@media (max-width:680px){.gov-marquee .glogo{margin:0 26px}.gov-marquee .glogo img{height:28px}}

/* 정부지원사업 탭 */
.v-center{text-align:center}
.vtabs{display:flex;justify-content:center;gap:6px;width:max-content;max-width:100%;margin:30px auto 0;padding:6px;background:var(--paper-2);border:1px solid var(--line);border-radius:14px;flex-wrap:wrap}
.vtab{font:inherit;font-weight:700;font-size:15px;padding:10px 24px;border:0;background:transparent;color:var(--gray);border-radius:9px;cursor:pointer;transition:.18s;white-space:nowrap}
.vtab.on{background:var(--ink);color:#fff;box-shadow:0 8px 18px rgba(14,15,13,.2)}
.vtab:hover:not(.on){color:var(--ink)}
.vpanel{margin-top:50px}
.vpanel.hide{display:none}
.vpanel:not(.hide){animation:vfade .45s cubic-bezier(.2,.7,.2,1)}
@keyframes vfade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.vpanel .reveal{opacity:1;transform:none}
.vintro{display:grid;grid-template-columns:.8fr 1.4fr;gap:46px;align-items:start}
.vintro h3{font-size:clamp(23px,2.5vw,32px);font-weight:800;letter-spacing:-.02em;line-height:1.28}
.vintro h3::before{content:"";display:block;width:42px;height:4px;border-radius:2px;background:var(--green);margin-bottom:20px}
.vintro .vtext p{color:var(--gray);line-height:1.9;font-size:15.5px}
.vintro .vtext p+p{margin-top:16px}
.vfield{margin-top:46px}
.vbox{background:linear-gradient(160deg,#1c1e1a,#0e0f0d);border:1px solid rgba(255,255,255,.07);color:#fff;border-radius:20px;padding:34px 40px;box-shadow:0 26px 64px rgba(14,15,13,.2)}
.vproc-title{font-size:16px;font-weight:800;display:flex;align-items:center;gap:10px;letter-spacing:.01em}
.vproc-title::before{content:"";width:18px;height:18px;border-radius:6px;background:var(--green);flex:none}
.vbox ul{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:15px 26px}
.vbox li{position:relative;padding-left:17px;color:#cfd3cb;font-size:15px;font-weight:600;transition:color .15s}
.vbox li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--green);transition:box-shadow .15s}
.vbox li:hover{color:#fff}
.vbox li:hover::before{box-shadow:0 0 0 4px rgba(47,170,84,.22)}
.vproc{margin-top:56px}
.vproc-title{margin-bottom:22px;color:var(--ink)}
.vsteps{background:linear-gradient(160deg,#1c1e1a,#0e0f0d);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:44px 22px;display:grid;grid-template-columns:repeat(5,1fr);gap:6px;align-items:start;box-shadow:0 26px 64px rgba(14,15,13,.2)}
.vstep{text-align:center;position:relative;padding:0 6px}
.vstep:not(:last-child)::after{content:"›";position:absolute;right:-2px;top:28px;color:#52564d;font-size:26px;line-height:1}
.vs-ic{width:80px;height:80px;border-radius:50%;border:1.5px solid rgba(255,255,255,.32);background:rgba(255,255,255,.02);display:grid;place-items:center;margin:0 auto 18px;color:#fff;transition:.25s}
.vstep:hover .vs-ic{border-color:var(--green);color:var(--green);transform:translateY(-4px);box-shadow:0 0 0 6px rgba(47,170,84,.1)}
.vs-ic svg{width:32px;height:32px}
.vs-no{font-size:12.5px;color:var(--green);font-weight:800;letter-spacing:.04em;margin-bottom:6px}
.vs-t{font-size:15.5px;font-weight:800;color:#fff;margin-bottom:7px}
.vstep p{font-size:13px;color:#9aa093;line-height:1.55}

/* 왜 퍼스트 — 번호 점선 카드 스태거(지그재그) */
.why-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:54px;align-items:start}
.why-steps.cols3{grid-template-columns:repeat(3,1fr)}
.why-card{border:2px dashed rgba(47,170,84,.5);border-radius:18px;padding:30px 26px;background:#fff;transition:transform .25s,box-shadow .25s,border-color .25s}
.why-card:nth-child(even){margin-top:66px}
.why-card:hover{border-style:solid;border-color:var(--green);box-shadow:var(--shadow);transform:translateY(-5px)}
.why-card .wn{font-size:15px;font-weight:900;color:var(--green);letter-spacing:.08em;margin-bottom:16px}
.why-card .wic{width:50px;height:50px;border-radius:14px;background:rgba(47,170,84,.1);color:var(--green);display:grid;place-items:center;margin-bottom:20px}
.why-card .wic svg{width:26px;height:26px}
.why-card h4{font-size:18px;font-weight:800;margin-bottom:10px;letter-spacing:-.01em}
.why-card p{font-size:14px;color:var(--gray);line-height:1.62}
@media (max-width:860px){.why-steps,.why-steps.cols3{grid-template-columns:1fr 1fr;gap:16px}.why-card:nth-child(even){margin-top:0}}
@media (max-width:520px){.why-steps,.why-steps.cols3{grid-template-columns:1fr}}
@media (max-width:860px){
  .vintro{grid-template-columns:1fr;gap:8px}
  .vintro h3::before{margin-bottom:14px}
  .vbox ul{grid-template-columns:1fr 1fr}
  .vsteps{grid-template-columns:1fr 1fr 1fr;gap:30px 8px}
  .vstep:not(:last-child)::after{display:none}
}
@media (max-width:520px){.vbox ul{grid-template-columns:1fr}.vsteps{grid-template-columns:1fr 1fr}}
@media (max-width:860px){.pg-cards,.pg-cards.four{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.pg-cards,.pg-cards.four{grid-template-columns:1fr}}

/* ---------- 프로세스 ---------- */
.process{background:#fff}
.process .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:54px}
.process .steps.cols3{grid-template-columns:repeat(3,1fr)}
.step{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:32px 26px;transition:.25s}
.step:hover{transform:translateY(-8px);background:var(--ink);border-color:transparent;box-shadow:var(--shadow)}
.step .badge{width:50px;height:50px;border-radius:50%;background:#fff;border:2px solid var(--green);color:var(--green);font-weight:900;font-size:17px;display:grid;place-items:center;margin-bottom:22px;transition:.25s}
.step:hover .badge{background:var(--green);color:#fff}
.step h4{font-size:18px;font-weight:800;margin-bottom:8px;transition:.25s}
.step p{font-size:14px;color:var(--gray);line-height:1.55;transition:.25s}
.step:hover h4{color:#fff}
.step:hover p{color:#aab0a4}
.step:not(:last-child)::after{content:"→";position:absolute;top:46px;right:-15px;color:#cfd3c8;font-size:18px;font-weight:800;z-index:1;transition:.25s}
.process .steps:hover .step:not(:last-child)::after{color:var(--green)}

/* ---------- 본문 콘텐츠 (서브페이지) ---------- */
.prose{max-width:760px}
.prose p{font-size:16.5px;color:#3a3d36;margin:0 0 18px;line-height:1.75}
.prose h3{font-size:24px;font-weight:800;margin:14px 0 14px;letter-spacing:-.01em}
.feature-rows{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;counter-reset:fr}
.frow{position:relative;padding:30px 28px;border:1px solid var(--line);border-radius:16px;background:#fff;transition:.2s;counter-increment:fr}
.frow:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.frow::before{content:counter(fr,decimal-leading-zero);display:block;font-size:13px;font-weight:800;color:var(--green);letter-spacing:.12em;margin-bottom:14px}
.frow h4{font-size:18px;font-weight:800;margin-bottom:8px}
.frow p{font-size:14.5px;color:var(--gray)}
.bg-soft{background:var(--paper-2)}

/* split 콘텐츠 (이미지+텍스트) */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.split.rev .split-img{order:2}
.split-img{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:4/3;box-shadow:20px 20px 0 rgba(47,170,84,.12),0 26px 56px rgba(14,15,13,.15)}
.split-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.split-img:hover img{transform:scale(1.05)}
.split-text h2{font-size:clamp(27px,3.4vw,37px);font-weight:800;letter-spacing:-.02em;line-height:1.28}
.split-text p{color:var(--gray);font-size:16px;line-height:1.72;margin-top:18px}
.split-text ul{margin:26px 0 0;padding:0;list-style:none;display:grid;gap:9px}
.split-text li{display:flex;align-items:center;gap:13px;padding:13px 16px;font-size:15px;font-weight:600;color:var(--ink-2);background:#f5f6f2;border-radius:12px;border:1px solid transparent;transition:background .2s,border-color .2s,transform .2s,box-shadow .2s}
.split-text li:hover{background:#fff;border-color:rgba(47,170,84,.45);transform:translateX(4px);box-shadow:0 8px 22px rgba(14,15,13,.07)}
.split-text li::before{content:"✓";flex:none;width:24px;height:24px;border-radius:50%;background:var(--green);color:#fff;font-size:13px;font-weight:900;display:flex;align-items:center;justify-content:center}
/* 로고 형태 카드 (이미지 예시) */
.lt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:40px}
.lt-card{display:flex;align-items:center;gap:26px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 32px;transition:border-color .2s,box-shadow .2s,transform .2s}
.lt-card:hover{border-color:rgba(47,170,84,.45);box-shadow:0 16px 38px rgba(14,15,13,.09);transform:translateY(-5px)}
.lt-img{flex:none;width:180px;height:128px;border-radius:14px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;overflow:hidden}
.lt-img img{width:90%;height:84%;object-fit:contain;display:block}
.lt-tx h4{font-size:21px;font-weight:800;letter-spacing:-.01em;margin-bottom:9px}
.lt-tx p{font-size:15px;color:var(--gray);line-height:1.6}
@media (max-width:720px){.lt-grid{grid-template-columns:1fr}}
@media (max-width:520px){.lt-card{flex-direction:column;text-align:center;gap:18px;padding:26px}}
/* 로고 가격 카드 (LOGO 15~500) */
.lp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:40px}
.lp-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s}
.lp-card:hover{border-color:rgba(47,170,84,.5);box-shadow:0 18px 42px rgba(14,15,13,.1);transform:translateY(-5px)}
.lp-img{aspect-ratio:7/6;background:#f5f6f2;overflow:hidden}
.lp-img img{width:100%;height:100%;object-fit:cover;display:block}
.lp-body{display:flex;flex-direction:column;flex:1;padding:20px 22px 22px}
.lp-head{display:flex;align-items:center;gap:9px;padding-bottom:14px;border-bottom:2px solid var(--ink)}
.lp-head h4{font-size:22px;font-weight:900;letter-spacing:-.01em}
.lp-badge{font-size:11px;font-weight:700;color:#fff;background:var(--green);padding:4px 10px;border-radius:20px;white-space:nowrap}
.lp-list{list-style:none;margin:15px 0 0;padding:0;flex:1}
.lp-list li{font-size:13.5px;color:#4a4d45;line-height:1.45;padding:7px 0;border-bottom:1px dashed var(--line)}
.lp-list li:last-child{border-bottom:none}
.lp-price{margin-top:16px;padding-top:15px;border-top:1px solid var(--line);text-align:right;font-size:22px;font-weight:900;color:var(--ink);letter-spacing:-.01em}
.lp-price span{font-size:15px;margin-left:1px}
@media (max-width:1080px){.lp-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.lp-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.lp-grid{grid-template-columns:1fr}}
/* 가로 프로세스 타임라인 */
.ptl{display:grid;grid-template-columns:repeat(6,1fr);margin-top:46px}
.ptl-step{position:relative;display:flex;flex-direction:column;align-items:center;padding:0 8px}
.ptl-ic{height:68px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--ink)}
.ptl-ic svg{width:48px;height:48px}
.ptl-node{width:30px;height:30px;border-radius:50%;background:#3a3d3a;position:relative;z-index:2}
.ptl-node::before{content:"";position:absolute;inset:0;margin:auto;width:13px;height:13px;border:2.5px solid #fff;border-radius:50%;border-right-color:transparent;transform:rotate(-45deg)}
.ptl-step:not(:last-child)::after{content:"";position:absolute;top:97.5px;left:50%;width:100%;height:3px;background:#33363a;z-index:1}
.ptl-label{margin-top:16px;font-size:15px;font-weight:700;color:var(--ink);text-align:center;line-height:1.4}
.ptl-label span{display:block;margin-top:5px;font-size:12px;font-weight:600;color:var(--green)}
.ptl-step:hover .ptl-node{background:var(--green)}
.ptl-step:hover .ptl-ic{color:var(--green)}
@media (max-width:780px){
  .ptl{grid-template-columns:repeat(3,1fr);row-gap:34px}
  .ptl-step:not(:last-child)::after{display:none}
}
@media (max-width:430px){.ptl{grid-template-columns:1fr 1fr}}
/* 촬영 종류 이미지 카드 */
.shoot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px}
.shoot-card{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/3;background:#0e0f0d;box-shadow:0 10px 26px rgba(14,15,13,.08)}
.shoot-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s ease}
.shoot-card:hover img{transform:scale(1.06)}
.shoot-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,10,7,.82),rgba(8,10,7,.12) 52%,transparent 78%)}
.shoot-cap{position:absolute;left:0;bottom:0;z-index:2;padding:20px 22px;color:#fff}
.shoot-cap .sn{font-size:12px;font-weight:800;letter-spacing:.08em;color:rgba(255,255,255,.72)}
.shoot-cap h4{font-size:19px;font-weight:800;letter-spacing:-.01em;margin:5px 0 5px}
.shoot-cap p{font-size:13.5px;line-height:1.45;color:rgba(255,255,255,.86)}
@media (max-width:860px){.shoot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.shoot-grid{grid-template-columns:1fr}}
/* 촬영 스튜디오 */
.studio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.studio-card{aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:#eceee8}
.studio-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.studio-card:hover img{transform:scale(1.05)}
@media (max-width:760px){.studio-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.studio-grid{grid-template-columns:1fr}}
/* 마케팅 PROBLEM 카드 */
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.prob-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;transition:border-color .2s,box-shadow .2s,transform .2s}
.prob-card:hover{border-color:rgba(47,170,84,.4);box-shadow:var(--shadow);transform:translateY(-4px)}
.prob-card h4{font-size:18px;font-weight:800;margin-bottom:12px;padding-left:16px;position:relative}
.prob-card h4::before{content:"";position:absolute;left:0;top:4px;width:5px;height:17px;border-radius:3px;background:var(--green)}
.prob-card p{font-size:14.5px;color:var(--gray);line-height:1.62}
.prob-quote{margin-top:42px;text-align:center;font-size:22px;font-weight:700;color:var(--ink);line-height:1.6;letter-spacing:-.01em}
@media (max-width:820px){.prob-grid{grid-template-columns:1fr}.prob-quote{font-size:18px}}
.try-slogan{text-align:center;margin-top:20px;font-size:clamp(26px,4.6vw,42px);font-weight:900;letter-spacing:.02em;color:var(--green);line-height:1.1}
.try-line{width:2px;height:64px;margin:26px auto 0;background:linear-gradient(var(--green),rgba(47,170,84,0))}
/* 마케팅 HOW TO WORK — 번호형 리스트 */
.howwork{margin-top:48px}
.hw-item{display:grid;grid-template-columns:130px 1fr;gap:32px;align-items:start;padding:30px 0;border-top:1px solid var(--line)}
.hw-item:last-child{border-bottom:1px solid var(--line)}
.hw-no{font-size:50px;font-weight:900;line-height:1;letter-spacing:-.02em;color:var(--green);opacity:.9}
.hw-tx h4{font-size:22px;font-weight:800;letter-spacing:-.01em;margin-bottom:10px}
.hw-tx p{font-size:15px;color:var(--gray);line-height:1.65;max-width:640px}
@media (max-width:640px){.hw-item{grid-template-columns:1fr;gap:10px;padding:24px 0}.hw-no{font-size:38px}.hw-tx h4{font-size:19px}}
/* 마케팅 컨설팅 — 그린 지그재그 카드 월 */
.svc-wall{position:relative;overflow:hidden;background:linear-gradient(150deg,#0c2f1b 0%,#176b34 52%,#2faa54 100%);color:#fff}
.svc-wall .eyebrow{color:rgba(255,255,255,.82)}
.svc-wall h2{color:#fff}
.svc-wall .lead{color:rgba(255,255,255,.8)}
.sw-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.sw-card{position:relative;display:block;border-radius:16px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 14px 32px rgba(0,0,0,.24);transition:transform .3s,box-shadow .3s}
.sw-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(0,0,0,.36)}
.sw-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s ease}
.sw-card:hover img{transform:scale(1.06)}
.sw-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(5,12,8,.92) 4%,rgba(5,12,8,.3) 46%,rgba(5,12,8,.04) 78%)}
.sw-cap{position:absolute;inset:0;z-index:2;padding:22px;display:flex;flex-direction:column;justify-content:flex-end}
.sw-cap h4{font-size:18px;font-weight:800;letter-spacing:-.01em;margin-bottom:7px}
.sw-cap p{font-size:13px;line-height:1.5;color:rgba(255,255,255,.86)}
.sw-more{display:inline-block;margin-top:16px;width:max-content;font-size:13px;font-weight:700;color:#fff;border:1px solid rgba(255,255,255,.55);border-radius:30px;padding:8px 16px;transition:background .2s,color .2s,border-color .2s}
.sw-card:hover .sw-more{background:#fff;color:var(--ink);border-color:#fff}
.sw-card.sw-grad{background:linear-gradient(155deg,#28a14c 0%,#0b3a20 100%)}
.sw-card.sw-grad::after{display:none}
.sw-card.sw-grad .sw-cap{justify-content:center}
.sw-card.sw-grad .sw-cap::before{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%)}
@media (max-width:1000px){.sw-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.sw-grid{grid-template-columns:1fr}}
/* 스튜디오 슬라이더 */
.studio-slider{position:relative;margin-top:36px}
.ss-viewport{overflow:hidden}
.ss-track{display:flex;gap:16px;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.ss-slide{flex:0 0 calc((100% - 16px) / 2);aspect-ratio:3/2;border-radius:14px;overflow:hidden;background:#eceee8}
.ss-slide img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:600px){.ss-slide{flex-basis:100%}}
.ss-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:none;background:rgba(255,255,255,.92);color:var(--ink);font-size:24px;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.18);transition:background .2s,transform .2s;z-index:3}
.ss-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.ss-prev{left:16px}
.ss-next{right:16px}
.ss-dots{display:flex;justify-content:center;gap:9px;margin-top:18px}
.ss-dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--line);cursor:pointer;padding:0;transition:background .2s,width .2s}
.ss-dots button.on{background:var(--green);width:24px;border-radius:5px}
@media (max-width:600px){.ss-arrow{width:38px;height:38px;font-size:20px}.ss-prev{left:10px}.ss-next{right:10px}}
/* 프로세스 플로우 칩 (번호 + 화살표) */
.flow{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px 12px;margin-top:44px}
.flow-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:50px;padding:8px 22px 8px 8px;box-shadow:0 2px 10px rgba(14,15,13,.04);transition:border-color .2s,box-shadow .2s,transform .2s}
.flow-item:hover{border-color:var(--green);box-shadow:0 10px 24px rgba(47,170,84,.16);transform:translateY(-3px)}
.fi-no{flex:none;width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;font-size:14px;font-weight:800;display:grid;place-items:center;box-shadow:0 4px 10px rgba(47,170,84,.3)}
.fi-tx{font-size:15px;font-weight:700;color:var(--ink);white-space:nowrap;letter-spacing:-.01em}
.flow-arrow{flex:none;display:flex;align-items:center;color:#cfd3ca}
.flow-arrow svg{width:18px;height:18px}
@media (max-width:680px){
  .flow{flex-direction:column;align-items:stretch;gap:10px;max-width:380px;margin-left:auto;margin-right:auto}
  .flow-item{width:100%}
  .flow-arrow{transform:rotate(90deg);align-self:center}
}

/* ---------- 칼럼 아티클 카드 ---------- */
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.article{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;transition:.22s;display:flex;flex-direction:column}
.article:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.article .a-thumb{aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,var(--olive),var(--ink))}
.article .a-thumb img{width:100%;height:100%;object-fit:cover}
.article .a-body{padding:24px;display:flex;flex-direction:column;flex:1}
.article .a-cat{font-size:12px;font-weight:800;color:var(--green);letter-spacing:.08em;text-transform:uppercase}
.article h3{font-size:18px;font-weight:800;margin:10px 0 10px;line-height:1.4}
.article p{font-size:14px;color:var(--gray);flex:1}
.article .a-meta{font-size:12.5px;color:#9aa093;margin-top:16px}
.article.featured{grid-column:span 3;flex-direction:row}
.article.featured .a-thumb{flex:1.2;aspect-ratio:auto}
.article.featured .a-body{flex:1;justify-content:center}
.article.featured h3{font-size:26px}
.article.featured p{flex:none;font-size:15.5px;margin-top:6px}

/* 사업 전담팀 */
.team-wrap{position:relative;margin-top:48px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.member{position:relative;aspect-ratio:4/4.3;border-radius:16px;overflow:hidden;background:linear-gradient(160deg,#34362f,#0e0f0d)}
.member::before{content:"";position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);width:52%;height:52%;opacity:.15;background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10Zm0 2c-5 0-9 2.7-9 6v2h18v-2c0-3.3-4-6-9-6Z'/%3E%3C/svg%3E")}
.member img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.04);z-index:1}
.member .role{position:absolute;left:12px;right:12px;bottom:12px;z-index:2;background:rgba(16,18,14,.78);color:#fff;font-weight:700;font-size:14px;text-align:center;padding:9px 10px;border-radius:10px;backdrop-filter:blur(4px)}
.team-badge{position:absolute;right:-6px;bottom:-6px;width:108px;height:108px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:900;font-size:25px;box-shadow:0 14px 32px rgba(47,170,84,.42);z-index:4;letter-spacing:-.02em}

/* 대표 메시지 */
.quote{max-width:840px;padding:38px 42px;background:var(--paper-2);border-radius:20px;border-left:4px solid var(--green);margin-top:8px}
.quote p{font-size:clamp(18px,2.3vw,23px);font-weight:700;line-height:1.62;letter-spacing:-.01em;color:var(--ink)}
.quote p+p{margin-top:14px;font-size:16px;font-weight:500;color:#3a3d36;line-height:1.7}
.quote .sign{margin-top:22px;font-size:14px;color:var(--gray)}
.quote .sign b{color:var(--ink);font-weight:800;font-size:16px}
/* 대표 인사말 — 가운데 풀인용 */
.ceo-quote{max-width:880px;margin:0 auto;text-align:center}
.ceo-quote .eyebrow{margin-bottom:10px}
.ceo-quote .ceo-mark{font-family:Georgia,'Times New Roman',serif;font-size:96px;line-height:.7;color:var(--green);height:52px;user-select:none}
.ceo-quote blockquote{margin:0;font-size:clamp(21px,2.7vw,31px);font-weight:800;line-height:1.55;letter-spacing:-.025em;color:var(--ink)}
.ceo-quote .ceo-body{color:var(--gray);font-size:clamp(15px,1.3vw,16.5px);line-height:1.9;max-width:700px;margin:26px auto 0}
.ceo-quote .ceo-sign{margin-top:30px;font-size:14px;color:var(--gray);display:inline-flex;align-items:center;gap:8px}
.ceo-quote .ceo-sign::before{content:"";width:26px;height:1px;background:var(--green);display:inline-block}
.ceo-quote .ceo-sign b{color:var(--ink);font-weight:800;font-size:16px}

/* 회사소개 가치 */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.value{padding:34px;border-radius:18px;background:var(--paper-2);border:1px solid var(--line);transition:.2s}
.value:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.value .vico{width:54px;height:54px;border-radius:14px;background:rgba(47,170,84,.1);color:var(--green);display:grid;place-items:center;margin-bottom:16px}
.value .vico svg{width:27px;height:27px}
.value .vn{font-size:12px;font-weight:800;color:var(--green);letter-spacing:.12em}
.value h4{font-size:20px;font-weight:800;margin:10px 0 8px}
.value p{font-size:15px;color:var(--gray)}
/* 연혁 */
.timeline{position:relative;margin-top:52px;padding-left:40px}
.timeline::before{content:"";position:absolute;left:7px;top:9px;bottom:9px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:34px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:0;top:3px;width:16px;height:16px;border-radius:50%;background:#fff;border:4px solid var(--green);box-sizing:border-box;transition:.2s}
.tl-item:hover::before{transform:scale(1.18);box-shadow:0 0 0 5px rgba(47,170,84,.14)}
.tl-item .yr{font-size:18px;font-weight:900;color:var(--ink);letter-spacing:-.01em;display:flex;align-items:center;gap:10px}
.tl-item .yr::after{content:"";flex:none;width:18px;height:2px;border-radius:2px;background:var(--green)}
.tl-item p{font-size:15px;color:var(--gray);margin-top:6px;line-height:1.65;max-width:540px}
/* 연혁 — 핀 고정 가로 스크롤잭 (스크롤하면 가로 진행 + 가운데 항목 확대) */
.htl{position:relative}
.htl-sticky{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.htl-head{margin-bottom:10px;text-align:center}
.htl-progress{height:4px;background:var(--line);border-radius:3px;margin:26px auto 0;max-width:760px;width:calc(100% - 48px)}
.htl-progress i{display:block;height:100%;width:0;background:var(--green);border-radius:3px;transition:width .1s linear}
.htl-viewport{position:relative;width:100%;overflow:hidden}
.htl-track{position:relative;display:flex;align-items:center;height:54vh;width:max-content;will-change:transform;padding-inline:calc(50vw - 132px)}
.htl-line{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:3px;background:linear-gradient(90deg,var(--green),rgba(47,170,84,.22))}
.htl-item{position:relative;flex:0 0 264px;height:100%}
.htl-dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;background:#fff;border:4px solid var(--green);z-index:2;transition:transform .35s,box-shadow .35s}
.htl-card{position:absolute;left:50%;transform:translateX(-50%) scale(.9);width:246px;text-align:center;opacity:.38;transition:transform .4s cubic-bezier(.2,.7,.2,1),opacity .4s}
.htl-item.top .htl-card{bottom:calc(50% + 48px)}
.htl-item.bottom .htl-card{top:calc(50% + 48px)}
.htl-card .date{color:var(--green);font-weight:900;font-size:clamp(18px,1.9vw,26px);letter-spacing:-.01em}
.htl-card .label{font-size:clamp(14px,1.1vw,16px);color:var(--ink);line-height:1.5;font-weight:600}
.htl-item.top .htl-card .label{margin-bottom:9px}
.htl-item.bottom .htl-card .label{margin-top:9px}
.htl-item.top .htl-card::after{content:"";position:absolute;left:50%;bottom:-48px;width:2px;height:48px;background:var(--line);transform:translateX(-50%)}
.htl-item.bottom .htl-card::before{content:"";position:absolute;left:50%;top:-48px;width:2px;height:48px;background:var(--line);transform:translateX(-50%)}
.htl-item.active .htl-card{transform:translateX(-50%) scale(1.22);opacity:1}
.htl-item.active .htl-dot{transform:translate(-50%,-50%) scale(1.6);box-shadow:0 0 0 8px rgba(47,170,84,.16)}
@media (max-width:760px){
  .htl-track{height:60vh;padding-inline:calc(50vw - 92px)}
  .htl-item{flex-basis:184px}
  .htl-card{width:172px}
  .htl-card .label{font-size:13px}
}

/* ---------- 비교 2단 (카탈로그 vs 브로슈어) ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:48px}
.compare .col{padding:34px;border-radius:18px;border:1px solid var(--line);background:#fff;transition:.2s;overflow:hidden}
.compare .col:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.compare .col .cmp-img{margin:-34px -34px 24px;aspect-ratio:16/9;overflow:hidden;background:#f5f6f2}
.compare .col .cmp-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.compare .col:hover .cmp-img img{transform:scale(1.05)}
.compare .col .tag{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.1em;color:var(--green);margin-bottom:10px}
.compare .col h4{font-size:22px;font-weight:800;margin-bottom:10px}
.compare .col p{font-size:15px;color:var(--gray)}
/* 카탈로그 vs 브로슈어 비교표 */
.cmp-table{margin-top:20px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}
.cmp-row{display:grid;grid-template-columns:1fr 1.5fr 1.5fr;border-top:1px solid var(--line)}
.cmp-row:first-child{border-top:none}
.cmp-row>div{padding:15px 22px;font-size:14.5px;color:var(--ink-2);line-height:1.5;border-left:1px solid var(--line);display:flex;align-items:center}
.cmp-row>div:first-child{border-left:none}
.cmp-row .cmp-k{font-weight:700;color:var(--ink);background:#fafbf9}
.cmp-head{background:var(--ink)}
.cmp-head>div{color:#fff;font-weight:800;font-size:15px}
.cmp-head .cmp-k{background:transparent;color:#fff}
@media (max-width:560px){.cmp-row>div{padding:12px 13px;font-size:12.5px}.cmp-head>div{font-size:13px}}

/* ---------- 가격 안내 ---------- */
.price-table{width:100%;border-collapse:collapse;margin-top:36px;font-size:15.5px;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.price-table th,.price-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--line)}
.price-table thead th{background:var(--ink);color:#fff;font-weight:700;letter-spacing:.02em}
.price-table thead th:last-child{text-align:right}
.price-table tbody tr:last-child td{border-bottom:none}
.price-table tbody tr:hover{background:var(--paper-2)}
.price-table td.price{font-weight:800;color:var(--green);text-align:right;font-variant-numeric:tabular-nums}
.price-note{font-size:13px;color:var(--gray);margin-top:14px;line-height:1.6}

/* ---------- 태그 칩 리스트 ---------- */
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.tags span{display:inline-block;padding:9px 16px;border:1px solid var(--line);border-radius:999px;font-size:14px;font-weight:600;color:var(--ink-2);background:#fff;transition:.18s}
.tags span:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px)}

/* ---------- 체크 배지 리스트 ---------- */
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:48px}
.check{display:flex;gap:14px;align-items:flex-start;padding:20px 22px;border:1px solid var(--line);border-radius:14px;background:#fff}
.check .ck{flex:none;width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff;font-weight:900;display:grid;place-items:center;font-size:15px}
.check h4{font-size:16px;font-weight:800;margin-bottom:4px}
.check p{font-size:13.5px;color:var(--gray)}

/* ---------- 오피스 (지도) ---------- */
.offices{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.office{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;transition:.2s}
.office:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.office-map{aspect-ratio:16/9;background:var(--paper-2)}
.office-map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.4) contrast(1.05)}
.office:hover .office-map iframe{filter:grayscale(0)}
.office-info{padding:26px 28px}
.office-info .vn{font-size:12px;font-weight:800;color:var(--green);letter-spacing:.12em}
.office-info h4{font-size:20px;font-weight:800;margin:8px 0 8px}
.office-info p{font-size:15px;color:var(--gray)}
.office-info .addr{font-size:13px;margin-top:6px}

/* ---------- 서비스 카드 (호버 시 이미지 리빌) ---------- */
.svc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.svc-card{position:relative;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;min-height:210px;display:flex;transition:transform .3s,box-shadow .3s,border-color .3s}
.svc-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.08);transition:opacity .5s,transform .6s}
.svc-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,15,13,.15),rgba(14,15,13,.82));opacity:0;transition:opacity .4s}
.svc-card .sc-body{position:relative;z-index:2;padding:26px 28px;display:flex;flex-direction:column;justify-content:flex-end;width:100%}
.svc-card .sc-num{font-size:12px;font-weight:800;color:var(--green);letter-spacing:.12em;margin-bottom:auto}
.svc-card h4{font-size:19px;font-weight:800;margin:0 0 6px;transition:color .3s}
.svc-card p{font-size:14px;color:var(--gray);transition:color .3s}
.svc-card .sc-arrow{margin-top:14px;font-weight:800;color:var(--green);font-size:14px;opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s,color .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.svc-card:hover img{opacity:1;transform:scale(1)}
.svc-card:hover::after{opacity:1}
.svc-card:hover .sc-num{color:#fff}
.svc-card:hover h4{color:#fff}
.svc-card:hover p{color:#d8dcd2}
.svc-card:hover .sc-arrow{opacity:1;transform:none;color:#fff}

/* ---------- 칼럼 글(블로그) 상세 ---------- */
.post-crumb{font-size:13px;color:var(--gray);margin-bottom:24px}
.post-crumb a:hover{color:var(--green)}
.post-crumb span{color:var(--green)}
.post .post-cat{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.1em;color:var(--green);text-transform:uppercase;margin-bottom:14px}
.post h1{font-size:clamp(26px,4vw,40px);font-weight:900;letter-spacing:-.02em;line-height:1.3}
.post .post-meta{font-size:14px;color:var(--gray);margin:16px 0 0;padding-bottom:24px;border-bottom:1px solid var(--line)}
.post .post-cover{border-radius:18px;overflow:hidden;margin:28px 0;aspect-ratio:16/8;background:var(--paper-2)}
.post .post-cover img{width:100%;height:100%;object-fit:cover}
.post .post-body{font-size:17px;line-height:1.85;color:#33352e;margin-top:28px}
.post .post-body p{margin:0 0 20px}
.post .post-body img{max-width:100%;border-radius:12px;margin:20px 0;display:block}
.post .post-body h3{font-size:22px;font-weight:800;margin:32px 0 14px;letter-spacing:-.01em}
.post .post-body ul,.post .post-body ol{margin:0 0 20px 22px}
.post .post-body li{margin:6px 0}

/* ---------- CTA 견적 ---------- */
.cta{background:var(--ink);color:#fff}
.cta .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.cta h2{font-size:clamp(28px,4vw,40px);font-weight:900;line-height:1.25}
.cta p{color:#b9bdb2;margin-top:14px}
.cta .quick{margin-top:24px;font-size:15px;color:#c8ccc2}
.cta .quick b{color:var(--green);font-size:22px}
form.estimate{background:#fff;color:var(--ink);border-radius:20px;padding:34px}
form.estimate label{display:block;font-size:13px;font-weight:700;margin:0 0 6px}
form.estimate .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form.estimate .field{margin-bottom:16px}
form.estimate input,form.estimate select,form.estimate textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit}
form.estimate input:focus,form.estimate select:focus,form.estimate textarea:focus{outline:none;border-color:var(--green)}
form.estimate .consent{font-size:12.5px;color:var(--gray);display:flex;gap:8px;align-items:flex-start;margin:6px 0 16px;line-height:1.5;cursor:pointer}
form.estimate .consent input{flex:none;width:17px;height:17px;margin:1px 0 0;accent-color:var(--green);cursor:pointer}
form.estimate button{width:100%;justify-content:center}

/* ---------- 푸터 ---------- */
footer{background:#070806;color:#969a8e;font-size:13.5px;padding:60px 0 40px}
footer .top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;border-bottom:1px solid #20221c;padding-bottom:28px;margin-bottom:24px}
footer .flogo{display:flex;align-items:baseline;gap:7px;margin-bottom:16px}
footer .flogo img{height:22px;filter:brightness(0) invert(1)}
footer .flogo span{color:#fff;font-weight:800;font-size:16px}
footer .info p{margin:3px 0}
footer .info b{color:#c8ccc2;font-weight:700}
footer .fmenu{display:flex;gap:26px;flex-wrap:wrap}
footer .fmenu a:hover{color:var(--green)}
footer .sns{display:flex;gap:12px;margin-top:14px}
footer .sns a{width:36px;height:36px;border:1px solid #2c2e26;border-radius:50%;display:grid;place-items:center;color:#c8ccc2;font-size:12px;font-weight:700}
footer .sns a:hover{background:var(--green);border-color:var(--green);color:#fff}
footer .copy{font-size:12px;color:#565a4e;margin-top:18px}

/* 떠있는 긴급문의 버튼 */
.float-cta{position:fixed;right:22px;bottom:22px;z-index:60;background:var(--green);color:#fff;font-weight:800;padding:15px 22px;border-radius:999px;box-shadow:0 12px 30px rgba(47,170,84,.45);font-size:15px}
.float-cta:hover{background:var(--green-dark)}
/* FAQ 아코디언 */
.faq{display:flex;flex-direction:column;gap:12px;margin-top:40px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq-item[open]{border-color:rgba(47,170,84,.5);box-shadow:0 12px 30px rgba(14,15,13,.07)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:13px;padding:19px 22px;font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .faq-q{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(47,170,84,.12);color:var(--green);font-weight:900;font-size:14px;display:grid;place-items:center}
.faq-item[open] summary .faq-q{background:var(--green);color:#fff}
.faq-item .faq-qt{flex:1}
.faq-item summary::after{content:"";flex:none;width:9px;height:9px;border-right:2px solid var(--gray);border-bottom:2px solid var(--gray);transform:rotate(45deg);transition:transform .25s;margin-left:6px}
.faq-item[open] summary::after{transform:rotate(-135deg)}
.faq-item .faq-a{padding:0 22px 22px 61px;font-size:14.5px;color:var(--gray);line-height:1.72}
@media (max-width:560px){.faq-item summary{font-size:15px;padding:16px 16px}.faq-item .faq-a{padding:0 16px 18px 16px}}
/* 플로팅 퀵버튼 스택 */
.quickbar{position:fixed;right:20px;bottom:20px;z-index:70;display:flex;flex-direction:column;gap:11px;align-items:center}
.quickbar .qbtn{width:54px;height:54px;border-radius:50%;border:none;cursor:pointer;display:grid;place-items:center;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.18);transition:transform .18s,box-shadow .18s,filter .18s;position:relative;text-decoration:none;padding:0}
.quickbar .qbtn:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 12px 26px rgba(0,0,0,.26)}
.quickbar .qbtn svg{width:25px;height:25px}
.quickbar .qb-kakao{background:#FEE500;color:#3A1D1D}
.quickbar .qb-insta{background:linear-gradient(45deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%)}
.quickbar .qb-blog{background:#03C75A;font-weight:800;font-size:13px;letter-spacing:-.02em}
.quickbar .qb-call{background:var(--green)}
.quickbar .qb-quote{background:var(--ink)}
.quickbar .qb-top{background:#3a3d3a;opacity:0;visibility:hidden;transform:translateY(8px)}
.quickbar .qb-top.show{opacity:1;visibility:visible;transform:none}
/* 말풍선 라벨 (호버 시) */
.quickbar .qbtn::after{content:attr(data-label);position:absolute;right:64px;top:50%;transform:translateY(-50%) translateX(6px);background:var(--ink);color:#fff;font-size:12.5px;font-weight:700;padding:7px 12px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s}
.quickbar .qbtn:hover::after{opacity:1;transform:translateY(-50%)}
.quickbar .qb-top::after{display:none}
@media (max-width:560px){.quickbar{right:14px;bottom:14px;gap:9px}.quickbar .qbtn{width:48px;height:48px}.quickbar .qbtn svg{width:22px;height:22px}.quickbar .qbtn::after{display:none}}

/* ============================================================
   모션 & 히어로 고도화
   ============================================================ */
/* 히어로 진입 애니메이션 (JS 불필요) */
@keyframes heroUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes cueBounce{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(6px);opacity:1}}
.hero{position:relative}
.hero::before{content:"";position:absolute;top:-130px;right:-110px;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(47,170,84,.16),transparent 68%);pointer-events:none;z-index:0}
.hero .wrap{position:relative;z-index:1}
.hero h1{animation:heroUp .75s .05s both}
.hero .sub{animation:heroUp .75s .18s both}
.hero .hero-cta{animation:heroUp .75s .30s both}
.hero-visual{animation:heroUp .9s .15s both}
.hero-visual .badge{animation:floaty 3.6s ease-in-out infinite}
/* 히어로 떠다니는 스탯 카드 */
.hero-visual .statcard{position:absolute;right:16px;top:16px;background:#fff;border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);text-align:center;animation:floaty 4.2s ease-in-out .6s infinite}
.hero-visual .statcard b{display:block;font-size:24px;font-weight:900;color:var(--green);letter-spacing:-.02em;line-height:1}
.hero-visual .statcard span{font-size:11.5px;color:var(--gray);margin-top:4px;display:block}
/* 스크롤 큐 */
.scroll-cue{display:inline-flex;align-items:center;gap:8px;margin-top:36px;font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--gray);text-transform:uppercase}
.scroll-cue i{display:inline-block;width:1px;height:30px;background:linear-gradient(var(--green),transparent);position:relative}
.scroll-cue i::after{content:"";position:absolute;left:-2px;top:0;width:5px;height:5px;border-radius:50%;background:var(--green);animation:cueBounce 1.8s ease-in-out infinite}

/* 스크롤 등장(reveal) — .js 일 때만 숨김 처리 (JS 없으면 그대로 보임) */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.js .reveal-group>*{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal-group.in>*{opacity:1;transform:none}
.reveal-group.in>*:nth-child(2){transition-delay:.07s}
.reveal-group.in>*:nth-child(3){transition-delay:.14s}
.reveal-group.in>*:nth-child(4){transition-delay:.21s}
.reveal-group.in>*:nth-child(5){transition-delay:.28s}
.reveal-group.in>*:nth-child(6){transition-delay:.35s}
.reveal-group.in>*:nth-child(7){transition-delay:.42s}
.reveal-group.in>*:nth-child(8){transition-delay:.49s}
/* 서브페이지 히어로 입장 모션 */
.js .page-hero .breadcrumb{animation:heroUp .7s .02s both}
.js .page-hero .eyebrow{animation:heroUp .7s .12s both}
.js .page-hero h1{animation:heroUp .85s .22s both}
.js .page-hero p{animation:heroUp .85s .34s both}
/* reveal 플레이버: 서비스 카드는 스케일+상승, HOW 리스트는 좌→우 슬라이드 */
.js .sw-grid.reveal-group>*{transform:translateY(38px) scale(.94);transition:opacity .6s ease,transform .65s cubic-bezier(.2,.7,.2,1)}
.sw-grid.reveal-group.in>*{transform:none}
.js .howwork.reveal-group>*{transform:translateX(-30px)}
.howwork.reveal-group.in>*{transform:none}
.howwork .hw-no{transition:color .3s,transform .3s}
.hw-item:hover .hw-no{transform:translateY(-3px) scale(1.08)}
.hw-item{transition:background .25s,border-color .25s}
.hw-item:hover{background:rgba(47,170,84,.04)}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important}
  .hero h1,.hero .sub,.hero .hero-cta,.hero-visual{animation:none!important}
  .js .reveal,.js .reveal-group>*{opacity:1!important;transform:none!important}
}

/* ---------- 반응형 ---------- */
@media(max-width:880px){
  .topbar .links{display:none}
  nav.menu{display:none;position:absolute;top:110px;left:0;right:0;flex-direction:column;background:#fff;padding:20px 24px;border-bottom:1px solid var(--line);gap:14px;align-items:flex-start}
  nav.menu.open{display:flex}
  .dropdown-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;padding:6px 0 6px 14px;min-width:0}
  .dropdown:hover .dropdown-menu{transform:none}
  .hamburger{display:block}
  .hero .wrap{grid-template-columns:1fr;gap:36px}
  .hero-slider{height:74vh;min-height:440px}
  .hslide::after{background:linear-gradient(90deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.82) 55%,rgba(255,255,255,.5) 100%)}
  .trust .wrap{grid-template-columns:repeat(2,1fr);gap:30px}
  .plogos{grid-template-columns:repeat(3,1fr)}
  .services .grid{grid-template-columns:1fr 1fr}
  .card.feature{grid-column:span 2;grid-row:auto;flex-direction:column}
  .card.feature .thumb{aspect-ratio:16/10;min-height:0}
  .pf-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery .g-item.wide{grid-column:span 1}
  .feature-rows{grid-template-columns:1fr}
  .svc-cards{grid-template-columns:1fr 1fr}
  .offices{grid-template-columns:1fr}
  .articles{grid-template-columns:1fr 1fr}
  .article.featured{grid-column:span 2;flex-direction:column}
  .article.featured .a-thumb{aspect-ratio:16/9}
  .values{grid-template-columns:1fr}
  .compare{grid-template-columns:1fr}
  .checks{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:30px}
  .split.rev .split-img{order:0}
  .process .steps,.process .steps.cols3{grid-template-columns:1fr 1fr}
  .step:not(:last-child)::after{display:none}
  .cta .wrap{grid-template-columns:1fr}
  .section{padding:70px 0}
}
@media(max-width:520px){
  .services .grid{grid-template-columns:1fr}
  .card.feature{grid-column:span 1}
  .pf-grid,.gallery,.articles{grid-template-columns:1fr}
  .article.featured{grid-column:auto}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .gallery .g-item.wide{grid-column:span 1}
  .trust .wrap{grid-template-columns:repeat(2,1fr)}
  form.estimate .row{grid-template-columns:1fr}
  .hero-visual .statcard{display:none}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .team-badge{width:84px;height:84px;font-size:20px}
  .svc-cards{grid-template-columns:1fr}
}

/* 정책 모달 (이용약관 / 개인정보처리방침) */
.policy-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(8,10,7,.6);opacity:0;visibility:hidden;transition:opacity .2s}
.policy-modal.open{opacity:1;visibility:visible}
.policy-modal .pm-box{background:#fff;border-radius:18px;max-width:680px;width:100%;max-height:84vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.35);transform:translateY(14px);transition:transform .25s}
.policy-modal.open .pm-box{transform:none}
.policy-modal .pm-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:26px 28px 18px;border-bottom:1px solid var(--line)}
.policy-modal .pm-head h3{font-size:21px;font-weight:800;letter-spacing:-.01em}
.policy-modal .pm-close{flex:none;width:38px;height:38px;border:none;background:#f5f6f2;border-radius:10px;cursor:pointer;font-size:20px;color:var(--ink);display:grid;place-items:center;transition:background .2s}
.policy-modal .pm-close:hover{background:#e7e9e3}
.policy-modal .pm-body{padding:22px 28px 30px;overflow-y:auto}
.policy-modal .pm-body h4{font-size:15px;font-weight:800;margin:18px 0 7px;color:var(--ink)}
.policy-modal .pm-body h4:first-child{margin-top:0}
.policy-modal .pm-body p,.policy-modal .pm-body li{font-size:14px;line-height:1.7;color:var(--gray)}
.policy-modal .pm-body ul{margin:4px 0 4px 2px;padding-left:16px;list-style:disc}
.policy-modal .pm-body li{margin-bottom:3px}
.policy-modal .pm-body .pm-meta{margin-top:22px;padding-top:16px;border-top:1px solid var(--line);font-size:13px;color:var(--gray)}
@media (max-width:520px){.policy-modal .pm-head{padding:20px 20px 14px}.policy-modal .pm-body{padding:18px 20px 24px}}
