:root{
  --bg:#0B0C10; --surface:#15171D; --surface-2:#101218;
  --ink:#F4F5F8; --ink-soft:#F0F1F4; --muted:#D6D9E1; --line:#23262F; --line-2:#333742;
  --brand:#4D9AF5; --brand-d:#3A86E8; --brand-tint:#13243C;
  --coral:#E8795C; --coral-d:#DC6747; --coral-tint:#2E1B15;
  --dark:#070809; --kakao:#FEE500;
  --neon:#4D9AF5; --neon2:#4D9AF5; --neon3:#4D9AF5; --neon-pink:#E8795C;
  --sans:'Pretendard',sans-serif; --disp:'Bricolage Grotesque',sans-serif;
  --r:16px; --r-lg:22px; --r-xl:30px;
  --sh-sm:0 2px 12px rgba(0,0,0,.4);
  --sh:0 18px 50px -18px rgba(0,0,0,.6);
  --sh-lg:0 40px 90px -30px rgba(0,0,0,.75);
  --wrap:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;word-break:keep-all}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
section{position:relative}

.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:15px;padding:14px 24px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s;line-height:1;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--coral);color:#fff;box-shadow:0 10px 24px -10px rgba(251,84,54,.7)}
.btn--primary:hover{background:var(--coral-d);box-shadow:0 14px 30px -10px rgba(251,84,54,.75)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink);background:var(--surface)}
.btn--kakao{background:var(--kakao);color:#3A2E00}
.btn--kakao:hover{filter:brightness(.97)}
.btn--lg{padding:17px 30px;font-size:16px}
.btn--block{width:100%;justify-content:center}
.ph{color:var(--coral);font-weight:700}

/* NAV */
.nav{position:sticky;top:0;z-index:60;background:rgba(248,245,239,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s}
.nav.scrolled{border-color:var(--line);box-shadow:var(--sh-sm);background:rgba(248,245,239,.95)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:38px;height:38px;border-radius:11px;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:17px}
.brand b{font-size:17px;font-weight:800;letter-spacing:-.01em}
.brand span{display:block;font-size:12px;color:var(--muted);font-weight:500;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink-soft);transition:color .2s;cursor:pointer}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--brand);font-weight:700}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;width:42px;height:42px;border:1.5px solid var(--line-2);border-radius:12px;background:var(--surface);cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{display:block;width:18px;height:2px;background:var(--ink);position:relative;transition:.25s}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
.nav.open .nav-toggle span{background:transparent}
.nav.open .nav-toggle span::before{top:0;transform:rotate(45deg)}
.nav.open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* VIEW SWITCH */
.view{display:none}
.view.active{display:block}

/* HERO */
.hero{padding:60px 0 80px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-80px;right:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(14,158,107,.22),rgba(14,158,107,0) 70%);filter:blur(8px);z-index:0}
.hero::after{content:"";position:absolute;bottom:40px;left:-100px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(251,84,54,.14),rgba(251,84,54,0) 70%);z-index:0}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr .98fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(34px,5.2vw,58px);line-height:1.12;font-weight:800;letter-spacing:-.02em;margin:18px 0 20px}
.hero h1 em{font-style:normal;color:var(--brand);position:relative}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:6px;height:14px;background:var(--brand-tint);z-index:-1;border-radius:4px}
.hero .lead{font-size:18px;color:var(--ink-soft);max-width:46ch}
.hero .svc-line{display:inline-flex;flex-wrap:wrap;gap:8px;margin:22px 0 28px}
.hero .svc-line span{font-size:13px;font-weight:500;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 13px;color:var(--ink-soft)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.trustline{display:flex;align-items:center;gap:10px;margin-top:24px;font-size:14px;color:var(--muted)}
.avatars{display:flex;flex-shrink:0}
.avatars i{width:30px;height:30px;border-radius:50%;border:2px solid var(--bg);margin-left:-9px;background:var(--brand);display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700}
.avatars i:first-child{margin-left:0}
.avatars i:nth-child(2){background:var(--coral)}.avatars i:nth-child(3){background:#2B7DE0}.avatars i:nth-child(4){background:#7A4FD6}
.rep{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:38px 34px;box-shadow:var(--sh-lg)}
.rep .photo{width:120px;height:120px;flex:0 0 120px;border-radius:var(--r-lg);background:linear-gradient(135deg,var(--brand-tint),var(--surface-2));display:grid;place-items:center;position:relative;overflow:hidden}
.rep-head{display:flex;align-items:center;gap:18px;margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--line)}
.rep-head .role{margin:3px 0 0}
.qf-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rep .photo .ini{width:84px;height:84px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:32px}
.rep .photo small{position:absolute;bottom:10px;font-size:11px;color:var(--muted)}
.rep h3{font-size:24px;font-weight:800;letter-spacing:-.01em}
.rep .role{font-size:14px;color:var(--brand);font-weight:700;margin:2px 0 16px}
.rep .contact{display:flex;flex-direction:column;gap:9px}
.rep .contact a{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:500;padding:12px 14px;border-radius:13px;border:1px solid var(--line);transition:.2s}
.rep .contact a:hover{border-color:var(--ink);background:var(--surface-2)}
.rep .contact .ico{width:20px;color:var(--brand)}
.rep .chip{position:absolute;top:-16px;right:22px;background:var(--ink);color:#fff;font-size:13px;font-weight:700;padding:9px 15px;border-radius:999px;box-shadow:var(--sh)}
.rep .chip b{color:#5FE0A8}

/* STATS */
.stats{background:var(--dark);color:#fff;border-radius:var(--r-xl);margin-top:8px;padding:38px 20px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat .num{font-family:var(--disp);font-weight:800;font-size:clamp(30px,4vw,44px);color:#fff;line-height:1}
.stat .num span{color:#5FE0A8}
.stat .lab{font-size:14px;color:rgba(255,255,255,.62);margin-top:8px}
.stat+.stat{border-left:1px solid rgba(255,255,255,.1)}

/* SECTION HEAD */
.sec{padding:84px 0}
.sec-tt{font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:12px 0 0}
.sec-desc{color:var(--ink-soft);max-width:54ch;margin:12px;font-size:16px}
.sec-head.center{text-align:center;margin:0 auto 44px}
.sec-head.center .sec-desc{margin-left:auto;margin-right:auto}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;transition:transform .2s,box-shadow .2s,border-color .2s}
.svc:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-2)}
.svc .ic{width:54px;height:54px;border-radius:15px;background:var(--brand-tint);color:var(--brand-d);display:grid;place-items:center;margin-bottom:18px}
.svc:nth-child(even) .ic{background:var(--coral-tint);color:var(--coral-d)}
.svc h3{font-size:20px;font-weight:800}
.svc p{color:var(--ink-soft);font-size:15px;margin:9px 0 16px}
.svc ul{list-style:none}
.svc li{position:relative;padding-left:24px;font-size:14px;color:var(--ink-soft);margin:7px 0}
.svc li::before{content:"";position:absolute;left:0;top:8px;width:14px;height:14px;border-radius:50%;background:var(--brand-tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%230A7B52' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* CASES + GRIDS */
.bg-tint{background:var(--surface-2)}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.case{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,box-shadow .2s}
.case:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.case .thumb{aspect-ratio:1;display:grid;place-items:center;position:relative;color:#fff;font-weight:800;font-size:17px}
.case .thumb small{position:absolute;bottom:10px;right:12px;font-weight:500;font-size:11px;opacity:.85}
.case .meta{display:flex;gap:6px;padding:16px 18px 0}
.case .tag{font-size:11px;font-weight:700;color:var(--brand-d);background:var(--brand-tint);padding:3px 9px;border-radius:999px}
.case h3{font-size:16px;font-weight:700;padding:10px 18px 18px;line-height:1.45}

/* TESTIMONIALS */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px}
.quote .stars{color:var(--coral);font-size:15px;letter-spacing:2px}
.quote p{font-size:16px;font-weight:500;margin:12px 0 18px;line-height:1.6}
.quote .by{font-size:13px;color:var(--muted)}
.quote .by b{color:var(--ink);font-weight:700}

/* POST CARDS (shared) */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;cursor:pointer}
.post:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.post .ph-img{aspect-ratio:1;position:relative;display:grid;place-items:center;color:#fff;font-weight:800}
.post .ph-img small{position:absolute;bottom:9px;right:11px;font-weight:500;font-size:11px;opacity:.85}
.t-homepage{background:linear-gradient(135deg,#0E9E6B,#0A7B52)}
.t-blog{background:linear-gradient(135deg,#2B7DE0,#1B5BB0)}
.t-ad{background:linear-gradient(135deg,#FB5436,#DE3E22)}
.t-map{background:linear-gradient(135deg,#7A4FD6,#5A33AE)}
.post .body{padding:18px;display:flex;flex-direction:column;flex:1}
.post .tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.post .tags span{font-size:11px;font-weight:500;color:var(--ink-soft);background:var(--surface-2);border-radius:999px;padding:3px 9px}
.post .tt{font-size:16px;font-weight:700;line-height:1.45}
.post .excerpt{font-size:13px;color:var(--muted);margin-top:8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post .date{font-size:12px;color:var(--muted);margin-top:auto;padding-top:12px;font-family:var(--disp)}
.carousel-sec{padding-top:8px}
.car-title{font-size:18px;font-weight:800;margin:0 0 14px}
.carousel{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh);background:var(--surface-2)}
.car-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.car-slide{min-width:100%;position:relative;height:clamp(220px,40vw,330px);display:block;background:linear-gradient(135deg,var(--brand-d),var(--dark))}
.car-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.car-slide .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.72))}
.car-cap{position:absolute;left:24px;right:24px;bottom:22px;color:#fff;z-index:2}
.car-cap .tg{display:flex;gap:6px;margin-bottom:10px}
.car-cap .tg span{font-size:11px;font-weight:700;background:rgba(255,255,255,.22);padding:3px 10px;border-radius:999px}
.car-cap .ct{font-size:clamp(18px,3vw,26px);font-weight:800;line-height:1.3}
.car-cap p{font-size:13px;opacity:.92;margin-top:7px;max-width:52ch;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.car-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:40px;height:40px;border-radius:50%;border:0;background:rgba(255,255,255,.85);cursor:pointer;font-size:20px;line-height:1;display:grid;place-items:center;color:var(--ink)}
.car-btn.prev{left:12px}.car-btn.next{right:12px}.car-btn:hover{background:#fff}
.car-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:7px}
.car-dots button{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:.2s}
.car-dots button.on{background:#fff;width:22px;border-radius:4px}
.sort-wrap{margin-top:14px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft)}
.sort-wrap select{font-family:inherit;font-size:13px;padding:8px 12px;border:1.5px solid var(--line-2);border-radius:999px;background:var(--surface);color:var(--ink);cursor:pointer}
.ph-img .ti,.case .thumb .ti{width:58px;height:58px;color:#fff;opacity:.92}
.art-hero .ti{width:90px;height:90px;color:#fff;opacity:.92}
.rep .photo .ti{width:56px;height:56px;color:var(--brand)}
.ph-tag{position:absolute;bottom:10px;left:12px;font-size:11px;font-weight:700;color:#fff;background:rgba(255,255,255,.22);padding:3px 11px;border-radius:999px}
.ph-img,.case .thumb,.art-hero{overflow:hidden}
.ph-img img,.case .thumb img,.rep .photo img,.art-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0;z-index:1}
.ph-tag{z-index:2}
.trustline{flex-wrap:wrap}

/* BOARD */
.page-head{padding:54px 0 8px;position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;top:-120px;right:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(14,158,107,.16),transparent 70%);z-index:0}
.page-head .wrap{position:relative;z-index:1}
.crumb{font-size:13px;color:var(--muted);margin:14px}
.crumb a{cursor:pointer}.crumb a:hover{color:var(--ink)}
.page-head h1{font-size:clamp(30px,4.6vw,48px);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin:10px 0 12px}
.page-head p{color:var(--ink-soft);max-width:54ch;font-size:16px}
.tools{padding:18px 0 8px}
.searchbar{position:relative;max-width:560px}
.searchbar>svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--muted)}
.searchbar input{width:100%;font-family:inherit;font-size:16px;padding:16px 18px 16px 50px;border:1.5px solid var(--line-2);border-radius:999px;background:var(--surface);box-shadow:var(--sh-sm);transition:border-color .2s,box-shadow .2s;color:var(--ink)}
.searchbar input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-tint)}
.searchbar .clear{position:absolute;right:14px;top:50%;transform:translateY(-50%);border:none;background:var(--surface-2);color:var(--ink-soft);width:28px;height:28px;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:15px}
.searchbar .clear.show{display:flex}
.filters{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}
.fchip{font-family:inherit;font-size:14px;font-weight:500;padding:9px 18px;border-radius:999px;border:1.5px solid var(--line-2);background:var(--surface);color:var(--ink-soft);cursor:pointer;transition:.18s}
.fchip:hover{border-color:var(--ink)}
.fchip.active{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:700}
.list{padding:28px 0 80px}
.result-count{font-size:14px;color:var(--muted);margin-bottom:20px}
.result-count b{color:var(--ink);font-weight:700}
.empty{display:none;text-align:center;padding:70px 20px;color:var(--muted)}
.empty.show{display:block}
.empty b{display:block;color:var(--ink);font-size:18px;font-weight:700;margin-bottom:6px}

/* ARTICLE DETAIL */
.article-wrap{padding:48px 0 70px}
.article{max-width:760px;margin:0 auto}
.article .tags{display:flex;gap:6px;margin:16px 0 10px}
.article .tags span{font-size:11px;font-weight:700;color:var(--brand-d);background:var(--brand-tint);border-radius:999px;padding:4px 11px}
.article h1{font-size:clamp(26px,4vw,40px);font-weight:800;letter-spacing:-.02em;line-height:1.25}
.art-meta{font-size:13px;color:var(--muted);font-family:var(--disp);margin:14px 0 24px}
.art-hero{height:clamp(180px,30vw,280px);border-radius:var(--r-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff;font-weight:800;font-size:18px;position:relative;margin-bottom:28px}
.art-hero small{position:absolute;bottom:12px;font-weight:500;font-size:12px;opacity:.85}
.art-body h2{font-size:18px;font-weight:800;margin:26px 0 8px;color:var(--ink)}
.art-body p{font-size:16px;color:var(--ink-soft);line-height:1.85}
.customer-box{margin:28px 0;padding:18px 20px;background:var(--brand-tint);border-radius:var(--r);font-size:15px;font-weight:500;color:var(--brand-d)}
.customer-box a{font-weight:700;text-decoration:underline;cursor:pointer}
.art-cta{margin:30px 0;padding:28px 24px;background:var(--surface-2);border-radius:var(--r-lg);text-align:center}
.art-cta b{font-size:17px;font-weight:800;display:block;margin-bottom:14px}
.post-nav{display:flex;justify-content:space-between;gap:12px;margin:32px 0;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.post-nav a{font-size:14px;color:var(--ink-soft);max-width:46%;cursor:pointer;font-weight:500}
.post-nav a:hover{color:var(--brand)}
.post-nav a.nx{text-align:right;margin-left:auto}
.post-nav .nl{font-family:var(--disp);font-size:11px;color:var(--muted);display:block;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.post-nav .off{opacity:.3;pointer-events:none}
.related-tt{font-size:20px;font-weight:800;margin:38px 0 18px}
.article .blog-grid{grid-template-columns:repeat(2,1fr)}
.back-link{display:inline-block;margin-top:30px;font-weight:700;color:var(--brand-d);cursor:pointer}

/* DARK CTA */
.cta-band{background:var(--dark);color:#fff;border-radius:var(--r-xl);padding:64px 40px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-60px;right:-40px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(95,224,168,.18),transparent 70%)}
.cta-band h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-.02em;position:relative}
.cta-band p{color:rgba(255,255,255,.7);margin:14px auto 28px;max-width:44ch;position:relative}
.cta-band .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

/* CONTACT (고정 등록폼) */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.contact-single{max-width:620px;margin:0 auto}
.contact-head{text-align:center;margin:0 auto 30px;max-width:560px}
.contact-head h2{font-size:clamp(24px,4vw,34px);font-weight:800;line-height:1.25;margin:10px 0 12px}
.contact-head p{color:var(--muted);font-size:15px;line-height:1.7}
.contact-info h2{font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-top:12px}
.contact-info p{color:var(--ink-soft);margin:14px 0 24px}
.info-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-top:1px solid var(--line)}
.info-row .ico{width:42px;height:42px;border-radius:12px;background:var(--brand-tint);color:var(--brand-d);display:grid;place-items:center;flex-shrink:0}
.info-row b{display:block;font-size:15px}
.info-row span{font-size:13px;color:var(--muted)}
.quickform{margin-top:16px;display:flex;flex-direction:column;gap:9px}
.quickform input{font-family:inherit;font-size:15px;padding:14px 15px;border:1px solid var(--line);border-radius:13px;background:var(--bg);color:var(--ink);transition:border-color .2s}
.quickform input:focus{outline:none;border-color:var(--brand)}
.quickform input.err{border-color:var(--coral)}
.quickform .btn{margin-top:2px}
.quickform .field{margin-bottom:0}
.qf-msg{display:none;background:var(--brand-tint);color:var(--brand-d);border-radius:11px;padding:11px 13px;font-size:13px;font-weight:500}
.qf-msg.show{display:block}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;overflow:hidden}
.qf-err{background:var(--coral-tint)!important;color:var(--coral-d)!important}
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:32px;box-shadow:var(--sh)}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:7px}
.field input,.field textarea{width:100%;font-family:inherit;font-size:15px;padding:13px 15px;border:1.5px solid var(--line);border-radius:13px;background:var(--bg);transition:border-color .2s;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brand)}
.field textarea{resize:vertical;min-height:96px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--ink-soft);margin-bottom:18px}
.consent input{width:18px;height:18px;margin-top:3px;accent-color:var(--brand);flex-shrink:0}
.form-msg{display:none;background:var(--brand-tint);color:var(--brand-d);border-radius:13px;padding:14px;font-size:14px;font-weight:500;margin-bottom:16px}
.form-msg.show{display:block}
.err{border-color:var(--coral)!important}

/* FOOTER */
footer{background:var(--ink);color:rgba(255,255,255,.6);padding:56px 0 40px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand b{color:#fff;font-size:18px;font-weight:800}
.foot-brand p{margin-top:12px;max-width:36ch;line-height:1.7}
.foot-col h4{color:#fff;font-size:14px;font-weight:700;margin-bottom:14px}
.foot-col a{display:block;margin:8px 0;transition:color .2s;cursor:pointer}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:13px;color:rgba(255,255,255,.45)}
.foot-bottom a{color:rgba(255,255,255,.7);cursor:pointer}

/* MOBILE STICKY */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.mbar .btn{flex:1}

.rv{opacity:0;transform:translateY(20px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:40px}.rep{max-width:420px}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .case-grid,.quote-grid,.blog-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 24px 18px}
  .nav.open .nav-links a{padding:13px 0;border-bottom:1px solid var(--line)}
  .stats-grid{grid-template-columns:1fr 1fr;gap:8px}
  .stat+.stat{border-left:none}
  .svc-grid,.case-grid,.quote-grid,.blog-grid,.article .blog-grid,.two,.foot-grid{grid-template-columns:1fr}
  .sec{padding:58px 0}.mbar{display:flex}body{padding-bottom:74px}.cta-band{padding:48px 24px}
  .hero{padding:34px 0 50px}.hero .lead{font-size:16px}.rep{margin:0 auto;padding:22px}.stats{padding:28px 16px}
  .wrap{padding:0 16px}.nav.open .nav-links{padding:8px 16px 18px}
  .hero-cta{flex-direction:column}.hero-cta .btn{width:100%;justify-content:center}
  .cta-band .btns{flex-direction:column}.cta-band .btns .btn{width:100%;justify-content:center}
}


/* ===================== CLEAN DARK THEME (차분한 다크) ===================== */
html,body{background:#0B0C10}
body{position:relative}
/* 아주 은은한 배경 음영 (움직임/형광 없음) */
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60vw 50vw at 50% -10%, rgba(77,154,245,.06), transparent 60%),
    radial-gradient(50vw 40vw at 100% 100%, rgba(255,255,255,.025), transparent 60%)}

/* 네비/푸터 - 차분한 다크 글래스 */
.nav{background:rgba(11,12,16,.72)!important;backdrop-filter:blur(14px) saturate(120%);-webkit-backdrop-filter:blur(14px) saturate(120%);border-bottom:1px solid rgba(255,255,255,.06)!important}
.nav-links a:hover,.nav-links a.active{color:var(--brand)!important}
footer{background:#0A0B0E!important;color:rgba(255,255,255,.55)!important;border-top:1px solid rgba(255,255,255,.06)}
.foot-brand b{color:#fff!important}

/* 강조 텍스트 - 절제 */
.eyebrow{color:var(--brand)!important;text-shadow:none}
.hero h1 em{-webkit-text-fill-color:initial;background:none;color:var(--brand)!important}
.hero h1 em::after{background:rgba(77,154,245,.16)!important;filter:none;height:14px;bottom:6px}
.hero .lead{color:var(--ink-soft)}
.hero .svc-line span{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.09)!important;color:var(--ink-soft)!important}

/* 버튼 - 글자 대비 확실 (단색, 진한 글자) */
.btn--primary{background:var(--brand)!important;color:#04162B!important;font-weight:800;border:0!important;box-shadow:0 10px 26px -12px rgba(77,154,245,.5)!important}
.btn--primary:hover{background:var(--brand-d)!important;box-shadow:0 14px 32px -12px rgba(77,154,245,.6)!important}
.btn--ghost{color:var(--ink)!important;border-color:rgba(255,255,255,.18)!important;background:transparent!important}
.btn--ghost:hover{border-color:var(--brand)!important;color:var(--brand)!important;background:rgba(77,154,245,.06)!important}
.btn--kakao{color:#3A2E00!important}

/* 카드 - 은은한 다크 (블러 약하게, 글로우 제거) */
.svc,.case,.quote,.post,.rep{background:rgba(255,255,255,.035)!important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08)!important;box-shadow:0 18px 50px -24px rgba(0,0,0,.7)!important}
.svc:hover,.case:hover,.quote:hover,.post:hover{transform:translateY(-4px);border-color:rgba(77,154,245,.4)!important;box-shadow:0 24px 60px -26px rgba(0,0,0,.8)!important}
.rep{box-shadow:0 30px 80px -30px rgba(0,0,0,.85)!important}

/* 서비스 아이콘/체크 - 차분 */
.svc .ic{background:rgba(77,154,245,.12)!important;color:var(--brand)!important;box-shadow:none}
.svc:nth-child(even) .ic{background:rgba(232,121,92,.14)!important;color:var(--coral)!important}
.svc li::before{background:rgba(77,154,245,.16);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%234D9AF5' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* 태그/칩/별점 */
.case .tag{color:var(--brand)!important;background:rgba(77,154,245,.1)!important}
.post .tags span{background:rgba(255,255,255,.06)!important;color:var(--ink-soft)!important}
.quote .stars{color:#E8B95C!important;text-shadow:none}
.rep .chip{background:var(--brand)!important;color:#04162B!important;box-shadow:none}
.rep .chip b{color:#04162B!important}
.rep .role{color:var(--brand)!important}

/* 통계/CTA */
.stats{background:#0E1014!important;border:1px solid rgba(255,255,255,.06)}
.stat .num span{color:var(--brand)!important;text-shadow:none}
.cta-band{background:linear-gradient(135deg,#16263F,#0E1726 60%,#101620)!important;border:1px solid rgba(77,154,245,.3)!important;box-shadow:0 0 0 1px rgba(77,154,245,.12),0 30px 70px -30px rgba(77,154,245,.35)!important}
.cta-band::before{background:radial-gradient(circle,rgba(77,154,245,.22),transparent 70%)!important}

/* 섹션/입력/본문 */
.bg-tint{background:rgba(255,255,255,.018)!important}
.quickform input,input,textarea,select{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.12)!important;color:var(--ink)!important}
.quickform input:focus,input:focus,textarea:focus{border-color:var(--brand)!important;box-shadow:0 0 0 3px rgba(77,154,245,.15)!important;outline:none}
.qf-msg{background:rgba(77,154,245,.1)!important;color:var(--brand)!important}
.art-body h2{color:var(--ink)!important}
.customer-box{background:none!important;border:0!important;padding:0!important;margin:26px 0;color:inherit!important}

/* 제작사례 - 좌우 교차 피처 행 (그리드 아님, 편집형) */
.case-grid{display:flex!important;flex-direction:column;gap:18px}
.case-feat{display:grid;grid-template-columns:1.05fr .95fr;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);overflow:hidden;transition:border-color .25s,box-shadow .25s,transform .25s}
.case-feat:hover{transform:translateY(-3px);border-color:rgba(77,154,245,.4);box-shadow:0 24px 60px -28px rgba(0,0,0,.8)}
.case-feat:nth-child(even){grid-template-columns:.95fr 1.05fr}
.case-feat:nth-child(even) .cf-media{order:2}
.cf-media{position:relative;min-height:210px;display:grid;place-items:center;overflow:hidden}
.cf-media .ti{width:54px;height:54px;color:#fff;opacity:.85;z-index:0}
.cf-info{padding:30px 32px;display:flex;flex-direction:column;justify-content:center}
.cf-tags{font-size:12.5px;font-weight:700;color:var(--brand);letter-spacing:.02em;margin-bottom:12px}
.cf-info h3{font-size:21px;font-weight:800;line-height:1.35;color:#fff}
.cf-date{font-size:12px;color:var(--muted);margin-top:12px;font-family:var(--disp)}
@media(max-width:680px){
  .case-feat,.case-feat:nth-child(even){grid-template-columns:1fr}
  .case-feat:nth-child(even) .cf-media{order:0}
  .cf-media{min-height:190px}.cf-info{padding:22px 22px 26px}
}

/* 글 본문 가독성 - 단락 구분 또렷하게 */
.art-body p{font-size:17px!important;line-height:1.95!important;color:#FFFFFF!important;margin:0 0 20px!important}
.art-body, .art-body *:not(a){color:#FFFFFF!important}
.art-body font{color:#FFFFFF!important}
.art-body a{color:var(--brand)!important}
.art-body a.btn{color:#fff!important}
.art-body p:last-child{margin-bottom:0!important}
.art-body h2{font-size:20px!important;color:#fff!important;margin:42px 0 14px!important;padding:2px 0 2px 14px!important;border-left:3px solid var(--brand)!important;font-weight:800!important}
.art-body h2:first-child{margin-top:8px!important}
.art-body img{margin:22px auto!important;border-radius:14px!important}
.art-body ul,.art-body ol{margin:0 0 20px 1.1em;color:#CBD0DA}
.art-body li{margin:6px 0}

/* 업체 정보 바로가기 - 중앙 + 깜빡이는 펄스 */
.customer-box{text-align:center!important;margin:36px 0!important}
.customer-box .btn{font-size:19px!important;padding:16px 34px!important;box-shadow:0 8px 20px -12px rgba(0,0,0,.55)!important}
@keyframes ctaPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(77,154,245,.55),0 10px 26px -12px rgba(77,154,245,.5);transform:scale(1)}
  50%{box-shadow:0 0 24px 9px rgba(77,154,245,0),0 10px 26px -12px rgba(77,154,245,.5);transform:scale(1.05)}
}
@media(prefers-reduced-motion:reduce){.customer-box .btn{animation:none}}

/* 글 CTA 박스 - 배경 확실히 구분 */
/* 게시글 본문: 테두리 박스로 감싸 내용 영역 명확화 */
.art-body{border:1px solid rgba(255,255,255,.14)!important;border-radius:14px;padding:30px 28px!important;background:rgba(255,255,255,.02)}
@media(max-width:680px){.art-body{padding:22px 18px!important}}
/* 문의 배너: 홈 "전화 한 통이면 됩니다" 스타일 (중앙 다크 배너) */
.art-cta{background:linear-gradient(135deg,#16263F,#0E1726 60%,#101620)!important;border:1px solid rgba(77,154,245,.3)!important;box-shadow:0 24px 60px -30px rgba(77,154,245,.35)!important;border-radius:16px;padding:40px 28px!important;margin:40px 0 30px!important;text-align:center}
.art-cta h2{font-size:26px!important;font-weight:800;color:#fff!important;margin:0 0 12px;letter-spacing:-.01em}
.art-cta p{font-size:15px!important;color:var(--muted)!important;margin:0 0 22px;line-height:1.7}
.art-cta .btn{font-size:16px!important}
@media(max-width:560px){.art-cta{padding:32px 20px!important}.art-cta h2{font-size:22px!important}}
.art-cta b{color:#fff!important}

/* 파란 버튼 텍스트 - 흰색 + 폰트 통일(Pretendard) */
.btn--primary{color:#fff!important;font-family:var(--sans)!important;letter-spacing:0}
.rep .chip,.rep .chip b{color:#fff!important}

/* 캐러셀 좌우 화살표 - 다크 글래스 + 흰 화살표 */
.car-btn{background:rgba(10,12,18,.55)!important;color:#fff!important;border:1px solid rgba(255,255,255,.28)!important;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.car-btn:hover{background:rgba(18,28,48,.8)!important;border-color:var(--brand)!important;color:var(--brand)!important}

/* 모바일 하단 고정바 - 다크 배경 + 글자 보이게 + 정렬 균등 */
.mbar{background:rgba(11,12,16,.96)!important;border-top:1px solid rgba(255,255,255,.08)!important}
.mbar .btn{flex:1;display:inline-flex!important;align-items:center;justify-content:center;height:50px;padding:0 12px!important;font-size:15px;font-weight:700}
.mbar .btn--ghost{background:rgba(255,255,255,.08)!important;color:#fff!important;border:1px solid rgba(255,255,255,.22)!important}
.mbar .btn--primary{color:#fff!important}

/* 좁은 화면: 빠른상담폼 이름/전화 세로 (전화번호 잘림 방지) */
@media(max-width:520px){
  .qf-row{grid-template-columns:1fr!important}
  .quickform input{font-size:16px!important}
}

/* 로고 이미지 (헤더 마크) */
.brand img.mark{width:auto!important;height:36px!important;background:none!important;border-radius:0!important;object-fit:contain;display:block}
@media(max-width:520px){.brand img.mark{height:30px!important}}

/* 본문 중간 전화 상담 버튼 */
.tel-box{text-align:center;margin:30px 0}
.tel-box .tel-cta{color:#fff!important;font-size:19px!important;padding:16px 34px!important;box-shadow:0 8px 20px -12px rgba(0,0,0,.55)!important}

/* 버튼 주목 효과 - 글자 위 번짐 없이 테두리 밖으로만 퍼지는 링 펄스 */
@keyframes ringPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(77,154,245,.5);transform:scale(1)}
  50%{box-shadow:0 0 0 9px rgba(77,154,245,0);transform:scale(1.035)}
}
.customer-box .btn,.tel-box .tel-cta{animation:ringPulse 1.6s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.customer-box .btn,.tel-box .tel-cta{animation:none}}

/* 게시판 페이지네이션 */
.pager{display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:wrap;margin:30px 0 6px}
.pager .pg-btn{min-width:40px;height:40px;padding:0 12px;border:1px solid rgba(255,255,255,.16);background:var(--surface);color:var(--ink-soft);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}
.pager .pg-btn:hover:not(:disabled){border-color:var(--brand);color:#fff}
.pager .pg-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}
.pager .pg-btn:disabled{opacity:.4;cursor:default}
@media(max-width:520px){.pager .pg-btn{min-width:36px;height:36px;padding:0 9px;font-size:13px}}
.ph-img.has-img{background:#0F1116!important}

/* 포함 혜택 */
.perks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.perk{background:var(--surface);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:18px 18px;color:var(--muted);font-size:14px;line-height:1.5}
.perk b{display:block;color:var(--ink);font-size:15.5px;margin-bottom:5px}
.perk::before{content:"✓";display:inline-block;margin-right:8px;color:var(--brand);font-weight:800}
/* 진행 과정 */
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;counter-reset:none}
.steps li{position:relative;background:var(--surface);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:20px 18px 18px;color:var(--muted);font-size:14px;line-height:1.5}
.steps li b{display:block;color:var(--ink);font-size:16px;margin:6px 0 4px}
.steps .st-no{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--brand);color:#04162B;font-weight:800;font-size:15px}
/* 왜 케이웹미디어 */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.why{background:var(--surface);border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:24px 22px}
.why b{display:block;color:var(--brand);font-size:17px;margin-bottom:10px}
.why p{color:var(--muted);font-size:14.5px;line-height:1.75;margin:0}
@media(max-width:820px){.perks,.steps,.why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.perks,.steps,.why-grid{grid-template-columns:1fr}}

/* ===== 미세 모션 (문구 가독성 해치지 않는 선) ===== */
@media (prefers-reduced-motion:no-preference){
  /* 서비스 아이콘: 살짝 떠다니기 + 호버 반응 */
  .svc .ic{transition:transform .25s ease, box-shadow .25s ease}
  .svc .ic svg{animation:kw-float 3.4s ease-in-out infinite;will-change:transform}
  .svc:nth-child(2) .ic svg{animation-delay:.35s}
  .svc:nth-child(3) .ic svg{animation-delay:.7s}
  .svc:nth-child(4) .ic svg{animation-delay:1.05s}
  .svc:hover .ic{transform:translateY(-4px) scale(1.06) rotate(-4deg)}
  /* 카드 호버 떠오름 */
  .svc:hover,.case:hover,.post:hover,.why:hover,.perk:hover{transform:translateY(-4px)}
  .why,.perk{transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease}
  .why:hover,.perk:hover{border-color:rgba(77,154,245,.4);box-shadow:0 16px 40px -26px rgba(77,154,245,.5)}
  /* 진행 단계 번호: 순차 맥동 */
  .steps .st-no{animation:kw-ring 2.6s ease-in-out infinite;will-change:box-shadow}
  .steps li:nth-child(2) .st-no{animation-delay:.3s}
  .steps li:nth-child(3) .st-no{animation-delay:.6s}
  .steps li:nth-child(4) .st-no{animation-delay:.9s}
  .steps li:nth-child(5) .st-no{animation-delay:1.2s}
  .steps li:nth-child(6) .st-no{animation-delay:1.5s}
  /* 포함혜택 체크 살짝 튀기 */
  .perk::before{display:inline-block;animation:kw-tick 3s ease-in-out infinite}
  .perk:nth-child(even)::before{animation-delay:.5s}
  /* 숫자 바: 호버 시 살짝 강조 */
  .stat{transition:transform .2s ease}
  .stat:hover{transform:translateY(-3px)}
  .stat:hover .num{color:var(--brand)}
  /* eyebrow 앞 점멸 점 */
  .eyebrow::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--brand);margin-right:8px;vertical-align:middle;animation:kw-blink 1.8s ease-in-out infinite}
  /* 히어로 강조어 밑줄 쓸어오기 */
  .hero h1 em::after{transform-origin:left;animation:kw-underline 1s ease .3s both}
}
@keyframes kw-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes kw-ring{0%,100%{box-shadow:0 0 0 0 rgba(77,154,245,.45)}50%{box-shadow:0 0 0 7px rgba(77,154,245,0)}}
@keyframes kw-tick{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}
@keyframes kw-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}
@keyframes kw-underline{from{transform:scaleX(0)}to{transform:scaleX(1)}}
/* ===================== /CLEAN DARK THEME ===================== */