/* =========================================================================
   CADAL — Monochrome Luxury Design System
   ========================================================================= */

/* ---------- Tokens ---------- */
:root {
  /* Ink scale (warm-cool neutral, almost true greyscale) */
  --ink-1000: #050505;
  --ink-950:  #0a0a0a;
  --ink-925:  #0e0e0e;
  --ink-900:  #111111;
  --ink-850:  #161616;
  --ink-800:  #1a1a1a;
  --ink-750:  #232323;
  --ink-700:  #2a2a2a;
  --ink-600:  #3a3a3a;
  --ink-500:  #555555;
  --ink-400:  #6e6e6e;
  --ink-300:  #8e8e8e;
  --ink-250:  #a8a8a8;
  --ink-200:  #c4c4c4;
  --ink-150:  #d4d4d4;
  --ink-100:  #e3e3e3;
  --ink-75:   #ededed;
  --ink-50:   #f5f5f5;
  --ink-25:   #fafafa;
  --white:    #ffffff;

  /* Brand */
  --brand-bg: var(--ink-950);
  --brand-fg: var(--white);

  /* Accent — chrome / silver gradients */
  --chrome-light: linear-gradient(180deg,#fdfdfd 0%,#e6e6e6 35%,#bcbcbc 60%,#7a7a7a 100%);
  --chrome-dark:  linear-gradient(180deg,#3a3a3a 0%,#1a1a1a 50%,#0a0a0a 100%);
  --chrome-btn:   linear-gradient(180deg,#fafafa 0%,#dcdcdc 50%,#9a9a9a 100%);
  --chrome-btn-hover: linear-gradient(180deg,#ffffff 0%,#e8e8e8 50%,#a8a8a8 100%);
  --chrome-edge: linear-gradient(90deg,transparent,#666 20%,#fff 50%,#666 80%,transparent);

  /* Shadows — almost invisible, just hint depth */
  --shadow-1: 0 1px 2px rgba(0,0,0,.04), 0 0 0 1px rgba(0,0,0,.03);
  --shadow-2: 0 8px 24px rgba(0,0,0,.05);
  --shadow-3: 0 24px 60px rgba(0,0,0,.08);
  --shadow-dark: 0 24px 60px rgba(0,0,0,.45);

  /* Type */
  --font-kr: "Pretendard Variable","Pretendard","Apple SD Gothic Neo","Noto Sans KR",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --font-en: "Inter","Pretendard Variable",system-ui,-apple-system,sans-serif;
  --font-display: "Space Grotesk","Inter",var(--font-kr);

  /* Layout */
  --container: 1200px;
  --container-narrow: 980px;
  --header-h: 64px;
  --ticker-h: 0px;
  --gutter: clamp(16px, 2.6vw, 24px);

  /* Motion */
  --ease: cubic-bezier(.65,0,.35,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --t-fast: .18s;
  --t-base: .32s;
  --t-slow: .6s;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-kr);
  font-weight: 400;
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--ink-900);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  word-break: keep-all;
  overflow-wrap: break-word;
  letter-spacing: -.005em;
}
img,svg,video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; transition: color var(--t-fast) var(--ease); }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; padding: 0; }
input,select,textarea { font: inherit; color: inherit; }
ul,ol { list-style: none; padding: 0; margin: 0; }
h1,h2,h3,h4,h5,h6 { margin: 0; font-weight: 700; letter-spacing: -.022em; line-height: 1.2; }
p { margin: 0; }
hr { border: 0; border-top: 1px solid var(--ink-100); margin: 0; }
::selection { background: var(--ink-900); color: var(--white); }

.cdl-body { padding-top: var(--header-h); padding-bottom: 96px; }
.cdl-main { display: block; }

/* Lucide icons placeholder before script-replace (prevents FOUC layout shift) */
[data-lucide] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  flex: 0 0 auto;
}
[data-lucide] svg { display: block; }
.lucide { display: inline-block; vertical-align: middle; flex: 0 0 auto; }
.cdl-container {
  width: 100%;
  max-width: var(--container);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

/* ---------- Typography helpers ---------- */
.cdl-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-en);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-500);
}
.cdl-eyebrow::before {
  content: "";
  width: 22px;
  height: 1px;
  background: currentColor;
  opacity: .55;
}
.cdl-eyebrow--light { color: var(--ink-200); }

.cdl-section { padding: clamp(56px, 7vw, 112px) 0; position: relative; }
.cdl-section--dark { background: var(--ink-950); color: var(--white); }
.cdl-section--soft { background: var(--ink-25); }

.cdl-section__head { max-width: 760px; margin: 0 0 56px; }
.cdl-section__head--center { margin-left: auto; margin-right: auto; text-align: center; }
.cdl-section__head--center .cdl-eyebrow::before { display: none; }
.cdl-section__head--center .cdl-eyebrow { padding: 0; }

.cdl-section__title {
  margin-top: 12px;
  font-family: var(--font-kr);
  font-size: clamp(24px, 3.4vw, 40px);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -.028em;
  color: var(--ink-1000);
}
.cdl-section__title--light { color: var(--white); }
.cdl-em {
  background: var(--chrome-btn);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
/* On light sections, drop the gradient (was washing out) and use solid black + a soft accent bar */
.cdl-section:not(.cdl-section--dark) .cdl-em,
.cdl-lead .cdl-em,
.cdl-process .cdl-em,
.cdl-contact .cdl-em {
  background: none;
  -webkit-background-clip: initial;
  background-clip: initial;
  color: var(--ink-1000);
  position: relative;
  display: inline-block;
  padding: 0 .08em;
  z-index: 0;
}
.cdl-section:not(.cdl-section--dark):not(.cdl-lead) .cdl-em::after,
.cdl-process .cdl-em::after,
.cdl-contact .cdl-em::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: .04em;
  height: .35em;
  background: var(--ink-1000);
  opacity: .08;
  border-radius: 3px;
  z-index: -1;
}

/* Lead "매입가" — slow draw-in underline with semi-transparent red */
.cdl-lead .cdl-em {
  padding: 0 .12em;
}
.cdl-lead .cdl-em::after {
  content: "";
  position: absolute;
  left: 2%; right: 2%;
  bottom: -.05em;
  height: 7px;
  border-radius: 4px;
  background: linear-gradient(90deg,
    rgba(230, 60, 60, 0) 0%,
    rgba(230, 60, 60, .65) 15%,
    rgba(220, 35, 35, .8) 50%,
    rgba(200, 35, 35, .7) 85%,
    rgba(200, 35, 35, 0) 100%);
  opacity: 1;
  transform-origin: left center;
  transform: scaleX(0);
  animation: cdl-lead-underline 6s ease-in-out infinite;
  box-shadow: 0 2px 14px rgba(230, 60, 60, .35), 0 0 18px rgba(230, 60, 60, .22);
  z-index: -1;
  pointer-events: none;
}
@keyframes cdl-lead-underline {
  0%       { transform-origin: left center; transform: scaleX(0); opacity: .0; }
  10%      { transform-origin: left center; transform: scaleX(0); opacity: .85; }
  45%      { transform-origin: left center; transform: scaleX(1); opacity: 1; }
  65%      { transform-origin: left center; transform: scaleX(1); opacity: 1; }
  80%      { transform-origin: right center; transform: scaleX(1); opacity: .9; }
  100%     { transform-origin: right center; transform: scaleX(0); opacity: 0; }
}

/* Contact lead "카달" — solid dark + animated underline glow */
.cdl-contact__lead { position: relative; }
.cdl-contact__lead strong {
  position: relative;
  display: inline-block;
  color: var(--ink-1000) !important;
  font-weight: 800;
  letter-spacing: -.02em;
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  padding: 0 .1em;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.cdl-contact__lead strong::before {
  content: "";
  position: absolute;
  left: 4%; right: 4%;
  bottom: -.05em;
  height: 3px;
  border-radius: 3px;
  background: linear-gradient(90deg, transparent, var(--ink-1000) 25%, var(--ink-1000) 75%, transparent);
  transform-origin: center;
  animation: cdl-contact-underline 3.6s var(--ease-out) infinite;
}
.cdl-contact__lead strong::after {
  content: "";
  position: absolute;
  inset: -.2em -.14em;
  border-radius: .4em;
  background: radial-gradient(ellipse at center, rgba(0,0,0,.07) 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
}
@keyframes cdl-contact-underline {
  0%, 70%, 100% { transform: scaleX(.55); opacity: .35; }
  20%, 50%     { transform: scaleX(1); opacity: 1; }
}
.cdl-section__sub {
  margin-top: 12px;
  font-size: clamp(14px, 1.2vw, 15.5px);
  line-height: 1.65;
  color: var(--ink-500);
  max-width: 56ch;
}
.cdl-section__sub--light { color: var(--ink-250); }
.cdl-section__head--center .cdl-section__sub { margin-left: auto; margin-right: auto; }

.cdl-section__more { margin-top: 48px; text-align: center; }

.cdl-prose p { margin-bottom: 14px; }
.cdl-prose { font-size: 15.5px; line-height: 1.85; color: var(--ink-700); }

/* ---------- Buttons ---------- */
.cdl-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 20px;
  font-family: var(--font-kr);
  font-weight: 600;
  font-size: 13.5px;
  letter-spacing: -.005em;
  border-radius: 999px;
  border: 1px solid transparent;
  background: var(--ink-900);
  color: var(--white);
  cursor: pointer;
  white-space: nowrap;
  transition: transform var(--t-fast) var(--ease), background var(--t-base) var(--ease), border-color var(--t-base) var(--ease), color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
  user-select: none;
}
.cdl-btn:hover { transform: translateY(-1px); }
.cdl-btn:active { transform: translateY(0); }
.cdl-btn--lg { padding: 14px 26px; font-size: 14px; }
.cdl-btn--sm { padding: 8px 14px; font-size: 13px; }
.cdl-btn--block { display: flex; width: 100%; }

.cdl-btn--chrome {
  background: var(--ink-950);
  color: var(--white);
  border-color: var(--ink-950);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16), 0 8px 24px rgba(0,0,0,.18);
  position: relative;
}
.cdl-btn--chrome::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  background: linear-gradient(180deg,rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 50%);
  pointer-events: none;
}
.cdl-btn--chrome:hover { background: var(--ink-1000); box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 12px 28px rgba(0,0,0,.28); }

.cdl-btn--ghost {
  background: transparent;
  color: var(--ink-900);
  border-color: var(--ink-900);
}
.cdl-btn--ghost:hover { background: var(--ink-900); color: var(--white); }

.cdl-btn--ghost-light {
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,.4);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.cdl-btn--ghost-light:hover { background: var(--white); color: var(--ink-1000); border-color: var(--white); }

.cdl-btn[disabled],.cdl-btn:disabled { opacity: .35; cursor: not-allowed; transform: none !important; }

/* ---------- Header ---------- */
.cdl-header {
  position: fixed;
  top: 0;
  left: 0; right: 0;
  z-index: 800;
  background: linear-gradient(180deg, rgba(10,10,10,.6) 0%, rgba(10,10,10,.0) 100%);
  -webkit-backdrop-filter: saturate(180%) blur(8px);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid transparent;
  transition: background var(--t-base) var(--ease), border-color var(--t-base) var(--ease), backdrop-filter var(--t-base) var(--ease);
}
.cdl-header.is-solid {
  background: rgba(10,10,10,.84);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  border-bottom-color: rgba(255,255,255,.08);
}
.cdl-header__bar { height: var(--header-h); }
.cdl-header__inner {
  height: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.cdl-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
}
.cdl-logo__mark {
  height: 28px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.4));
}
.cdl-logo__tag {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  color: var(--ink-250);
  padding-left: 10px;
  border-left: 1px solid rgba(255,255,255,.16);
}

.cdl-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  justify-content: center;
}
.cdl-nav__link {
  position: relative;
  padding: 6px 13px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--ink-150);
  border-radius: 999px;
  transition: color var(--t-fast) var(--ease), background var(--t-base) var(--ease);
}
.cdl-nav__link::after {
  content: "";
  position: absolute;
  left: 16px; right: 16px; bottom: 1px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--white) 20%, var(--white) 80%, transparent);
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--t-base) var(--ease);
}
.cdl-nav__link:hover { color: var(--white); }
.cdl-nav__link:hover::after { transform: scaleX(.7); }
.cdl-nav__link.is-active { color: var(--white); font-weight: 700; }
.cdl-nav__link.is-active::after { transform: scaleX(1); }

.cdl-header__cta { display: flex; align-items: center; gap: 10px; flex: 0 0 auto; }

/* Phone CTA — dark pill + circular icon w/ pulse */
.cdl-header__phone {
  display: inline-flex; align-items: center;
  gap: 12px;
  padding: 4px 22px 4px 4px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(20,20,24,.75), rgba(8,8,10,.6));
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  position: relative;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
.cdl-header__phone::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(255,255,255,.35) 0%, transparent 40%, transparent 60%, rgba(255,255,255,.15) 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: .55;
  pointer-events: none;
}
.cdl-header__phone:hover {
  background: linear-gradient(135deg, rgba(36,36,40,.85), rgba(14,14,16,.7));
  border-color: rgba(255,255,255,.32);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.32), 0 0 24px rgba(255,255,255,.05);
}
.cdl-header__phone-icon {
  position: relative;
  width: 34px; height: 34px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(50,50,56,.95), rgba(8,8,12,.95));
  border: 1px solid rgba(255,255,255,.22);
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 1px rgba(255,255,255,.05), inset 0 1px 0 rgba(255,255,255,.15);
  flex: 0 0 auto;
  overflow: visible;
}
.cdl-header__phone-pulse {
  position: absolute; inset: -2px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.55);
  animation: cdl-header-pulse 2.4s var(--ease) infinite;
  opacity: 0;
  pointer-events: none;
}
.cdl-header__phone-pulse--2 { animation-delay: 1.2s; }
@keyframes cdl-header-pulse {
  0%   { transform: scale(.85); opacity: .7; }
  100% { transform: scale(1.85); opacity: 0; }
}
.cdl-header__phone-num {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--white);
  font-size: 18px;
  letter-spacing: -.01em;
  line-height: 1;
}

.cdl-header__quote {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  font-size: 13.5px; font-weight: 600;
  color: var(--white);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0));
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 999px;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  white-space: nowrap;
}
.cdl-header__quote svg { transition: transform var(--t-fast) var(--ease); opacity: .7; }
.cdl-header__quote:hover {
  background: var(--white);
  color: var(--ink-1000);
  border-color: var(--white);
  transform: translateY(-1px);
}
.cdl-header__quote:hover svg { transform: translateX(2px); opacity: 1; }

/* Burger (mobile only) */
.cdl-burger {
  display: none;
  width: 42px; height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  position: relative;
}
.cdl-burger span {
  position: absolute;
  left: 12px; right: 12px;
  height: 1px;
  background: var(--white);
  transition: transform var(--t-base) var(--ease), opacity var(--t-base) var(--ease), top var(--t-base) var(--ease);
}
.cdl-burger span:nth-child(1) { top: 14px; }
.cdl-burger span:nth-child(2) { top: 20px; }
.cdl-burger span:nth-child(3) { top: 26px; }
body.cdl-drawer-open .cdl-burger span:nth-child(1) { top: 20px; transform: rotate(45deg); }
body.cdl-drawer-open .cdl-burger span:nth-child(2) { opacity: 0; }
body.cdl-drawer-open .cdl-burger span:nth-child(3) { top: 20px; transform: rotate(-45deg); }

/* Drawer */
.cdl-drawer-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1080;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-base) var(--ease);
}
.cdl-drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }

.cdl-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(86%, 360px);
  background: var(--ink-950);
  color: var(--white);
  z-index: 1100;
  padding: 24px;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--t-base) var(--ease);
  box-shadow: -24px 0 60px rgba(0,0,0,.4);
  overflow-y: auto;
}
.cdl-drawer.is-open { transform: translateX(0); }
.cdl-drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; }
.cdl-drawer__head img { height: 30px; }
.cdl-drawer__close {
  width: 40px; height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--white);
}
.cdl-drawer__nav { display: flex; flex-direction: column; gap: 2px; }
.cdl-drawer__link {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 8px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-size: 17px; font-weight: 600; color: var(--ink-100);
  transition: color var(--t-fast) var(--ease), padding var(--t-fast) var(--ease);
}
.cdl-drawer__link:hover { color: var(--white); padding-left: 16px; }
.cdl-drawer__link-arrow { color: var(--ink-400); font-weight: 400; }
.cdl-drawer__foot { margin-top: auto; padding-top: 24px; display: flex; flex-direction: column; gap: 14px; }
.cdl-drawer__phone { display: flex; flex-direction: column; padding: 16px; border: 1px solid rgba(255,255,255,.12); border-radius: 14px; }
.cdl-drawer__phone-label { font-size: 11px; color: var(--ink-300); letter-spacing: .12em; text-transform: uppercase; }
.cdl-drawer__phone strong { font-family: var(--font-en); font-size: 22px; font-weight: 700; margin-top: 4px; }

/* ---------- Top Ticker ---------- */
.cdl-ticker {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--ticker-h);
  background: var(--ink-1000);
  border-bottom: 1px solid rgba(255,255,255,.06);
  z-index: 850;
  font-size: 12.5px;
  color: var(--ink-200);
  display: flex;
  align-items: center;
}
.cdl-ticker__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex; align-items: center; gap: 16px;
  width: 100%;
}
.cdl-ticker__pulse { display: flex; align-items: center; gap: 6px; flex: 0 0 auto; font-family: var(--font-en); font-weight: 700; letter-spacing: .14em; font-size: 11px; color: #ff6464; }
.cdl-ticker__dot {
  width: 6px; height: 6px; border-radius: 50%; background: #ff4646;
  box-shadow: 0 0 0 0 rgba(255,70,70,.6);
  animation: cdl-pulse 1.6s var(--ease) infinite;
}
@keyframes cdl-pulse {
  0% { box-shadow: 0 0 0 0 rgba(255,70,70,.55); }
  70% { box-shadow: 0 0 0 8px rgba(255,70,70,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,70,70,0); }
}
.cdl-ticker__viewport { flex: 1; height: var(--ticker-h); overflow: hidden; position: relative; }
.cdl-ticker__list { position: relative; }
.cdl-ticker__item {
  position: absolute; left: 0; right: 0; top: 0;
  height: var(--ticker-h);
  display: flex; align-items: center; gap: 10px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  opacity: 0; transform: translateY(100%);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.cdl-ticker__item.is-active { opacity: 1; transform: translateY(0); }
.cdl-ticker__sep { color: var(--ink-600); }
.cdl-ticker__time { color: var(--ink-300); font-family: var(--font-en); }
.cdl-ticker__region { color: var(--white); font-weight: 600; }
.cdl-ticker__name { color: var(--ink-200); }
.cdl-ticker__vehicle { color: var(--white); font-weight: 600; }
.cdl-ticker__action { color: var(--ink-200); }

/* ---------- HERO ---------- */
.cdl-hero {
  position: relative;
  min-height: clamp(540px, 78vh, 720px);
  background: var(--ink-1000);
  color: var(--white);
  overflow: hidden;
  display: flex; align-items: stretch;
  margin-top: calc(-1 * var(--header-h));
  padding-top: var(--header-h);
}
.cdl-hero__bg-stack { position: absolute; inset: 0; z-index: 0; }
.cdl-hero__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0; transform: scale(1.06);
  transition: opacity 1.4s var(--ease), transform 8s var(--ease);
}
.cdl-hero__bg.is-active { opacity: .8; transform: scale(1); }
.cdl-hero__veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(8,8,8,.88) 0%, rgba(8,8,8,.55) 45%, rgba(8,8,8,.15) 75%, rgba(8,8,8,.05) 100%),
    linear-gradient(180deg, rgba(8,8,8,.25) 0%, rgba(8,8,8,.0) 35%, rgba(8,8,8,.55) 100%);
}
.cdl-hero__grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: linear-gradient(90deg, #000 0%, #000 35%, transparent 70%);
  -webkit-mask-image: linear-gradient(90deg, #000 0%, #000 35%, transparent 70%);
}

.cdl-hero__inner {
  position: relative;
  z-index: 1;
  display: flex; flex-direction: column;
  width: 100%;
  padding-top: clamp(32px, 6vw, 72px);
  padding-bottom: clamp(40px, 6vw, 64px);
}

.cdl-hero__top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: clamp(28px, 4.5vw, 56px);
  gap: 16px;
}
.cdl-hero__live {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  font-size: 11.5px; font-weight: 500; letter-spacing: .04em;
  color: var(--ink-100);
  background: rgba(255,255,255,.03);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.cdl-hero__live-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #ff4d4d;
  box-shadow: 0 0 8px rgba(255,77,77,.7);
  animation: cdl-pulse 1.8s var(--ease) infinite;
}

.cdl-hero__copy { position: relative; min-height: 240px; }
.cdl-hero__copy-item {
  position: absolute; inset: 0;
  opacity: 0; transform: translateY(20px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
  pointer-events: none;
}
.cdl-hero__copy-item.is-active { opacity: 1; transform: translateY(0); pointer-events: auto; position: relative; }

.cdl-hero__title {
  font-family: var(--font-kr);
  font-weight: 800;
  font-size: clamp(30px, 5vw, 64px);
  line-height: 1.08;
  letter-spacing: -.03em;
  color: var(--white);
  max-width: 16ch;
}
.cdl-hero__sub {
  margin-top: 18px;
  max-width: 56ch;
  font-size: clamp(14px, 1.3vw, 16.5px);
  line-height: 1.65;
  color: var(--ink-150);
}

.cdl-hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}
.cdl-hero__cta .cdl-btn--chrome {
  background: var(--white);
  color: var(--ink-1000);
  border-color: var(--white);
  box-shadow: 0 12px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.7);
}
.cdl-hero__cta .cdl-btn--chrome:hover { background: var(--ink-25); }

.cdl-hero__dots {
  display: flex; gap: 10px; margin-top: 36px;
}
.cdl-hero__dot {
  width: 28px; height: 2px; border-radius: 2px;
  background: rgba(255,255,255,.18);
  transition: background var(--t-base) var(--ease), width var(--t-base) var(--ease);
}
.cdl-hero__dot.is-active { background: var(--white); width: 56px; }

.cdl-hero__stats {
  margin-top: clamp(36px, 5vw, 72px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 22px;
}
.cdl-hero__stat {
  display: flex; flex-direction: column; gap: 6px;
  padding: 0 12px;
  border-right: 1px solid rgba(255,255,255,.06);
}
.cdl-hero__stat:last-child { border-right: 0; }
.cdl-hero__stat:first-child { padding-left: 0; }
.cdl-hero__stat-num {
  font-family: var(--font-display);
  font-size: clamp(26px, 3.6vw, 42px);
  font-weight: 700;
  color: var(--white);
  letter-spacing: -.02em;
  line-height: 1;
  display: flex; align-items: baseline; gap: 4px;
}
.cdl-hero__stat-suffix { font-size: .55em; font-weight: 600; color: var(--ink-200); }
.cdl-hero__stat-label { font-size: 12.5px; color: var(--ink-250); letter-spacing: .04em; }

.cdl-hero__scroll {
  position: absolute;
  right: var(--gutter);
  bottom: 36px;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  font-family: var(--font-en);
  font-size: 10px; letter-spacing: .3em;
  color: var(--ink-300);
}
.cdl-hero__scroll-bar {
  width: 1px; height: 56px;
  background: linear-gradient(180deg, var(--ink-400), transparent);
  position: relative;
  overflow: hidden;
}
.cdl-hero__scroll-bar::after {
  content: ""; position: absolute; left: 0; right: 0;
  top: -30%; height: 30%;
  background: var(--white);
  animation: cdl-scroll-bar 2.4s var(--ease) infinite;
}
@keyframes cdl-scroll-bar {
  0% { top: -30%; } 100% { top: 110%; }
}

/* ---------- VS Compare (cinematic, monochrome) ---------- */
:root {
  --vs-gold: #a8a8a8;       /* 좌측 — 다머 silver */
  --vs-gold-soft: #6e6e6e;
  --vs-violet: #ededed;     /* 우측 — bright silver/white */
  --vs-violet-soft: #c4c4c4;
}
.cdl-vs { position: relative; overflow: hidden; }
.cdl-vs__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.cdl-vs__bg-img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: right center;
  opacity: .22;
  filter: blur(2px) brightness(.55) contrast(1.1);
  mask-image: linear-gradient(90deg, transparent 0%, transparent 35%, rgba(0,0,0,.6) 60%, #000 80%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, transparent 35%, rgba(0,0,0,.6) 60%, #000 80%);
}
.cdl-vs__bg-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .85;
  filter: brightness(.85) contrast(1.08) saturate(1);
  pointer-events: none;
  /* 영상 자체 워터마크(Veo) + 하단 페이지네이션을 잘라내기 위해 살짝 확대 */
  transform: scale(1.18);
  transform-origin: center 45%;
}
.cdl-vs__bg-glow {
  position: absolute;
  right: -10%; top: 50%;
  width: 60%; height: 70%;
  transform: translateY(-50%);
  background: radial-gradient(ellipse at center, rgba(255,255,255,.08) 0%, rgba(255,255,255,.04) 40%, transparent 70%);
  filter: blur(40px);
}
.cdl-vs__bg-veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(8,8,10,.55) 0%, rgba(8,8,10,.18) 40%, rgba(8,8,10,.08) 65%, rgba(8,8,10,.35) 100%),
    linear-gradient(180deg, rgba(8,8,10,.15) 0%, rgba(8,8,10,.0) 40%, rgba(8,8,10,.55) 100%);
}
.cdl-vs__inner { position: relative; z-index: 1; }

.cdl-eyebrow--gold { color: var(--ink-200); }
.cdl-eyebrow--gold::before { background: var(--ink-200); opacity: .9; }

.cdl-vs__stage {
  position: relative;
  min-height: 420px;
  margin-top: 8px;
}
.cdl-vs__scenario {
  position: absolute; inset: 0;
  display: grid;
  grid-template-columns: 1fr 80px 1fr;
  gap: 24px;
  align-items: stretch;
  opacity: 0; transform: translateY(16px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
  pointer-events: none;
}
.cdl-vs__scenario.is-active { opacity: 1; transform: translateY(0); pointer-events: auto; position: relative; }

.cdl-vs__col {
  position: relative;
  background: linear-gradient(180deg, rgba(20,20,24,.55) 0%, rgba(12,12,14,.45) 100%);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px;
  padding: clamp(28px, 3.4vw, 44px) clamp(24px, 3vw, 36px);
  display: flex; flex-direction: column; gap: 16px;
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  backdrop-filter: blur(18px) saturate(140%);
  box-shadow: 0 20px 60px rgba(0,0,0,.4);
}
.cdl-vs__col--left {
  border-color: rgba(255,255,255,.1);
  box-shadow: 0 20px 60px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}
.cdl-vs__col--right {
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 20px 60px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.14);
}

/* Side icon (gold for left, violet for right) */
.cdl-vs__icon {
  position: absolute;
  top: 50%;
  width: 56px; height: 56px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 30% 30%, #1a1a1d, #0a0a0c);
  z-index: 2;
  overflow: visible;
}
.cdl-vs__icon svg { width: 22px; height: 22px; position: relative; z-index: 3; }
/* Pulsing ripple rings emanating from the icon */
.cdl-vs__icon::before,
.cdl-vs__icon::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1px solid currentColor;
  opacity: 0;
  pointer-events: none;
  animation: cdl-vs-ripple 3.2s var(--ease) infinite;
}
.cdl-vs__icon::after { animation-delay: 1.6s; }
@keyframes cdl-vs-ripple {
  0%   { transform: scale(.85); opacity: .55; }
  100% { transform: scale(2.2);  opacity: 0;   }
}
.cdl-vs__icon--left {
  left: -28px; transform: translateY(-50%);
  color: var(--vs-gold);
  border: 1px solid rgba(168,168,168,.4);
  box-shadow: 0 0 0 1px rgba(168,168,168,.1), 0 0 24px rgba(168,168,168,.2), inset 0 1px 0 rgba(255,255,255,.1);
}
.cdl-vs__icon--right {
  right: -28px; transform: translateY(-50%);
  color: var(--vs-violet);
  border: 1px solid rgba(255,255,255,.5);
  box-shadow: 0 0 0 1px rgba(255,255,255,.15), 0 0 30px rgba(255,255,255,.25), inset 0 1px 0 rgba(255,255,255,.25);
}

/* Concentric rings behind icon (decorative + slow breathing) */
.cdl-vs__rings {
  position: absolute;
  top: 50%;
  width: 220px; height: 220px;
  border-radius: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 1;
  animation: cdl-vs-breathe 6s ease-in-out infinite;
}
.cdl-vs__rings::before,
.cdl-vs__rings::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  border: 1px solid currentColor;
}
.cdl-vs__rings::before { inset: 30%; opacity: .3; }
.cdl-vs__rings::after  { inset: 10%; opacity: .14; }
.cdl-vs__rings--left  { left: -110px; color: var(--vs-gold); }
.cdl-vs__rings--right { right: -110px; color: var(--vs-violet); animation-delay: 3s; }
@keyframes cdl-vs-breathe {
  0%,100% { transform: translateY(-50%) scale(1); }
  50%     { transform: translateY(-50%) scale(1.08); }
}

.cdl-vs__col-label { font-size: 14px; font-weight: 500; color: var(--ink-300); letter-spacing: .02em; position: relative; z-index: 2; }
.cdl-vs__col-label--win { color: var(--white); }

.cdl-vs__price { display: flex; align-items: baseline; gap: 8px; position: relative; z-index: 2; }
.cdl-vs__price strong {
  font-family: var(--font-display);
  font-size: clamp(40px, 5.4vw, 68px);
  font-weight: 700;
  color: var(--vs-gold);
  letter-spacing: -.03em;
  line-height: 1;
  text-decoration: none;
  text-shadow: 0 0 24px rgba(168,168,168,.15);
}
.cdl-vs__price--win strong {
  color: var(--white);
  text-shadow: 0 0 30px rgba(255,255,255,.2);
}
.cdl-vs__price-unit { font-size: 17px; color: var(--ink-300); font-weight: 500; }

.cdl-vs__pill { align-self: flex-start; padding: 6px 14px; border-radius: 999px; font-size: 12px; font-weight: 600; letter-spacing: .02em; position: relative; z-index: 2; }
.cdl-vs__pill--muted {
  background: rgba(255,255,255,.05);
  color: var(--ink-200);
  border: 1px solid rgba(255,255,255,.1);
}
.cdl-vs__pill--win {
  background: linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.08));
  color: var(--white);
  border: 1px solid rgba(255,255,255,.3);
  box-shadow: 0 0 16px rgba(255,255,255,.12);
}

.cdl-vs__list {
  display: flex; flex-direction: column; gap: 12px;
  margin-top: auto; padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.06);
  position: relative; z-index: 2;
}
.cdl-vs__list li { display: flex; gap: 10px; align-items: flex-start; font-size: 13.5px; color: var(--ink-200); line-height: 1.55; }
.cdl-vs__minus, .cdl-vs__plus {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  flex: 0 0 auto;
  margin-top: 1px;
}
.cdl-vs__minus { background: rgba(255,255,255,.05); color: var(--ink-300); border: 1px solid rgba(255,255,255,.1); }
.cdl-vs__plus  { background: rgba(255,255,255,.12); color: var(--white); border: 1px solid rgba(255,255,255,.25); }
.cdl-vs__list--win li { color: var(--ink-100); }

/* VS center medallion */
.cdl-vs__divider {
  align-self: center;
  width: 64px; height: 64px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(40,40,46,.9), rgba(10,10,12,.95));
  border: 1px solid rgba(255,255,255,.15);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 14px; letter-spacing: .22em;
  color: var(--white);
  font-weight: 700;
  position: relative;
  box-shadow: 0 0 30px rgba(255,255,255,.05), inset 0 1px 0 rgba(255,255,255,.1);
}
.cdl-vs__divider::before {
  content: "";
  position: absolute; inset: -10px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.08);
}
.cdl-vs__divider::after {
  content: "";
  position: absolute; inset: -20px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.04);
}

/* Bottom callout */
.cdl-vs__callout {
  margin: 40px auto 0;
  display: inline-flex;
  align-items: center; gap: 12px;
  padding: 12px 22px 12px 12px;
  background: linear-gradient(180deg, rgba(30,30,36,.8), rgba(16,16,20,.7));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px rgba(0,0,0,.3);
  color: var(--ink-100);
  font-size: 14px;
  position: relative;
  left: 50%; transform: translateX(-50%);
}
.cdl-vs__callout-icon {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--white), var(--ink-200));
  color: var(--ink-1000);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 0 16px rgba(255,255,255,.18);
}
.cdl-vs__callout-icon svg { width: 16px; height: 16px; }
.cdl-vs__callout strong { color: var(--white); font-weight: 700; }

.cdl-vs__dots { display: flex; gap: 8px; justify-content: center; margin-top: 28px; }
.cdl-vs__dot {
  width: 8px; height: 8px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.35); background: transparent;
  transition: background var(--t-base) var(--ease), width var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.cdl-vs__dot.is-active { background: var(--white); border-color: var(--white); width: 24px; border-radius: 999px; }

/* ---------- Lead Form ---------- */
/* Lead section — light tone, decorations, promise list with icons */
.cdl-lead { background: #fafafa; position: relative; overflow: hidden; }
.cdl-lead__bg { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.cdl-lead__bg-map {
  position: absolute; top: 8%; right: -8%;
  width: 55%; height: 70%;
  background-image: radial-gradient(circle, var(--ink-200) 1.6px, transparent 1.6px);
  background-size: 20px 20px;
  opacity: .35;
  mask-image: radial-gradient(55% 50% at 60% 50%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(55% 50% at 60% 50%, #000 0%, transparent 80%);
}
.cdl-lead__bg-car {
  position: absolute; left: -60px; bottom: -40px;
  width: 520px; height: 320px;
  background-size: cover; background-position: center;
  opacity: .18;
  filter: grayscale(1) brightness(.55) contrast(1.05);
  mask-image: radial-gradient(70% 80% at 25% 80%, #000 0%, rgba(0,0,0,.4) 50%, transparent 85%);
  -webkit-mask-image: radial-gradient(70% 80% at 25% 80%, #000 0%, rgba(0,0,0,.4) 50%, transparent 85%);
}
.cdl-lead__grid {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 500px;
  gap: clamp(36px, 5vw, 72px);
  align-items: stretch;
}
.cdl-lead__copy { display: flex; flex-direction: column; }
.cdl-lead__copy .cdl-promise { flex: 1; min-height: 0; }

/* Promise list — icon, number, title, desc with dividers */
.cdl-promise {
  display: flex; flex-direction: column;
  margin: 36px 0 0;
  padding: 0;
  border-top: 1px solid var(--ink-100);
}
.cdl-promise li {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 18px;
  align-items: center;
  padding: 18px 0;
  border-bottom: 1px solid var(--ink-100);
}
.cdl-promise__icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ink-700), var(--ink-1000));
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 18px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.1);
}
.cdl-promise__icon svg { width: 20px; height: 20px; }
.cdl-promise__body { display: flex; flex-direction: column; gap: 4px; }
.cdl-promise__head { display: flex; align-items: baseline; gap: 12px; }
.cdl-promise__num {
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: .14em;
  color: var(--ink-400);
  font-weight: 600;
}
.cdl-promise__title { font-size: 16px; font-weight: 700; color: var(--ink-1000); }
.cdl-promise__desc { font-size: 13px; color: var(--ink-500); }

/* Phone CTA — luxury chrome card */
.cdl-lead__phone {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
  margin-top: 24px;
  padding: 18px 22px;
  background: linear-gradient(180deg, #ffffff 0%, #f3f3f3 100%);
  border: 1px solid var(--ink-150);
  border-radius: 18px;
  text-decoration: none;
  transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}
.cdl-lead__phone:hover { transform: translateY(-2px); border-color: var(--ink-700); box-shadow: 0 12px 32px rgba(0,0,0,.08); }
.cdl-lead__phone-icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--ink-700), var(--ink-1000));
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 20px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.12);
}
.cdl-lead__phone-icon svg { width: 22px; height: 22px; }
.cdl-lead__phone-body { display: flex; flex-direction: column; gap: 4px; }
.cdl-lead__phone-label { font-size: 11px; color: var(--ink-500); letter-spacing: .1em; text-transform: uppercase; }
.cdl-lead__phone-num {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.4vw, 30px);
  font-weight: 700;
  color: var(--ink-1000);
  letter-spacing: -.015em;
  line-height: 1;
}

/* Form — white card with subtle shadow + light inputs */
.cdl-lead__form {
  background: var(--white);
  color: var(--ink-1000);
  padding: clamp(28px, 3.6vw, 40px);
  border-radius: 22px;
  border: 1px solid var(--ink-100);
  box-shadow: 0 24px 60px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.04);
  display: flex; flex-direction: column;
}
.cdl-lead__form .cdl-form__grid { margin-top: 4px; }
.cdl-lead__form-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  margin-bottom: 26px;
  padding-bottom: 26px;
  border-bottom: 1px solid var(--ink-100);
}
.cdl-lead__form-icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ink-700), var(--ink-1000));
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 20px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.1);
}
.cdl-lead__form-icon svg { width: 20px; height: 20px; }
.cdl-lead__form-head h3 { font-size: 19px; font-weight: 700; color: var(--ink-1000); }
.cdl-lead__form-head p { margin-top: 4px; font-size: 13px; color: var(--ink-500); }

/* Override the global dark form rule for lead form (was dark, now light) */
.cdl-lead__form .cdl-input {
  background: var(--ink-25);
  color: var(--ink-1000);
  border-color: var(--ink-100);
}
.cdl-lead__form .cdl-input::placeholder { color: var(--ink-400); }
.cdl-lead__form .cdl-input:focus { background: var(--white); border-color: var(--ink-1000); }
.cdl-lead__form .cdl-field__label { color: var(--ink-700); text-transform: none; letter-spacing: 0; font-weight: 600; font-size: 13px; }
.cdl-lead__form .cdl-check { color: var(--ink-700); }
.cdl-lead__form .cdl-check input { accent-color: var(--ink-1000); }

/* ---------- Form ---------- */
.cdl-form__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.cdl-lead__form .cdl-form__grid { gap: 18px; }
.cdl-field { display: flex; flex-direction: column; gap: 6px; }
.cdl-field--full { grid-column: 1 / -1; }
.cdl-field__label { font-size: 12px; font-weight: 500; letter-spacing: .04em; color: var(--ink-300); text-transform: uppercase; }
.cdl-field__req { color: #ff6868; }

.cdl-input {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  padding: 14px 16px;
  background: rgba(255,255,255,.04);
  color: var(--white);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  font-size: 15px;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.cdl-input::placeholder { color: var(--ink-400); }
.cdl-input:focus { outline: 0; border-color: var(--white); background: rgba(255,255,255,.07); }
.cdl-input--lg { padding: 16px 18px; font-size: 16.5px; }
.cdl-input--area { resize: vertical; min-height: 96px; }
.cdl-input:where(select) { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8a8a8' stroke-width='1.6'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; }

/* Light variant for forms on white sections */
.cdl-section:not(.cdl-section--dark) .cdl-form:not(.cdl-lead__form) .cdl-input,
.cdl-section:not(.cdl-section--dark) .cdl-partnership__form .cdl-input,
.cdl-section:not(.cdl-section--dark) .cdl-lookup-card .cdl-input,
.cdl-modal .cdl-input {
  background: var(--ink-25);
  color: var(--ink-1000);
  border-color: var(--ink-150);
}
.cdl-section:not(.cdl-section--dark) .cdl-form:not(.cdl-lead__form) .cdl-input::placeholder,
.cdl-section:not(.cdl-section--dark) .cdl-partnership__form .cdl-input::placeholder,
.cdl-section:not(.cdl-section--dark) .cdl-lookup-card .cdl-input::placeholder,
.cdl-modal .cdl-input::placeholder {
  color: var(--ink-400);
}
.cdl-section:not(.cdl-section--dark) .cdl-form:not(.cdl-lead__form) .cdl-input:focus,
.cdl-section:not(.cdl-section--dark) .cdl-partnership__form .cdl-input:focus,
.cdl-section:not(.cdl-section--dark) .cdl-lookup-card .cdl-input:focus,
.cdl-modal .cdl-input:focus {
  background: var(--white);
  border-color: var(--ink-1000);
}
.cdl-section:not(.cdl-section--dark) .cdl-form:not(.cdl-lead__form) .cdl-field__label,
.cdl-section:not(.cdl-section--dark) .cdl-partnership__form .cdl-field__label,
.cdl-section:not(.cdl-section--dark) .cdl-lookup-card .cdl-field__label,
.cdl-modal .cdl-field__label {
  color: var(--ink-500);
}

.cdl-check {
  display: flex; align-items: center; gap: 10px;
  margin-top: 16px;
  font-size: 13.5px;
  color: var(--ink-300);
}

/* Unified form rhythm — consistent spacing for every .cdl-form */
.cdl-form .cdl-privacy { margin-top: 18px; }
.cdl-form .cdl-privacy + .cdl-check { margin-top: 12px; }
.cdl-form .cdl-check + .cdl-btn,
.cdl-form > .cdl-btn,
.cdl-form .cdl-privacy + .cdl-btn { margin-top: 22px; }
.cdl-form .cdl-alert { margin-bottom: 16px; }
.cdl-check input { width: 16px; height: 16px; accent-color: var(--white); }
.cdl-section:not(.cdl-section--dark) .cdl-form:not(.cdl-lead__form) .cdl-check,
.cdl-section:not(.cdl-section--dark) .cdl-partnership__form .cdl-check,
.cdl-section:not(.cdl-section--dark) .cdl-lookup-card .cdl-check,
.cdl-modal .cdl-check {
  color: var(--ink-500);
}
.cdl-section:not(.cdl-section--dark) .cdl-form:not(.cdl-lead__form) .cdl-check input,
.cdl-section:not(.cdl-section--dark) .cdl-partnership__form .cdl-check input,
.cdl-section:not(.cdl-section--dark) .cdl-lookup-card .cdl-check input,
.cdl-modal .cdl-check input { accent-color: var(--ink-1000); }

.cdl-privacy {
  margin-top: 12px;
  font-size: 13px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  padding: 10px 14px;
  color: var(--ink-200);
}
.cdl-privacy summary { cursor: pointer; }
.cdl-privacy pre { white-space: pre-wrap; margin: 8px 0 0; font: inherit; color: var(--ink-300); }
.cdl-section:not(.cdl-section--dark) .cdl-privacy,
.cdl-modal .cdl-privacy {
  border-color: var(--ink-150); color: var(--ink-700); background: var(--ink-25);
}
.cdl-section:not(.cdl-section--dark) .cdl-privacy pre,
.cdl-modal .cdl-privacy pre { color: var(--ink-500); }

.cdl-form__head h3 { font-size: 22px; font-weight: 700; }
.cdl-form__head p { margin-top: 6px; color: var(--ink-500); font-size: 14px; }
.cdl-form__head { margin-bottom: 22px; }

/* ---------- Process (card grid + arrows + promise card) ---------- */
.cdl-process { background: #fafafa; position: relative; overflow: hidden; }
.cdl-process__bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, var(--ink-150) 1.4px, transparent 1.4px);
  background-size: 22px 22px;
  opacity: .25;
  mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 70%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 70%, transparent 100%);
}
.cdl-process__inner { position: relative; z-index: 1; }

.cdl-process__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}
/* Reverse z-index so card 1's arrow sits on top of card 2, card 2's on top of card 3, etc. */
.cdl-process__list > li { position: relative; }
.cdl-process__list > li:nth-child(1) { z-index: 50; }
.cdl-process__list > li:nth-child(2) { z-index: 40; }
.cdl-process__list > li:nth-child(3) { z-index: 30; }
.cdl-process__list > li:nth-child(4) { z-index: 20; }
.cdl-process__list > li:nth-child(5) { z-index: 10; }
.cdl-process__card {
  position: relative;
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 18px;
  padding: 30px 20px 24px;
  text-align: center;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
  box-shadow: 0 8px 20px rgba(0,0,0,.03);
}
.cdl-process__card:hover {
  transform: translateY(-4px);
  border-color: var(--ink-700);
  box-shadow: 0 18px 36px rgba(0,0,0,.08);
}
.cdl-process__badge {
  position: absolute; top: 14px; left: 14px;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ink-700), var(--ink-1000));
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 11px; font-weight: 700;
  box-shadow: 0 6px 14px rgba(0,0,0,.18);
}
.cdl-process__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: linear-gradient(180deg, #f7f7f7, #ececec);
  border: 1px solid var(--ink-100);
  color: var(--ink-1000);
  margin: 4px auto 14px;
  box-shadow: inset 0 1px 0 var(--white), 0 6px 16px rgba(0,0,0,.04);
}
.cdl-process__icon svg { width: 24px; height: 24px; }
.cdl-process__step {
  display: block;
  font-family: var(--font-display);
  font-size: 11px; font-weight: 600;
  color: var(--ink-500);
  letter-spacing: .18em;
  margin-bottom: 10px;
}
.cdl-process__title { font-size: 16px; font-weight: 700; color: var(--ink-1000); }
.cdl-process__card p { margin-top: 8px; font-size: 13px; color: var(--ink-500); line-height: 1.6; }

.cdl-process__arrow {
  position: absolute;
  right: -22px; top: 50%;
  transform: translateY(-50%);
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, #ffffff 0%, #ededed 100%);
  border: 1px solid var(--ink-1000);
  border-radius: 50%;
  color: var(--ink-1000);
  z-index: 20;
  box-shadow:
    0 0 0 5px var(--white),
    0 12px 28px rgba(0,0,0,.18),
    inset 0 1px 0 rgba(255,255,255,.9);
  animation: cdl-arrow-wave 4.5s var(--ease) infinite;
}
.cdl-process__arrow svg { width: 16px; height: 16px; }
.cdl-process__arrow::before {
  content: "";
  position: absolute; inset: -3px;
  border-radius: 50%;
  border: 1.5px solid var(--ink-1000);
  opacity: 0;
  animation: cdl-arrow-ping 4.5s var(--ease) infinite;
  animation-delay: inherit;
}
/* Sequential 0.6s offset for each arrow (4 arrows between 5 cards) */
.cdl-process__list li:nth-child(1) .cdl-process__arrow { animation-delay: 0s; }
.cdl-process__list li:nth-child(2) .cdl-process__arrow { animation-delay: .55s; }
.cdl-process__list li:nth-child(3) .cdl-process__arrow { animation-delay: 1.10s; }
.cdl-process__list li:nth-child(4) .cdl-process__arrow { animation-delay: 1.65s; }
.cdl-process__list li:nth-child(1) .cdl-process__arrow::before { animation-delay: 0s; }
.cdl-process__list li:nth-child(2) .cdl-process__arrow::before { animation-delay: .55s; }
.cdl-process__list li:nth-child(3) .cdl-process__arrow::before { animation-delay: 1.10s; }
.cdl-process__list li:nth-child(4) .cdl-process__arrow::before { animation-delay: 1.65s; }
@keyframes cdl-arrow-wave {
  0%, 70%, 100% {
    background: linear-gradient(180deg, #ffffff 0%, #ededed 100%);
    color: var(--ink-1000);
    transform: translateY(-50%) scale(1);
    box-shadow: 0 0 0 5px var(--white), 0 12px 28px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.9);
  }
  8% {
    background: linear-gradient(180deg, var(--ink-1000), var(--ink-700));
    color: var(--white);
    transform: translateY(-50%) scale(1.18) translateX(4px);
    box-shadow: 0 0 0 5px var(--white), 0 0 28px rgba(0,0,0,.45), 0 16px 32px rgba(0,0,0,.32);
  }
  20% {
    background: linear-gradient(180deg, #ffffff 0%, #ededed 100%);
    color: var(--ink-1000);
    transform: translateY(-50%) scale(1);
    box-shadow: 0 0 0 5px var(--white), 0 12px 28px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.9);
  }
}
@keyframes cdl-arrow-ping {
  0%, 70%, 100% { transform: scale(.85); opacity: 0; }
  4%           { transform: scale(.85); opacity: .7; }
  20%          { transform: scale(2.4);  opacity: 0; }
}

/* Promise card under process */
.cdl-process__promise {
  margin-top: 32px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 22px;
  align-items: center;
  padding: 20px 24px;
  background: linear-gradient(180deg, #ffffff 0%, #f3f3f3 100%);
  border: 1px solid var(--ink-100);
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.04);
  position: relative;
  overflow: hidden;
}
.cdl-process__promise-icon {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ink-700), var(--ink-1000));
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 20px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.12);
  flex: 0 0 auto;
}
.cdl-process__promise-icon svg { width: 22px; height: 22px; }
.cdl-process__promise-text { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.cdl-process__promise-eyebrow {
  font-family: var(--font-display);
  font-size: 11px; font-weight: 600;
  letter-spacing: .16em;
  color: var(--ink-500);
  text-transform: uppercase;
}
.cdl-process__promise-text strong { font-size: 17px; font-weight: 700; color: var(--ink-1000); letter-spacing: -.005em; }
.cdl-process__promise-text p { font-size: 13px; color: var(--ink-500); }
.cdl-process__promise-img {
  width: 280px; height: 80px;
  background-size: cover;
  background-position: center;
  border-radius: 14px;
  opacity: .55;
  filter: grayscale(.4) contrast(1.05);
  mask-image: linear-gradient(90deg, transparent 0%, #000 50%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 50%);
}

/* ---------- Why ---------- */
/* Why — dark cards w/ rounded corners + side stat card + bg car */
.cdl-why { position: relative; overflow: hidden; }
.cdl-why__bg { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.cdl-why__bg-car {
  position: absolute; left: -5%; top: 30%;
  width: 55%; height: 55%;
  background-size: cover;
  background-position: center;
  opacity: .18;
  filter: blur(2px) brightness(.65) contrast(1.05);
  mask-image: radial-gradient(60% 60% at 30% 50%, #000, transparent 75%);
  -webkit-mask-image: radial-gradient(60% 60% at 30% 50%, #000, transparent 75%);
}
.cdl-why__bg-glow {
  position: absolute; left: 5%; top: 50%;
  width: 35%; height: 40%;
  transform: translateY(-50%);
  background: radial-gradient(ellipse at center, rgba(255,255,255,.06) 0%, transparent 70%);
  filter: blur(40px);
}
.cdl-why__grid {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: stretch;
}
.cdl-why__head { display: flex; flex-direction: column; }

/* Side stat card */
.cdl-why__stat {
  margin-top: auto;
  padding: 20px 22px;
  background: linear-gradient(180deg, rgba(20,20,24,.85), rgba(12,12,14,.7));
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
  max-width: 480px;
}
.cdl-why__stat-icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
}
.cdl-why__stat-icon svg { width: 20px; height: 20px; }
.cdl-why__stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.cdl-why__stat-grid > div { display: flex; flex-direction: column; gap: 2px; }
.cdl-why__stat-label { font-size: 11px; color: var(--ink-300); letter-spacing: .04em; }
.cdl-why__stat-value {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--white);
  letter-spacing: -.02em;
  line-height: 1;
}
.cdl-why__stat-value em { font-style: normal; font-size: .55em; font-weight: 600; color: var(--ink-300); }
.cdl-why__stat-value--win { color: var(--white); }
.cdl-why__stat-foot { grid-column: 1 / -1; font-size: 10.5px; color: var(--ink-400); letter-spacing: .02em; }

/* Why media card — cinematic vehicle frame with chrome badge */
.cdl-why__media {
  margin: 32px 0 0;
  position: relative;
  width: 100%;
  max-width: 520px;
  aspect-ratio: 16/10;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 24px 60px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.05);
}
.cdl-why__media-frame {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: grayscale(.35) contrast(1.05) brightness(.9);
  transform: scale(1);
  transition: transform 8s var(--ease);
}
.cdl-why__media:hover .cdl-why__media-frame { transform: scale(1.06); }
.cdl-why__media-veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.9) 100%),
    linear-gradient(90deg, rgba(0,0,0,.25), rgba(0,0,0,.0) 50%);
}
.cdl-why__media-cap {
  position: absolute;
  left: 22px; right: 22px; bottom: 20px;
  display: flex; flex-direction: column; gap: 10px;
  z-index: 2;
}
.cdl-why__media-tag {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border-radius: 999px;
  color: var(--white);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: -.005em;
}
.cdl-why__media-title {
  font-size: clamp(17px, 1.6vw, 20px);
  font-weight: 700;
  color: var(--white);
  letter-spacing: -.015em;
  line-height: 1.35;
}
.cdl-why__media-sub {
  font-family: var(--font-display);
  font-size: 11px; font-weight: 600;
  letter-spacing: .2em;
  color: var(--ink-300);
  text-transform: uppercase;
}

/* Why cards grid */
.cdl-why__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.cdl-why__card {
  position: relative;
  padding: 28px 26px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(22,22,26,.7) 0%, rgba(14,14,16,.6) 100%);
  border: 1px solid rgba(255,255,255,.08);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  transition: transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.cdl-why__card::before {
  content: "";
  position: absolute; top: 0; left: 24px; right: 24px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  opacity: .9;
}
.cdl-why__card:hover { transform: translateY(-3px); border-color: rgba(255,255,255,.2); }
.cdl-why__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.14);
  color: var(--white);
  margin-bottom: 22px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.cdl-why__icon svg { width: 20px; height: 20px; }
.cdl-why__card h3 { font-size: 17px; font-weight: 700; color: var(--white); }
.cdl-why__card p { margin-top: 12px; color: var(--ink-200); font-size: 13.5px; line-height: 1.6; }

/* ---------- Estimates rail ---------- */
.cdl-estimates__rail { position: relative; }
.cdl-estimates__track {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 24px;
  scrollbar-width: thin;
}
.cdl-estimates__track::-webkit-scrollbar { height: 4px; }
.cdl-estimates__track::-webkit-scrollbar-thumb { background: var(--ink-150); border-radius: 4px; }
.cdl-est-card {
  flex: 0 0 280px;
  scroll-snap-align: start;
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 16px;
  overflow: hidden;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.cdl-est-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--ink-200); }
.cdl-est-card__img {
  height: 168px;
  background: var(--ink-100);
  background-size: cover;
  background-position: center;
}
.cdl-est-card__body { padding: 18px 20px 22px; }
.cdl-est-card__name { font-size: 16.5px; font-weight: 700; color: var(--ink-1000); }
.cdl-est-card__meta { margin-top: 6px; display: flex; gap: 10px; font-size: 12.5px; color: var(--ink-500); }
.cdl-est-card__meta span:not(:last-child)::after { content: "·"; margin-left: 10px; color: var(--ink-300); }
.cdl-est-card__compare { margin-top: 16px; display: flex; flex-direction: column; gap: 6px; padding-top: 16px; border-top: 1px solid var(--ink-100); }
.cdl-est-card__row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; font-size: 13.5px; }
.cdl-est-card__row span { color: var(--ink-500); }
.cdl-est-card__row strong { font-family: var(--font-en); font-weight: 600; color: var(--ink-700); font-size: 14px; }
.cdl-est-card__row--low strong { color: var(--ink-400); text-decoration: line-through; }
.cdl-est-card__row--mid strong { color: var(--ink-700); }
.cdl-est-card__row--win { padding: 10px 12px; margin-top: 4px; background: var(--ink-1000); color: var(--white); border-radius: 12px; }
.cdl-est-card__row--win span { color: var(--ink-200); }
.cdl-est-card__row--win strong { color: var(--white); font-size: 15.5px; }

.cdl-estimates__nav {
  position: absolute;
  top: -64px; right: 0;
  display: flex; gap: 8px;
}
.cdl-est-nav {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--ink-200);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-700);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.cdl-est-nav:hover { background: var(--ink-1000); color: var(--white); border-color: var(--ink-1000); }

/* ---------- Reviews ---------- */
.cdl-reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cdl-rev-card {
  display: block;
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 16px;
  overflow: hidden;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.cdl-rev-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--ink-200); }
.cdl-rev-card__img {
  height: 188px;
  background: var(--ink-100);
  background-size: cover; background-position: center;
}
.cdl-rev-card__body { padding: 18px 20px 22px; display: flex; flex-direction: column; gap: 8px; }
.cdl-rev-card__meta { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; font-size: 12px; color: var(--ink-500); }
.cdl-dot { color: var(--ink-300); }
.cdl-rev-card__title { font-size: 17px; font-weight: 700; color: var(--ink-1000); line-height: 1.35; }
.cdl-rev-card__excerpt { font-size: 13.5px; color: var(--ink-500); line-height: 1.6; }
.cdl-rev-card__more { font-size: 12.5px; font-weight: 600; color: var(--ink-1000); margin-top: auto; }

/* ---------- FAQ ---------- */
.cdl-faq__grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
}
.cdl-faq__head { position: sticky; top: calc(var(--header-h) + var(--ticker-h) + 30px); }
.cdl-faq__list { display: flex; flex-direction: column; }
.cdl-faq__item { border-bottom: 1px solid var(--ink-100); }
.cdl-faq__list--light .cdl-faq__item { border-color: rgba(255,255,255,.08); }
.cdl-faq__q {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 22px 0;
  text-align: left;
  font-size: 16px; font-weight: 600; color: var(--ink-1000);
  transition: color var(--t-fast) var(--ease);
}
.cdl-faq__list--light .cdl-faq__q { color: var(--white); }
.cdl-faq__q-text { display: flex; align-items: center; gap: 14px; }
.cdl-faq__q-cat { display: inline-flex; padding: 3px 10px; font-size: 11px; font-weight: 600; letter-spacing: .04em; color: var(--ink-500); background: var(--ink-50); border-radius: 999px; }
.cdl-faq__list--light .cdl-faq__q-cat { color: var(--ink-200); background: rgba(255,255,255,.08); }
.cdl-faq__q-icon {
  width: 28px; height: 28px;
  border: 1px solid var(--ink-200);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; line-height: 1;
  transition: transform var(--t-base) var(--ease), background var(--t-base) var(--ease), color var(--t-base) var(--ease);
  flex: 0 0 auto;
  color: var(--ink-700);
}
.cdl-faq__list--light .cdl-faq__q-icon { border-color: rgba(255,255,255,.18); color: var(--white); }
.cdl-faq__item.is-open .cdl-faq__q-icon { transform: rotate(45deg); background: var(--ink-1000); color: var(--white); border-color: var(--ink-1000); }
.cdl-faq__list--light .cdl-faq__item.is-open .cdl-faq__q-icon { background: var(--white); color: var(--ink-1000); border-color: var(--white); }
.cdl-faq__a { max-height: 0; overflow: hidden; transition: max-height .5s var(--ease); }
.cdl-faq__a-inner { padding: 0 0 26px; font-size: 14.5px; color: var(--ink-500); line-height: 1.75; }
.cdl-faq__list--light .cdl-faq__a-inner { color: var(--ink-200); }

/* ---------- Contact strip (light, car bg, 4 trust cards) ---------- */
.cdl-contact { background: #f7f7f8; position: relative; overflow: hidden; color: var(--ink-1000); }
.cdl-contact__bg { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.cdl-contact__bg-car {
  position: absolute; right: -8%; top: 0; bottom: 0;
  width: 65%;
  background-size: cover;
  background-position: center;
  opacity: .35;
  filter: grayscale(.4) contrast(1.05);
  mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.4) 30%, #000 70%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.4) 30%, #000 70%);
}
.cdl-contact__bg-veil {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, #f7f7f8 0%, rgba(247,247,248,.7) 40%, rgba(247,247,248,.2) 70%, transparent 100%);
}
.cdl-contact__bg-dots {
  position: absolute;
  background-image: radial-gradient(circle, var(--ink-200) 1.4px, transparent 1.4px);
  background-size: 18px 18px;
  opacity: .5;
}
.cdl-contact__bg-dots--left {
  top: 10%; bottom: 20%; left: 2%;
  width: 80px;
  mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
}

.cdl-contact__inner {
  position: relative; z-index: 1;
  display: flex; flex-direction: column;
  align-items: center;
}
.cdl-contact__top { text-align: center; display: flex; flex-direction: column; align-items: center; }
.cdl-contact__lead {
  margin-top: 14px;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  color: var(--ink-1000);
  letter-spacing: -.02em;
}
.cdl-contact__num {
  display: inline-block;
  margin-top: 14px;
  font-family: var(--font-display);
  font-size: clamp(48px, 7vw, 96px);
  font-weight: 800;
  letter-spacing: -.045em;
  line-height: 1;
  /* Black chrome gradient + sweeping highlight band */
  background:
    linear-gradient(110deg,
      #4a4a4a 0%,
      #1a1a1a 18%,
      #050505 34%,
      #ffffff 50%,
      #050505 66%,
      #1a1a1a 82%,
      #4a4a4a 100%);
  background-size: 220% 100%;
  background-position: 110% 0;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  animation: cdl-chrome-sweep 4.2s ease-in-out infinite;
  filter: drop-shadow(0 1px 0 rgba(255,255,255,.6)) drop-shadow(0 2px 8px rgba(0,0,0,.08));
}
@keyframes cdl-chrome-sweep {
  0%   { background-position: 200% 0; }
  100% { background-position: -100% 0; }
}
.cdl-contact__sub { margin-top: 14px; color: var(--ink-500); font-size: 14.5px; }
.cdl-contact__cta { margin-top: 24px; display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
.cdl-contact__cta-icon {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
  display: inline-flex; align-items: center; justify-content: center;
  color: inherit;
  margin-right: 2px;
}

/* 4 trust cards row */
.cdl-contact__cards {
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  list-style: none;
  padding: 16px 20px;
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.04);
  width: 100%;
  max-width: 1100px;
}
.cdl-contact__cards li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px 20px;
  position: relative;
}
.cdl-contact__cards li:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0; top: 18%; bottom: 18%;
  width: 1px;
  background: var(--ink-100);
}
.cdl-contact__card-icon {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--ink-25);
  border: 1px solid var(--ink-100);
  color: var(--ink-1000);
  display: inline-flex; align-items: center; justify-content: center;
}
.cdl-contact__card-icon svg { width: 18px; height: 18px; }
.cdl-contact__cards li > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cdl-contact__cards strong { font-size: 14px; font-weight: 700; color: var(--ink-1000); }
.cdl-contact__cards span { font-size: 12px; color: var(--ink-500); }

/* ---------- Page Hero ---------- */
.cdl-page-hero {
  background: var(--ink-950);
  color: var(--white);
  padding: clamp(56px, 8vw, 112px) 0 clamp(40px, 6vw, 72px);
  position: relative;
  overflow: hidden;
  margin-top: calc(-1 * var(--header-h));
  padding-top: calc(var(--header-h) + clamp(56px, 8vw, 112px));
}
.cdl-page-hero > .cdl-container { position: relative; z-index: 2; }

/* Ambient background video (subtle, randomly picked from set) */
.cdl-page-hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.cdl-page-hero__video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .35;
  filter: brightness(.6) contrast(1.05) saturate(.95);
  transform: scale(1.12);
  transform-origin: center 45%;
}
.cdl-page-hero__veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(8,8,10,.45) 0%, rgba(8,8,10,.35) 50%, rgba(8,8,10,.85) 100%),
    radial-gradient(80% 60% at 50% 0%, rgba(8,8,10,.2) 0%, transparent 60%);
}
.cdl-page-hero::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
}
.cdl-page-hero__title { font-size: clamp(28px, 4vw, 48px); font-weight: 800; letter-spacing: -.025em; line-height: 1.15; color: var(--white); margin-top: 14px; position: relative; }
.cdl-page-hero__title--sm { font-size: clamp(22px, 2.8vw, 32px); }
.cdl-page-hero__sub { margin-top: 12px; color: var(--ink-200); font-size: clamp(13.5px, 1.2vw, 15.5px); max-width: 60ch; position: relative; }

/* ---------- About ---------- */
.cdl-about__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.cdl-about__stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border: 1px solid var(--ink-100); border-radius: 22px; overflow: hidden; }
.cdl-about__stat { padding: 28px; border-right: 1px solid var(--ink-100); border-bottom: 1px solid var(--ink-100); }
.cdl-about__stat:nth-child(2n) { border-right: 0; }
.cdl-about__stat:nth-last-child(-n+2) { border-bottom: 0; }
.cdl-about__stat-num { font-family: var(--font-display); font-size: clamp(36px, 4.5vw, 52px); font-weight: 700; color: var(--ink-1000); letter-spacing: -.03em; line-height: 1; display: flex; align-items: baseline; gap: 4px; }
.cdl-about__stat-num em { font-size: .5em; font-weight: 600; color: var(--ink-500); font-style: normal; }
.cdl-about__stat-label { display: block; margin-top: 8px; font-size: 13px; color: var(--ink-500); }

/* ---------- Values ---------- */
.cdl-values__list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(255,255,255,.08); }
.cdl-values__list li { padding: 36px 28px; border-right: 1px solid rgba(255,255,255,.08); }
.cdl-values__list li:last-child { border-right: 0; }
.cdl-values__num { font-family: var(--font-display); font-size: 13px; font-weight: 600; letter-spacing: .14em; color: var(--ink-400); }
.cdl-values__list h3 { margin-top: 32px; font-size: 19px; font-weight: 700; color: var(--white); }
.cdl-values__list p { margin-top: 12px; font-size: 14px; color: var(--ink-200); line-height: 1.65; }

/* ---------- Export page ---------- */
.cdl-export__list { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--ink-100); border-radius: 22px; overflow: hidden; }
.cdl-export__item { padding: 24px 28px; border-bottom: 1px solid var(--ink-100); }
.cdl-export__item:last-child { border-bottom: 0; }
.cdl-export__item h3 { font-size: 16px; font-weight: 700; color: var(--ink-1000); }
.cdl-export__item p { margin-top: 8px; font-size: 14px; color: var(--ink-500); line-height: 1.65; }

/* ---------- CTA strip ---------- */
.cdl-cta-strip__inner { text-align: center; padding: clamp(40px, 5vw, 60px) 0; border-top: 1px solid var(--ink-100); border-bottom: 1px solid var(--ink-100); display: flex; flex-direction: column; align-items: center; gap: 16px; }
.cdl-cta-strip h2 { font-size: clamp(24px, 3vw, 36px); font-weight: 800; color: var(--ink-1000); letter-spacing: -.025em; }
.cdl-cta-strip p { color: var(--ink-500); }
.cdl-cta-strip__buttons { margin-top: 14px; display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ---------- Location ---------- */
.cdl-location__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: stretch; }
.cdl-location__map { background: var(--ink-100); border-radius: 24px; overflow: hidden; min-height: 420px; }
.cdl-location__map iframe { width: 100%; height: 100%; border: 0; min-height: 420px; }
.cdl-location__info { padding: 12px 4px; }
.cdl-location__dl { margin-top: 24px; display: grid; grid-template-columns: auto 1fr; gap: 14px 24px; }
.cdl-location__dl dt { font-size: 12.5px; color: var(--ink-500); text-transform: uppercase; letter-spacing: .08em; padding-top: 4px; }
.cdl-location__dl dd { font-size: 15px; color: var(--ink-1000); }
.cdl-location__dl a { color: var(--ink-1000); border-bottom: 1px solid var(--ink-200); padding-bottom: 1px; }
.cdl-location__dl a:hover { border-color: var(--ink-1000); }
.cdl-location__cta { margin-top: 28px; display: flex; gap: 10px; flex-wrap: wrap; }

/* ---------- Partnership ---------- */
.cdl-partnership__grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 48px; align-items: start; }
.cdl-partnership__info { display: flex; flex-direction: column; }
.cdl-partnership__list { margin-top: 24px; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--ink-100); }
.cdl-partnership__list li { padding: 18px 0; border-bottom: 1px solid var(--ink-100); }
.cdl-partnership__list li strong { display: block; font-size: 15.5px; font-weight: 700; color: var(--ink-1000); }
.cdl-partnership__list li p { margin-top: 4px; color: var(--ink-500); font-size: 13.5px; line-height: 1.55; }
.cdl-partnership__contact { margin-top: 28px; display: flex; flex-direction: column; gap: 14px; padding: 22px; border: 1px solid var(--ink-100); border-radius: 18px; background: var(--ink-25); }
.cdl-partnership__contact div { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.cdl-partnership__contact-label { font-size: 11px; color: var(--ink-500); letter-spacing: .12em; text-transform: uppercase; }
.cdl-partnership__contact a { font-family: var(--font-en); font-size: 16px; font-weight: 700; color: var(--ink-1000); word-break: break-all; line-height: 1.2; }
.cdl-partnership__form {
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 22px;
  padding: clamp(28px, 3.6vw, 40px);
  box-shadow: 0 24px 60px rgba(0,0,0,.05), 0 2px 8px rgba(0,0,0,.03);
}
.cdl-partnership__form .cdl-form__head { margin-bottom: 22px; padding-bottom: 22px; border-bottom: 1px solid var(--ink-100); }

.cdl-alert { padding: 14px 16px; border-radius: 12px; font-size: 14px; margin-bottom: 16px; }
.cdl-alert--ok { background: var(--ink-50); color: var(--ink-1000); border: 1px solid var(--ink-150); }
.cdl-alert--err { background: #fff5f5; color: #b00020; border: 1px solid #ffd7d7; }
.cdl-alert ul { margin: 0; padding-left: 18px; list-style: disc; }

/* ---------- Doc page ---------- */
.cdl-doc__inner { max-width: var(--container-narrow); margin: 0 auto; }
.cdl-doc__text { white-space: pre-wrap; font-family: var(--font-kr); font-size: 15px; line-height: 1.85; color: var(--ink-700); }

/* ---------- Reviews detail ---------- */
.cdl-review-detail__inner { max-width: var(--container-narrow); margin: 0 auto; }
.cdl-review-detail__gallery { display: grid; gap: 8px; margin-bottom: 32px; border-radius: 22px; overflow: hidden; }
.cdl-review-detail__gallery--1 { grid-template-columns: 1fr; }
.cdl-review-detail__gallery--2 { grid-template-columns: 1fr 1fr; }
.cdl-review-detail__gallery--3,
.cdl-review-detail__gallery--4 { grid-template-columns: repeat(2, 1fr); }
.cdl-review-detail__cell img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; }
.cdl-review-detail__back { margin-top: 36px; text-align: center; }

/* Pagination */
.cdl-pagination { margin-top: 56px; display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; }
.cdl-pagination .pagination,
.cdl-pagination ul { display: flex; gap: 6px; flex-wrap: wrap; padding: 0; margin: 0; list-style: none; }
.cdl-pagination li, .cdl-pagination span, .cdl-pagination a { display: inline-flex; }
.cdl-pagination a, .cdl-pagination span {
  min-width: 40px; padding: 8px 14px;
  border-radius: 999px; border: 1px solid var(--ink-150);
  font-size: 13.5px; color: var(--ink-700);
  align-items: center; justify-content: center;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.cdl-pagination a:hover { background: var(--ink-1000); color: var(--white); border-color: var(--ink-1000); }
.cdl-pagination .active span,
.cdl-pagination [aria-current] span { background: var(--ink-1000); color: var(--white); border-color: var(--ink-1000); }
.cdl-pagination .disabled span { opacity: .35; }

.cdl-empty { text-align: center; padding: 64px 0; color: var(--ink-500); }

/* ---------- Lookup ---------- */
.cdl-page-hero--lookup { padding-bottom: 40px; }

.cdl-stepper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 0 auto 40px;
  max-width: 820px;
}
.cdl-stepper__step {
  display: flex; align-items: center; justify-content: center;
  gap: 12px;
  padding: 18px 24px;
  background: var(--ink-25);
  border: 1px solid var(--ink-100);
  border-radius: 999px;
  font-size: 15px; font-weight: 700;
  color: var(--ink-400);
  letter-spacing: -.01em;
  transition: all var(--t-base) var(--ease);
  text-align: center;
}
.cdl-stepper__step span {
  font-family: var(--font-display);
  font-size: 13px;
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--ink-100); color: var(--ink-500);
  display: inline-flex; align-items: center; justify-content: center;
  flex: 0 0 auto;
}
.cdl-stepper__step.is-active { background: var(--ink-1000); color: var(--white); border-color: var(--ink-1000); }
.cdl-stepper__step.is-active span { background: var(--white); color: var(--ink-1000); }
.cdl-stepper__step.is-done { background: var(--white); color: var(--ink-700); border-color: var(--ink-200); }
.cdl-stepper__step.is-done span { background: var(--ink-1000); color: var(--white); }

.cdl-lookup-card {
  max-width: 1120px; margin: 0 auto;
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 28px;
  padding: clamp(20px, 3vw, 36px);
}
.cdl-lookup-tabs {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px;
  background: var(--ink-50); padding: 4px; border-radius: 999px;
  margin-bottom: 24px;
  max-width: 320px;
}
.cdl-lookup-tab {
  text-align: center; padding: 12px 0;
  font-size: 14px; font-weight: 600;
  color: var(--ink-500);
  border-radius: 999px;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.cdl-lookup-tab.is-active { background: var(--ink-1000); color: var(--white); }

.cdl-lookup-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.cdl-lookup-col { background: var(--ink-25); border: 1px solid var(--ink-100); border-radius: 18px; overflow: hidden; display: flex; flex-direction: column; min-height: 380px; }
.cdl-lookup-col header { display: flex; align-items: center; gap: 10px; padding: 14px 18px; background: var(--white); border-bottom: 1px solid var(--ink-100); font-size: 13px; font-weight: 600; color: var(--ink-700); }
.cdl-lookup-col__num { font-family: var(--font-display); font-size: 11px; color: var(--ink-400); letter-spacing: .14em; }
.cdl-lookup-col__list { flex: 1; overflow-y: auto; padding: 6px; max-height: 420px; }
.cdl-lookup-col__hint { padding: 28px 18px; text-align: center; color: var(--ink-400); font-size: 13px; }

.cdl-lookup-item {
  display: flex; align-items: center; gap: 12px;
  width: 100%;
  padding: 11px 12px;
  border-radius: 12px;
  text-align: left;
  font-size: 14px;
  color: var(--ink-700);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.cdl-lookup-item:hover { background: var(--white); color: var(--ink-1000); }
.cdl-lookup-item.is-selected { background: var(--ink-1000); color: var(--white); }
.cdl-lookup-item img { width: 36px; height: 28px; object-fit: contain; background: var(--white); border-radius: 6px; padding: 3px; }
.cdl-lookup-item__mark { width: 36px; height: 28px; display: inline-flex; align-items: center; justify-content: center; background: var(--white); color: var(--ink-700); border-radius: 6px; font-size: 14px; font-weight: 700; }
.cdl-lookup-item.is-selected .cdl-lookup-item__mark { background: var(--white); }
.cdl-lookup-item__name { flex: 1; }

.cdl-lookup-actions { margin-top: 24px; display: flex; justify-content: space-between; gap: 12px; }

.cdl-lookup-form { display: flex; flex-direction: column; gap: 28px; }
.cdl-lookup-form__group { padding: 20px 22px; border: 1px solid var(--ink-100); border-radius: 18px; background: var(--white); }
.cdl-lookup-form__group--row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 28px; align-items: start; }
.cdl-lookup-form__col { display: flex; flex-direction: column; }
@media (max-width: 540px) {
  .cdl-lookup-form__group--row { grid-template-columns: 1fr; gap: 18px; }
}
.cdl-lookup-form__h { font-size: 14px; font-weight: 700; color: var(--ink-1000); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.cdl-lookup-form__opt { font-weight: 500; color: var(--ink-400); font-size: 12px; }
.cdl-lookup-form__inline { display: flex; align-items: center; gap: 12px; }
.cdl-lookup-form__unit { font-size: 14px; color: var(--ink-500); }

.cdl-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.cdl-chips label { position: relative; }
.cdl-chips input { position: absolute; opacity: 0; pointer-events: none; }
.cdl-chips span {
  display: inline-flex; align-items: center;
  padding: 9px 16px;
  border: 1px solid var(--ink-150);
  border-radius: 999px;
  font-size: 13.5px;
  color: var(--ink-700);
  transition: all var(--t-fast) var(--ease);
  cursor: pointer;
}
.cdl-chips input:checked + span { background: var(--ink-1000); color: var(--white); border-color: var(--ink-1000); }
.cdl-chips label:hover span { border-color: var(--ink-700); }

.cdl-colors { display: grid; grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)); gap: 10px; }
.cdl-color { position: relative; cursor: pointer; }
.cdl-color input { position: absolute; opacity: 0; }
.cdl-color__swatch { display: block; height: 56px; border-radius: 12px; border: 1px solid var(--ink-150); transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); }
.cdl-color__name { display: block; margin-top: 6px; text-align: center; font-size: 12px; color: var(--ink-500); }
.cdl-color input:checked + .cdl-color__swatch { transform: scale(1.04); box-shadow: 0 0 0 2px var(--white), 0 0 0 4px var(--ink-1000); }

.cdl-lookup-final { display: flex; flex-direction: column; gap: 24px; }
.cdl-lookup-final__head .cdl-section__title { font-size: clamp(22px, 2.8vw, 30px); }
.cdl-summary { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--ink-100); border: 1px solid var(--ink-100); border-radius: 18px; overflow: hidden; }
.cdl-summary > div { background: var(--white); padding: 16px 18px; display: flex; flex-direction: column; gap: 4px; }
.cdl-summary__full { grid-column: 1 / -1; }
.cdl-summary dt { font-size: 11.5px; color: var(--ink-500); letter-spacing: .08em; text-transform: uppercase; }
.cdl-summary dd { font-size: 15px; font-weight: 600; color: var(--ink-1000); }

.cdl-lookup-final__note { font-size: 12.5px; color: var(--ink-500); text-align: center; }

/* Done card */
.cdl-done { padding: clamp(80px, 12vw, 140px) 0; }
.cdl-done__card { max-width: 540px; margin: 0 auto; padding: clamp(36px, 5vw, 56px); border: 1px solid var(--ink-100); border-radius: 28px; background: var(--white); text-align: center; box-shadow: var(--shadow-2); }
.cdl-done__check { width: 72px; height: 72px; margin: 0 auto 20px; border-radius: 50%; background: var(--ink-1000); color: var(--white); display: inline-flex; align-items: center; justify-content: center; }
.cdl-done__title { margin-top: 16px; font-size: clamp(22px, 3vw, 28px); font-weight: 800; color: var(--ink-1000); }
.cdl-done__msg { margin-top: 14px; color: var(--ink-500); font-size: 14.5px; line-height: 1.7; }
.cdl-done__actions { margin-top: 28px; display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

/* ---------- Countries marquee ---------- */
.cdl-countries { padding: clamp(64px, 8vw, 100px) 0; background: var(--white); border-top: 1px solid var(--ink-100); }
.cdl-countries__head { text-align: center; margin-bottom: 36px; }
.cdl-countries__title { margin-top: 12px; font-size: clamp(24px, 3vw, 36px); font-weight: 800; color: var(--ink-1000); }
.cdl-countries__sub { margin-top: 8px; color: var(--ink-500); font-size: 14px; }

.cdl-marquee { overflow: hidden; mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.cdl-marquee__track { display: flex; gap: 32px; animation: cdl-marquee 60s linear infinite; }
@keyframes cdl-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.cdl-marquee__chip { display: inline-flex; align-items: center; gap: 10px; padding: 10px 18px; border: 1px solid var(--ink-100); border-radius: 999px; background: var(--white); white-space: nowrap; flex: 0 0 auto; }
.cdl-marquee__chip img { width: 22px; height: 16px; object-fit: cover; border-radius: 2px; }
.cdl-marquee__chip span { font-size: 13px; color: var(--ink-700); font-weight: 500; }

/* ---------- Brand strip ---------- */
.cdl-brands { padding: 60px 0; background: var(--ink-25); border-top: 1px solid var(--ink-100); }
.cdl-brands__caption { text-align: center; font-size: 11.5px; color: var(--ink-500); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 24px; }
.cdl-marquee--mono .cdl-marquee__track { gap: 56px; animation-duration: 50s; }
.cdl-brand-cell { display: inline-flex; align-items: center; height: 60px; flex: 0 0 auto; opacity: .55; transition: opacity var(--t-base) var(--ease); }
.cdl-brand-cell:hover { opacity: 1; }
.cdl-brand-cell img { max-height: 100%; width: auto; filter: grayscale(1); }

/* ---------- Footer ---------- */
.cdl-footer { background: var(--ink-1000); color: var(--ink-200); padding: clamp(56px, 7vw, 88px) 0 28px; }
.cdl-footer__top { display: grid; grid-template-columns: 1.2fr 2fr; gap: 56px; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.cdl-footer__logo { height: 36px; width: auto; }
.cdl-footer__tagline { margin-top: 12px; color: var(--ink-150); font-size: 13px; letter-spacing: .12em; }
.cdl-footer__blurb { margin-top: 16px; color: var(--ink-300); font-size: 13.5px; line-height: 1.65; max-width: 36ch; }
.cdl-footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.cdl-footer__h { font-size: 12px; font-weight: 600; letter-spacing: .12em; color: var(--ink-300); text-transform: uppercase; margin-bottom: 18px; }
.cdl-footer__links { display: flex; flex-direction: column; gap: 10px; font-size: 13.5px; color: var(--ink-150); }
.cdl-footer__links a { color: inherit; }
.cdl-footer__links a:hover { color: var(--white); }
.cdl-footer__muted { color: var(--ink-400); margin-right: 4px; font-size: 11.5px; letter-spacing: .04em; }
.cdl-footer__sns { display: flex; gap: 8px; margin-top: 18px; flex-wrap: wrap; }
.cdl-footer__sns a { width: 34px; height: 34px; border-radius: 50%; border: 1px solid rgba(255,255,255,.12); display: inline-flex; align-items: center; justify-content: center; padding: 7px; transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease); }
.cdl-footer__sns a img { width: 100%; height: 100%; filter: brightness(0) invert(1); opacity: .85; }
.cdl-footer__sns a:hover { background: var(--white); border-color: var(--white); }
.cdl-footer__sns a:hover img { filter: none; opacity: 1; }

.cdl-footer__biz { max-width: var(--container); margin: 48px auto 0; padding: 28px var(--gutter) 0; border-top: 1px solid rgba(255,255,255,.06); }
.cdl-footer__biz-note { font-size: 12.5px; color: var(--ink-250); line-height: 1.65; margin-bottom: 18px; }
.cdl-footer__biz-note strong { color: var(--white); font-weight: 700; }
.cdl-footer__biz-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px 24px;
  margin: 0;
}
.cdl-footer__biz-grid > div { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cdl-footer__biz-full { grid-column: 1 / -1; }
.cdl-footer__biz-grid dt { font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-400); font-weight: 500; }
.cdl-footer__biz-grid dd { margin: 0; font-size: 13px; color: var(--ink-150); font-weight: 500; word-break: break-all; }
.cdl-footer__biz-grid dd strong { color: var(--white); font-weight: 700; font-size: 13.5px; }
.cdl-footer__addr, .cdl-footer__disclaimer { margin-top: 14px; font-size: 12px; color: var(--ink-400); line-height: 1.65; }
.cdl-footer__disclaimer { margin-top: 18px; padding-top: 14px; border-top: 1px dashed rgba(255,255,255,.08); }
@media (max-width: 1100px) {
  .cdl-footer__biz-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .cdl-footer__biz-grid { grid-template-columns: 1fr; gap: 12px; }
}

.cdl-footer__bottom { max-width: var(--container); margin: 24px auto 0; padding: 18px var(--gutter) 0; border-top: 1px solid rgba(255,255,255,.06); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; font-size: 12px; color: var(--ink-400); }
.cdl-footer__brandeng { letter-spacing: .12em; }

/* ---------- Right rail (minimal floating SNS) ---------- */
.cdl-rail {
  position: fixed; right: 14px; top: 50%; transform: translateY(-50%);
  z-index: 600;
  display: flex; flex-direction: column; gap: 4px;
  padding: 6px;
  background: var(--white);
  border: 1px solid var(--ink-100);
  border-radius: 999px;
  box-shadow: 0 12px 32px rgba(0,0,0,.12), 0 0 0 1px rgba(0,0,0,.02);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.cdl-rail.is-hidden { opacity: 0; pointer-events: none; transform: translate(40px, -50%); }
.cdl-rail.is-qr-only { background: transparent; border: 0; box-shadow: none; padding: 0; }
.cdl-rail__list { display: flex; flex-direction: column; gap: 2px; }
.cdl-rail__btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: transparent;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 8px;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.cdl-rail__btn:hover { background: var(--ink-25); }
.cdl-rail__btn img {
  width: 100%; height: 100%; object-fit: contain;
  opacity: .95;
  transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.cdl-rail__btn:hover img { opacity: 1; transform: scale(1.06); }
.cdl-rail__btn.is-unset { display: none; }   /* URL 미설정 항목은 숨김 */

/* Compact QR pill below the SNS dots */
.cdl-rail__qr {
  margin-top: 6px;
  width: 84px; padding: 8px;
  background: var(--white);
  border-radius: 16px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-decoration: none;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.cdl-rail__qr:hover { transform: scale(1.04); box-shadow: 0 12px 24px rgba(0,0,0,.3); }
.cdl-rail__qr-label { font-size: 9.5px; font-weight: 700; letter-spacing: .08em; color: var(--ink-1000); text-transform: uppercase; }
.cdl-rail__qr-img { width: 100%; aspect-ratio: 1; }
.cdl-rail__qr-img img { width: 100%; height: 100%; object-fit: contain; }

/* ---------- Mobile dual CTA bar ---------- */
.cdl-mobile-cta {
  display: none;
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 700;
  padding: 8px;
  gap: 6px;
  background: rgba(10,10,10,.92);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  backdrop-filter: saturate(180%) blur(16px);
  border-top: 1px solid rgba(255,255,255,.06);
}
.cdl-mobile-cta__btn {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 12px;
  border-radius: 12px;
  font-size: 14px; font-weight: 600;
  letter-spacing: -.005em;
}
.cdl-mobile-cta__btn--ghost { background: rgba(255,255,255,.06); color: var(--white); border: 1px solid rgba(255,255,255,.1); }
.cdl-mobile-cta__btn--solid { background: var(--white); color: var(--ink-1000); }

/* ---------- Desktop quickbar (cinematic dark pill) ---------- */
.cdl-quickbar {
  position: fixed; left: 50%; bottom: 16px;
  transform: translateX(-50%);
  z-index: 650;
  width: min(calc(100vw - 32px), 920px);
  background:
    radial-gradient(ellipse at 15% 50%, rgba(255,255,255,.04) 0%, transparent 60%),
    linear-gradient(180deg, rgba(18,18,22,.96) 0%, rgba(8,8,10,.94) 100%);
  -webkit-backdrop-filter: saturate(180%) blur(22px);
  backdrop-filter: saturate(180%) blur(22px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  box-shadow:
    0 24px 60px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,255,255,.02),
    inset 0 1px 0 rgba(255,255,255,.08);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.cdl-quickbar.is-hidden { opacity: 0; pointer-events: none; transform: translate(-50%, 30px); }

/* ambient ring glow behind whole bar */
.cdl-quickbar__glow {
  position: absolute; inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  background: conic-gradient(from 180deg at 50% 50%,
    rgba(255,255,255,0) 0deg,
    rgba(255,255,255,.16) 45deg,
    rgba(255,255,255,0) 110deg,
    rgba(255,255,255,0) 250deg,
    rgba(255,255,255,.16) 315deg,
    rgba(255,255,255,0) 360deg);
  filter: blur(8px);
  opacity: .55;
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: cdl-qb-spin 12s linear infinite;
}
@keyframes cdl-qb-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.cdl-quickbar__inner {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 16px;
  align-items: center;
  padding: 8px 10px 8px 8px;
}

/* Phone icon with pulse rings */
.cdl-quickbar__pulse {
  position: relative;
  width: 44px; height: 44px;
  flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
}
.cdl-quickbar__pulse-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.4);
  animation: cdl-qb-pulse 2.6s var(--ease) infinite;
  opacity: 0;
}
.cdl-quickbar__pulse-ring--2 { animation-delay: 1.3s; }
@keyframes cdl-qb-pulse {
  0%   { transform: scale(.7); opacity: .8; }
  100% { transform: scale(1.8); opacity: 0; }
}
.cdl-quickbar__pulse-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ink-700), var(--ink-1000));
  border: 1px solid rgba(255,255,255,.22);
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow:
    0 0 24px rgba(255,255,255,.18),
    inset 0 1px 0 rgba(255,255,255,.14);
  position: relative;
  z-index: 2;
}

.cdl-quickbar__copy {
  display: flex; align-items: center; gap: 12px;
  min-width: 0;
}
.cdl-quickbar__title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--white);
  letter-spacing: -.005em;
  white-space: nowrap;
}
.cdl-quickbar__sep {
  width: 1px; height: 16px;
  background: rgba(255,255,255,.15);
  flex: 0 0 auto;
}
.cdl-quickbar__static {
  font-size: 12.5px;
  color: var(--ink-250);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cdl-quickbar__form { display: flex; gap: 8px; align-items: center; }

/* Phone field — visible label + icon + clear bordered input */
.cdl-quickbar__field {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 6px 4px 14px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.32);
  border-radius: 999px;
  cursor: text;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.cdl-quickbar__field:hover { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.45); }
.cdl-quickbar__field:focus-within {
  background: rgba(255,255,255,.18);
  border-color: var(--white);
  box-shadow: 0 0 0 3px rgba(255,255,255,.12);
}
.cdl-quickbar__field-icon { color: var(--ink-100); flex: 0 0 auto; }
.cdl-quickbar__field-hint {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  color: var(--ink-100);
  text-transform: uppercase;
  padding-right: 6px;
  border-right: 1px solid rgba(255,255,255,.2);
  margin-right: 2px;
  flex: 0 0 auto;
}
.cdl-quickbar__input {
  width: 150px;
  padding: 8px 12px;
  background: transparent;
  border: 0;
  outline: 0;
  border-radius: 999px;
  color: var(--white);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -.005em;
}
.cdl-quickbar__input::placeholder { color: rgba(255,255,255,.55); font-weight: 500; }

.cdl-quickbar__submit {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, #fafafa 0%, #d4d4d4 100%);
  color: var(--ink-1000);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -.005em;
  border: 0;
  cursor: pointer;
  white-space: nowrap;
  box-shadow:
    0 0 24px rgba(255,255,255,.22),
    inset 0 1px 0 rgba(255,255,255,.6);
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.cdl-quickbar__submit:hover {
  transform: translateY(-1px);
  box-shadow:
    0 0 32px rgba(255,255,255,.32),
    inset 0 1px 0 rgba(255,255,255,.7);
}
.cdl-quickbar__submit svg { transition: transform var(--t-fast) var(--ease); }
.cdl-quickbar__submit:hover svg { transform: translateX(2px); }

.cdl-quickbar__close {
  width: 28px; height: 28px;
  border-radius: 50%;
  color: var(--ink-300);
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.cdl-quickbar__close:hover { background: rgba(255,255,255,.1); color: var(--white); border-color: rgba(255,255,255,.2); }

/* ---------- Scroll-top ---------- */
.cdl-scroll-top {
  position: fixed; right: 22px; bottom: 100px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--ink-1000);
  color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow-2);
  opacity: 0; pointer-events: none;
  transform: translateY(8px);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease), background var(--t-fast) var(--ease);
  z-index: 600;
}
.cdl-scroll-top.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.cdl-scroll-top:hover { background: var(--ink-925); }

/* ---------- Modal ---------- */
.cdl-modal {
  position: fixed; inset: 0;
  z-index: 1200;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  visibility: hidden; opacity: 0;
  transition: opacity var(--t-base) var(--ease), visibility var(--t-base) var(--ease);
}
.cdl-modal.is-open { visibility: visible; opacity: 1; }
.cdl-modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.65); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.cdl-modal__panel {
  position: relative;
  width: min(560px, 100%);
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  background: var(--white);
  border-radius: 24px;
  padding: clamp(28px, 4vw, 40px);
  transform: translateY(20px);
  transition: transform var(--t-base) var(--ease);
}
.cdl-modal.is-open .cdl-modal__panel { transform: translateY(0); }
.cdl-modal__head { margin-bottom: 24px; }
.cdl-modal__title { margin-top: 12px; font-size: 24px; font-weight: 800; color: var(--ink-1000); }
.cdl-modal__sub { margin-top: 6px; color: var(--ink-500); font-size: 14px; }
.cdl-modal__close { position: absolute; top: 18px; right: 18px; width: 36px; height: 36px; border-radius: 50%; color: var(--ink-700); display: inline-flex; align-items: center; justify-content: center; transition: background var(--t-fast) var(--ease); }
.cdl-modal__close:hover { background: var(--ink-50); }
.cdl-modal__actions { margin-top: 24px; display: flex; gap: 8px; justify-content: flex-end; }

/* Count-up animations show via JS but element should not jump */
.cdl-count { display: inline-block; min-width: 1ch; }

/* Reveal-on-scroll */
.cdl-reveal { opacity: 0; transform: translateY(18px); transition: opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.cdl-reveal.is-revealed { opacity: 1; transform: translateY(0); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1100px) {
  .cdl-nav { display: none; }
  .cdl-burger { display: inline-flex; }
  .cdl-header__phone { display: none; }
  .cdl-header__quote { display: none; }

  .cdl-hero__stats { grid-template-columns: repeat(3, 1fr); gap: 0; }
  .cdl-faq__head { position: static; }
  .cdl-faq__grid { grid-template-columns: 1fr; }
  .cdl-lead__grid { grid-template-columns: 1fr; }
  .cdl-why__grid { grid-template-columns: 1fr; }
  .cdl-about__grid { grid-template-columns: 1fr; }
  .cdl-location__grid { grid-template-columns: 1fr; }
  .cdl-partnership__grid { grid-template-columns: 1fr; }
  .cdl-process__list { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .cdl-process__arrow { display: none; }
  .cdl-process__promise { grid-template-columns: auto 1fr; }
  .cdl-process__promise-img { display: none; }
  .cdl-contact__cards { grid-template-columns: repeat(2, 1fr); padding: 10px 12px; }
  .cdl-contact__cards li:nth-child(2)::after { display: none; }
  .cdl-contact__cards li:nth-child(odd)::after { display: none; }
  .cdl-contact__cards li:nth-child(2n)::after { display: block; }
  .cdl-contact__bg-car { width: 80%; opacity: .25; }
  .cdl-why__stat { max-width: 100%; }
  .cdl-values__list { grid-template-columns: repeat(2, 1fr); }
  .cdl-values__list li:nth-child(2n) { border-right: 0; }
  .cdl-values__list li:nth-child(-n+2) { border-bottom: 1px solid rgba(255,255,255,.08); }
  .cdl-reviews__grid { grid-template-columns: repeat(2, 1fr); }
  .cdl-est-card { flex-basis: 280px; }
  .cdl-estimates__nav { position: static; margin-top: 18px; justify-content: center; }
  .cdl-rail { display: none; }

  .cdl-mobile-cta { display: flex; }
  .cdl-quickbar { display: none; }
  .cdl-body { padding-bottom: 76px; }

  .cdl-vs__scenario { grid-template-columns: 1fr; gap: 14px; }
  .cdl-vs__divider {
    width: 44px; height: 44px;
    font-size: 12px;
    justify-self: center;
    margin: -8px 0;
    position: relative;
    z-index: 3;
  }
  .cdl-vs__divider::before { inset: -6px; }
  .cdl-vs__divider::after { inset: -12px; }
  .cdl-vs__col { padding: 22px; border-radius: 16px; }
  .cdl-vs__price strong { font-size: clamp(36px, 8vw, 52px); }
  .cdl-vs__icon { width: 44px; height: 44px; top: 22px; transform: none; }
  .cdl-vs__icon svg { width: 18px; height: 18px; }
  .cdl-vs__icon--left { left: auto; right: 16px; transform: none; }
  .cdl-vs__icon--right { right: 16px; transform: none; }
  .cdl-vs__rings { display: none; }
  .cdl-vs__bg-img { mask-image: none; -webkit-mask-image: none; opacity: .15; }
  .cdl-vs__callout { font-size: 13px; padding: 10px 18px 10px 10px; flex-wrap: wrap; justify-content: center; text-align: center; }
}

@media (max-width: 760px) {
  .cdl-hero__veil {
    background:
      linear-gradient(180deg, rgba(8,8,8,.35) 0%, rgba(8,8,8,.55) 50%, rgba(8,8,8,.88) 100%);
  }
  .cdl-hero__grid {
    mask-image: linear-gradient(180deg, #000 0%, transparent 70%);
    -webkit-mask-image: linear-gradient(180deg, #000 0%, transparent 70%);
  }
  .cdl-section { padding: clamp(40px, 8vw, 72px) 0; }
  .cdl-section__title { font-size: clamp(22px, 5.5vw, 30px); }
  .cdl-section__head { margin-bottom: 32px; }
  .cdl-page-hero { padding: calc(var(--header-h) + clamp(48px, 11vw, 80px)) 0 clamp(28px, 5vw, 48px); }
  .cdl-page-hero__title { font-size: clamp(24px, 6.5vw, 34px); }
  .cdl-page-hero__sub { font-size: 13.5px; }

  .cdl-form__grid { grid-template-columns: 1fr; }
  .cdl-lookup-grid { grid-template-columns: 1fr; }
  .cdl-lookup-col { min-height: 240px; }
  .cdl-lookup-col__list { max-height: 280px; }

  .cdl-process__list { grid-template-columns: 1fr; }
  .cdl-process__card { padding: 24px 20px; }
  .cdl-contact__cards { grid-template-columns: 1fr; padding: 8px 12px; }
  .cdl-contact__cards li::after { display: none !important; }
  .cdl-contact__cards li { border-bottom: 1px solid var(--ink-100); padding: 14px 10px; }
  .cdl-contact__cards li:last-child { border-bottom: 0; }
  .cdl-contact__num { font-size: clamp(38px, 10vw, 60px); }
  .cdl-why__stat-grid { grid-template-columns: 1fr; gap: 10px; }
  .cdl-why__stat { grid-template-columns: 1fr; }

  .cdl-values__list { grid-template-columns: 1fr; }
  .cdl-values__list li { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.08); padding: 28px 0; }
  .cdl-values__list li:last-child { border-bottom: 0; }

  .cdl-why__list { grid-template-columns: 1fr; }
  .cdl-why__list li { border-right: 0; padding-left: 0; padding-right: 0; }
  .cdl-why__list li:nth-child(2n) { padding: 32px 0; }

  .cdl-reviews__grid { grid-template-columns: 1fr; }
  .cdl-about__stats { grid-template-columns: 1fr; }
  .cdl-about__stat { border-right: 0; }
  .cdl-about__stat:nth-last-child(-n+1) { border-bottom: 0; }

  .cdl-vs__scenario { grid-template-columns: 1fr; }

  .cdl-hero__top { flex-direction: column; align-items: flex-start; }
  .cdl-hero__title { font-size: clamp(36px, 11vw, 56px); max-width: 100%; }
  .cdl-hero__sub { font-size: 15px; }
  .cdl-hero__stats { grid-template-columns: repeat(3, 1fr); padding-top: 22px; }
  .cdl-hero__stat { padding: 0 6px; }
  .cdl-hero__stat-num { font-size: clamp(24px, 7vw, 36px); }
  .cdl-hero__stat-label { font-size: 11px; }
  .cdl-hero__scroll { display: none; }

  .cdl-stepper { grid-template-columns: 1fr 1fr 1fr; gap: 6px; max-width: 100%; }
  .cdl-stepper__step { padding: 12px 6px; gap: 6px; font-size: 12.5px; font-weight: 700; }
  .cdl-stepper__step span { width: 22px; height: 22px; font-size: 11px; }

  .cdl-footer__top { grid-template-columns: 1fr; gap: 32px; }
  .cdl-footer__cols { grid-template-columns: 1fr 1fr; gap: 24px; }
  .cdl-footer__bottom { flex-direction: column; align-items: flex-start; }

  .cdl-est-card { flex-basis: 84%; }
  .cdl-summary { grid-template-columns: 1fr; }
  .cdl-logo__tag { display: none; }
  .cdl-logo__mark { height: 30px; }
  .cdl-ticker__time { display: none; }
}

@media (max-width: 420px) {
  .cdl-section__title { font-size: 26px; }
  .cdl-hero { min-height: 80vh; }
  .cdl-hero__title { font-size: 38px; }
  .cdl-hero__cta { flex-direction: column; }
  .cdl-hero__cta .cdl-btn { width: 100%; }
  .cdl-page-hero__title { font-size: 32px; }
  .cdl-vs__col { padding: 20px; }
  .cdl-vs__price strong { font-size: 40px; }
}

/* ---------- Print friendliness (basic) ---------- */
@media print {
  .cdl-header, .cdl-ticker, .cdl-rail, .cdl-mobile-cta, .cdl-quickbar, .cdl-scroll-top, .cdl-modal { display: none !important; }
  .cdl-body { padding-top: 0; }
}

/* ---------- Reduce motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}
