/* ============================================================
   CKP 한국경영지원센터 — Design System v2
   Light · Navy primary · Deep-green secondary · Gold accent
   Trust / public-feel but explicitly a PRIVATE platform
   ============================================================ */

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css");

:root {
  /* Navy (primary) — KOSME deep blue */
  --navy:      #0a3d7c;
  --navy-2:    #155ba6;
  --navy-soft: #2f78c4;
  --navy-deep: #06264f;

  /* Deep green (secondary) */
  --green:      #1c6b54;
  --green-2:    #228066;
  --green-soft: #e7f1ec;

  /* Coral / Terracotta (accent / point) — pairs with navy */
  --gold:      #d1654a;
  --gold-2:    #e7896d;
  --gold-soft: #fbe9e1;

  /* Sky (alt point) */
  --sky:       #2c79bd;
  --sky-soft:  #e9f1fa;

  /* Neutrals */
  --bg:        #ffffff;
  --bg-soft:   #f3f6f9;
  --bg-soft-2: #e9eef4;
  --card:      #ffffff;

  --ink:    #142231;
  --ink-2:  #3c4b5b;
  --muted:  #647688;
  --faint:  #95a4b4;

  --line:   #e3e9ef;
  --line-2: #d2dce5;

  /* On-navy */
  --on-navy:      #ffffff;
  --on-navy-mid:  #b7c7d9;
  --on-navy-soft: #8ca3bc;
  --on-navy-line: rgba(255,255,255,0.14);

  /* status */
  --warn: #c0392b;

  --r-sm: 6px;
  --r:    10px;
  --r-lg: 16px;
  --r-xl: 22px;
  --shadow:    0 10px 30px -16px rgba(14,44,79,0.22);
  --shadow-md: 0 18px 44px -22px rgba(14,44,79,0.30);

  --sans: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  --mono: "SFMono-Regular", ui-monospace, "JetBrains Mono", Consolas, monospace;

  --maxw: 1300px;
  --util-h: 38px;
  --nav-h: 70px;

  /* premium motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,.84,.44,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --shadow-lift: 0 26px 60px -28px rgba(10,44,79,0.38);

  /* jewel-tone aurora palette for cinematic surfaces */
  --indigo: #3b4fd6;
  --teal:   #119a8e;
  --violet: #6d4bd4;
  --champagne: #f0c987;

  --gold-grad:  linear-gradient(118deg, #f0c987, #e7896d 46%, #d1654a);
  --navy-grad:  linear-gradient(135deg, #0a3d7c, #1b4f9e 55%, #2f78c4);
  --aurora-text: linear-gradient(100deg, #ffe3b0, #f6a877 40%, #ff9d6c 70%, #ffd9a0);

  --glow-navy: 0 22px 50px -20px rgba(10,44,79,0.5);
  --glow-gold: 0 18px 44px -18px rgba(209,101,74,0.55);
}

@property --angle { syntax: "<angle>"; initial-value: 0deg; inherits: false; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.6;
  letter-spacing: -0.01em;
}
h1, h2, h3, h4, h5 { margin: 0; font-weight: 700; letter-spacing: -0.025em; line-height: 1.2; color: var(--ink); }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
ul { margin: 0; padding: 0; list-style: none; }
button { font-family: inherit; }

/* ============================================================ Utility */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 26px; }
.section { padding: clamp(56px, 7vw, 100px) 0; }
.section.soft { background: var(--bg-soft); }
.center { text-align: center; }

.eyebrow {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.eyebrow::before { content: ""; width: 22px; height: 2px; background: var(--gold); border-radius: 2px; }
.eyebrow.no-rule::before { display: none; }
.eyebrow.on-navy { color: var(--gold-2); }

.lede { font-size: clamp(15px, 1.4vw, 18px); color: var(--muted); line-height: 1.75; max-width: 62ch; }

.sec-head { max-width: 760px; }
.sec-head h2 { font-size: clamp(25px, 3.2vw, 40px); font-weight: 800; margin-top: 16px; letter-spacing: -0.035em; }
.sec-head .lede { margin-top: 16px; }
.sec-head.center { margin-left: auto; margin-right: auto; }
.sec-head.center .lede { margin-left: auto; margin-right: auto; }

/* ============================================================ Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 24px; border-radius: var(--r);
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  border: 1.5px solid transparent; cursor: pointer;
  transition: transform .16s ease, background .18s, border-color .18s, color .18s, box-shadow .18s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { filter: brightness(1.1) saturate(1.08); box-shadow: var(--shadow); }
.btn-gold { background: var(--gold); color: #fff; }
.btn-gold:hover { filter: brightness(1.08) saturate(1.06); box-shadow: var(--shadow); }
.btn-green { background: var(--green); color: #fff; }
.btn-green:hover { filter: brightness(1.1) saturate(1.08); box-shadow: var(--shadow); }
.btn-ghost { background: #fff; color: var(--navy); border-color: var(--line-2); }
.btn-ghost:hover { border-color: var(--navy); }
.btn-ghost-navy { background: transparent; color: #fff; border-color: var(--on-navy-line); }
.btn-ghost-navy:hover { border-color: #fff; background: rgba(255,255,255,0.08); }
.btn-lg { padding: 16px 30px; font-size: 16px; }
.btn .ic, .btn [data-lucide] { width: 17px; height: 17px; }

/* ============================================================ Top utility bar */
.utilbar { background: var(--navy-deep); color: var(--on-navy-soft); height: var(--util-h); font-size: 12.5px; }
.utilbar-inner { height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.utilbar .disc { display: inline-flex; align-items: center; gap: 7px; }
.utilbar .disc .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold-2); }
.utilbar-right { display: flex; align-items: center; gap: 18px; }
.utilbar-right a { color: var(--on-navy-mid); transition: color .15s; display: inline-flex; align-items: center; gap: 6px; }
.utilbar-right a:hover { color: #fff; }
.utilbar-right a [data-lucide] { width: 13px; height: 13px; }
@media (max-width: 820px){ .utilbar .disc span.full { display: none; } .utilbar-right { gap: 12px; } .utilbar-right a span { display: none; } }

/* ============================================================ Nav */
.nav { position: sticky; top: 0; z-index: 100; height: var(--nav-h); background: rgba(255,255,255,0.94); backdrop-filter: saturate(140%) blur(14px); border-bottom: 1px solid var(--line); }
.nav-inner { height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: flex; align-items: center; gap: 11px; }
.brand-mark { width: 34px; height: 34px; border-radius: 50%; background: transparent; display: grid; place-items: center; position: relative; overflow: visible; }
.brand-mark .logo-sym { width: 34px; height: 34px; display: block; border-radius: 50%; }
/* taegeuk symbol — slow continuous swirl, site-wide */
.brand-mark .logo-sym { animation: ckpSpin 22s linear infinite; transform-origin: 50% 50%; }
.brand .brand-mark { animation: ckpMarkIn .75s var(--ease) both; }

/* Korean wordmark — gradient shine sweeping left→right at reading pace, small neon glow */
.brand .brand-text b {
  background: linear-gradient(100deg, var(--navy) 0%, var(--navy) 42%, #7db4ff 49%, #d6e8ff 50%, #7db4ff 51%, var(--navy) 58%, var(--navy) 100%);
  background-size: 230% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  filter: drop-shadow(0 0 1px rgba(125,180,255,.5));
  animation: ckpShine 6s linear infinite;
}
/* English tagline — very subtle slow breathing (grow/shrink) */
.brand .brand-text span { display: inline-block; transform-origin: center center; animation: ckpTagPulse 5.5s ease-in-out infinite; }
/* red laser — only a small bright dot travels (no long base line) */
.brand-text { position: relative; }
.brand-text::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 2px; border-radius: 2px; pointer-events: none;
  background: linear-gradient(90deg, transparent 0 48.6%, #ff3b54 49.4%, #ff8092 50%, #ff3b54 50.6%, transparent 51.4% 100%);
  background-size: 200% 100%;
  filter: drop-shadow(0 0 2px rgba(255,59,84,.65));
  animation: ckpLaser 6.5s linear infinite;
}
@keyframes ckpMarkIn { from { opacity: 0; transform: scale(.45); } to { opacity: 1; transform: scale(1); } }
@keyframes ckpShine { from { background-position: 150% 0; } to { background-position: -150% 0; } }
@keyframes ckpTagPulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.035); } }
@keyframes ckpLaser { from { background-position: 150% 0; } to { background-position: -150% 0; } }
@media (prefers-reduced-motion: reduce){
  .brand-mark .logo-sym, .brand .brand-mark, .brand .brand-text b, .brand .brand-text span, .brand-text::after { animation: none !important; opacity: 1 !important; transform: none !important; }
  .brand .brand-text b { -webkit-text-fill-color: var(--navy); color: var(--navy); }
  .brand-text::after { display: none; }
}
.footer-brand .brand-mark { box-shadow: none; }
.brand-text { display: flex; flex-direction: column; line-height: 1.08; }
.brand-text b { font-size: 16px; font-weight: 800; letter-spacing: -0.03em; color: var(--navy); }
.brand-text span { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.16em; color: var(--muted); text-transform: uppercase; }

.nav-links { display: flex; align-items: center; gap: 2px; }
.nav-item { position: relative; }
.nav-item > a { padding: 0 8px; height: var(--nav-h); display: inline-flex; align-items: center; font-size: 13.5px; font-weight: 600; color: var(--ink-2); transition: color .15s; white-space: nowrap; }
.nav-item > a:hover, .nav-item.active > a { color: var(--navy); }
.nav-item > a .caret { width: 13px; height: 13px; margin-left: 3px; color: var(--faint); }
.nav-item::after { content: ""; position: absolute; left: 8px; right: 8px; bottom: 0; height: 3px; background: var(--gold); transform: scaleX(0); transition: transform .2s; transform-origin: left; }
.nav-item:hover::after, .nav-item.active::after { transform: scaleX(1); }

.dropdown { position: absolute; top: calc(var(--nav-h) - 6px); left: 50%; transform: translateX(-50%) translateY(8px); min-width: 230px; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--shadow-md); padding: 10px; opacity: 0; visibility: hidden; transition: opacity .16s, transform .16s; z-index: 110; }
.nav-item:hover .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--r-sm); font-size: 14px; color: var(--ink-2); transition: background .14s, color .14s; }
.dropdown a:hover { background: var(--bg-soft); color: var(--navy); }
.dropdown a [data-lucide] { width: 16px; height: 16px; color: var(--green); flex-shrink: 0; }

.nav-cta { display: flex; align-items: center; gap: 8px; }
.nav-toggle { display: none; background: none; border: 0; color: var(--navy); cursor: pointer; padding: 6px; }

@media (max-width: 1240px){ .nav-links, .nav-cta .btn-ghost { display: none; } .nav-toggle { display: grid; place-items: center; } }

.mobile-menu { display: none; position: fixed; inset: calc(var(--util-h) + var(--nav-h)) 0 0 0; background: #fff; z-index: 95; padding: 14px 26px 120px; overflow-y: auto; }
.mobile-menu.open { display: grid; grid-template-columns: 1fr 1fr; column-gap: 14px; align-content: start; }
body.menu-open { overflow: hidden; }
.mobile-menu .mgrp { border-bottom: 1px solid var(--line); }
.mobile-menu .mgrp > b { display: block; padding: 14px 2px 6px; font-size: 14.5px; color: var(--navy); font-weight: 700; }
.mobile-menu .mgrp a { display: block; padding: 8px 8px; font-size: 13px; color: var(--ink-2); line-height: 1.3; }
.mobile-menu .mcta { display: grid; gap: 10px; margin-top: 22px; grid-column: 1 / -1; }

/* ============================================================ Mobile fixed CTA */
.mfab { display: none; position: fixed; left: 0; right: 0; bottom: 0; z-index: 120; background: #fff; border-top: 1px solid var(--line); box-shadow: 0 -8px 24px -16px rgba(14,44,79,0.3); }
.mfab-inner { display: grid; grid-template-columns: repeat(3, 1fr); }
.mfab a { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 11px 4px; font-size: 12px; font-weight: 600; color: var(--ink-2); border-left: 1px solid var(--line); }
.mfab a:first-child { border-left: 0; }
.mfab a [data-lucide] { width: 19px; height: 19px; }
.mfab a.call { color: var(--navy); }
.mfab a.kakao { color: #3a1d1d; background: #FAE100; }
.mfab a.diag { color: #fff; background: var(--gold); }
@media (max-width: 1180px){ .mfab { display: block; } body { padding-bottom: 64px; } }

/* fixed hotline — small blue text, transparent bg, follows scroll, tap-to-call on mobile */
.hotline { position: fixed; right: 16px; bottom: 14px; z-index: 130; font-family: var(--mono); font-size: 21px; font-weight: 700; letter-spacing: .02em; color: #e23b2e; background: transparent; border: 0; outline: none; box-shadow: none; text-shadow: none; text-decoration: none; padding: 4px 6px; pointer-events: auto; transition: color .15s var(--ease), transform .1s var(--ease); }
.hotline:hover { color: #b71c12; }
.hotline:active { transform: scale(.96); }
@media (max-width: 1180px){ .hotline { bottom: 74px; } }

/* ============================================================ Hero */
.hero { position: relative; overflow: hidden; background: linear-gradient(160deg, var(--navy-deep), var(--navy) 55%, var(--navy-2)); color: var(--on-navy); padding: clamp(48px,7vw,86px) 0 clamp(40px,6vw,72px); }
.hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.09) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.09) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(circle at 70% 30%, #000, transparent 80%); opacity: 0.9; }
.hero-glow { position: absolute; top: -120px; right: -80px; width: 520px; height: 520px; background: radial-gradient(circle, rgba(214,110,84,0.22), transparent 65%); pointer-events: none; }
.hero-inner { position: relative; }
.hero h1 { color: #fff; font-size: clamp(30px,4.6vw,58px); font-weight: 800; line-height: 1.14; letter-spacing: -0.035em; margin-top: 22px; }
.hero h1 .hl { color: var(--gold-2); }
.hero .lede { color: var(--on-navy-mid); margin-top: 22px; font-size: clamp(15px,1.6vw,19px); max-width: 56ch; }

/* hero quad CTA */
.hero-quad { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 36px; }
@media (max-width: 880px){ .hero-quad { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 440px){ .hero-quad { grid-template-columns: 1fr; } }
.qcta { display: flex; align-items: center; gap: 13px; padding: 18px 18px; border-radius: var(--r-lg); background: rgba(255,255,255,0.06); border: 1px solid var(--on-navy-line); transition: background .18s, transform .18s, border-color .18s; }
.qcta:hover { background: rgba(255,255,255,0.12); transform: translateY(-3px); border-color: rgba(255,255,255,0.3); }
.qcta .qic { width: 42px; height: 42px; border-radius: 10px; background: var(--gold); color: #fff; display: grid; place-items: center; flex-shrink: 0; }
.qcta .qic [data-lucide] { width: 21px; height: 21px; }
.qcta .qtx b { display: block; font-size: 15.5px; color: #fff; font-weight: 700; }
.qcta .qtx span { font-size: 12.5px; color: var(--on-navy-soft); }

/* ============================================================ Trust strip (fact-based, NO fake numbers) */
.trust { background: var(--navy-deep); border-top: 1px solid var(--on-navy-line); }
.trust-inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--on-navy-line); }
.trust-cell { background: var(--navy-deep); padding: 22px 20px; text-align: center; }
.trust-cell b { display: block; font-size: clamp(18px,2vw,24px); color: #fff; font-weight: 800; letter-spacing: -0.02em; }
.trust-cell span { font-size: 12.5px; color: var(--on-navy-soft); margin-top: 5px; display: block; }
@media (max-width: 680px){ .trust-inner { grid-template-columns: repeat(2,1fr); } }

/* ============================================================ Service cards */
.svc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 1040px){ .svc-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px){ .svc-grid { grid-template-columns: 1fr; } }
.svc-card { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px 24px 26px; transition: transform .2s, box-shadow .2s, border-color .2s; display: flex; flex-direction: column; min-height: 210px; overflow: hidden; }
.svc-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--green); transform: scaleY(0); transform-origin: top; transition: transform .3s; }
.svc-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--line-2); }
.svc-card:hover::before { transform: scaleY(1); }
.svc-ic { width: 50px; height: 50px; border-radius: 12px; background: var(--bg-soft); color: var(--navy); display: grid; place-items: center; transition: background .2s, color .2s; }
.svc-card:hover .svc-ic { background: var(--navy); color: #fff; }
.svc-ic [data-lucide] { width: 25px; height: 25px; }
.svc-card h3 { font-size: 18px; margin-top: 18px; color: var(--navy); }
.svc-card p { margin-top: 9px; color: var(--muted); font-size: 14px; line-height: 1.6; }
.svc-card .more { margin-top: auto; padding-top: 16px; font-size: 13px; color: var(--green); font-weight: 600; display: inline-flex; align-items: center; gap: 6px; }
.svc-card .more [data-lucide] { width: 14px; height: 14px; transition: transform .2s; }
.svc-card:hover .more [data-lucide] { transform: translateX(4px); }

/* ============================================================ Diagnosis promo */
.diag-promo { display: grid; grid-template-columns: 1.1fr 1fr; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); }
@media (max-width: 880px){ .diag-promo { grid-template-columns: 1fr; } }
.diag-promo .dl { background: linear-gradient(160deg, var(--navy), var(--navy-2)); color: #fff; padding: clamp(32px,4.5vw,56px); }
.diag-promo .dl h2 { color: #fff; font-size: clamp(24px,3vw,36px); font-weight: 800; }
.diag-promo .dl .lede { color: var(--on-navy-mid); margin-top: 16px; }
.diag-promo .dr { background: #fff; padding: clamp(32px,4.5vw,56px); display: flex; flex-direction: column; justify-content: center; gap: 14px; }
.dstep { display: flex; align-items: flex-start; gap: 14px; }
.dstep .n { width: 32px; height: 32px; border-radius: 50%; background: var(--green-soft); color: var(--green); display: grid; place-items: center; font-weight: 700; font-size: 14px; flex-shrink: 0; }
.dstep b { font-size: 15px; color: var(--navy); }
.dstep span { display: block; font-size: 13px; color: var(--muted); margin-top: 2px; }

/* ============================================================ Manufacturer search preview */
.mfind { display: grid; grid-template-columns: 1.15fr 1fr; gap: 0; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); background: #fff; }
@media (max-width: 900px){ .mfind { grid-template-columns: 1fr; } }
.map-mock { position: relative; min-height: 380px; background:
    radial-gradient(circle at 30% 40%, rgba(44,121,189,0.07), transparent 40%),
    repeating-linear-gradient(0deg, rgba(14,44,79,0.05) 0 1px, transparent 1px 40px),
    repeating-linear-gradient(90deg, rgba(14,44,79,0.05) 0 1px, transparent 1px 40px),
    #eef3f7; }
.map-mock .road { position: absolute; background: #fff; }
.map-pin { position: absolute; transform: translate(-50%,-100%); display: flex; flex-direction: column; align-items: center; cursor: pointer; }
.map-pin .pin { width: 30px; height: 30px; border-radius: 50% 50% 50% 0; background: var(--gold); transform: rotate(-45deg); display: grid; place-items: center; box-shadow: 0 4px 10px -3px rgba(0,0,0,0.4); border: 2px solid #fff; }
.map-pin .pin [data-lucide] { width: 14px; height: 14px; color: #fff; transform: rotate(45deg); }
.map-pin.navy .pin { background: var(--navy); }
.map-pin.green .pin { background: var(--green); }
.map-pin .lbl { margin-top: 5px; background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 2px 9px; font-size: 11px; font-weight: 600; color: var(--navy); white-space: nowrap; box-shadow: var(--shadow); }
.map-cluster { position: absolute; transform: translate(-50%,-50%); width: 46px; height: 46px; border-radius: 50%; background: rgba(209,101,74,0.94); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 15px; border: 3px solid #fff; box-shadow: var(--shadow); }

.mfind-side { padding: 26px 26px 30px; display: flex; flex-direction: column; }
.mfind-search { display: flex; gap: 8px; }
.mfind-search input { flex: 1; padding: 12px 14px; border: 1px solid var(--line-2); border-radius: var(--r); font-size: 14px; font-family: var(--sans); }
.mfind-search input:focus { outline: none; border-color: var(--navy); }
.mfind-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 14px; }
.mchip { font-size: 12.5px; padding: 6px 12px; border-radius: 999px; background: var(--bg-soft); border: 1px solid var(--line); color: var(--ink-2); cursor: pointer; transition: all .14s; }
.mchip:hover, .mchip.on { background: var(--navy); color: #fff; border-color: var(--navy); }
.mlist { margin-top: 18px; display: grid; gap: 10px; }
.mrow { display: flex; gap: 13px; padding: 14px; border: 1px solid var(--line); border-radius: var(--r); transition: border-color .15s, box-shadow .15s; }
.mrow:hover { border-color: var(--line-2); box-shadow: var(--shadow); }
.mrow .mlogo { width: 46px; height: 46px; border-radius: 9px; background: var(--bg-soft-2); color: var(--navy); display: grid; place-items: center; font-weight: 800; font-size: 13px; flex-shrink: 0; }
.mrow .minfo b { font-size: 15px; color: var(--navy); }
.mrow .minfo .mtags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.mrow .minfo .mtags span { font-size: 11px; padding: 2px 8px; border-radius: 5px; background: var(--green-soft); color: var(--green); }
.mrow .minfo .mloc { font-size: 12px; color: var(--muted); margin-top: 6px; display: inline-flex; align-items: center; gap: 4px; }
.mrow .minfo .mloc [data-lucide] { width: 12px; height: 12px; }

/* ============================================================ Content cards (info center) */
.info-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
@media (max-width: 860px){ .info-grid { grid-template-columns: 1fr; } }
.info-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; transition: transform .2s, box-shadow .2s; }
.info-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.info-card .ic-top { padding: 20px 22px 0; }
.info-card .cat { font-size: 11.5px; font-weight: 700; color: var(--green); letter-spacing: 0.04em; }
.info-card h4 { font-size: 17px; color: var(--navy); margin-top: 10px; line-height: 1.4; }
.info-card p { font-size: 13.5px; color: var(--muted); margin-top: 8px; padding: 0 22px; line-height: 1.6; }
.info-card .ic-foot { padding: 16px 22px 20px; margin-top: 12px; font-size: 12.5px; color: var(--faint); display: flex; align-items: center; gap: 6px; }

/* ============================================================ CTA band */
.cta-band { position: relative; overflow: hidden; border-radius: var(--r-xl); background: linear-gradient(150deg, var(--navy), var(--navy-2)); color: #fff; padding: clamp(38px,5vw,68px); text-align: center; }
.cta-band::after { content: ""; position: absolute; right: -60px; top: -60px; width: 320px; height: 320px; background: radial-gradient(circle, rgba(214,110,84,0.24), transparent 65%); }
.cta-band h2 { color: #fff; font-size: clamp(24px,3.2vw,40px); font-weight: 800; position: relative; }
.cta-band .lede { color: var(--on-navy-mid); margin: 16px auto 0; position: relative; }
.cta-band .btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 30px; position: relative; }

/* ============================================================ Breadcrumb */
.crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); flex-wrap: wrap; }
.crumb a:hover { color: var(--navy); }
.crumb [data-lucide] { width: 13px; height: 13px; color: var(--faint); }
.crumb .cur { color: var(--navy); font-weight: 600; }

/* ============================================================ Footer */
.footer { background: var(--navy-deep); color: var(--on-navy-soft); padding: 56px 0 30px; }
.footer-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr; gap: 30px; }
@media (max-width: 900px){ .footer-top { grid-template-columns: 1fr 1fr; gap: 26px; } }
.footer h5 { color: #fff; font-size: 13px; font-weight: 700; margin-bottom: 14px; letter-spacing: 0.02em; }
.footer-links a { display: block; padding: 5px 0; font-size: 13.5px; color: var(--on-navy-soft); transition: color .15s; }
.footer-links a:hover { color: #fff; }
.footer-brand .brand-text b { color: #fff; }
.footer-brand .brand-text span { color: var(--on-navy-soft); }
.footer-brand .brand-mark { background: transparent; }
.footer-disc { margin-top: 18px; font-size: 12.5px; line-height: 1.7; color: var(--on-navy-soft); max-width: 42ch; padding: 14px 16px; background: rgba(255,255,255,0.04); border: 1px solid var(--on-navy-line); border-radius: var(--r); }
.footer-bottom { margin-top: 40px; padding-top: 22px; border-top: 1px solid var(--on-navy-line); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; font-size: 12px; color: var(--on-navy-soft); }
.footer-bottom .fmono { font-family: var(--mono); letter-spacing: 0.04em; }

/* ============================================================ Reveal */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease), transform .8s var(--ease); will-change: opacity, transform; }
.reveal.in { opacity: 1; transform: none; }
.reveal.r-left  { transform: translateX(-28px); }
.reveal.r-right { transform: translateX(28px); }
.reveal.r-scale { transform: translateY(20px) scale(.97); }
.reveal.r-left.in, .reveal.r-right.in, .reveal.r-scale.in { transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity: 1 !important; transform: none !important; transition: none !important; } }

/* ============================================================ Pills / tags */
.pill { display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; border-radius: 999px; background: rgba(255,255,255,0.1); border: 1px solid var(--on-navy-line); font-size: 13px; color: #fff; font-weight: 500; }
.pill .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold-2); box-shadow: 0 0 0 4px rgba(214,110,84,0.22); }
.tag-green { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; padding: 4px 11px; border-radius: 999px; background: var(--green-soft); color: var(--green); font-weight: 600; }
.note-private { display: flex; gap: 11px; align-items: flex-start; background: var(--bg-soft); border: 1px solid var(--line); border-left: 3px solid var(--gold); border-radius: var(--r); padding: 14px 16px; font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.note-private [data-lucide] { width: 17px; height: 17px; color: var(--gold); flex-shrink: 0; margin-top: 1px; }

/* image placeholder */
.ph { position: relative; border-radius: var(--r-lg); background: repeating-linear-gradient(45deg, rgba(14,44,79,0.06) 0 12px, transparent 12px 24px), var(--bg-soft); border: 1px solid var(--line); display: grid; place-items: center; color: var(--muted); font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; min-height: 280px; text-align: center; padding: 22px; }

/* ============================================================ Inner page hero */
.page-hero { background: linear-gradient(160deg, var(--navy-deep), var(--navy) 60%, var(--navy-2)); color:#fff; padding: clamp(34px,5vw,58px) 0 clamp(30px,4vw,48px); position:relative; overflow:hidden; }
.page-hero h1 { color:#fff; font-size:clamp(27px,3.9vw,46px); font-weight:800; letter-spacing:-0.035em; margin-top:14px; line-height:1.18; }
.page-hero .lede { color:var(--on-navy-mid); margin-top:16px; }
.page-hero .crumb { color:var(--on-navy-soft); }
.page-hero .crumb a:hover{ color:#fff; } .page-hero .crumb .cur{ color:#fff; } .page-hero .crumb [data-lucide]{ color:var(--on-navy-soft); }
.page-hero .btns { display:flex; gap:12px; flex-wrap:wrap; margin-top:26px; position:relative; }
.page-hero .inner { position:relative; }
.page-hero.center { text-align:center; }
.page-hero.center .lede { margin-left:auto; margin-right:auto; }

/* ============================================================ Sub tabs (anchor nav) */
.subtabs { background:#fff; border-bottom:1px solid var(--line); position:sticky; top:var(--nav-h); z-index:50; }
.subtabs-inner { display:flex; gap:4px; overflow-x:auto; padding:10px 0; scrollbar-width:none; }
.subtabs-inner::-webkit-scrollbar { display:none; }
.subtabs a { white-space:nowrap; padding:8px 15px; border-radius:999px; font-size:14px; font-weight:600; color:var(--muted); transition:all .15s; }
.subtabs a:hover { background:var(--bg-soft); color:var(--navy); }

/* ============================================================ Service detail */
.maincols { display:grid; grid-template-columns:1fr 320px; gap:40px; align-items:start; }
@media (max-width:980px){ .maincols { grid-template-columns:1fr; } .aside { position:static !important; } }
.aside { position:sticky; top:calc(var(--nav-h) + 60px); display:grid; gap:16px; }
.doc { max-width:880px; }
.block { padding:clamp(40px,5vw,64px) 0; border-top:1px solid var(--line); scroll-margin-top:130px; }
.block:first-of-type { border-top:0; padding-top:0; }
.block h2 { font-size:clamp(22px,2.9vw,32px); font-weight:800; color:var(--navy); }
.block > p { color:var(--ink-2); font-size:15.5px; line-height:1.8; margin-top:16px; }
.block .eyebrow { margin-bottom:6px; }
.three { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:28px; }
@media (max-width:760px){ .three { grid-template-columns:1fr; } }
.fcard { border:1px solid var(--line); border-radius:var(--r-lg); padding:24px 22px; background:#fff; transition:box-shadow .2s, transform .2s, border-color .2s; }
.fcard:hover { box-shadow:var(--shadow); transform:translateY(-3px); border-color:var(--line-2); }
.fcard .ic { width:46px;height:46px;border-radius:11px; background:var(--bg-soft); color:var(--navy); display:grid;place-items:center; }
.fcard .ic [data-lucide]{ width:23px;height:23px; }
.fcard h3 { font-size:17px; color:var(--navy); margin-top:16px; }
.fcard p { font-size:13.5px; color:var(--muted); margin-top:8px; line-height:1.6; }
.checklist { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:24px; }
@media (max-width:600px){ .checklist { grid-template-columns:1fr; } }
.citem { display:flex; gap:12px; align-items:flex-start; padding:16px 18px; border:1px solid var(--line); border-radius:var(--r); background:#fff; }
.citem .ck { width:24px;height:24px;border-radius:7px; background:var(--green-soft); color:var(--green); display:grid;place-items:center; flex-shrink:0; }
.citem .ck [data-lucide]{ width:14px;height:14px; }
.citem b { font-size:14.5px; color:var(--ink); } .citem p { font-size:13px; color:var(--muted); margin-top:3px; }
.steps { margin-top:24px; display:grid; gap:0; }
.pstep { display:grid; grid-template-columns:64px 1fr; gap:18px; padding:20px 0; border-top:1px dashed var(--line-2); }
.pstep:first-child { border-top:0; }
.pstep .n { width:48px;height:48px;border-radius:50%; background:var(--navy); color:#fff; display:grid;place-items:center; font-weight:800; font-size:17px; font-family:var(--mono); }
.pstep b { font-size:16px; color:var(--navy); } .pstep p { font-size:14px; color:var(--muted); margin-top:5px; }
.faq { margin-top:24px; }
.faq-item { border:1px solid var(--line); border-radius:var(--r); margin-bottom:10px; overflow:hidden; background:#fff; }
.faq-q { width:100%; text-align:left; border:0; background:#fff; padding:18px 20px; font-size:15.5px; font-weight:700; color:var(--navy); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:12px; font-family:var(--sans); }
.faq-q [data-lucide]{ width:18px;height:18px; color:var(--muted); transition:transform .2s; flex-shrink:0; }
.faq-item.open .faq-q [data-lucide]{ transform:rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a p { padding:0 20px 18px; font-size:14.5px; color:var(--ink-2); line-height:1.7; }
.sidebar-cta { background:linear-gradient(160deg,var(--navy),var(--navy-2)); color:#fff; border-radius:var(--r-xl); padding:32px 30px; text-align:center; overflow:hidden; }
.sidebar-cta h3 { color:#fff; font-size:21px; } .sidebar-cta p { color:var(--on-navy-mid); font-size:14px; margin-top:10px; }
.sidebar-cta .btn { width:100%; margin-top:10px; }
/* line-art 태극 mark behind the CTA — colorless, slow rotation */
.taegeuk-deco { position:absolute; inset:0; margin:auto; width:320px; height:320px; z-index:0; opacity:.17; pointer-events:none; animation:ckpSpin 32s linear infinite; }
.sidebar-cta > :not(.taegeuk-deco) { position:relative; z-index:1; }
@keyframes ckpSpin { to { transform:rotate(360deg); } }
@media (prefers-reduced-motion: reduce){ .taegeuk-deco { animation:none; } }
/* large line-art 태극 accent on inner page heroes — tilted 45°, bleeds off the edge */
.hero-taegeuk { position:absolute; right:-160px; top:50%; width:560px; height:560px; transform:translateY(-50%) rotate(45deg); transform-origin:50% 50%; z-index:0; opacity:.13; pointer-events:none; animation:ckpTaegeukDrift 18s ease-in-out infinite alternate; }
.page-hero > .wrap, .page-hero > .inner { position:relative; z-index:2; }
@keyframes ckpTaegeukDrift { from { transform:translateY(-50%) rotate(42deg) scale(1); } to { transform:translateY(-54%) rotate(48deg) scale(1.04); } }
@media (max-width:760px){ .hero-taegeuk { width:380px; height:380px; right:-150px; opacity:.1; } }
@media (prefers-reduced-motion: reduce){ .hero-taegeuk { animation:none; } }

/* "어떤 지원이 필요하세요?" box — handshake emblem on top + emphasized heading */
.cta-emblem { width:62px; height:62px; margin:0 auto 16px; border-radius:50%; display:grid; place-items:center; background:radial-gradient(circle at 50% 35%, rgba(255,255,255,.22), rgba(255,255,255,.08)); border:1px solid rgba(255,255,255,.32); box-shadow:0 8px 22px -10px rgba(0,0,0,.5); animation:ckpShake 3.2s ease-in-out infinite; }
.cta-emblem [data-lucide]{ width:30px; height:30px; color:#fff; }
@keyframes ckpShake {
  0%,72%,100% { transform:rotate(0deg); }
  78% { transform:rotate(-9deg); }
  84% { transform:rotate(7deg); }
  90% { transform:rotate(-5deg); }
  95% { transform:rotate(2deg); }
}
.cta-handshake h3 { animation:ckpEmph 2.8s ease-in-out infinite; display:inline-block; }
@keyframes ckpEmph {
  0%,100% { transform:scale(1); text-shadow:0 0 0 rgba(240,201,135,0); }
  50%     { transform:scale(1.045); text-shadow:0 0 18px rgba(240,201,135,.65); }
}
@media (prefers-reduced-motion: reduce){ .cta-emblem, .cta-handshake h3 { animation:none; } }
.related a { display:flex; align-items:center; justify-content:space-between; padding:13px 16px; border:1px solid var(--line); border-radius:var(--r); margin-bottom:8px; font-size:14px; font-weight:600; color:var(--ink-2); transition:all .15s; }
.related a:hover { border-color:var(--navy); color:var(--navy); }
.related a [data-lucide]{ width:15px;height:15px; }

/* ============================================================ Forms (shared) */
.field { margin-bottom:20px; }
.field > label { display:block; font-size:13.5px; font-weight:700; color:var(--ink); margin-bottom:8px; }
.field > label .req { color:var(--gold); margin-left:3px; }
.field input, .field textarea, .field select { width:100%; padding:13px 15px; border:1px solid var(--line-2); border-radius:var(--r); font-size:15px; font-family:var(--sans); color:var(--ink); background:#fff; transition:border-color .15s, box-shadow .15s; }
.field input::placeholder, .field textarea::placeholder { color:var(--faint); }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color:var(--navy); box-shadow:0 0 0 3px var(--sky-soft); }
.field textarea { resize:vertical; min-height:110px; line-height:1.6; }
.frow { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .frow { grid-template-columns:1fr; } }
.frow.three-col { grid-template-columns:1fr 1fr 1fr; }
@media (max-width:640px){ .frow.three-col { grid-template-columns:1fr; } }
.chips { display:flex; flex-wrap:wrap; gap:8px; }
.chip-opt { padding:10px 15px; border-radius:999px; border:1px solid var(--line-2); background:#fff; font-size:13.5px; font-weight:600; cursor:pointer; transition:all .15s; color:var(--ink-2); user-select:none; }
.chip-opt:hover { border-color:var(--navy); }
.chip-opt.sel { background:var(--navy); color:#fff; border-color:var(--navy); }
.consent { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--muted); margin:4px 0 20px; }
.consent input { width:18px;height:18px;margin-top:2px; accent-color:var(--green); }
.consent a { color:var(--navy); text-decoration:underline; }
.form-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--shadow); padding:clamp(26px,4vw,42px); }
.cgrid { display:grid; grid-template-columns:1.3fr 0.7fr; gap:clamp(24px,4vw,48px); align-items:start; }
@media (max-width:900px){ .cgrid { grid-template-columns:1fr; } }
.success .badge { width:74px;height:74px;border-radius:50%; background:var(--green-soft); color:var(--green); display:grid;place-items:center; margin:0 auto 20px; }
.success .badge [data-lucide]{ width:36px;height:36px; }

/* ============================================================ List / post cards (info, cases) */
.list-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:880px){ .list-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .list-grid { grid-template-columns:1fr; } }
.post { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:transform .2s, box-shadow .2s; display:flex; flex-direction:column; }
.post:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.post .thumb { aspect-ratio:16/9; background:repeating-linear-gradient(45deg, rgba(14,44,79,0.06) 0 12px, transparent 12px 24px), var(--bg-soft); display:grid; place-items:center; color:var(--faint); font-family:var(--mono); font-size:11px; }
.post .body { padding:20px 22px 22px; display:flex; flex-direction:column; flex:1; }
.post .cat { font-size:11.5px; font-weight:700; color:var(--green); letter-spacing:0.04em; }
.post h4 { font-size:17px; color:var(--navy); margin-top:10px; line-height:1.4; }
.post p { font-size:13.5px; color:var(--muted); margin-top:8px; line-height:1.6; flex:1; }
.post .meta { margin-top:14px; font-size:12.5px; color:var(--faint); display:flex; align-items:center; gap:7px; }
.post .meta [data-lucide]{ width:13px;height:13px; }

/* category filter row */
.catfilter { display:flex; flex-wrap:wrap; gap:8px; }
.catfilter a, .catfilter button { padding:9px 16px; border-radius:999px; border:1px solid var(--line-2); background:#fff; font-size:13.5px; font-weight:600; color:var(--ink-2); cursor:pointer; transition:all .15s; }
.catfilter a:hover, .catfilter button:hover { border-color:var(--navy); color:var(--navy); }
.catfilter a.on, .catfilter button.on { background:var(--navy); color:#fff; border-color:var(--navy); }

/* ============================================================ Legal doc */
.legal { max-width:840px; }
.legal h2 { font-size:19px; color:var(--navy); margin:30px 0 12px; }
.legal h2:first-child { margin-top:0; }
.legal p, .legal li { font-size:14.5px; color:var(--ink-2); line-height:1.8; }
.legal ul { margin:10px 0 10px 6px; }
.legal li { padding:3px 0 3px 18px; position:relative; }
.legal li::before { content:""; position:absolute; left:2px; top:13px; width:5px; height:5px; border-radius:50%; background:var(--gold); }
.legal .updated { font-size:13px; color:var(--muted); font-family:var(--mono); margin-bottom:24px; }
.legal table { width:100%; border-collapse:collapse; margin:12px 0; }
.legal th, .legal td { border:1px solid var(--line); padding:11px 13px; font-size:13.5px; text-align:left; color:var(--ink-2); }
.legal th { background:var(--bg-soft); color:var(--navy); font-weight:700; }

/* ============================================================ Sitemap */
.sitemap-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:900px){ .sitemap-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .sitemap-grid { grid-template-columns:1fr; } }
.smcol { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:24px 22px; }
.smcol > b { display:flex; align-items:center; gap:9px; font-size:15.5px; color:var(--navy); padding-bottom:12px; margin-bottom:10px; border-bottom:2px solid var(--navy); }
.smcol > b [data-lucide]{ width:17px;height:17px; color:var(--gold); }
.smcol a { display:block; padding:7px 0; font-size:14px; color:var(--ink-2); transition:color .14s, padding .14s; }
.smcol a:hover { color:var(--navy); padding-left:5px; }

/* ============================================================ 404 */
.nf { min-height:62vh; display:grid; place-items:center; text-align:center; padding:60px 20px; }
.nf .big { font-size:clamp(80px,16vw,160px); font-weight:800; color:var(--navy); letter-spacing:-0.05em; line-height:1; font-family:var(--mono); }
.nf h1 { font-size:clamp(22px,3vw,30px); color:var(--navy); margin-top:16px; }
.nf p { color:var(--muted); margin-top:12px; max-width:46ch; }
.nf .btns { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:28px; }

/* ============================================================ Portal — unified search */
.searchbig { background:#fff; border:2px solid var(--navy); border-radius:var(--r-lg); display:flex; align-items:stretch; box-shadow:var(--shadow-md); overflow:hidden; }
.searchbig .cat { border:0; border-right:1px solid var(--line); background:var(--bg-soft); padding:0 16px; font-size:14.5px; font-weight:600; color:var(--navy); font-family:var(--sans); cursor:pointer; outline:none; }
.searchbig input { flex:1; border:0; outline:0; padding:16px 18px; font-size:16px; font-family:var(--sans); min-width:0; }
.searchbig button { border:0; background:var(--navy); color:#fff; padding:0 26px; font-size:16px; font-weight:700; cursor:pointer; display:flex; align-items:center; gap:8px; transition:background .15s; }
.searchbig button:hover { background:var(--navy-2); }
.searchbig button [data-lucide]{ width:19px;height:19px; }
@media (max-width:560px){ .searchbig .cat { display:none; } .searchbig button span.t{ display:none; } .searchbig button{ padding:0 18px; } }
.pop-kw { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:14px; }
.pop-kw .lbl { font-size:12.5px; color:var(--on-navy-soft); font-weight:600; }
.pop-kw a { font-size:13px; color:var(--on-navy-mid); padding:4px 11px; border:1px solid var(--on-navy-line); border-radius:999px; transition:all .15s; }
.pop-kw a:hover { color:#fff; border-color:#fff; }
.pop-kw.on-light .lbl { color:var(--muted); }
.pop-kw.on-light a { color:var(--ink-2); border-color:var(--line-2); }
.pop-kw.on-light a:hover { color:var(--navy); border-color:var(--navy); }

/* connected agencies strip */
.src-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
@media (max-width:880px){ .src-grid { grid-template-columns:repeat(2,1fr); } }
.src-card { display:flex; align-items:center; gap:12px; padding:16px 16px; border:1px solid var(--line); border-radius:var(--r); background:#fff; transition:all .16s; }
.src-card:hover { border-color:var(--navy); box-shadow:var(--shadow); transform:translateY(-2px); }
.src-card .badge { width:42px;height:42px;border-radius:10px; display:grid;place-items:center; color:#fff; font-weight:800; font-size:12px; flex-shrink:0; letter-spacing:-0.03em; }
.src-card .tx b { font-size:14px; color:var(--navy); display:block; }
.src-card .tx span { font-size:11.5px; color:var(--muted); display:inline-flex; align-items:center; gap:4px; }
.src-card .tx span [data-lucide]{ width:11px;height:11px; }

/* hub layout */
.hub-layout { display:grid; grid-template-columns:260px 1fr 280px; gap:22px; align-items:start; }
@media (max-width:1140px){ .hub-layout { grid-template-columns:240px 1fr; } .hub-aside { display:none; } }
@media (max-width:820px){ .hub-layout { grid-template-columns:1fr; } .hub-filters { position:static !important; } }
.hub-filters { position:sticky; top:calc(var(--nav-h) + 14px); }
.hub-aside { position:sticky; top:calc(var(--nav-h) + 14px); display:grid; gap:16px; }

/* announcement list */
.hub-bar { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.hub-bar .cnt { font-size:14px; color:var(--muted); } .hub-bar .cnt b { color:var(--navy); }
.hub-bar select { border:1px solid var(--line-2); border-radius:var(--r); padding:9px 12px; font-size:13.5px; font-family:var(--sans); color:var(--ink); background:#fff; }
.ann-list { display:grid; gap:10px; }
.ann-row { display:flex; gap:14px; align-items:center; padding:18px 20px; border:1px solid var(--line); border-radius:var(--r-lg); background:#fff; transition:border-color .15s, box-shadow .15s; }
.ann-row:hover { border-color:var(--line-2); box-shadow:var(--shadow); }
.ann-row .main { flex:1; min-width:0; }
.ann-row .toprow { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.src-badge { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; color:var(--navy); background:var(--bg-soft); border:1px solid var(--line); padding:3px 9px; border-radius:6px; }
.src-badge .dot { width:7px;height:7px;border-radius:50%; }
.cat-tag { font-size:11.5px; font-weight:600; color:var(--green); background:var(--green-soft); padding:3px 9px; border-radius:6px; }
.ann-row h3 { font-size:16px; color:var(--navy); margin-top:9px; line-height:1.4; font-weight:700; }
.ann-row .meta { display:flex; flex-wrap:wrap; gap:6px 16px; margin-top:9px; font-size:12.5px; color:var(--muted); }
.ann-row .meta span { display:inline-flex; align-items:center; gap:5px; }
.ann-row .meta [data-lucide]{ width:13px;height:13px; color:var(--faint); }
.ann-row .side { display:flex; flex-direction:column; align-items:flex-end; gap:10px; flex-shrink:0; }
.dday { font-family:var(--mono); font-size:13px; font-weight:700; padding:6px 12px; border-radius:999px; white-space:nowrap; }
.dday.soon { background:#fbe9e1; color:#b9533a; }
.dday.open { background:var(--green-soft); color:var(--green); }
.dday.always { background:var(--bg-soft-2); color:var(--muted); }
.ann-row .side a.src-link { font-size:12.5px; font-weight:600; color:var(--navy); display:inline-flex; align-items:center; gap:5px; white-space:nowrap; }
.ann-row .side a.src-link [data-lucide]{ width:13px;height:13px; }
.ann-row .side a.src-link:hover { color:var(--navy-2); text-decoration:underline; }
@media (max-width:600px){ .ann-row { flex-direction:column; align-items:stretch; } .ann-row .side { flex-direction:row; align-items:center; justify-content:space-between; } }

/* widgets */
.widget { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:20px 20px; }
.widget h4 { font-size:14.5px; color:var(--navy); display:flex; align-items:center; gap:8px; padding-bottom:12px; margin-bottom:6px; border-bottom:2px solid var(--navy); }
.widget h4 [data-lucide]{ width:16px;height:16px; color:var(--gold); }
.widget .wrow { display:flex; gap:10px; align-items:flex-start; padding:10px 0; border-top:1px solid var(--line); }
.widget .wrow:first-of-type { border-top:0; }
.widget .wrow .rank { font-family:var(--mono); font-size:13px; font-weight:800; color:var(--gold); width:16px; flex-shrink:0; }
.widget .wrow a { font-size:13px; color:var(--ink-2); line-height:1.45; transition:color .14s; }
.widget .wrow a:hover { color:var(--navy); }
.widget .wrow .dd { font-size:11px; color:var(--faint); font-family:var(--mono); margin-top:3px; display:block; }
.live-dot { width:8px;height:8px;border-radius:50%; background:var(--green-2); box-shadow:0 0 0 3px var(--green-soft); display:inline-block; }

/* 2026 support-program calendar */
.cal-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:24px; }
@media (max-width:680px){ .cal-grid { grid-template-columns:1fr; } }
.cal-q { border:1px solid var(--line); border-radius:var(--r-lg); padding:18px 18px 8px; background:#fff; }
.cal-qh { display:inline-block; font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.04em; color:var(--green); background:var(--green-soft); padding:5px 11px; border-radius:999px; margin-bottom:12px; }
.cal-item { display:flex; flex-direction:column; gap:2px; padding:11px 0; border-top:1px solid var(--line); }
.cal-item:first-of-type { border-top:0; }
.cal-item b { font-size:14.5px; color:var(--navy); font-weight:700; }
.cal-item span { font-size:12.5px; color:var(--muted); }

/* ============================================================
   PREMIUM MOTION LAYER  ·  entrance, hover micro-interactions, mobile
   ============================================================ */
@media (prefers-reduced-motion: no-preference){

  /* --- Hero & inner page-hero: staggered load-in --- */
  .hero-inner > *,
  .page-hero .inner > * {
    animation: ckpRise .9s var(--ease) backwards;
  }
  .hero-inner > *:nth-child(1), .page-hero .inner > *:nth-child(1) { animation-delay: .06s; }
  .hero-inner > *:nth-child(2), .page-hero .inner > *:nth-child(2) { animation-delay: .15s; }
  .hero-inner > *:nth-child(3), .page-hero .inner > *:nth-child(3) { animation-delay: .24s; }
  .hero-inner > *:nth-child(4), .page-hero .inner > *:nth-child(4) { animation-delay: .33s; }
  .hero-inner > *:nth-child(5), .page-hero .inner > *:nth-child(5) { animation-delay: .42s; }

  /* hero ambient drift */
  .hero-glow { animation: ckpGlow 12s ease-in-out infinite alternate; }
  .cta-band::after { animation: ckpGlow 11s ease-in-out infinite alternate; }

  /* live pulse */
  .pill .dot, .live-dot { animation: ckpPulse 2.4s ease-in-out infinite; }

  /* nav chrome eases in once */
  .utilbar, .nav { animation: ckpFade .6s ease backwards; }
  .nav { animation-delay: .08s; }
}

@keyframes ckpRise  { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:none; } }
@keyframes ckpFade  { from { opacity:0; } to { opacity:1; } }
@keyframes ckpGlow  { from { transform:translate(0,0) scale(1); opacity:.85; } to { transform:translate(-26px,20px) scale(1.12); opacity:1; } }
@keyframes ckpPulse { 0%,100% { box-shadow:0 0 0 0 rgba(214,110,84,0.28); } 50% { box-shadow:0 0 0 7px rgba(214,110,84,0); } }
@keyframes ckpSheen { to { transform:translateX(220%) skewX(-18deg); } }

/* --- Refined easing on existing transitions for a smoother, costlier feel --- */
.btn, .svc-card, .info-card, .post, .fcard, .qcta, .src-card, .mrow, .ann-row,
.diag-promo, .mfind, .smcol, .nav-item > a, .dropdown a, .related a, .mchip,
.chip-opt, .catfilter a, .catfilter button { transition-timing-function: var(--ease); }

.svc-card, .info-card, .post, .fcard, .qcta, .src-card { transition-duration: .32s; }

/* --- Deeper, premium hover lift on key cards --- */
.svc-card:hover, .info-card:hover, .post:hover, .fcard:hover { box-shadow: var(--shadow-lift); }

/* --- Button sheen sweep --- */
.btn { position: relative; overflow: hidden; }
.btn::after {
  content:""; position:absolute; top:0; left:0; width:40%; height:100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.35), transparent);
  transform: translateX(-160%) skewX(-18deg); pointer-events:none;
}
.btn-navy:hover::after, .btn-gold:hover::after, .btn-green:hover::after { animation: ckpSheen .8s var(--ease-out); }
.btn .ic, .btn [data-lucide] { position:relative; transition: transform .28s var(--ease); }
.btn:hover [data-lucide="arrow-right"] { transform: translateX(3px); }

/* --- Service icon: gentle pop --- */
.svc-card:hover .svc-ic { transform: translateY(-2px) scale(1.04); }
.svc-ic { transition: background .28s var(--ease), color .28s var(--ease), transform .28s var(--ease); }

/* --- Thumbnails / map zoom subtly on hover --- */
.post .thumb, .info-card .ic-top { transition: transform .5s var(--ease); }
.post:hover .thumb { transform: scale(1.04); }
.thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.ph img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:inherit; display:block; }
/* hero illustration (right side of page-hero) */
.page-hero { position: relative; }
.hero-art { position:absolute; right:max(16px,3vw); top:50%; transform:translateY(-50%); width:clamp(210px,29vw,360px); border-radius:18px; box-shadow:0 18px 50px rgba(8,26,52,.38); z-index:2; }
.page-hero:has(.hero-art) .wrap { padding-right: clamp(250px,35vw,400px); }
@media (max-width:920px){ .hero-art{ display:none; } .page-hero:has(.hero-art) .wrap{ padding-right:18px; } }
.post { overflow: hidden; }

/* --- Source / agency badges: nudge --- */
a.src-badge { transition: transform .2s var(--ease), border-color .2s, box-shadow .2s; }
a.src-badge:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--line-2); }

/* --- Quick-CTA arrow hint --- */
.qcta .qic { transition: transform .3s var(--ease), background .2s; }
.qcta:hover .qic { transform: scale(1.06) rotate(-3deg); }

/* --- Announcement rows: accent slide --- */
.ann-row { position: relative; overflow: hidden; }
.ann-row::before { content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--gold); transform:scaleY(0); transform-origin:top; transition:transform .3s var(--ease); }
.ann-row:hover::before { transform: scaleY(1); }
.ann-row:hover { transform: translateY(-2px); }

/* --- Mobile menu slide-in --- */
.mobile-menu.open { animation: ckpFade .26s ease; }
.mobile-menu .mgrp { opacity: 0; animation: ckpRise .4s var(--ease) forwards; }
.mobile-menu.open .mgrp:nth-child(1){ animation-delay:.03s; }
.mobile-menu.open .mgrp:nth-child(2){ animation-delay:.06s; }
.mobile-menu.open .mgrp:nth-child(3){ animation-delay:.09s; }
.mobile-menu.open .mgrp:nth-child(4){ animation-delay:.12s; }
.mobile-menu.open .mgrp:nth-child(5){ animation-delay:.15s; }
.mobile-menu.open .mgrp:nth-child(n+6){ animation-delay:.18s; }

@media (prefers-reduced-motion: reduce){
  .hero-inner > *, .page-hero .inner > *, .hero-glow, .cta-band::after,
  .pill .dot, .live-dot, .utilbar, .nav, .mobile-menu .mgrp { animation: none !important; opacity: 1 !important; }
  .btn::after { display: none; }
}

/* ============================================================
   SMARTPHONE RESPONSIVE REFINEMENTS
   ============================================================ */
@media (max-width: 600px){
  .wrap { padding: 0 18px; }
  .section { padding: 46px 0; }

  /* tighter hero on phones */
  .hero { padding: 38px 0 34px; }
  .hero h1 { margin-top: 16px; }
  .hero .lede { margin-top: 16px; }
  .hero-quad { margin-top: 26px; gap: 10px; }
  .qcta { padding: 15px 15px; }

  /* generous tap targets */
  .btn { padding: 14px 22px; min-height: 48px; }
  .btn-lg { padding: 16px 26px; }
  .mfind-search input, .field input, .field select, .field textarea, .searchbig input { font-size: 16px; } /* avoid iOS zoom */

  /* full-width primary CTAs in stacked button rows */
  .cta-band .btns .btn, .page-hero .btns .btn { width: 100%; }

  /* card inner spacing */
  .svc-card { padding: 22px 20px; min-height: 0; }
  .diag-promo .dl, .diag-promo .dr { padding: 28px 22px; }

  /* sub-tabs & chips scroll comfortably */
  .subtabs-inner { padding: 8px 0; }

  /* footer stacks to single column for thumbs-reach */
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer { padding: 44px 0 90px; }
}

@media (max-width: 420px){
  .footer-top { grid-template-columns: 1fr; }
  .trust-cell { padding: 18px 14px; }
}

/* mobile fixed CTA: premium tap feedback */
.mfab a { transition: filter .15s var(--ease), transform .1s var(--ease); }
.mfab a:active { transform: scale(.96); filter: brightness(.95); }
.btn:active, .qcta:active, .svc-card:active { transform: translateY(0) scale(.985); }

/* diagnosis dark panel: flat navy, no glow/gradient behind the text */
.diag-promo .dl h2 { color: #fff; text-shadow: 0 1px 14px rgba(6,38,79,0.45); position: relative; }
.diag-promo .dl { background: var(--navy); }
.diag-promo .dl::before { display: none !important; }

/* ============================================================
   ★ CINEMATIC LAYER — "flagship" production value
   ============================================================ */

/* ---- cross-document View Transitions (premium page nav) ---- */
@view-transition { navigation: auto; }
::view-transition-old(root), ::view-transition-new(root) { animation-duration: .45s; animation-timing-function: var(--ease); }
.nav { view-transition-name: ckp-nav; }
.footer { view-transition-name: ckp-footer; }
.mfab { view-transition-name: ckp-mfab; }
@media (prefers-reduced-motion: reduce){ ::view-transition-group(*){ animation: none !important; } }

/* ---- film grain + vignette over everything (very subtle) ---- */
body::after {
  content:""; position:fixed; inset:0; z-index:9990; pointer-events:none; opacity:.04; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- scroll progress bar ---- */
.scroll-prog { position:fixed; top:0; left:0; height:3px; width:0; z-index:9995; background:var(--gold-grad); box-shadow:0 0 12px rgba(209,101,74,0.6); transition:width .12s linear; }

/* ---- nav: elevate + condense on scroll ---- */
.nav { transition: height .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; }
.nav.scrolled { height: 60px; background: rgba(255,255,255,0.82); box-shadow: 0 10px 30px -18px rgba(10,44,79,0.4); border-bottom-color: transparent; }
.nav.scrolled .brand-mark { transform: scale(.92); }
.brand-mark { transition: transform .3s var(--ease); }

/* =================== CINEMATIC HERO / DARK SURFACES =================== */
.hero, .page-hero, .cta-band, .diag-promo .dl, .sidebar-cta {
  background: var(--navy-deep);
  position: relative; isolation: isolate;
}
/* animated aurora mesh */
.hero::before, .page-hero::before, .cta-band::before, .diag-promo .dl::before, .sidebar-cta::before {
  content:""; position:absolute; inset:-30%; z-index:-2; pointer-events:none;
  background:
    radial-gradient(40% 50% at 18% 22%, rgba(59,79,214,0.55), transparent 60%),
    radial-gradient(36% 44% at 82% 18%, rgba(209,101,74,0.45), transparent 62%),
    radial-gradient(46% 52% at 68% 88%, rgba(17,154,142,0.42), transparent 60%),
    radial-gradient(40% 48% at 28% 92%, rgba(109,75,212,0.40), transparent 62%);
  background-color: var(--navy-deep);
  filter: blur(14px) saturate(125%);
  animation: ckpAurora 20s ease-in-out infinite alternate;
}
/* fine grid + pointer-reactive glow stay above mesh */
.hero-grid { z-index:-1; }
.hero-glow { z-index:-1; }
/* energy field canvas must be positioned regardless of motion preference
   (the rAF animation itself is gated; a still frame renders under reduced-motion) */
.energy-canvas { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.hero-inner, .page-hero .inner { position: relative; z-index: 2; }
/* site-wide ambient star/energy layer — fixed overlay, drifts with scroll */
.ambient-field { position: fixed; inset: 0; z-index: 70; pointer-events: none; }
@media print { .ambient-field, .energy-canvas { display: none; } }
@keyframes ckpAurora {
  0%   { transform: translate(0,0) rotate(0deg)   scale(1.05); }
  50%  { transform: translate(2%, -2%) rotate(8deg) scale(1.18); }
  100% { transform: translate(-2%, 1%) rotate(-6deg) scale(1.1); }
}
/* pointer parallax glow inside hero */
.hero-glow, .cta-band::after { will-change: transform; }
.hero[data-px] .hero-glow { transform: translate(calc((var(--px,.5) - .5) * -60px), calc((var(--py,.5) - .5) * -40px)); transition: transform .4s var(--ease); }

/* aurora gradient TEXT on the hero highlight + key headings */
.hero h1 .hl {
  background: var(--aurora-text); background-size: 220% 220%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: ckpTextFlow 9s ease infinite;
}
@keyframes ckpTextFlow { 0%,100%{ background-position:0% 50%; } 50%{ background-position:100% 50%; } }
@keyframes ckpAuroraStill { from{} to{} }

/* =================== PREMIUM BUTTONS =================== */
.btn-navy { background: var(--navy); box-shadow: 0 10px 26px -14px rgba(10,44,79,0.6); }
.btn-navy:hover { box-shadow: var(--glow-navy); }
.btn-gold { background: var(--gold); box-shadow: 0 10px 26px -14px rgba(209,101,74,0.55); }
.btn-gold:hover { box-shadow: var(--glow-gold); }
.btn-lg { letter-spacing: -0.005em; }

/* =================== GLASS + SPOTLIGHT CARDS =================== */
.svc-card, .info-card, .fcard, .post, .qcta, .src-card { position: relative; }
/* cursor-following spotlight */
.svc-card::after, .info-card::after, .fcard::after {
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:0; pointer-events:none; opacity:0;
  background: radial-gradient(220px circle at var(--mx,50%) var(--my,50%), rgba(47,120,196,0.14), transparent 60%);
  transition: opacity .3s var(--ease);
}
.svc-card:hover::after, .info-card:hover::after, .fcard:hover::after { opacity:1; }
.svc-card > *, .info-card > *, .fcard > * { position: relative; z-index:1; }

/* tilt setup (JS adds .tilt-on while interacting) */
.tilt { transform-style: preserve-3d; will-change: transform; }

/* =================== ANIMATED CONIC BORDER (featured) =================== */
.searchbig, .cta-band, .sidebar-cta, .diag-promo { position: relative; }
.searchbig::before {
  content:""; position:absolute; inset:-2px; border-radius:inherit; z-index:-1; padding:2px;
  background: conic-gradient(from var(--angle), var(--navy), var(--gold), var(--teal), var(--indigo), var(--navy));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: ckpAngle 6s linear infinite; opacity:.0; transition:opacity .3s;
}
.searchbig:focus-within::before { opacity:1; }
@keyframes ckpAngle { to { --angle: 360deg; } }

/* =================== MARQUEE (agency strip) =================== */
.marquee { overflow:hidden; position:relative; -webkit-mask:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.mq-track { display:flex; gap:10px; width:max-content; animation: ckpMarquee 32s linear infinite; }
.marquee:hover .mq-track { animation-play-state: paused; }
@keyframes ckpMarquee { to { transform: translateX(-50%); } }

/* =================== RICHER REVEAL VARIANTS =================== */
.reveal.r-blur { filter: blur(10px); }
.reveal.r-blur.in { filter: blur(0); }
.reveal.r-clip { clip-path: inset(0 0 100% 0); transform:none; opacity:1; transition: clip-path .9s var(--ease); }
.reveal.r-clip.in { clip-path: inset(0 0 0 0); }
.reveal { transition: opacity .8s var(--ease), transform .8s var(--ease), filter .8s var(--ease); }

@media (prefers-reduced-motion: reduce){
  body::after, .scroll-prog { display:none; }
  .hero::before, .page-hero::before, .cta-band::before, .diag-promo .dl::before, .sidebar-cta::before,
  .hero h1 .hl, .searchbig::before, .mq-track { animation: none !important; }
  .hero h1 .hl { background: none; color: var(--gold-2); -webkit-text-fill-color: initial; }
}

/* touch / coarse pointer: drop hover-only flourishes that can stick */
@media (hover: none){
  .svc-card::after, .info-card::after, .fcard::after { display:none; }
}

@media (max-width: 600px){
  .hero::before, .page-hero::before { inset:-15%; filter: blur(10px) saturate(120%); }
  .scroll-prog { height:2px; }
}

/* ============================================================
   ★★ LUMINOUS LAYER — everything glows, pulses & flows
   ============================================================ */
@media (prefers-reduced-motion: no-preference){

  /* ---------- 1. GLOWING STATUS LIGHTS (신호등) ---------- */
  /* every colored status dot emits and breathes light */
  .dot, .live-dot {
    animation: ckpBeacon 2.4s ease-in-out infinite;
    border-radius: 50%;
  }
  /* sequential "running lights" stagger inside rows */
  .mq-track .src-badge:nth-child(2n) .dot { animation-delay: .35s; }
  .mq-track .src-badge:nth-child(3n) .dot { animation-delay: .7s; }
  .mq-track .src-badge:nth-child(4n) .dot { animation-delay: 1.05s; }
  .ann-list .ann-row:nth-child(2) .dot { animation-delay: .3s; }
  .ann-list .ann-row:nth-child(3) .dot { animation-delay: .6s; }
  .ann-list .ann-row:nth-child(4) .dot { animation-delay: .9s; }
  .src-grid .src-card:nth-child(2n) .badge { animation: ckpBeacon 2.8s ease-in-out infinite .3s; }

  @keyframes ckpBeacon {
    0%, 100% { filter: brightness(1) saturate(1); box-shadow: 0 0 3px 0 rgba(255,255,255,.25); transform: scale(1); }
    50%      { filter: brightness(1.55) saturate(1.5); box-shadow: 0 0 11px 2px rgba(255,255,255,.65); transform: scale(1.25); }
  }

  /* D-day pills pulse in their own state color (traffic-light) */
  .dday.soon  { animation: ckpPulseRed 1.5s ease-in-out infinite; }
  .dday.open  { animation: ckpPulseGreen 2.4s ease-in-out infinite; }
  @keyframes ckpPulseRed   { 0%,100%{ box-shadow:0 0 0 0 rgba(185,83,58,0); } 50%{ box-shadow:0 0 16px 1px rgba(185,83,58,.6); } }
  @keyframes ckpPulseGreen { 0%,100%{ box-shadow:0 0 0 0 rgba(28,107,84,0); } 50%{ box-shadow:0 0 14px 1px rgba(28,107,84,.45); } }

  /* live ticker dot ring + glow */
  .live-dot { box-shadow: 0 0 0 3px var(--green-soft), 0 0 10px 1px var(--green-2); }

  /* ---------- 2. SHINING (solid colour + soft breathing glow, no gradient) ---------- */
  .btn-navy {
    background: var(--navy);
    animation: ckpHaloNavy 3.6s ease-in-out infinite;
  }
  .btn-gold {
    background: var(--gold);
    animation: ckpHaloGold 3.4s ease-in-out infinite;
  }
  .btn-green {
    background: var(--green);
  }
  @keyframes ckpGradFlow { to { background-position: 240% 50%; } }
  @keyframes ckpHaloNavy { 0%,100%{ box-shadow:0 8px 22px -14px rgba(10,44,79,.6); } 50%{ box-shadow:0 12px 34px -12px rgba(47,120,196,.7); } }
  @keyframes ckpHaloGold { 0%,100%{ box-shadow:0 8px 22px -14px rgba(209,101,74,.55); } 50%{ box-shadow:0 12px 34px -12px rgba(231,137,109,.7); } }

  /* eyebrow accent rule shimmers */
  .eyebrow::before {
    background: linear-gradient(90deg, #d1654a, #f0c987, #d1654a);
    background-size: 200% 100%;
    animation: ckpGradFlow 3.2s linear infinite;
  }
  /* brand emblem: spark pulses, bars breathe */
  .lg-spark { transform-box: fill-box; transform-origin: center; animation: lgSpark 2.6s ease-in-out infinite; }
  @keyframes lgSpark { 0%,100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.4); opacity: .7; } }
  .lg-bar { transform-box: fill-box; transform-origin: bottom; animation: lgRise .7s var(--ease-spring) backwards; }
  .lg-b1 { animation-delay: .05s; } .lg-b2 { animation-delay: .15s; } .lg-b3 { animation-delay: .25s; }
  @keyframes lgRise { from { transform: scaleY(0); } }
  .lg-arc { stroke-dasharray: 44; animation: lgDraw 1s var(--ease) .3s backwards; }
  @keyframes lgDraw { from { stroke-dashoffset: 44; } to { stroke-dashoffset: 0; } }
  .brand:hover .lg-spark { animation-duration: 1s; }

  /* ---------- 3. MOVING / BREATHING HIGHLIGHTS ---------- */
  /* gradient text headline flows + a roaming specular highlight scales in dark bands */
  .cta-band h2 {
    background: linear-gradient(100deg, #ffffff, #ffe3b0 45%, #ffffff 70%, #ffd9a0);
    background-size: 220% 220%;
    -webkit-background-clip: text; background-clip: text; color: transparent;
    animation: ckpTextFlow 7s ease infinite;
  }
  /* roaming highlight orb that grows, shrinks & travels across dark surfaces */
  .cta-band::after {
    animation: ckpRoam 14s ease-in-out infinite;
  }
  @keyframes ckpRoam {
    0%   { transform: translate(0,0) scale(1);    opacity:.85; }
    25%  { transform: translate(-160px,40px) scale(1.5); opacity:1; }
    50%  { transform: translate(-60px,120px) scale(.8); opacity:.7; }
    75%  { transform: translate(-200px,20px) scale(1.3); opacity:1; }
    100% { transform: translate(0,0) scale(1);    opacity:.85; }
  }

  /* pill badge glows + breathes */
  .pill { animation: ckpPillGlow 3.4s ease-in-out infinite; }
  @keyframes ckpPillGlow {
    0%,100%{ box-shadow:0 0 0 0 rgba(214,110,84,0); border-color:var(--on-navy-line); }
    50%    { box-shadow:0 0 20px -2px rgba(214,110,84,.45); border-color:rgba(231,137,109,.5); }
  }

  /* category/green tags get a soft luminous wash */
  .cat-tag, .tag-green { animation: ckpTagGlow 3s ease-in-out infinite; }
  @keyframes ckpTagGlow { 0%,100%{ filter:brightness(1); } 50%{ filter:brightness(1.12); } }

  /* service icon tiles emit a faint inner light */
  .qcta .qic { animation: ckpIcGlow 3.2s ease-in-out infinite; }
  @keyframes ckpIcGlow { 0%,100%{ box-shadow:0 0 0 0 rgba(209,101,74,0); } 50%{ box-shadow:0 0 18px -2px rgba(231,137,109,.7); } }

  /* hero highlight orb roams as well */
  .hero-glow { animation: ckpRoam 16s ease-in-out infinite, ckpGlow 12s ease-in-out infinite alternate; }
}

@media (prefers-reduced-motion: reduce){
  .dot, .live-dot, .dday, .btn-navy, .btn-gold, .btn-green, .eyebrow::before, .brand-mark::after,
  .cta-band h2, .cta-band::after, .sidebar-cta::after, .pill, .cat-tag, .tag-green, .qcta .qic {
    animation: none !important;
  }
  .cta-band h2 { background: none; color: #fff; -webkit-text-fill-color: initial; }
}

/* ============================================================
   ★★★ LIVING LAYER — ambient, organic, never-still
   ============================================================ */
@media (prefers-reduced-motion: no-preference){

  /* ---------- floating cards: gentle organic undulation ----------
     uses the independent `translate` property so it composes cleanly
     with reveal (transform) and 3D tilt (inline transform). */
  .svc-grid > *, .info-grid > *, .hero-quad > *, .three > *, .list-grid > *,
  .mfind, .diag-promo, .src-grid > * {
    animation: ckpFloat 6.5s ease-in-out infinite;
  }
  .svc-grid > :nth-child(2n), .info-grid > :nth-child(2n), .hero-quad > :nth-child(2n),
  .three > :nth-child(2n), .list-grid > :nth-child(2n), .src-grid > :nth-child(2n) {
    animation-duration: 7.6s; animation-delay: -1.7s;
  }
  .svc-grid > :nth-child(3n), .info-grid > :nth-child(3n), .hero-quad > :nth-child(3n),
  .three > :nth-child(3n), .list-grid > :nth-child(3n), .src-grid > :nth-child(3n) {
    animation-duration: 5.6s; animation-delay: -3.2s;
  }
  .svc-grid > :nth-child(4n), .info-grid > :nth-child(4n), .hero-quad > :nth-child(4n) {
    animation-duration: 8.2s; animation-delay: -2.4s;
  }
  @keyframes ckpFloat { 0%,100% { translate: 0 0; } 50% { translate: 0 -7px; } }

  /* service & quick icons softly bob and tilt — "breathing" */
  .svc-ic { animation: ckpIcoLife 5s ease-in-out infinite; }
  .svc-card:nth-child(2n) .svc-ic { animation-delay: -1.6s; }
  .svc-card:nth-child(3n) .svc-ic { animation-delay: -2.8s; }
  @keyframes ckpIcoLife { 0%,100%{ transform: translateY(0) rotate(0); } 50%{ transform: translateY(-3px) rotate(-3deg); } }

  /* ---------- living hero backdrop ---------- */
  .hero-grid { animation: ckpGridPan 36s linear infinite; }
  @keyframes ckpGridPan { from { background-position: 0 0; } to { background-position: 56px 56px; } }

  @keyframes ckpDrift {
    0%   { transform: translate(0,0) scale(1); }
    33%  { transform: translate(80px,40px) scale(1.15); }
    66%  { transform: translate(30px,-50px) scale(.9); }
    100% { transform: translate(0,0) scale(1); }
  }

  /* ---------- map comes alive ---------- */
  .map-pin { animation: ckpBob 3.2s ease-in-out infinite; }
  .map-pin:nth-child(odd) { animation-delay: -1.3s; }
  .map-pin.green { animation-delay: -2.1s; }
  @keyframes ckpBob { 0%,100%{ transform: translate(-50%,-100%); } 50%{ transform: translate(-50%,-112%); } }
  .map-cluster { animation: ckpClusterPulse 2.6s ease-in-out infinite; }
  @keyframes ckpClusterPulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(209,101,74,.35), var(--shadow); }
    50%     { box-shadow: 0 0 0 12px rgba(209,101,74,0), var(--shadow); }
  }

  /* ---------- nav active underline pulses width ---------- */
  .nav-item.active::after { animation: ckpUnderline 3s ease-in-out infinite; }
  @keyframes ckpUnderline { 0%,100%{ opacity:.7; } 50%{ opacity:1; } }

  /* ---------- periodic shine sweep across section headings ---------- */
  .sec-head h2, .block h2 { position: relative; }

  /* parallax layers get smoothing (JS drives the offset) */
  [data-parallax] { will-change: transform; }
}

@media (prefers-reduced-motion: reduce){
  .svc-grid > *, .info-grid > *, .hero-quad > *, .three > *, .list-grid > *, .mfind, .diag-promo, .src-grid > *,
  .svc-ic, .hero-grid, .map-pin, .map-cluster, .nav-item.active::after {
    animation: none !important;
  }
}
/* phones: calm the floats a touch (battery + readability) */
@media (max-width: 600px){
  .svc-grid > *, .info-grid > *, .hero-quad > *, .three > *, .list-grid > *, .src-grid > * { animation-duration: 8s; }
}

/* ============================================================
   ★★★★ EXTRA AMBIENT — even more life, everywhere
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  /* trust strip numbers softly glow */
  .trust-cell b { animation: ckpValueGlow 3.4s ease-in-out infinite; }
  .trust-cell:nth-child(2) b { animation-delay: -0.8s; }
  .trust-cell:nth-child(3) b { animation-delay: -1.6s; }
  .trust-cell:nth-child(4) b { animation-delay: -2.4s; }
  @keyframes ckpValueGlow { 0%,100%{ text-shadow: 0 0 0 rgba(231,137,109,0); } 50%{ text-shadow: 0 0 18px rgba(231,137,109,.5); } }

  /* step-number badges pulse a ring */
  .dstep .n, .pstep .n { position: relative; }
  .dstep .n::after, .pstep .n::after {
    content:""; position:absolute; inset:0; border-radius:inherit; animation: ckpRing 2.6s ease-out infinite;
  }
  .pstep:nth-child(2) .n::after { animation-delay: -.8s; }
  .pstep:nth-child(3) .n::after { animation-delay: -1.6s; }
  @keyframes ckpRing { 0%{ box-shadow:0 0 0 0 rgba(10,61,124,.4); } 70%,100%{ box-shadow:0 0 0 12px rgba(10,61,124,0); } }

  /* dropdown icons nudge continuously, settle on hover */
  .dropdown a [data-lucide] { transition: transform .2s var(--ease); }
  .dropdown a:hover [data-lucide] { transform: translateX(3px) scale(1.1); }

  /* footer links slide a hair on hover */
  .footer-links a { transition: color .15s, transform .18s var(--ease), padding-left .18s var(--ease); }
  .footer-links a:hover { transform: translateX(3px); padding-left: 4px; }

  /* widget heading icons & section eyebrow icons gently pulse */
  .widget h4 [data-lucide], .smcol > b [data-lucide] { animation: ckpIcoSpin 4s ease-in-out infinite; }
  @keyframes ckpIcoSpin { 0%,100%{ transform: scale(1) rotate(0); } 50%{ transform: scale(1.12) rotate(6deg); } }

  /* hero pill floats */
  .hero .pill { animation: ckpPillGlow 3.4s ease-in-out infinite, ckpFloat 5.5s ease-in-out infinite; }

  /* mobile fab icons bob */
  .mfab a [data-lucide] { animation: ckpBob2 2.8s ease-in-out infinite; }
  .mfab a:nth-child(2) [data-lucide] { animation-delay: -.9s; }
  .mfab a:nth-child(3) [data-lucide] { animation-delay: -1.8s; }
  @keyframes ckpBob2 { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-3px); } }

  /* section headings: slow shine sweep */
  .sec-head h2 { position: relative; overflow: hidden; }
  .sec-head h2::after {
    content:""; position:absolute; top:0; left:-60%; width:40%; height:100%;
    background: linear-gradient(100deg, transparent, rgba(255,255,255,.45), transparent);
    transform: skewX(-18deg); animation: ckpHeadShine 6.5s ease-in-out infinite; pointer-events:none;
  }
  @keyframes ckpHeadShine { 0%,70%{ left:-60%; } 100%{ left:130%; } }
}
@media (prefers-reduced-motion: reduce){
  .trust-cell b, .dstep .n::after, .pstep .n::after, .widget h4 [data-lucide], .smcol > b [data-lucide],
  .hero .pill, .mfab a [data-lucide], .sec-head h2::after { animation: none !important; }
  .sec-head h2::after { display: none; }
}

/* ckp footer-brand shine + wider PC nav wordmark (20260612j) */
.footer-brand .brand-text b{
  background:linear-gradient(100deg,#ffffff 0%,#ffffff 38%,#f3d27a 50%,#ffffff 62%,#ffffff 100%);
  background-size:230% 100%;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  animation:ckpFooterShine 6s linear infinite;
}
@keyframes ckpFooterShine{ from{ background-position:165% 0; } to{ background-position:-165% 0; } }
.footer-brand .brand-text span{ color:#d8b24a; opacity:.92; }
.footer-brand .brand-text::after{ display:none; }
.brand-br{ display:inline; }
.footer-brand .brand-br{ display:none; }
.brand .brand-text b{ white-space:nowrap; }
.nav .brand{ flex:none; }
/* PC: 상단 메뉴 영역을 넓혀 로고를 한 줄로 다 보이게 */
@media (min-width:1300px){
  .utilbar .wrap, header.nav .wrap{ max-width:1500px; padding-left:18px; padding-right:18px; }
  .nav .brand-br{ display:none; }
}
@media (prefers-reduced-motion: reduce){
  .footer-brand .brand-text b{ -webkit-text-fill-color:#fff; color:#fff; background:none; animation:none; }
}
